AuthService.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. <?php
  2. namespace App\Services;
  3. use App\Enums\UserTypeEnum;
  4. use App\Models\User;
  5. use App\Models\PersonalAccessToken;
  6. use Carbon\Carbon;
  7. use Exception;
  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 $origem): ?array
  14. {
  15. if (!Auth::attempt(["email" => $email, "password" => $password])) {
  16. return null;
  17. }
  18. $user = User::where("email", $email)->first();
  19. if ($origem === 'admin') {
  20. if ($user->user_type !== UserTypeEnum::ADMIN) {
  21. throw new Exception('credenciais invalidas para acesso de franqueadora');
  22. }
  23. }
  24. $deviceId = Str::uuid()->toString();
  25. $accessToken = $user->createAccessToken($deviceId);
  26. $refreshToken = $user->createRefreshToken($deviceId);
  27. return [
  28. "payload" => [
  29. "access_token" => $accessToken,
  30. "user" => $user,
  31. ],
  32. "refreshToken" => $refreshToken,
  33. ];
  34. }
  35. public function refresh(string $refreshToken): ?array
  36. {
  37. if (!$refreshToken) {
  38. return null;
  39. }
  40. $tokenModel = PersonalAccessToken::findToken($refreshToken);
  41. if (
  42. !$tokenModel ||
  43. !in_array("refresh", $tokenModel->abilities) ||
  44. $tokenModel->expires_at < now()
  45. ) {
  46. return null;
  47. }
  48. $user = $tokenModel->tokenable;
  49. if (!$user) {
  50. return null;
  51. }
  52. $deviceId = Str::afterLast($tokenModel->name, "_");
  53. $tokens = $this->refreshTokenTransaction($tokenModel, $user, $deviceId);
  54. return [
  55. "payload" => [
  56. "access_token" => $tokens["access_token"],
  57. "user" => $user,
  58. ],
  59. "refreshToken" => $tokens["refresh_token"],
  60. ];
  61. }
  62. public function logout(): void
  63. {
  64. $user = Auth::user();
  65. if (!$user) {
  66. return;
  67. }
  68. $tokenName = $user->currentAccessToken()->name;
  69. $deviceId = Str::afterLast($tokenName, "_");
  70. $user
  71. ->tokens()
  72. ->where("name", "like", "%_{$deviceId}")
  73. ->delete();
  74. }
  75. protected function refreshTokenTransaction(
  76. PersonalAccessToken $tokenModel,
  77. User $user,
  78. string $deviceId,
  79. ): array {
  80. return DB::transaction(function () use (
  81. $tokenModel,
  82. $user,
  83. $deviceId,
  84. ): array {
  85. $tokenModel->update(["expires_at" => Carbon::now()]);
  86. $accessToken = $user->createAccessToken($deviceId);
  87. $refreshToken = $user->createRefreshToken($deviceId);
  88. return [
  89. "access_token" => $accessToken,
  90. "refresh_token" => $refreshToken,
  91. ];
  92. });
  93. }
  94. }