87 lines
2.1 KiB
PHP
87 lines
2.1 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Policies;
|
|
|
|
use Illuminate\Foundation\Auth\User as AuthUser;
|
|
use App\Models\Activity;
|
|
use Illuminate\Auth\Access\HandlesAuthorization;
|
|
|
|
class ActivityPolicy
|
|
{
|
|
use HandlesAuthorization;
|
|
|
|
public function viewAny(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('ViewAny:Activity');
|
|
}
|
|
|
|
public function view(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
return $authUser->can('View:Activity');
|
|
}
|
|
|
|
public function create(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('Create:Activity');
|
|
}
|
|
|
|
public function update(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
if ($authUser->can('Update:Activity')) {
|
|
return true;
|
|
}
|
|
|
|
return $authUser->hasRole('koordinator')
|
|
&& $activity->created_by === $authUser->id
|
|
&& is_null($activity->approved_at);
|
|
}
|
|
|
|
public function delete(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
if ($authUser->can('Delete:Activity')) {
|
|
return true;
|
|
}
|
|
|
|
return $authUser->hasRole('koordinator')
|
|
&& $activity->created_by === $authUser->id
|
|
&& is_null($activity->approved_at);
|
|
}
|
|
|
|
public function deleteAny(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('DeleteAny:Activity');
|
|
}
|
|
|
|
public function restore(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
return $authUser->can('Restore:Activity');
|
|
}
|
|
|
|
public function forceDelete(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
return $authUser->can('ForceDelete:Activity');
|
|
}
|
|
|
|
public function forceDeleteAny(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('ForceDeleteAny:Activity');
|
|
}
|
|
|
|
public function restoreAny(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('RestoreAny:Activity');
|
|
}
|
|
|
|
public function replicate(AuthUser $authUser, Activity $activity): bool
|
|
{
|
|
return $authUser->can('Replicate:Activity');
|
|
}
|
|
|
|
public function reorder(AuthUser $authUser): bool
|
|
{
|
|
return $authUser->can('Reorder:Activity');
|
|
}
|
|
|
|
} |