AuthController.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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. if($request->input('code')) {
  26. $res = $app->auth->session($request->input('code'));
  27. if(isset($res['session_key'])) {
  28. $data = $app->encryptor->decryptData($res['session_key'], $request->input('iv'), $request->input('encryptedData'));
  29. if(isset($data['openId'])) {
  30. if($request->input('bind')) {
  31. $token = $request->header('X-Token');
  32. $user = User::where('token', $token)->first();
  33. if(!$user) return $this->error(['msg' => '找不到用户']);
  34. } else {
  35. $user = User::where('open_id', $data['openId'])->first();
  36. if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
  37. }
  38. $user->update([
  39. 'nickname' => $data['nickName'],
  40. 'avatar' => $data['avatarUrl']
  41. ]);
  42. Log::info($data);
  43. $user->updateToken();
  44. $user->topRole = $user->getTopRole();
  45. return $this->success(['data' => $user]);
  46. }
  47. }
  48. }
  49. return $this->error(['msg' => '登陆失败']);
  50. }
  51. public function reset(Request $request)
  52. {
  53. $user = User::where('phone', $request->input('phone'))->first();
  54. if(!$user) return $this->error(['msg' => '账号不存在']);
  55. UserReset::create([
  56. 'user_id' => $user->id,
  57. 'phone' => $request->input('phone'),
  58. 'name' => $request->input('name')
  59. ]);
  60. return $this->success();
  61. }
  62. public function getUserInfo()
  63. {
  64. $user = Auth::guard('mini')->user();
  65. $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
  66. return $this->success(['data' => $user]);
  67. }
  68. }