koel/app/Services/AuthenticationService.php

74 lines
2.1 KiB
PHP
Raw Normal View History

2023-08-20 22:35:58 +00:00
<?php
namespace App\Services;
use App\Exceptions\InvalidCredentialsException;
use App\Models\User;
use App\Repositories\UserRepository;
use App\Values\CompositeToken;
2024-02-25 19:32:53 +00:00
use Illuminate\Auth\Events\PasswordReset;
use Illuminate\Auth\Passwords\PasswordBroker;
2023-08-20 22:35:58 +00:00
use Illuminate\Hashing\HashManager;
2024-02-25 19:32:53 +00:00
use Illuminate\Support\Facades\Password;
2023-08-20 22:35:58 +00:00
class AuthenticationService
{
public function __construct(
private UserRepository $userRepository,
private TokenManager $tokenManager,
2024-02-25 19:32:53 +00:00
private HashManager $hash,
private PasswordBroker $passwordBroker
2023-08-20 22:35:58 +00:00
) {
}
public function login(string $email, string $password): CompositeToken
2023-08-20 22:35:58 +00:00
{
/** @var User|null $user */
$user = $this->userRepository->getFirstWhere('email', $email);
if (!$user || !$this->hash->check($password, $user->password)) {
throw new InvalidCredentialsException();
}
if ($this->hash->needsRehash($user->password)) {
$user->password = $this->hash->make($password);
$user->save();
}
2024-03-30 16:49:25 +00:00
return $this->logUserIn($user);
}
public function logUserIn(User $user): CompositeToken
{
return $this->tokenManager->createCompositeToken($user);
2023-08-20 22:35:58 +00:00
}
public function logoutViaBearerToken(string $token): void
{
$this->tokenManager->deleteCompositionToken($token);
}
2024-02-25 19:32:53 +00:00
public function trySendResetPasswordLink(string $email): bool
{
return $this->passwordBroker->sendResetLink(['email' => $email]) === Password::RESET_LINK_SENT;
}
public function tryResetPasswordUsingBroker(string $email, string $password, string $token): bool
{
$credentials = [
'email' => $email,
'password' => $password,
'password_confirmation' => $password,
'token' => $token,
];
$status = $this->passwordBroker->reset($credentials, function (User $user, string $password): void {
$user->password = $this->hash->make($password);
$user->save();
event(new PasswordReset($user));
});
return $status === Password::PASSWORD_RESET;
}
2023-08-20 22:35:58 +00:00
}