mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-31 16:37:27 -08:00
934afa036f
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the adopted coding style by adding your own [PHP CS Fixer][1] `.php_cs` config file to your project root. Feel free to use [Shift's Laravel ruleset][2] to help you get started. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200
50 lines
1.3 KiB
PHP
50 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace App\Policies;
|
|
|
|
use App\Models\License;
|
|
use App\Models\User;
|
|
|
|
class LicensePolicy extends CheckoutablePermissionsPolicy
|
|
{
|
|
protected function columnName()
|
|
{
|
|
return 'licenses';
|
|
}
|
|
|
|
/**
|
|
* Determine whether the user can view license keys.
|
|
* This gets a little tricky, UX/logic-wise. If a user has the ability
|
|
* to create a license (which requires a product key), shouldn't they
|
|
* have the ability to see the product key as well?
|
|
*
|
|
* Example: I create the license, realize I need to change
|
|
* something (maybe I got the product key wrong), and now I can never
|
|
* see/edit that product key.
|
|
*
|
|
* @see https://github.com/snipe/snipe-it/issues/6956
|
|
* @param \App\Models\User $user
|
|
* @param \App\Models\License $license
|
|
* @return mixed
|
|
*/
|
|
public function viewKeys(User $user, License $license = null)
|
|
{
|
|
if ($user->hasAccess('licenses.keys') || $user->hasAccess('licenses.create') || $user->hasAccess('licenses.edit')) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Determine whether the user can access files associated with licenses.
|
|
*
|
|
* @param \App\Models\User $user
|
|
* @return mixed
|
|
*/
|
|
public function files(User $user)
|
|
{
|
|
return $user->hasAccess($this->columnName().'.files');
|
|
}
|
|
}
|