extend User entity with displayname and email confirmation
Add display_name (unique) and email_confirmed_at columns plus matching getters, DTO fields, repo methods (findByDisplayName, update), and migration. Existing auth tests updated to construct User with the new params.
This commit is contained in:
parent
d547ec2c61
commit
298b8634ec
10 changed files with 131 additions and 15 deletions
|
|
@ -3,6 +3,9 @@
|
|||
namespace App\User;
|
||||
|
||||
use App\Shared\ValueObject\EmailAddress;
|
||||
use DateTimeImmutable;
|
||||
use DateTimeZone;
|
||||
use RuntimeException;
|
||||
|
||||
class EloquentUserRepository implements UserRepository
|
||||
{
|
||||
|
|
@ -10,8 +13,10 @@ class EloquentUserRepository implements UserRepository
|
|||
{
|
||||
$model = UserModel::create([
|
||||
'email' => $dto->email->value(),
|
||||
'display_name' => $dto->displayName,
|
||||
'password_hash' => $dto->passwordHash,
|
||||
'is_admin' => $dto->isAdmin,
|
||||
'email_confirmed_at' => $dto->emailConfirmedAt,
|
||||
]);
|
||||
|
||||
return $this->toDomain($model);
|
||||
|
|
@ -31,13 +36,51 @@ class EloquentUserRepository implements UserRepository
|
|||
return $model === null ? null : $this->toDomain($model);
|
||||
}
|
||||
|
||||
public function findByDisplayName(string $displayName): ?User
|
||||
{
|
||||
$model = UserModel::where('display_name', $displayName)->first();
|
||||
|
||||
return $model === null ? null : $this->toDomain($model);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws RuntimeException
|
||||
*/
|
||||
public function update(User $user): User
|
||||
{
|
||||
$model = UserModel::find($user->getId());
|
||||
if ($model === null) {
|
||||
throw new RuntimeException(
|
||||
"User with id: {$user->getId()} does not exist"
|
||||
);
|
||||
}
|
||||
$model->email = $user->getEmail()->value();
|
||||
$model->display_name = $user->getDisplayName();
|
||||
$model->password_hash = $user->getPasswordHash();
|
||||
$model->is_admin = $user->isAdmin();
|
||||
$model->email_confirmed_at = $user->getEmailConfirmedAt();
|
||||
$model->save();
|
||||
|
||||
return $this->toDomain($model);
|
||||
}
|
||||
|
||||
private function toDomain(UserModel $model): User
|
||||
{
|
||||
$confirmedAt = null;
|
||||
if ($model->email_confirmed_at !== null) {
|
||||
$confirmedAt = new DateTimeImmutable(
|
||||
$model->email_confirmed_at->toDateTimeString(),
|
||||
new DateTimeZone('UTC'),
|
||||
);
|
||||
}
|
||||
|
||||
return new User(
|
||||
id: $model->id,
|
||||
email: new EmailAddress($model->email),
|
||||
displayName: $model->display_name,
|
||||
passwordHash: $model->password_hash,
|
||||
isAdmin: $model->is_admin,
|
||||
emailConfirmedAt: $confirmedAt,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue