66 lines
1.8 KiB
PHP
66 lines
1.8 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Contracts\AuthServiceContract;
|
|
use App\Data\Auth\LoginData;
|
|
use App\Http\Requests\LoginRequest;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Log;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
use Throwable;
|
|
|
|
final class AuthController extends Controller
|
|
{
|
|
public function __construct(
|
|
private readonly AuthServiceContract $authService
|
|
) {
|
|
}
|
|
|
|
public function login(LoginRequest $request): JsonResponse
|
|
{
|
|
try {
|
|
$credentials = LoginData::fromArray($request->validated());
|
|
$result = $this->authService->attemptLogin($credentials);
|
|
|
|
if ($result->error) {
|
|
return response()->json([
|
|
'message' => $result->error->message(),
|
|
], $result->error->httpStatusCode());
|
|
}
|
|
|
|
return response()->json([
|
|
'token' => $result->token,
|
|
]);
|
|
} catch (Throwable $e) {
|
|
Log::error('AuthController.login: '.$e->getMessage(), [
|
|
'ip' => $request->ip()
|
|
]);
|
|
return response()->json([
|
|
'message' => 'Unavailable'
|
|
], Response::HTTP_SERVICE_UNAVAILABLE);
|
|
}
|
|
}
|
|
|
|
|
|
public function logout(Request $request): JsonResponse
|
|
{
|
|
try {
|
|
$request->user()->tokens()->delete();
|
|
return response()->json([
|
|
'message' => 'Logged out'
|
|
], Response::HTTP_OK);
|
|
} catch (Throwable $e) {
|
|
Log::error('AuthController.logout: '.$e->getMessage(), [
|
|
'ip' => $request->ip()
|
|
]);
|
|
return response()->json([
|
|
'message' => 'Unavailable'
|
|
], Response::HTTP_SERVICE_UNAVAILABLE);
|
|
}
|
|
}
|
|
}
|