Files
cpo_test/laravel/app/Services/AuthService.php
2026-02-06 23:26:56 +07:00

47 lines
1.3 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Services;
use App\Contracts\AuthServiceContract;
use App\Data\Auth\LoginData;
use App\Data\Auth\LoginResult;
use App\Enums\LoginError;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use Log;
use Throwable;
final class AuthService implements AuthServiceContract
{
public function attemptLogin(LoginData $credentials): LoginResult
{
try {
if (!Auth::attempt(['email' => $credentials->email, 'password' => $credentials->password])) {
Log::warning('Failed login attempt', [
'email' => $credentials->email,
'ip' => request()->ip()
]);
return LoginResult::error(LoginError::INVALID_CREDENTIALS);
}
$user = User::where('email', $credentials->email)->firstOrFail();
$token = $user->createToken('auth_token')->plainTextToken;
Log::info('User logged in', [
'user_id' => $user->id,
'email' => $user->email,
'ip' => request()->ip()
]);
return LoginResult::success($user, $token);
} catch (Throwable $e) {
Log::error($e->getMessage(), [
'exception' => $e,
]);
return LoginResult::error(LoginError::SERVER_ERROR);
}
}
}