AuthController.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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 crmeb\services\CacheService;
  15. /**
  16. * Class AuthController
  17. * @package app\api\controller\v2\wechat
  18. */
  19. class AuthController
  20. {
  21. protected $services = NUll;
  22. /**
  23. * AuthController constructor.
  24. * @param RoutineServices $services
  25. */
  26. public function __construct(RoutineServices $services)
  27. {
  28. $this->services = $services;
  29. }
  30. /**
  31. * 小程序授权登录
  32. * @param Request $request
  33. * @return mixed
  34. * @throws \Psr\SimpleCache\InvalidArgumentException
  35. * @throws \think\db\exception\DataNotFoundException
  36. * @throws \think\db\exception\ModelNotFoundException
  37. * @throws \think\exception\DbException
  38. */
  39. public function auth(Request $request)
  40. {
  41. [$code, $spid, $spread, $iv, $encryptedData] = $request->postMore([
  42. ['code', ''],
  43. ['spread_spid', 0],
  44. ['spread_code', ''],
  45. ['iv', ''],
  46. ['encryptedData', ''],
  47. ], true);
  48. $token = $this->services->newAuth($code, $spid, $spread, $iv, $encryptedData);
  49. if ($token) {
  50. if (isset($token['key']) && $token['key']) {
  51. return app('json')->successful('授权成功,请绑定手机号', $token);
  52. } else {
  53. return app('json')->successful('登录成功!', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp']]);
  54. }
  55. } else
  56. return app('json')->fail('获取用户访问token失败!');
  57. }
  58. /**
  59. * 静默授权
  60. * @param $code
  61. * @param $spread
  62. * @return mixed
  63. */
  64. public function silenceAuth($code, $spread_code = '', $spread_spid = '')
  65. {
  66. $token = $this->services->silenceAuth($code, $spread_code, $spread_spid);
  67. if ($token && isset($token['key'])) {
  68. return app('json')->success('授权成功,请绑定手机号', $token);
  69. } else if ($token) {
  70. return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp']]);
  71. } else
  72. return app('json')->fail('登录失败');
  73. }
  74. /**
  75. * 静默授权 不登录
  76. * @param $code
  77. * @param $spread
  78. * @return mixed
  79. */
  80. public function silenceAuthNoLogin($code, $spread_code = '', $spread_spid = '')
  81. {
  82. $token = $this->services->silenceAuthNoLogin($code, $spread_code, $spread_spid);
  83. if ($token && isset($token['auth_login'])) {
  84. return app('json')->success('授权成功');
  85. } else if ($token) {
  86. return app('json')->success('登录成功', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp']]);
  87. } else
  88. return app('json')->fail('登录失败');
  89. }
  90. /**
  91. * 静默授权
  92. * @param $code
  93. * @param $spread
  94. * @return mixed
  95. */
  96. public function silenceAuthBindingPhone($code = '', $spread_code = '', $spread_spid = '', $phone = '', $captcha = '')
  97. {
  98. //验证验证码
  99. $verifyCode = CacheService::get('code_' . $phone);
  100. if (!$verifyCode)
  101. return app('json')->fail('请先获取验证码');
  102. $verifyCode = substr($verifyCode, 0, 6);
  103. if ($verifyCode != $captcha) {
  104. CacheService::delete('code_' . $phone);
  105. return app('json')->fail('验证码错误');
  106. }
  107. CacheService::delete('code_' . $phone);
  108. $token = $this->services->silenceAuthBindingPhone($code, $spread_code, $spread_spid, $phone);
  109. if ($token) {
  110. return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp']]);
  111. } else
  112. return app('json')->fail('登录失败');
  113. }
  114. /**
  115. * 授权获取小程序用户手机号 直接绑定
  116. * @param $code
  117. * @param $iv
  118. * @param $encryptedData
  119. * @return mixed
  120. */
  121. public function authBindingPhone($code = '', $iv = '', $encryptedData ='', $spread_code ='', $spread_spid = '', $key = '')
  122. {
  123. if (!$code || !$iv || !$encryptedData)
  124. return app('json')->fail('参数有误');
  125. $token = $this->services->authBindingPhone($code, $iv, $encryptedData, $spread_code, $spread_spid, $key);
  126. if ($token) {
  127. return app('json')->success('登录成功', $token);
  128. } else
  129. return app('json')->fail('登录失败');
  130. }
  131. /**
  132. * 更新用户信息
  133. * @param $userInfo
  134. * @return mixed
  135. */
  136. public function updateInfo(Request $request, $userInfo)
  137. {
  138. if (!$userInfo) {
  139. return app('json')->fail('参数有误');
  140. }
  141. $uid = (int)$request->uid();
  142. $re = $this->services->updateUserInfo($uid, $userInfo);
  143. if ($re) {
  144. return app('json')->success('更新成功');
  145. } else
  146. return app('json')->fail('更新失败');
  147. }
  148. }