當前位置: 首頁>>代碼示例>>Java>>正文


Java AccessControlException類代碼示例

本文整理匯總了Java中org.apache.hadoop.security.AccessControlException的典型用法代碼示例。如果您正苦於以下問題:Java AccessControlException類的具體用法?Java AccessControlException怎麽用?Java AccessControlException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AccessControlException類屬於org.apache.hadoop.security包,在下文中一共展示了AccessControlException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: setAcl

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
public void setAcl(String src, List<AclEntry> aclSpec) throws IOException {
  checkOpen();
  TraceScope scope = Trace.startSpan("setAcl", traceSampler);
  try {
    namenode.setAcl(src, aclSpec);
  } catch(RemoteException re) {
    throw re.unwrapRemoteException(AccessControlException.class,
                                   AclException.class,
                                   FileNotFoundException.class,
                                   NSQuotaExceededException.class,
                                   SafeModeException.class,
                                   SnapshotAccessControlException.class,
                                   UnresolvedPathException.class);
  } finally {
    scope.close();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:18,代碼來源:DFSClient.java

示例2: getDelegationToken

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public Token<DelegationTokenIdentifier> getDelegationToken(
    final String renewer) throws IOException {
  final HttpOpParam.Op op = GetOpParam.Op.GETDELEGATIONTOKEN;
  Token<DelegationTokenIdentifier> token =
      new FsPathResponseRunner<Token<DelegationTokenIdentifier>>(
          op, null, new RenewerParam(renewer)) {
    @Override
    Token<DelegationTokenIdentifier> decodeResponse(Map<?,?> json)
        throws IOException {
      return JsonUtil.toDelegationToken(json);
    }
  }.run();
  if (token != null) {
    token.setService(tokenServiceName);
  } else {
    if (disallowFallbackToInsecureCluster) {
      throw new AccessControlException(CANT_FALLBACK_TO_INSECURE_MSG);
    }
  }
  return token;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:23,代碼來源:WebHdfsFileSystem.java

示例3: checkSuperuserPrivilege

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
/** Check whether the current user is in the superuser group. */
private void checkSuperuserPrivilege() throws IOException, AccessControlException {
  if (!isPermissionEnabled) {
    return;
  }
  // Try to get the ugi in the RPC call.
  UserGroupInformation callerUgi = ipcServer.getRemoteUser();
  if (callerUgi == null) {
    // This is not from RPC.
    callerUgi = UserGroupInformation.getCurrentUser();
  }

  // Is this by the DN user itself?
  assert dnUserName != null;
  if (callerUgi.getShortUserName().equals(dnUserName)) {
    return;
  }

  // Is the user a member of the super group?
  List<String> groups = Arrays.asList(callerUgi.getGroupNames());
  if (groups.contains(supergroup)) {
    return;
  }
  // Not a superuser.
  throw new AccessControlException();
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:27,代碼來源:DataNode.java

示例4: createSymlink

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
/**
 * Create a symbolic link.
 */
@SuppressWarnings("deprecation")
void createSymlink(String target, String link,
    PermissionStatus dirPerms, boolean createParent, boolean logRetryCache)
    throws IOException {
  if (!FileSystem.areSymlinksEnabled()) {
    throw new UnsupportedOperationException("Symlinks not supported");
  }
  HdfsFileStatus auditStat = null;
  checkOperation(OperationCategory.WRITE);
  writeLock();
  try {
    checkOperation(OperationCategory.WRITE);
    checkNameNodeSafeMode("Cannot create symlink " + link);
    auditStat = FSDirSymlinkOp.createSymlinkInt(this, target, link, dirPerms,
                                                createParent, logRetryCache);
  } catch (AccessControlException e) {
    logAuditEvent(false, "createSymlink", link, target, null);
    throw e;
  } finally {
    writeUnlock();
  }
  getEditLog().logSync();
  logAuditEvent(true, "createSymlink", link, target, auditStat);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:28,代碼來源:FSNamesystem.java

示例5: getFileStatus

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public FileStatus getFileStatus(final Path f) throws AccessControlException,
    FileNotFoundException, UnresolvedLinkException, IOException {
  InodeTree.ResolveResult<AbstractFileSystem> res = 
    fsState.resolve(getUriPath(f), true);

  //  FileStatus#getPath is a fully qualified path relative to the root of 
  // target file system.
  // We need to change it to viewfs URI - relative to root of mount table.
  
  // The implementors of RawLocalFileSystem were trying to be very smart.
  // They implement FileStatus#getOwener lazily -- the object
  // returned is really a RawLocalFileSystem that expect the
  // FileStatus#getPath to be unchanged so that it can get owner when needed.
  // Hence we need to interpose a new ViewFsFileStatus that works around.
  
  
  FileStatus status =  res.targetFileSystem.getFileStatus(res.remainingPath);
  return new ViewFsFileStatus(status, this.makeQualified(f));
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:21,代碼來源:ViewFs.java

示例6: listXAttrs

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
public List<String> listXAttrs(String src)
        throws IOException {
  checkOpen();
  TraceScope scope = getPathTraceScope("listXAttrs", src);
  try {
    final Map<String, byte[]> xattrs =
      XAttrHelper.buildXAttrMap(namenode.listXAttrs(src));
    return Lists.newArrayList(xattrs.keySet());
  } catch(RemoteException re) {
    throw re.unwrapRemoteException(AccessControlException.class,
                                   FileNotFoundException.class,
                                   UnresolvedPathException.class);
  } finally {
    scope.close();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:17,代碼來源:DFSClient.java

示例7: getFileStatus

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public FileStatus getFileStatus(final Path f) throws AccessControlException,
    FileNotFoundException, IOException {
  InodeTree.ResolveResult<FileSystem> res = 
    fsState.resolve(getUriPath(f), true);
  
  // FileStatus#getPath is a fully qualified path relative to the root of 
  // target file system.
  // We need to change it to viewfs URI - relative to root of mount table.
  
  // The implementors of RawLocalFileSystem were trying to be very smart.
  // They implement FileStatus#getOwener lazily -- the object
  // returned is really a RawLocalFileSystem that expect the
  // FileStatus#getPath to be unchanged so that it can get owner when needed.
  // Hence we need to interpose a new ViewFileSystemFileStatus that 
  // works around.
  FileStatus status =  res.targetFileSystem.getFileStatus(res.remainingPath);
  return new ViewFsFileStatus(status, this.makeQualified(f));
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:20,代碼來源:ViewFileSystem.java

示例8: testRemoveAclEntriesMustBeOwnerOrSuper

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Test
public void testRemoveAclEntriesMustBeOwnerOrSuper() throws Exception {
  Path bruceDir = new Path(path, "bruce");
  Path bruceFile = new Path(bruceDir, "file");
  fs.mkdirs(bruceDir);
  fs.setOwner(bruceDir, "bruce", null);
  fsAsBruce.create(bruceFile).close();
  List<AclEntry> aclSpec = Lists.newArrayList(
    aclEntry(ACCESS, USER, "diana"));
  fsAsBruce.removeAclEntries(bruceFile, aclSpec);
  fs.removeAclEntries(bruceFile, aclSpec);
  fsAsSupergroupMember.removeAclEntries(bruceFile, aclSpec);
  exception.expect(AccessControlException.class);
  fsAsDiana.removeAclEntries(bruceFile, aclSpec);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:16,代碼來源:FSAclBaseTest.java

示例9: createSymlink

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public void createSymlink(Path target, Path link, boolean createParent)
    throws AccessControlException, FileAlreadyExistsException,
    FileNotFoundException, ParentNotDirectoryException,
    UnsupportedFileSystemException, IOException {
  fs.createSymlink(target, link, createParent);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:8,代碼來源:FileSystemTestWrapper.java

示例10: verifyCorruptedBlockCount

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
/**
 * Verify the number of corrupted block replicas by fetching the block
 * location from name node.
 */
private void verifyCorruptedBlockCount(Path filePath, int expectedReplicas)
    throws AccessControlException, FileNotFoundException,
    UnresolvedLinkException, IOException {
  final LocatedBlocks lBlocks = dfs.dfs.getNamenode().getBlockLocations(
      filePath.toUri().getPath(), 0, Long.MAX_VALUE);
  // we expect only the first block of the file is used for this test
  LocatedBlock firstLocatedBlock = lBlocks.get(0);
  Assert.assertEquals(expectedReplicas,
      firstLocatedBlock.getLocations().length);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:15,代碼來源:TestClientReportBadBlock.java

示例11: rename

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@SuppressWarnings("deprecation")
@Override
public void rename(Path src, Path dst, Rename... options)
    throws AccessControlException, FileAlreadyExistsException,
    FileNotFoundException, ParentNotDirectoryException,
    UnsupportedFileSystemException, IOException {
  fs.rename(src, dst, options);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:9,代碼來源:FileSystemTestWrapper.java

示例12: transitionToStandby

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public void transitionToStandby(StateChangeRequestInfo req) throws ServiceFailedException,
    AccessControlException, IOException {
  checkUnreachable();
  if (failToBecomeStandby) {
    throw new ServiceFailedException("injected failure");
  }
  if (sharedResource != null) {
    sharedResource.release(DummyHAService.this);
  }
  state = HAServiceState.STANDBY;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:13,代碼來源:DummyHAService.java

示例13: listLocatedStatus

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public RemoteIterator<LocatedFileStatus> listLocatedStatus(final Path f)
    throws AccessControlException, FileNotFoundException,
           UnresolvedLinkException, IOException {
  checkPath(f);
  return myFs.listLocatedStatus(f);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:8,代碼來源:FilterFs.java

示例14: doCedeActive

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
private void doCedeActive(int millisToCede) 
    throws AccessControlException, ServiceFailedException, IOException {
  int timeout = FailoverController.getGracefulFenceTimeout(conf);

  // Lock elector to maintain lock ordering of elector -> ZKFC
  synchronized (elector) {
    synchronized (this) {
      if (millisToCede <= 0) {
        delayJoiningUntilNanotime = 0;
        recheckElectability();
        return;
      }

      LOG.info("Requested by " + UserGroupInformation.getCurrentUser() +
          " at " + Server.getRemoteAddress() + " to cede active role.");
      boolean needFence = false;
      try {
        localTarget.getProxy(conf, timeout).transitionToStandby(createReqInfo());
        LOG.info("Successfully ensured local node is in standby mode");
      } catch (IOException ioe) {
        LOG.warn("Unable to transition local node to standby: " +
            ioe.getLocalizedMessage());
        LOG.warn("Quitting election but indicating that fencing is " +
            "necessary");
        needFence = true;
      }
      delayJoiningUntilNanotime = System.nanoTime() +
          TimeUnit.MILLISECONDS.toNanos(millisToCede);
      elector.quitElection(needFence);
      serviceState = HAServiceState.INITIALIZING;
    }
  }
  recheckElectability();
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:35,代碼來源:ZKFailoverController.java

示例15: access

import org.apache.hadoop.security.AccessControlException; //導入依賴的package包/類
@Override
public void access(Path path, FsAction mode) throws AccessControlException,
    FileNotFoundException, IOException {
  InodeTree.ResolveResult<FileSystem> res =
    fsState.resolve(getUriPath(path), true);
  res.targetFileSystem.access(res.remainingPath, mode);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:8,代碼來源:ViewFileSystem.java


注:本文中的org.apache.hadoop.security.AccessControlException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。