Files
online.tbbank.gov.tm-larave…/app/Nova/Easy/Permission/NovaEasyPermission.php
2024-11-25 22:33:27 +05:00

82 lines
1.5 KiB
PHP

<?php
namespace App\Nova\Easy\Permission;
use Illuminate\Auth\Access\AuthorizationException;
use Illuminate\Http\Request;
trait NovaEasyPermission
{
/** View button */
public function authorizedToView(Request $request)
{
return false;
}
/** Create button */
public static function authorizedToCreate(Request $request)
{
$user = auth()->user();
if ($user->isMe()) {
return true;
}
return false;
}
/** Create */
public static function authorizeToCreate(Request $request)
{
throw_unless(auth()->user()->isMe(), AuthorizationException::class);
}
/** Edit button */
public function authorizedToUpdate(Request $request): bool
{
$user = auth()->user();
if ($user->isSystemUser()) {
return true;
}
return false;
}
/** Update */
public function authorizeToUpdate(Request $request): void
{
$user = auth()->user();
if ($user->isMe()) {
return;
}
$user = auth()->user();
if ($user->isSystemUser()) {
return;
}
throw new AuthorizationException;
}
/** Delete button */
public function authorizedToDelete(Request $request)
{
$user = auth()->user();
if ($user->isMe()) {
return true;
}
return false;
}
/** Force delete */
public function authorizedToForceDelete(Request $request)
{
return auth()->user()->isMe() ? true : false;
}
}