1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-13 22:54:25 +01:00
invoiceninja/app/Policies/TicketPolicy.php

80 lines
1.7 KiB
PHP
Raw Normal View History

2019-01-30 12:00:26 +01:00
<?php
namespace App\Policies;
use App\Models\User;
/**
* Class TicketPolicy
* @package App\Policies
*/
class TicketPolicy extends EntityPolicy
{
/**
* @param User $user
* @param mixed $item
*
* @return bool
*/
public function create(User $user)
{
if (! $this->createPermission($user, ENTITY_TICKET))
return false;
return $user->hasFeature(FEATURE_TICKETS);
}
/**
* @param User $user
* @param $item
* @param null $entityType
* @return bool
*/
public function view(User $user, $item, $entityType = null)
{
if(!$entityType)
$entityType = is_string($item) ? $item : $item->getEntityType();
return $user->hasPermission('view_' . $entityType) || $user->owns($item) || $user->id == $item->agent_id;
}
/**
* @param User $user
* @param $item
* @param null $entityType
* @return bool
*/
public function edit(User $user, $item, $entityType = null)
{
if(!$entityType)
$entityType = is_string($item) ? $item : $item->getEntityType();
return $user->hasPermission('edit_' . $entityType) || $user->owns($item) || $user->id == $item->agent_id;
}
/**
* @param User $user
* @param $item
* @return bool
*/
public function isMergeable(User $user, $item)
{
if($item->is_internal == false && $item->status_id != TICKET_STATUS_MERGED)
return false;
else
return true;
}
/**
* @param User $user
* @param $item
* @return bool
*/
public function isTicketMaster(User $user, $item)
{
return $user->isTicketMaster() || $user->is_admin;
}
}