add EmailConfirmationToken persistence: model, migration, eloquent + fake repo

This commit is contained in:
Yisroel Baum 2026-05-06 22:05:52 +03:00
parent 9747d07c31
commit e16cb45387
Signed by: yisroelbaum
GPG key ID: 0FA60884F75520A9
7 changed files with 288 additions and 0 deletions

View file

@ -0,0 +1,73 @@
<?php
namespace App\Email\EmailConfirmationToken;
use App\User\User;
use App\User\UserRepository;
use DateTimeImmutable;
use DateTimeZone;
use DomainException;
class EloquentEmailConfirmationTokenRepository implements EmailConfirmationTokenRepository
{
public function __construct(
private UserRepository $userRepo,
) {}
public function create(
CreateEmailConfirmationTokenDto $dto,
): EmailConfirmationToken {
$model = EmailConfirmationTokenModel::create([
'user_id' => $dto->user->getId(),
'token' => bin2hex(random_bytes(32)),
'available_to' => $dto->availableTo,
]);
return $this->toDomain($model);
}
public function findByToken(string $token): ?EmailConfirmationToken
{
$model = EmailConfirmationTokenModel::where(
'token', $token,
)->first();
return $model === null ? null : $this->toDomain($model);
}
public function findByUser(User $user): ?EmailConfirmationToken
{
$model = EmailConfirmationTokenModel::where(
'user_id', $user->getId(),
)->first();
return $model === null ? null : $this->toDomain($model);
}
public function delete(int $id): void
{
EmailConfirmationTokenModel::query()->where('id', $id)->delete();
}
private function toDomain(
EmailConfirmationTokenModel $model,
): EmailConfirmationToken {
$user = $this->userRepo->find($model->user_id);
if ($user === null) {
throw new DomainException(
"User with id {$model->user_id} not found"
);
}
$availableTo = new DateTimeImmutable(
$model->available_to->toDateTimeString(),
new DateTimeZone('UTC'),
);
return new EmailConfirmationToken(
id: $model->id,
user: $user,
availableTo: $availableTo,
token: $model->token,
);
}
}