implement PromoteUserToAdmin use case
This commit is contained in:
parent
8cbc84b051
commit
ac7295faf3
2 changed files with 64 additions and 0 deletions
|
|
@ -0,0 +1,53 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\User\UseCases\PromoteUserToAdmin;
|
||||||
|
|
||||||
|
use App\Exceptions\BadRequestException;
|
||||||
|
use App\Exceptions\ForbiddenException;
|
||||||
|
use App\User\User;
|
||||||
|
use App\User\UserRepository;
|
||||||
|
use DomainException;
|
||||||
|
|
||||||
|
class PromoteUserToAdmin
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private UserRepository $userRepo,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws BadRequestException
|
||||||
|
* @throws ForbiddenException
|
||||||
|
* @throws DomainException
|
||||||
|
*/
|
||||||
|
public function execute(PromoteUserToAdminRequest $request): User
|
||||||
|
{
|
||||||
|
if (! $request->requesterIsAdmin) {
|
||||||
|
throw new ForbiddenException(
|
||||||
|
'only admins can promote users'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if ($request->targetUserId <= 0) {
|
||||||
|
throw new BadRequestException(
|
||||||
|
'targetUserId must be positive'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$target = $this->userRepo->find($request->targetUserId);
|
||||||
|
if ($target === null) {
|
||||||
|
throw new DomainException('user not found');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($target->isAdmin()) {
|
||||||
|
return $target;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->userRepo->update(new User(
|
||||||
|
id: $target->getId(),
|
||||||
|
email: $target->getEmail(),
|
||||||
|
displayName: $target->getDisplayName(),
|
||||||
|
passwordHash: $target->getPasswordHash(),
|
||||||
|
isAdmin: true,
|
||||||
|
emailConfirmedAt: $target->getEmailConfirmedAt(),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,11 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\User\UseCases\PromoteUserToAdmin;
|
||||||
|
|
||||||
|
class PromoteUserToAdminRequest
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
public int $targetUserId,
|
||||||
|
public bool $requesterIsAdmin,
|
||||||
|
) {}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue