invoiceninja/app/Policies/EntityPolicy.php

89 lines
1.8 KiB
PHP
Raw Normal View History

2016-04-23 11:52:36 -04:00
<?php
namespace App\Policies;
use App\Models\User;
2016-04-23 11:52:36 -04:00
use Illuminate\Auth\Access\HandlesAuthorization;
/**
2017-01-30 21:40:43 +02:00
* Class EntityPolicy.
*/
2016-04-25 21:53:39 -04:00
class EntityPolicy
2016-04-23 11:52:36 -04:00
{
use HandlesAuthorization;
/**
2017-01-30 21:49:42 +02:00
* @param User $user
* @param mixed $item
2017-01-30 21:40:43 +02:00
*
* @return bool
*/
2017-01-30 18:05:31 +02:00
public static function create(User $user, $item)
{
if (! static::checkModuleEnabled($user, $item)) {
2016-10-27 11:57:51 +03:00
return false;
}
2016-04-25 21:53:39 -04:00
return $user->hasPermission('create_all');
2016-04-23 11:52:36 -04:00
}
/**
* @param User $user
* @param $item
*
* @return bool
*/
2017-01-30 18:05:31 +02:00
public static function edit(User $user, $item)
{
if (! static::checkModuleEnabled($user, $item)) {
2016-10-27 11:57:51 +03:00
return false;
}
2016-04-25 21:53:39 -04:00
return $user->hasPermission('edit_all') || $user->owns($item);
2016-04-23 11:52:36 -04:00
}
/**
* @param User $user
* @param $item
*
* @return bool
*/
2017-01-30 18:05:31 +02:00
public static function view(User $user, $item)
{
if (! static::checkModuleEnabled($user, $item)) {
2016-10-27 11:57:51 +03:00
return false;
}
2016-04-25 21:53:39 -04:00
return $user->hasPermission('view_all') || $user->owns($item);
}
/**
* @param User $user
* @param $ownerUserId
2017-01-30 21:40:43 +02:00
*
* @return bool
*/
2017-01-30 18:05:31 +02:00
public static function viewByOwner(User $user, $ownerUserId)
{
2016-04-25 21:53:39 -04:00
return $user->hasPermission('view_all') || $user->id == $ownerUserId;
}
/**
* @param User $user
* @param $ownerUserId
2017-01-30 21:40:43 +02:00
*
* @return bool
*/
2017-01-30 18:05:31 +02:00
public static function editByOwner(User $user, $ownerUserId)
{
2016-04-25 21:53:39 -04:00
return $user->hasPermission('edit_all') || $user->id == $ownerUserId;
2016-04-23 11:52:36 -04:00
}
2016-10-27 11:57:51 +03:00
private static function checkModuleEnabled(User $user, $item)
{
$entityType = is_string($item) ? $item : $item->getEntityType();
2016-12-08 20:00:13 +02:00
2016-10-27 11:57:51 +03:00
return $user->account->isModuleEnabled($entityType);
}
}