AuthService.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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, string $tipo): ?array
  12. {
  13. if (!Auth::attempt(["email" => $email, "password" => $password])) {
  14. return null;
  15. }
  16. $user = User::where("email", $email)->first();
  17. if ($user->type->value !== $tipo) {
  18. Auth::logout();
  19. return ["error" => "wrong_type"];
  20. }
  21. $deviceId = Str::uuid()->toString();
  22. $accessToken = $user->createAccessToken($deviceId);
  23. $refreshToken = $user->createRefreshToken($deviceId);
  24. return [
  25. "payload" => [
  26. "access_token" => $accessToken,
  27. "user" => $user,
  28. ],
  29. "refreshToken" => $refreshToken,
  30. ];
  31. }
  32. public function refresh(string $refreshToken): ?array
  33. {
  34. if (!$refreshToken) {
  35. return null;
  36. }
  37. $tokenModel = PersonalAccessToken::findToken($refreshToken);
  38. if (
  39. !$tokenModel ||
  40. !in_array("refresh", $tokenModel->abilities) ||
  41. $tokenModel->expires_at < now()
  42. ) {
  43. return null;
  44. }
  45. $user = $tokenModel->tokenable;
  46. if (!$user) {
  47. return null;
  48. }
  49. $deviceId = Str::afterLast($tokenModel->name, "_");
  50. $tokens = $this->refreshTokenTransaction($tokenModel, $user, $deviceId);
  51. return [
  52. "payload" => [
  53. "access_token" => $tokens["access_token"],
  54. "user" => $user,
  55. ],
  56. "refreshToken" => $tokens["refresh_token"],
  57. ];
  58. }
  59. public function logout(): void
  60. {
  61. $user = Auth::user();
  62. if (!$user) {
  63. return;
  64. }
  65. $tokenName = $user->currentAccessToken()->name;
  66. $deviceId = Str::afterLast($tokenName, "_");
  67. $user
  68. ->tokens()
  69. ->where("name", "like", "%_{$deviceId}")
  70. ->delete();
  71. }
  72. protected function refreshTokenTransaction(
  73. PersonalAccessToken $tokenModel,
  74. User $user,
  75. string $deviceId,
  76. ): array {
  77. return DB::transaction(function () use (
  78. $tokenModel,
  79. $user,
  80. $deviceId,
  81. ): array {
  82. $tokenModel->update(["expires_at" => Carbon::now()]);
  83. $accessToken = $user->createAccessToken($deviceId);
  84. $refreshToken = $user->createRefreshToken($deviceId);
  85. return [
  86. "access_token" => $accessToken,
  87. "refresh_token" => $refreshToken,
  88. ];
  89. });
  90. }
  91. }