mirror of
https://github.com/Part-DB/Part-DB-server.git
synced 2026-02-11 03:59:35 +00:00
Do not automatically give existing users the right to manage updates, but include that for new databases
This commit is contained in:
parent
7e486a93c9
commit
1bfd36ccf5
3 changed files with 3 additions and 19 deletions
|
|
@ -43,7 +43,7 @@ final class PermissionData implements \JsonSerializable
|
|||
/**
|
||||
* The current schema version of the permission data
|
||||
*/
|
||||
public const CURRENT_SCHEMA_VERSION = 4;
|
||||
public const CURRENT_SCHEMA_VERSION = 3;
|
||||
|
||||
/**
|
||||
* Creates a new Permission Data Instance using the given data.
|
||||
|
|
|
|||
|
|
@ -111,8 +111,9 @@ class PermissionPresetsHelper
|
|||
|
||||
//Allow to manage Oauth tokens
|
||||
$this->permissionResolver->setPermission($perm_holder, 'system', 'manage_oauth_tokens', PermissionData::ALLOW);
|
||||
//Allow to show updates
|
||||
//Allow to show and manage updates
|
||||
$this->permissionResolver->setPermission($perm_holder, 'system', 'show_updates', PermissionData::ALLOW);
|
||||
$this->permissionResolver->setPermission($perm_holder, 'system', 'manage_updates', PermissionData::ALLOW);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -157,21 +157,4 @@ class PermissionSchemaUpdater
|
|||
$permissions->setPermissionValue('system', 'show_updates', $new_value);
|
||||
}
|
||||
}
|
||||
|
||||
private function upgradeSchemaToVersion4(HasPermissionsInterface $holder): void //@phpstan-ignore-line This is called via reflection
|
||||
{
|
||||
$permissions = $holder->getPermissions();
|
||||
|
||||
//If the system.manage_updates permission is not defined yet, set it to true if the user can show updates AND has server_infos permission
|
||||
//This ensures that admins who can view updates and server info can also manage (execute) updates
|
||||
if (!$permissions->isPermissionSet('system', 'manage_updates')) {
|
||||
|
||||
$new_value = TrinaryLogicHelper::and(
|
||||
$permissions->getPermissionValue('system', 'show_updates'),
|
||||
$permissions->getPermissionValue('system', 'server_infos')
|
||||
);
|
||||
|
||||
$permissions->setPermissionValue('system', 'manage_updates', $new_value);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue