#73 - cancel vacation request
This commit is contained in:
parent
43870fa060
commit
d1bef0ac92
@ -5,6 +5,9 @@ declare(strict_types=1);
|
|||||||
namespace Toby\Domain\Policies;
|
namespace Toby\Domain\Policies;
|
||||||
|
|
||||||
use Toby\Domain\Enums\Role;
|
use Toby\Domain\Enums\Role;
|
||||||
|
use Toby\Domain\States\VacationRequest\Created;
|
||||||
|
use Toby\Domain\States\VacationRequest\WaitingForAdministrative;
|
||||||
|
use Toby\Domain\States\VacationRequest\WaitingForTechnical;
|
||||||
use Toby\Eloquent\Models\User;
|
use Toby\Eloquent\Models\User;
|
||||||
use Toby\Eloquent\Models\VacationRequest;
|
use Toby\Eloquent\Models\VacationRequest;
|
||||||
|
|
||||||
@ -40,8 +43,16 @@ class VacationRequestPolicy
|
|||||||
return in_array($user->role, [Role::AdministrativeApprover, Role::TechnicalApprover], true);
|
return in_array($user->role, [Role::AdministrativeApprover, Role::TechnicalApprover], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function cancel(User $user): bool
|
public function cancel(User $user, VacationRequest $vacationRequest): bool
|
||||||
{
|
{
|
||||||
|
if ($vacationRequest->user->is($user) && $vacationRequest->state->equals(
|
||||||
|
Created::class,
|
||||||
|
WaitingForAdministrative::class,
|
||||||
|
WaitingForTechnical::class,
|
||||||
|
)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
return $user->role === Role::AdministrativeApprover;
|
return $user->role === Role::AdministrativeApprover;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user