[
https://issues.apache.org/jira/browse/HDDS-14207?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
ASF GitHub Bot updated HDDS-14207:
----------------------------------
Labels: pull-request-available (was: )
> Inconsistent Ozone admin check
> ------------------------------
>
> Key: HDDS-14207
> URL: https://issues.apache.org/jira/browse/HDDS-14207
> Project: Apache Ozone
> Issue Type: Bug
> Reporter: Sammi Chen
> Assignee: Gargi Jaiswal
> Priority: Major
> Labels: pull-request-available
>
> Ozone administrators have super privileges in Ozone system. Some actions are
> only allowed by Ozone administrators.
> While currently the ozone administrator check is not consistent. Some codes,
> check permission is enabled first, then check if user has the admin
> privilege. For example, OMFinalizeUpgradeRequest#validateAndUpdateCache
> {code:java}
> if (ozoneManager.getAclsEnabled()) {
> UserGroupInformation ugi = createUGIForApi();
> if (!ozoneManager.isAdmin(ugi)) {
> throw new OMException("Access denied for user " + ugi + ". "
> + "Superuser privilege is required to finalize upgrade.",
> OMException.ResultCodes.ACCESS_DENIED);
> }
> }
> {code}
> Some codes, check if user has the admin privilege directly, for example,
> OzoneManager#triggerSnapshotDefrag
> {code:java}
> final UserGroupInformation ugi = getRemoteUser();
> // Check Ozone admin privilege
> if (!isAdmin(ugi)) {
> throw new OMException("Only Ozone admins are allowed to trigger "
> + "snapshot defragmentation manually", PERMISSION_DENIED);
> }
> {code}
> The expected and consistent behavior is we should check whether the
> permission is enabled, if enabled then check whether user is an
> administrator.
> Appendix-1
> Ozone administrator property list, just for check reference,
> - ozone.administrators
> - ozone.administrators.groups
> - ozone.s3.administrators
> - ozone.s3.administrators.groups
> - ozone.readonly.administrators
> - ozone.readonly.administrators.groups
> - ozone.recon.administrators
> - ozone.recon.administrators.groups
> Ozone permission enable property
> - ozone.acl.enabled
> Appendix-2
> HDFS checks permission enabled first, then checks super user if permission
> check is enabled. And HDFS by default enables permission
> check(dfs.permissions.enabled), while Ozone ozone.acl.enabled by default is
> false.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]