AuthController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  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\GlobalUser;
  9. use App\Models\User;
  10. use App\Services\User\UserService;
  11. use Carbon\Carbon;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Facades\Auth;
  14. use Illuminate\Support\Facades\Cache;
  15. use Illuminate\Support\Facades\Crypt;
  16. use Illuminate\Support\Facades\DB;
  17. use Illuminate\Support\Facades\Hash;
  18. use Illuminate\Support\Facades\Mail;
  19. use Illuminate\Support\Str;
  20. use Illuminate\Validation\ValidationException;
  21. class AuthController extends Controller
  22. {
  23. public function login(LoginRequest $request)
  24. {
  25. $user = User::query()
  26. ->where("username", $request->username)
  27. ->orWhere("email", $request->username)
  28. ->first();
  29. if (! $user || ! Hash::check($request->password, $user->password)) {
  30. throw ValidationException::withMessages([
  31. 'username' => [__("auth.failed")],
  32. ]);
  33. }
  34. if ($user->status===0){
  35. throw ValidationException::withMessages([
  36. 'username' => [__("auth.ban")],
  37. ]);
  38. }
  39. // 创建token
  40. $token = $user->createToken('user')->plainTextToken;
  41. $tenantId = GlobalUser::query()->where('username', $request->username)->value('tenant_id');
  42. return $this->success([
  43. 'data' => [
  44. 'token' => $token,
  45. 'tenant_id' => $tenantId
  46. ]
  47. ])->withCookie('X-Tenant', tenant()->id);
  48. }
  49. public function logout(Request $request)
  50. {
  51. Auth::user()->currentAccessToken()->delete();
  52. return $this->noContent()->withCookie('X-Tenant', null);
  53. }
  54. /**
  55. * 发送重置密码邮件
  56. * @param ForgetPasswordEmialRequest $request username用户名或邮箱
  57. * @return \Illuminate\Http\Response
  58. * @throws \Random\RandomException
  59. */
  60. public function sendForgetPasswordEmail(ForgetPasswordEmialRequest $request)
  61. {
  62. //1.通过用户名或邮箱检索用户
  63. $user = User::query()
  64. ->where('username',$request->username)
  65. ->orWhere('email',$request->username)
  66. ->first();
  67. $code = uniqid();
  68. $exists = DB::table('password_reset_tokens')->where('email', $user->email)->exists();
  69. if ($exists) {
  70. // 如果记录存在,更新它
  71. DB::table('password_reset_tokens')->where('email', $user->email)->update([
  72. 'token' => $code,
  73. 'exp_date' => Carbon::now(),
  74. ]);
  75. } else {
  76. // 如果记录不存在,插入新记录
  77. DB::table('password_reset_tokens')->insert([
  78. 'email' => $user->email,
  79. 'token' => $code,
  80. 'created_at' => Carbon::now(),
  81. 'exp_date' => Carbon::now(),
  82. ]);
  83. }
  84. //3.发送重置验证码邮件
  85. Mail::to($user)->send(new ForgetPasswordMailable($code));
  86. return $this->noContent();
  87. }
  88. /**
  89. * 重置用户密码
  90. * @param ResetPasswordRequest $request
  91. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response
  92. */
  93. public function resetPassword(ResetPasswordRequest $request)
  94. {
  95. //1.通过用户名或邮箱检索用户
  96. $user = User::query()
  97. ->where('username',$request->username)
  98. ->orWhere('email',$request->username)
  99. ->first();
  100. //2.获取该用户的最后验证码信息
  101. $resetToken = DB::table('password_reset_tokens')
  102. ->where('email', $user->email)
  103. ->orderBy('created_at', 'desc')
  104. ->first(); // 获取第一条记录;
  105. //3.判断验证码是否存在 验证码是否一致 验证码是否过期(15分钟) 若过期,执行以下if代码
  106. if (!$resetToken || $resetToken->token != $request->code || Carbon::parse($resetToken->exp_date)->diffInMinutes(Carbon::now()) > 15){
  107. return $this->badRequest('Verification code error or expired');
  108. }
  109. //4.一切没问题,则修改该用户的密码
  110. $user->password = Hash::make($request->new_password);
  111. $user->save();
  112. return $this->noContent();
  113. }
  114. }