| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- <?php
- namespace App\Http\Controllers;
- use App\DTO\AuthDTO;
- use App\Http\Requests\AuthRequest;
- use App\Http\Requests\RefreshTokenRequest;
- use Illuminate\Http\JsonResponse;
- use App\Http\Resources\AuthResource;
- use App\Services\AuthService;
- use App\DTO\RefreshTokenDTO;
- class AuthController extends Controller
- {
- public function __construct(
- protected AuthService $authService,
- ) {}
- public function login(AuthRequest $request): JsonResponse
- {
- $result = $this->authService->login(credentials: AuthDTO::fromRequest(request: $request));
- if (!$result) {
- return $this->errorResponse(message: __('auth.failed'), code: 401);
- }
- return $this->successResponse(payload: new AuthResource($result['payload']), message: __('auth.logged_in'))
- ->withCookie(
- cookie(
- 'refresh_token',
- $result['refreshToken'],
- config('sanctum.rt_expiration') * 60,
- '/',
- config('session.domain'),
- config('session.secure'),
- true,
- false,
- 'Lax'
- )
- );
- }
- public function logout(): JsonResponse
- {
- $this->authService->logout();
- return $this->successResponse(message: __('auth.logout'))
- ->withoutCookie('refresh_token');
- }
- public function refresh(RefreshTokenRequest $request): JsonResponse
- {
- $result = $this->authService->refresh(RefreshTokenDTO::fromRequest(request: $request));
- if (is_null($result)) {
- return $this->errorResponse(message: __('auth.unauthorized'), code: 403)
- ->withoutCookie('refresh_token');
- }
- return $this->successResponse(payload: new AuthResource($result['payload']))
- ->withCookie(
- cookie(
- 'refresh_token',
- $result['refreshToken'],
- config('sanctum.rt_expiration') * 60,
- '/',
- config('session.domain'),
- config('session.secure'),
- true,
- true,
- 'Lax'
- )
- );
- }
- }
|