Files
persegi/app/Policies/ActivityPolicy.php
T

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');
}
}