1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-08 20:22:42 +01:00
invoiceninja/app/Policies/DocumentPolicy.php

48 lines
988 B
PHP
Raw Normal View History

2016-04-26 03:53:39 +02:00
<?php
namespace App\Policies;
use App\Models\User;
/**
2017-01-30 20:40:43 +01:00
* Class DocumentPolicy.
*/
class DocumentPolicy extends EntityPolicy
{
/**
2017-01-30 20:49:42 +01:00
* @param User $user
* @param mixed $item
2017-01-30 20:40:43 +01:00
*
* @return bool
*/
2016-10-28 08:42:49 +02:00
public static function create(User $user, $item)
{
2017-01-30 20:40:43 +01:00
return ! empty($user);
2016-04-26 03:53:39 +02:00
}
/**
2017-01-30 20:40:43 +01:00
* @param User $user
2016-07-21 14:35:23 +02:00
* @param Document $document
2017-01-30 20:40:43 +01:00
*
* @return bool
*/
2016-07-21 14:35:23 +02:00
public static function view(User $user, $document)
{
if ($user->hasPermission(['view_expense', 'view_invoice'], true)) {
return true;
}
if ($document->expense) {
if ($document->expense->invoice) {
return $user->can('view', $document->expense->invoice);
}
2017-01-30 20:40:43 +01:00
return $user->can('view', $document->expense);
}
if ($document->invoice) {
return $user->can('view', $document->invoice);
}
2017-05-29 17:02:08 +02:00
return $user->owns($document);
2016-04-26 03:53:39 +02:00
}
2016-07-14 11:01:05 +02:00
}