mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-27 06:29:47 -08:00
157d9e4ebb
* Add permission to view and modify files for licenses * Actually use the permission
49 lines
1.3 KiB
PHP
49 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');
|
|
}
|
|
}
|