* wip * fix * wip * #63 - permissions Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl>
This commit is contained in:
51
app/Domain/Policies/VacationRequestPolicy.php
Normal file
51
app/Domain/Policies/VacationRequestPolicy.php
Normal file
@@ -0,0 +1,51 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Toby\Domain\Policies;
|
||||
|
||||
use Toby\Domain\Enums\Role;
|
||||
use Toby\Eloquent\Models\User;
|
||||
use Toby\Eloquent\Models\VacationRequest;
|
||||
|
||||
class VacationRequestPolicy
|
||||
{
|
||||
public function createOnBehalfOfEmployee(User $user): bool
|
||||
{
|
||||
return $user->role === Role::AdministrativeApprover;
|
||||
}
|
||||
|
||||
public function acceptAsAdminApprover(User $user): bool
|
||||
{
|
||||
return $user->role === Role::AdministrativeApprover;
|
||||
}
|
||||
|
||||
public function acceptAsTechApprover(User $user): bool
|
||||
{
|
||||
return $user->role === Role::TechnicalApprover;
|
||||
}
|
||||
|
||||
public function skipFlow(User $user): bool
|
||||
{
|
||||
return $user->role === Role::AdministrativeApprover;
|
||||
}
|
||||
|
||||
public function reject(User $user): bool
|
||||
{
|
||||
return in_array($user->role, [Role::AdministrativeApprover, Role::TechnicalApprover], true);
|
||||
}
|
||||
|
||||
public function cancel(User $user): bool
|
||||
{
|
||||
return $user->role === Role::AdministrativeApprover;
|
||||
}
|
||||
|
||||
public function show(User $user, VacationRequest $vacationRequest): bool
|
||||
{
|
||||
if ($vacationRequest->user->is($user)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return in_array($user->role, [Role::TechnicalApprover, Role::AdministrativeApprover], true);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user