Uploaded image for project: 'Hadoop Common'
  1. Hadoop Common
  2. HADOOP-11337

KeyAuthorizationKeyProvider access checks need to be done atomically

VotersWatch issueWatchersCreate sub-taskLinkCloneUpdate Comment AuthorReplace String in CommentUpdate Comment VisibilityDelete Comments
    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Major
    • Resolution: Fixed
    • None
    • 2.7.0
    • None
    • None

    Description

      In KeyAuthorizationKeyProvider#getMetadata, if firstly call KeyAuthorizationKeyProvider#doAccessCheck to check if client has the permission to do this operation. However, if the metadata is null when KeyAuthorizationKeyProvider#doAccessCheck is called and becomes not null after KeyAuthorizationKeyProvider#doAccessCheck called, key based ACL check will be skipped. The getMetadata operation should be atomic.

        public Metadata getMetadata(String name) throws IOException {
          doAccessCheck(name, KeyOpType.READ);
          return provider.getMetadata(name);
        }
      
        private void doAccessCheck(String keyName, KeyOpType opType) throws
            IOException {
          Metadata metadata = provider.getMetadata(keyName);
          if (metadata != null) {
            String aclName = metadata.getAttributes().get(KEY_ACL_NAME);
            checkAccess((aclName == null) ? keyName : aclName, getUser(), opType);
          }
        }
      

      Attachments

        1. HADOOP-11337.patch
          7 kB
          Dian Fu

        Activity

          This comment will be Viewable by All Users Viewable by All Users
          Cancel

          People

            dian.fu Dian Fu
            dian.fu Dian Fu
            Votes:
            0 Vote for this issue
            Watchers:
            4 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Slack

                Issue deployment