AuthService.php 3.1 KB

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