1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-09-21 17:01:33 +02:00
invoiceninja/app/Policies/EntityPolicy.php

61 lines
1.2 KiB
PHP
Raw Normal View History

2016-04-23 17:52:36 +02:00
<?php
namespace App\Policies;
use App\Models\User;
2016-04-23 17:52:36 +02:00
use Illuminate\Auth\Access\HandlesAuthorization;
/**
* Class EntityPolicy
*/
2016-04-26 03:53:39 +02:00
class EntityPolicy
2016-04-23 17:52:36 +02:00
{
use HandlesAuthorization;
/**
* @param User $user
* @return bool
*/
public static function create(User $user) {
2016-04-26 03:53:39 +02:00
return $user->hasPermission('create_all');
2016-04-23 17:52:36 +02:00
}
/**
* @param User $user
* @param $item
*
* @return bool
*/
public static function edit(User $user, $item) {
2016-04-26 03:53:39 +02:00
return $user->hasPermission('edit_all') || $user->owns($item);
2016-04-23 17:52:36 +02:00
}
/**
* @param User $user
* @param $item
*
* @return bool
*/
public static function view(User $user, $item) {
2016-04-26 03:53:39 +02:00
return $user->hasPermission('view_all') || $user->owns($item);
}
/**
* @param User $user
* @param $ownerUserId
* @return bool
*/
public static function viewByOwner(User$user, $ownerUserId) {
2016-04-26 03:53:39 +02:00
return $user->hasPermission('view_all') || $user->id == $ownerUserId;
}
/**
* @param User $user
* @param $ownerUserId
* @return bool
*/
public static function editByOwner(User $user, $ownerUserId) {
2016-04-26 03:53:39 +02:00
return $user->hasPermission('edit_all') || $user->id == $ownerUserId;
2016-04-23 17:52:36 +02:00
}
}