AuthController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. <?php
  2. namespace App\Http\Controllers\Api\mini;
  3. use App\Models\User;
  4. use App\Models\UserReset;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\Auth;
  7. use Illuminate\Support\Facades\Log;
  8. class AuthController extends BaseController
  9. {
  10. public function login(Request $request)
  11. {
  12. $credentials = $request->only('phone', 'password');
  13. if(Auth::guard('mini')->attempt($credentials)) {
  14. $user = Auth::guard('mini')->user();
  15. $user->updateToken();
  16. $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
  17. $user->topRole = $user->getTopRole();
  18. return $this->success(['data' => $user]);
  19. }
  20. return $this->error(['msg' => '账号或密码错误']);
  21. }
  22. public function loginByWechat(Request $request)
  23. {
  24. $app = app('wechat.mini_program');
  25. $session_key = $request->input('session_key');
  26. if(empty($session_key) && $request->input('code')) {
  27. $res = $app->auth->session($request->input('code'));
  28. if(isset($res['session_key'])) $session_key = $res['session_key'];
  29. }
  30. if($session_key) {
  31. $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
  32. if(isset($data['openId'])) {
  33. if($request->input('bind')) {
  34. $token = $request->header('X-Token');
  35. $user = User::where('token', $token)->first();
  36. if(!$user) return $this->error(['msg' => '找不到用户']);
  37. } else {
  38. $user = User::firstOrCreate([
  39. 'open_id' => $data['openId']
  40. ], [
  41. 'name' => $data['nickName'],
  42. 'nickname' => $data['nickName'],
  43. 'avatar' => $data['avatarUrl']
  44. ]);
  45. if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
  46. }
  47. $union_id = isset($data['unionId']) ? $data['unionId'] : $user->union_id;
  48. $user->update([
  49. 'nickname' => $data['nickName'],
  50. 'avatar' => $data['avatarUrl'],
  51. 'union_id' => $union_id
  52. ]);
  53. $user->updateToken();
  54. $user = $user->getUserInfo($session_key);
  55. return $this->success(['data' => $user]);
  56. }
  57. }
  58. return $this->error(['msg' => '登陆失败']);
  59. }
  60. public function parsePhone(Request $request)
  61. {
  62. $app = app('wechat.mini_program');
  63. $session_key = $request->input('session_key');
  64. if(!$session_key && $request->input('code')) {
  65. $res = $app->auth->session($request->input('code'));
  66. Log::info('进入parsePhone函数 code是',$request->input('code').PHP_EOL);
  67. if(isset($res['session_key'])) $session_key = $res['session_key'];
  68. }
  69. if($session_key) {
  70. Log::info('进入parsePhone函数 有code是',$request->input('code').PHP_EOL);
  71. $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
  72. Log::info('进入parsePhone函数 解析信息',json_encode($data));
  73. if(isset($data['phoneNumber'])) {
  74. Log::info('进入parsePhone函数 没有电话号码');
  75. $user = Auth::guard('mini')->user();
  76. $user->update(['phone' => $data['phoneNumber']]);
  77. $user = $user->getUserInfo($session_key);
  78. return $this->success(['data' => $user]);
  79. }
  80. return $this->error(['msg' => '获取失败']);
  81. }
  82. Log::info('进入parsePhone函数 没有code'.PHP_EOL);
  83. return $this->error(['msg' => '获取失败']);
  84. }
  85. public function reset(Request $request)
  86. {
  87. $user = User::where('phone', $request->input('phone'))->first();
  88. if(!$user) return $this->error(['msg' => '账号不存在']);
  89. UserReset::create([
  90. 'user_id' => $user->id,
  91. 'phone' => $request->input('phone'),
  92. 'name' => $request->input('name')
  93. ]);
  94. return $this->success();
  95. }
  96. public function getUserInfo()
  97. {
  98. $user = Auth::guard('mini')->user();
  99. $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
  100. $user = $user->getUserInfo();
  101. return $this->success(['data' => $user]);
  102. }
  103. }