AuthController.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <?php
  2. namespace app\api\controller\wechat;
  3. use app\models\routine\RoutineTemplate;
  4. use app\models\user\WechatUser;
  5. use app\Request;
  6. use crmeb\services\CacheService;
  7. use crmeb\services\MiniProgramService;
  8. use crmeb\services\UtilService;
  9. use app\models\user\UserToken;
  10. use crmeb\services\SystemConfigService;
  11. use app\models\user\User;
  12. use app\models\routine\RoutineFormId;
  13. use think\facade\Cache;
  14. use crmeb\services\SubscribeTemplateService;
  15. /**
  16. * 小程序相关
  17. * Class AuthController
  18. * @package app\api\controller\wechat
  19. */
  20. class AuthController
  21. {
  22. /**
  23. * 小程序授权登录
  24. * @param Request $request
  25. * @return mixed
  26. * @throws \Psr\SimpleCache\InvalidArgumentException
  27. * @throws \think\db\exception\DataNotFoundException
  28. * @throws \think\db\exception\ModelNotFoundException
  29. * @throws \think\exception\DbException
  30. */
  31. public function mp_auth(Request $request)
  32. {
  33. $cache_key = '';
  34. list($code, $post_cache_key, $login_type) = UtilService::postMore([
  35. ['code', ''],
  36. ['cache_key', ''],
  37. ['login_type', '']
  38. ], $request, true);
  39. $session_key = Cache::get('eb_api_code_' . $post_cache_key);
  40. if (!$code && !$session_key)
  41. return app('json')->fail('授权失败,参数有误');
  42. if ($code && !$session_key) {
  43. try {
  44. $userInfoCong = MiniProgramService::getUserInfo($code);
  45. $session_key = $userInfoCong['session_key'];
  46. $cache_key = md5(time() . $code);
  47. Cache::set('eb_api_code_' . $cache_key, $session_key, 86400);
  48. } catch (\Exception $e) {
  49. return app('json')->fail('获取session_key失败,请检查您的配置!', ['line' => $e->getLine(), 'message' => $e->getMessage()]);
  50. }
  51. }
  52. $data = UtilService::postMore([
  53. ['spread_spid', 0],
  54. ['spread_code', ''],
  55. ['iv', ''],
  56. ['encryptedData', ''],
  57. ]);//获取前台传的code
  58. try {
  59. //解密获取用户信息
  60. $userInfo = MiniProgramService::encryptor($session_key, $data['iv'], $data['encryptedData']);
  61. } catch (\Exception $e) {
  62. if ($e->getCode() == '-41003') return app('json')->fail('获取会话密匙失败');
  63. }
  64. if (!isset($userInfo['openId'])) return app('json')->fail('openid获取失败');
  65. if (!isset($userInfo['unionId'])) $userInfo['unionId'] = '';
  66. $userInfo['spid'] = $data['spread_spid'];
  67. $userInfo['code'] = $data['spread_code'];
  68. $userInfo['session_key'] = $session_key;
  69. $userInfo['login_type'] = $login_type;
  70. $uid = WechatUser::routineOauth($userInfo);
  71. $userInfo = User::where('uid', $uid)->find();
  72. if ($userInfo->login_type == 'h5' && ($h5UserInfo = User::where(['account' => $userInfo->phone, 'phone' => $userInfo->phone, 'user_type' => 'h5'])->find()))
  73. $token = UserToken::createToken($userInfo, 'routine');
  74. else
  75. $token = UserToken::createToken($userInfo, 'routine');
  76. if ($token) {
  77. event('UserLogin', [$userInfo, $token]);
  78. return app('json')->successful('登陆成功!', [
  79. 'token' => $token->token,
  80. 'userInfo' => $userInfo,
  81. 'expires_time' => strtotime($token->expires_time),
  82. 'cache_key' => $cache_key
  83. ]);
  84. } else
  85. return app('json')->fail('获取用户访问token失败!');
  86. }
  87. /**
  88. * 获取授权logo
  89. * @param Request $request
  90. * @return mixed
  91. */
  92. public function get_logo(Request $request)
  93. {
  94. $logoType = $request->get('type', 1);
  95. switch ((int)$logoType) {
  96. case 1:
  97. $logo = sys_config('routine_logo');
  98. break;
  99. case 2:
  100. $logo = sys_config('wechat_avatar');
  101. break;
  102. default:
  103. $logo = '';
  104. break;
  105. }
  106. if (strstr($logo, 'http') === false && $logo) $logo = sys_config('site_url') . $logo;
  107. return app('json')->successful(['logo_url' => str_replace('\\', '/', $logo)]);
  108. }
  109. /**
  110. * 保存form id
  111. * @param Request $request
  112. * @return mixed
  113. */
  114. public function set_form_id(Request $request)
  115. {
  116. $formId = $request->post('formId', '');
  117. if (!$formId) return app('json')->fail('缺少form id');
  118. RoutineFormId::SetFormId($formId, $request->uid());
  119. return app('json')->successful('保存form id 成功!', ['uid' => $request->uid()]);
  120. }
  121. /**
  122. * 小程序支付回调
  123. */
  124. public function notify()
  125. {
  126. MiniProgramService::handleNotify();
  127. }
  128. /**
  129. * 获取小程序订阅消息id
  130. * @return mixed
  131. */
  132. public function teml_ids()
  133. {
  134. $temlIdsName = SubscribeTemplateService::getConstants();
  135. $temlIdsList = CacheService::get('TEML_IDS_LIST', function () use ($temlIdsName) {
  136. $temlId = [];
  137. foreach ($temlIdsName as $key => $item) {
  138. $temlId[strtolower($key)] = SubscribeTemplateService::setTemplateId($item);
  139. }
  140. return $temlId;
  141. });
  142. return app('json')->success($temlIdsList);
  143. }
  144. }