AuthController.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\AuthRequest;
  4. use App\Http\Requests\RefreshTokenRequest;
  5. use Illuminate\Http\JsonResponse;
  6. use App\Http\Resources\AuthResource;
  7. use App\Services\AuthService;
  8. use Illuminate\Http\Request;
  9. class AuthController extends Controller
  10. {
  11. public function __construct(protected AuthService $authService) {}
  12. public function login(AuthRequest $request): JsonResponse
  13. {
  14. $validated = $request->validated();
  15. $result = $this->authService->login(
  16. email: $validated["email"],
  17. password: $validated["password"],
  18. tipo: $validated["tipo"],
  19. );
  20. if (!$result) {
  21. return $this->errorResponse(message: __("auth.failed"), code: 401);
  22. }
  23. if (isset($result["error"]) && $result["error"] === "wrong_type") {
  24. return $this->errorResponse(message: __("auth.wrong_type"), code: 403);
  25. }
  26. $cookieName = $this->getCookieName($request);
  27. return $this->successResponse(
  28. payload: new AuthResource($result["payload"]),
  29. message: __("auth.logged_in"),
  30. )->withCookie(
  31. cookie(
  32. $cookieName,
  33. $result["refreshToken"],
  34. config("sanctum.rt_expiration") * 60,
  35. "/",
  36. config("session.domain"),
  37. config("session.secure"),
  38. true,
  39. false,
  40. "Lax",
  41. ),
  42. );
  43. }
  44. public function logout(Request $request): JsonResponse
  45. {
  46. $this->authService->logout();
  47. $cookieName = $this->getCookieName($request);
  48. return $this->successResponse(
  49. message: __("auth.logout"),
  50. )->withoutCookie($cookieName);
  51. }
  52. public function refresh(RefreshTokenRequest $request): JsonResponse
  53. {
  54. $cookieName = $this->getCookieName($request);
  55. $refresh_token = $request->cookie($cookieName);
  56. if (is_null($refresh_token)) {
  57. return $this->errorResponse(
  58. code: 403,
  59. )->withoutCookie($cookieName);
  60. }
  61. $result = $this->authService->refresh(
  62. $refresh_token
  63. );
  64. if (is_null($result)) {
  65. return $this->errorResponse(
  66. message: __("auth.unauthorized"),
  67. code: 403,
  68. )->withoutCookie($cookieName);
  69. }
  70. return $this->successResponse(
  71. payload: new AuthResource($result["payload"]),
  72. )->withCookie(
  73. cookie(
  74. $cookieName,
  75. $result["refreshToken"],
  76. config("sanctum.rt_expiration") * 60,
  77. "/",
  78. config("session.domain"),
  79. config("session.secure"),
  80. true,
  81. true,
  82. "Lax",
  83. ),
  84. );
  85. }
  86. }