public class FSPermissionChecker extends Object implements INodeAttributeProvider.AccessControlEnforcer
FSNamesystem.readLock().| Modifier | Constructor and Description | 
|---|---|
| protected  | FSPermissionChecker(String fsOwner,
                   String supergroup,
                   org.apache.hadoop.security.UserGroupInformation callerUgi,
                   INodeAttributeProvider attributeProvider) | 
| protected  | FSPermissionChecker(String fsOwner,
                   String supergroup,
                   org.apache.hadoop.security.UserGroupInformation callerUgi,
                   INodeAttributeProvider attributeProvider,
                   boolean useAuthorizationWithContextAPI,
                   long accessControlEnforcerReportingThresholdMs) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | checkPermission(org.apache.hadoop.hdfs.server.namenode.CachePool pool,
               org.apache.hadoop.fs.permission.FsAction access)Whether a cache pool can be accessed by the current context | 
| void | checkPermission(String fsOwner,
               String supergroup,
               org.apache.hadoop.security.UserGroupInformation callerUgi,
               org.apache.hadoop.hdfs.server.namenode.INodeAttributes[] inodeAttrs,
               org.apache.hadoop.hdfs.server.namenode.INode[] inodes,
               byte[][] components,
               int snapshotId,
               String path,
               int ancestorIndex,
               boolean doCheckOwner,
               org.apache.hadoop.fs.permission.FsAction ancestorAccess,
               org.apache.hadoop.fs.permission.FsAction parentAccess,
               org.apache.hadoop.fs.permission.FsAction access,
               org.apache.hadoop.fs.permission.FsAction subAccess,
               boolean ignoreEmptyDir)Checks permission on a file system object. | 
| void | checkPermissionWithContext(INodeAttributeProvider.AuthorizationContext authzContext)Checks permission on a file system object. | 
| void | checkSuperuserPrivilege()This method is retained to maintain backward compatibility. | 
| void | checkSuperuserPrivilege(String path)Checks if the caller has super user privileges. | 
| void | denyUserAccess(String path,
              String errorMessage)Calls the external enforcer to notify denial of access to the user with
 the given error message. | 
| INodeAttributeProvider | getAttributesProvider() | 
| String | getUser() | 
| boolean | isMemberOfGroup(String group) | 
| boolean | isSuperUser() | 
| static void | setOperationType(String opType) | 
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitcheckSuperUserPermissionWithContext, denyUserAccessprotected FSPermissionChecker(String fsOwner, String supergroup, org.apache.hadoop.security.UserGroupInformation callerUgi, INodeAttributeProvider attributeProvider)
protected FSPermissionChecker(String fsOwner, String supergroup, org.apache.hadoop.security.UserGroupInformation callerUgi, INodeAttributeProvider attributeProvider, boolean useAuthorizationWithContextAPI, long accessControlEnforcerReportingThresholdMs)
public static void setOperationType(String opType)
public boolean isMemberOfGroup(String group)
public String getUser()
public boolean isSuperUser()
public INodeAttributeProvider getAttributesProvider()
public void checkSuperuserPrivilege()
                             throws org.apache.hadoop.security.AccessControlException
checkSuperuserPrivilege(String) to make
 sure that the external enforcers have the correct context to audit.org.apache.hadoop.security.AccessControlException - if the caller is not a super user.public void checkSuperuserPrivilege(String path) throws org.apache.hadoop.security.AccessControlException
AccessControlException for non super users.path - The resource path for which permission is being requested.org.apache.hadoop.security.AccessControlException - if the caller is not a super user.public void denyUserAccess(String path, String errorMessage) throws org.apache.hadoop.security.AccessControlException
path - The resource path for which permission is being requested.errorMessage - message for the exception.org.apache.hadoop.security.AccessControlException - with the error message.public void checkPermission(String fsOwner, String supergroup, org.apache.hadoop.security.UserGroupInformation callerUgi, org.apache.hadoop.hdfs.server.namenode.INodeAttributes[] inodeAttrs, org.apache.hadoop.hdfs.server.namenode.INode[] inodes, byte[][] components, int snapshotId, String path, int ancestorIndex, boolean doCheckOwner, org.apache.hadoop.fs.permission.FsAction ancestorAccess, org.apache.hadoop.fs.permission.FsAction parentAccess, org.apache.hadoop.fs.permission.FsAction access, org.apache.hadoop.fs.permission.FsAction subAccess, boolean ignoreEmptyDir) throws org.apache.hadoop.security.AccessControlException
INodeAttributeProvider.AccessControlEnforcercheckPermission in interface INodeAttributeProvider.AccessControlEnforcerfsOwner - Filesystem owner (The Namenode user)supergroup - super user groupcallerUgi - UserGroupInformation of the callerinodeAttrs - Array of INode attributes for each path element in the
                   the pathinodes - Array of INodes for each path element in the pathcomponents - Array of byte arrays of the LocalNamesnapshotId - the snapshotId of the requested pathpath - Path StringancestorIndex - Index of ancestordoCheckOwner - perform ownership checkancestorAccess - The access required by the ancestor of the path.parentAccess - The access required by the parent of the path.access - The access required by the path.subAccess - If path is a directory, It is the access required of
                  the path and all the sub-directories. If path is not a
                  directory, there should ideally be no effect.ignoreEmptyDir - Ignore permission checking for empty directory?org.apache.hadoop.security.AccessControlExceptionpublic void checkPermissionWithContext(INodeAttributeProvider.AuthorizationContext authzContext) throws org.apache.hadoop.security.AccessControlException
INodeAttributeProvider.AccessControlEnforcercheckPermissionWithContext in interface INodeAttributeProvider.AccessControlEnforcerauthzContext - an INodeAttributeProvider.AuthorizationContext object encapsulating
                     the various parameters required to authorize an
                     operation.org.apache.hadoop.security.AccessControlExceptionpublic void checkPermission(org.apache.hadoop.hdfs.server.namenode.CachePool pool,
                            org.apache.hadoop.fs.permission.FsAction access)
                     throws org.apache.hadoop.security.AccessControlException
pool - CachePool being accessedaccess - type of action being performed on the cache poolorg.apache.hadoop.security.AccessControlException - if pool cannot be accessedCopyright © 2008–2024 Apache Software Foundation. All rights reserved.