| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- <?php
- namespace App\Http\Controllers;
- use App\Http\Requests\AuthRequest;
- use App\Http\Requests\RefreshTokenRequest;
- use App\Http\Requests\UserAppsRequest;
- use App\Http\Requests\UserAppsValidateCodeRequest;
- use Illuminate\Http\JsonResponse;
- use App\Http\Resources\AuthResource;
- use App\Services\AuthService;
- class AuthController extends Controller
- {
- public function __construct(protected AuthService $authService) {}
- public function login(AuthRequest $request): JsonResponse
- {
- $validated = $request->validated();
- $result = $this->authService->login(
- email: $validated["email"],
- password: $validated["password"],
- );
- if (!$result) {
- return $this->errorResponse(message: __("auth.failed"), code: 401);
- }
- return $this->successResponse(
- payload: new AuthResource([
- ...$result["payload"],
- "refresh_token" => $result["refreshToken"],
- ]),
- message: __("auth.logged_in"),
- );
- }
- public function logout(): JsonResponse
- {
- $this->authService->logout();
- return $this->successResponse(
- message: __("auth.logout"),
- )->withoutCookie("refresh_token");
- }
- public function refresh(RefreshTokenRequest $request): JsonResponse
- {
- $refresh_token = $request->validated("refresh_token");
- if (is_null($refresh_token)) {
- return $this->errorResponse(code: 403);
- }
- $result = $this->authService->refresh(
- $refresh_token
- );
- if (is_null($result)) {
- return $this->errorResponse(
- message: __("auth.unauthorized"),
- code: 403,
- );
- }
- return $this->successResponse(
- payload: new AuthResource([
- ...$result["payload"],
- "refresh_token" => $result["refreshToken"],
- ]),
- );
- }
- public function sendCode(UserAppsRequest $request): JsonResponse
- {
- $this->authService->sendCode($request->validated());
- return $this->successResponse(
- message: __("messages.code_sent"),
- code: 201,
- );
- }
- public function validateCode(UserAppsValidateCodeRequest $request): JsonResponse
- {
- try {
- $email = $request->input("email");
- $phone = $request->input("phone");
- $code = $request->input("code");
- $result = $this->authService->validateCode($request->validated());
-
- if (!$result) {
- return $this->errorResponse(
- message: __("auth.invalid_code"),
- code: 400,
- );
- }
-
- return $this->successResponse(
- payload: ['email' => $email, 'phone' => $phone, 'code' => $code],
- message: __("auth.valid_code"),
- code: 200,
- );
- } catch (\Exception $e) {
- return $this->errorResponse(
- message: __("auth.validation_error"),
- code: 500,
- );
- }
- }
-
- }
|