AuthController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\api\controller\v2\wechat;
  12. use app\Request;
  13. use app\services\wechat\RoutineServices;
  14. use app\jobs\TaskJob;
  15. use crmeb\services\CacheService;
  16. /**
  17. * Class AuthController
  18. * @package app\api\controller\v2\wechat
  19. */
  20. class AuthController
  21. {
  22. protected $services = NUll;
  23. /**
  24. * AuthController constructor.
  25. * @param RoutineServices $services
  26. */
  27. public function __construct(RoutineServices $services)
  28. {
  29. $this->services = $services;
  30. }
  31. /**
  32. * 小程序授权登录
  33. * @param Request $request
  34. * @return mixed
  35. * @throws \Psr\SimpleCache\InvalidArgumentException
  36. * @throws \think\db\exception\DataNotFoundException
  37. * @throws \think\db\exception\ModelNotFoundException
  38. * @throws \think\exception\DbException
  39. */
  40. public function auth(Request $request)
  41. {
  42. [$code, $spid, $spread, $iv, $encryptedData] = $request->postMore([
  43. ['code', ''],
  44. ['spread_spid', 0],
  45. ['spread_code', ''],
  46. ['iv', ''],
  47. ['encryptedData', ''],
  48. ], true);
  49. $token = $this->services->newAuth($code, $spid, $spread, $iv, $encryptedData);
  50. if ($token) {
  51. if (isset($token['key']) && $token['key']) {
  52. return app('json')->successful('授权成功,请绑定手机号', $token);
  53. } else {
  54. return app('json')->successful('登录成功!', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp']]);
  55. }
  56. } else
  57. return app('json')->fail('获取用户访问token失败!');
  58. }
  59. /**
  60. * 静默授权
  61. * @param $code
  62. * @param $spread
  63. * @return mixed
  64. */
  65. public function silenceAuth($code, $spread_code = '', $spread_spid = '')
  66. {
  67. $token = $this->services->silenceAuth($code, $spread_code, $spread_spid);
  68. TaskJob::dispatchDo('emptyYesterdayAttachment');
  69. if ($token && isset($token['key'])) {
  70. return app('json')->success('授权成功,请绑定手机号', $token);
  71. } else if ($token) {
  72. return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp']]);
  73. } else
  74. return app('json')->fail('登录失败');
  75. }
  76. /**
  77. * 静默授权 不登录
  78. * @param $code
  79. * @param $spread
  80. * @return mixed
  81. */
  82. public function silenceAuthNoLogin($code, $spread_code = '', $spread_spid = '')
  83. {
  84. $token = $this->services->silenceAuthNoLogin($code, $spread_code, $spread_spid);
  85. TaskJob::dispatchDo('emptyYesterdayAttachment');
  86. if ($token && isset($token['auth_login'])) {
  87. return app('json')->success('授权成功');
  88. } else if ($token) {
  89. return app('json')->success('登录成功', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp']]);
  90. } else
  91. return app('json')->fail('登录失败');
  92. }
  93. /**
  94. * 静默授权
  95. * @param $code
  96. * @param $spread
  97. * @return mixed
  98. */
  99. public function silenceAuthBindingPhone($code = '', $spread_code = '', $spread_spid = '', $phone = '', $captcha = '')
  100. {
  101. //验证验证码
  102. $verifyCode = CacheService::get('code_' . $phone);
  103. if (!$verifyCode)
  104. return app('json')->fail('请先获取验证码');
  105. $verifyCode = substr($verifyCode, 0, 6);
  106. if ($verifyCode != $captcha) {
  107. CacheService::delete('code_' . $phone);
  108. return app('json')->fail('验证码错误');
  109. }
  110. CacheService::delete('code_' . $phone);
  111. $token = $this->services->silenceAuthBindingPhone($code, $spread_code, $spread_spid, $phone);
  112. TaskJob::dispatchDo('emptyYesterdayAttachment');
  113. if ($token) {
  114. return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp']]);
  115. } else
  116. return app('json')->fail('登录失败');
  117. }
  118. /**
  119. * 授权获取小程序用户手机号 直接绑定
  120. * @param $code
  121. * @param $iv
  122. * @param $encryptedData
  123. * @return mixed
  124. */
  125. public function authBindingPhone($code = '', $iv = '', $encryptedData ='', $spread_code ='', $spread_spid = '', $key = '')
  126. {
  127. if (!$code || !$iv || !$encryptedData)
  128. return app('json')->fail('参数有误');
  129. $token = $this->services->authBindingPhone($code, $iv, $encryptedData, $spread_code, $spread_spid, $key);
  130. if ($token) {
  131. return app('json')->success('登录成功', $token);
  132. } else
  133. return app('json')->fail('登录失败');
  134. }
  135. /**
  136. * 更新用户信息
  137. * @param $userInfo
  138. * @return mixed
  139. */
  140. public function updateInfo(Request $request, $userInfo)
  141. {
  142. if (!$userInfo) {
  143. return app('json')->fail('参数有误');
  144. }
  145. $uid = (int)$request->uid();
  146. $re = $this->services->updateUserInfo($uid, $userInfo);
  147. if ($re) {
  148. return app('json')->success('更新成功');
  149. } else
  150. return app('json')->fail('更新失败');
  151. }
  152. }