AuthController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\AuthRequest;
  4. use App\Http\Requests\ForgotPasswordRequest;
  5. use App\Http\Requests\RefreshTokenRequest;
  6. use App\Http\Requests\ResetPasswordRequest;
  7. use App\Http\Requests\VerifyPasswordCodeRequest;
  8. use Illuminate\Http\JsonResponse;
  9. use App\Http\Resources\AuthResource;
  10. use App\Services\AuthService;
  11. use Request;
  12. class AuthController extends Controller
  13. {
  14. public function __construct(protected AuthService $authService) {}
  15. public function login(AuthRequest $request): JsonResponse
  16. {
  17. $validated = $request->validated();
  18. $result = $this->authService->login(
  19. email: $validated["email"],
  20. password: $validated["password"],
  21. origem: $validated["origem"]
  22. );
  23. if (!$result) {
  24. return $this->errorResponse(message: __("auth.failed"), code: 401);
  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 forgotPassword(ForgotPasswordRequest $request): JsonResponse
  45. {
  46. $validated = $request->validated();
  47. $sent = $this->authService->forgotPassword(email: $validated['email']);
  48. if (!$sent) {
  49. return $this->errorResponse(message: __('auth.email_not_found'), code: 422);
  50. }
  51. return $this->successResponse(message: __('auth.password_reset_sent'));
  52. }
  53. public function verifyPasswordCode(VerifyPasswordCodeRequest $request): JsonResponse
  54. {
  55. $validated = $request->validated();
  56. $valid = $this->authService->verifyPasswordCode(
  57. email: $validated['email'],
  58. code: $validated['code'],
  59. );
  60. if (!$valid) {
  61. return $this->errorResponse(message: __('auth.invalid_code'), code: 422);
  62. }
  63. return $this->successResponse(message: __('auth.code_verified'));
  64. }
  65. public function resetPassword(ResetPasswordRequest $request): JsonResponse
  66. {
  67. $validated = $request->validated();
  68. $reset = $this->authService->resetPassword(
  69. email: $validated['email'],
  70. code: $validated['code'],
  71. password: $validated['password'],
  72. );
  73. if (!$reset) {
  74. return $this->errorResponse(message: __('auth.invalid_code'), code: 422);
  75. }
  76. return $this->successResponse(message: __('auth.password_reset_success'));
  77. }
  78. public function logout(Request $request): JsonResponse
  79. {
  80. $this->authService->logout();
  81. $cookieName = $this->getCookieName($request);
  82. return $this->successResponse(
  83. message: __("auth.logout"),
  84. )->withoutCookie($cookieName);
  85. }
  86. public function refresh(RefreshTokenRequest $request): JsonResponse
  87. {
  88. $cookieName = $this->getCookieName($request);
  89. $refresh_token = $request->cookie($cookieName);
  90. if (is_null($refresh_token)) {
  91. return $this->errorResponse(
  92. code: 403,
  93. )->withoutCookie($cookieName);
  94. }
  95. $result = $this->authService->refresh(
  96. $refresh_token
  97. );
  98. if (is_null($result)) {
  99. return $this->errorResponse(
  100. message: __("auth.unauthorized"),
  101. code: 403,
  102. )->withoutCookie($cookieName);
  103. }
  104. return $this->successResponse(
  105. payload: new AuthResource($result["payload"]),
  106. )->withCookie(
  107. cookie(
  108. $cookieName,
  109. $result["refreshToken"],
  110. config("sanctum.rt_expiration") * 60,
  111. "/",
  112. config("session.domain"),
  113. config("session.secure"),
  114. true,
  115. true,
  116. "Lax",
  117. ),
  118. );
  119. }
  120. /**
  121. * Resolves the dynamic cookie name based on the requesting application.
  122. */
  123. private function getCookieName(mixed $request): string
  124. {
  125. $appOrigin = $request->header("X-App-Origin", "default");
  126. return "{$appOrigin}_refresh_token";
  127. }
  128. }