AuthService.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace App\Services;
  3. use App\Models\User;
  4. use App\Models\PersonalAccessToken;
  5. use Carbon\Carbon;
  6. use Illuminate\Support\Facades\Auth;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Support\Str;
  9. class AuthService
  10. {
  11. public function login(string $email, string $password): ?array
  12. {
  13. if (!Auth::attempt(["email" => $email, "password" => $password]) || (User::where("email", $email)->first()->type == 'CLIENT' || User::where("email", $email)->first()->type == 'PROVIDER')) {
  14. return null;
  15. }
  16. $user = User::where("email", $email)->first();
  17. $deviceId = Str::uuid()->toString();
  18. $accessToken = $user->createAccessToken($deviceId);
  19. $refreshToken = $user->createRefreshToken($deviceId);
  20. return [
  21. "payload" => [
  22. "access_token" => $accessToken,
  23. "user" => $user,
  24. ],
  25. "refreshToken" => $refreshToken,
  26. ];
  27. }
  28. public function refresh(string $refreshToken): ?array
  29. {
  30. if (!$refreshToken) {
  31. return null;
  32. }
  33. $tokenModel = PersonalAccessToken::findToken($refreshToken);
  34. if (
  35. !$tokenModel ||
  36. !in_array("refresh", $tokenModel->abilities) ||
  37. $tokenModel->expires_at < now()
  38. ) {
  39. return null;
  40. }
  41. $user = $tokenModel->tokenable;
  42. if (!$user) {
  43. return null;
  44. }
  45. $deviceId = Str::afterLast($tokenModel->name, "_");
  46. $tokens = $this->refreshTokenTransaction($tokenModel, $user, $deviceId);
  47. return [
  48. "payload" => [
  49. "access_token" => $tokens["access_token"],
  50. "user" => $user,
  51. ],
  52. "refreshToken" => $tokens["refresh_token"],
  53. ];
  54. }
  55. public function logout(): void
  56. {
  57. $user = Auth::user();
  58. if (!$user) {
  59. return;
  60. }
  61. $tokenName = $user->currentAccessToken()->name;
  62. $deviceId = Str::afterLast($tokenName, "_");
  63. $user
  64. ->tokens()
  65. ->where("name", "like", "%_{$deviceId}")
  66. ->delete();
  67. }
  68. protected function refreshTokenTransaction(
  69. PersonalAccessToken $tokenModel,
  70. User $user,
  71. string $deviceId,
  72. ): array {
  73. return DB::transaction(function () use (
  74. $tokenModel,
  75. $user,
  76. $deviceId,
  77. ): array {
  78. $tokenModel->update(["expires_at" => Carbon::now()]);
  79. $accessToken = $user->createAccessToken($deviceId);
  80. $refreshToken = $user->createRefreshToken($deviceId);
  81. return [
  82. "access_token" => $accessToken,
  83. "refresh_token" => $refreshToken,
  84. ];
  85. });
  86. }
  87. }