hasPermissionTo('permission.view'); } /** * Determine whether the user can view the model. */ public function view(User $user, Permission $permission): bool { return $user->hasPermissionTo('permission.view'); } /** * Determine whether the user can create models. */ public function create(User $user): bool { return $user->hasPermissionTo('permission.create'); } /** * Determine whether the user can update the model. */ public function update(User $user, Permission $permission): bool { if($permission->is_system) return false; return $user->hasPermissionTo('permission.edit'); } /** * Determine whether the user can delete the model. */ public function delete(User $user, Permission $permission): bool { if($permission->is_system || $permission->roles()->exists()) { return false; } return $user->hasPermissionTo('permission.delete'); } /** * Determine whether the user can restore the model. */ public function restore(User $user, Permission $permission): bool { return $user->hasPermissionTo('permission.create'); } /** * Determine whether the user can permanently delete the model. */ public function forceDelete(User $user, Permission $permission): bool { return $user->hasPermissionTo('permission.delete'); } }