invoiceninja/app/Policies/DocumentPolicy.php

44 lines
901 B
PHP
Raw Normal View History

2016-04-25 21:53:39 -04:00
<?php
namespace App\Policies;
use App\Models\User;
/**
* Class DocumentPolicy
*/
class DocumentPolicy extends EntityPolicy
{
/**
* @param User $user
* @return bool
*/
public static function create(User $user)
{
2016-04-25 21:53:39 -04:00
return !empty($user);
}
/**
* @param User $user
2016-07-21 15:35:23 +03:00
* @param Document $document
* @return bool
*/
2016-07-21 15:35:23 +03:00
public static function view(User $user, $document)
{
if ($user->hasPermission('view_all')) {
return true;
}
if ($document->expense) {
if ($document->expense->invoice) {
return $user->can('view', $document->expense->invoice);
}
return $user->can('view', $document->expense);
}
if ($document->invoice) {
return $user->can('view', $document->invoice);
}
return $user->owns($item);
2016-04-25 21:53:39 -04:00
}
2016-07-14 12:01:05 +03:00
}