AuthController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\User\ForgetPasswordEmialRequest;
  5. use App\Http\Requests\API\User\LoginRequest;
  6. use App\Http\Requests\API\User\ResetPasswordRequest;
  7. use App\Mail\ForgetPasswordMailable;
  8. use App\Models\User;
  9. use Carbon\Carbon;
  10. use Illuminate\Support\Facades\Auth;
  11. use Illuminate\Support\Facades\DB;
  12. use Illuminate\Support\Facades\Hash;
  13. use Illuminate\Support\Facades\Mail;
  14. use Illuminate\Support\Str;
  15. use Illuminate\Validation\ValidationException;
  16. class AuthController extends Controller
  17. {
  18. public function login(LoginRequest $request)
  19. {
  20. $user = User::query()
  21. ->where("username", $request->username)
  22. ->orWhere("email", $request->username)
  23. ->first();
  24. if (! $user || ! Hash::check($request->password, $user->password)) {
  25. throw ValidationException::withMessages([
  26. 'username' => [__("auth.failed")],
  27. ]);
  28. }
  29. if ($user->status===0){
  30. throw ValidationException::withMessages([
  31. 'username' => [__("auth.ban")],
  32. ]);
  33. }
  34. return $this->success([
  35. 'data' => [
  36. 'token' => $user->createToken('user')->plainTextToken,
  37. ]
  38. ]);
  39. }
  40. public function logout()
  41. {
  42. Auth::user()->currentAccessToken()->delete();
  43. return $this->noContent();
  44. }
  45. /**
  46. * 发送重置密码邮件
  47. * @param ForgetPasswordEmialRequest $request username用户名或邮箱
  48. * @return \Illuminate\Http\Response
  49. * @throws \Random\RandomException
  50. */
  51. public function sendForgetPasswordEmail(ForgetPasswordEmialRequest $request)
  52. {
  53. //1.通过用户名或邮箱检索用户
  54. $user = User::query()
  55. ->where('username',$request->username)
  56. ->orWhere('email',$request->username)
  57. ->first();
  58. //2.生成 验证码
  59. $captcha = random_int(100000, 999999);
  60. DB::table('password_reset_tokens')->insert([
  61. 'email' => $user->email,
  62. 'token' => $captcha,
  63. 'created_at' => Carbon::now()
  64. ]);
  65. //3.发送重置验证码邮件
  66. Mail::to($user)->send(new ForgetPasswordMailable($captcha));
  67. return $this->noContent();
  68. }
  69. /**
  70. * 重置用户密码
  71. * @param ResetPasswordRequest $request
  72. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response
  73. */
  74. public function resetPassword(ResetPasswordRequest $request)
  75. {
  76. //1.通过用户名或邮箱检索用户
  77. $user = User::query()
  78. ->where('username',$request->username)
  79. ->orWhere('email',$request->username)
  80. ->first();
  81. //2.获取该用户的最后验证码信息
  82. $resetToken = DB::table('password_reset_tokens')
  83. ->where('email', $user->email)
  84. ->orderBy('created_at', 'desc')
  85. ->first(); // 获取第一条记录;
  86. //3.判断验证码是否存在 验证码是否一致 验证码是否过期(15分钟) 若过期,执行以下if代码
  87. if (!$resetToken || $resetToken->token != $request->code || Carbon::parse($resetToken->created_at)->diffInMinutes(Carbon::now()) > 15){
  88. // 这里抛出错误是否更好?
  89. return $this->badRequest('Verification code error or expired');
  90. }
  91. //4.一切没问题,则修改该用户的密码
  92. $user->password = Hash::make($request->new_password);
  93. $user->save();
  94. return $this->noContent();
  95. }
  96. }