当前位置: 首页>>代码示例>>Java>>正文


Java AbstractDelegationTokenIdentifier类代码示例

本文整理汇总了Java中org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier的典型用法代码示例。如果您正苦于以下问题:Java AbstractDelegationTokenIdentifier类的具体用法?Java AbstractDelegationTokenIdentifier怎么用?Java AbstractDelegationTokenIdentifier使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


AbstractDelegationTokenIdentifier类属于org.apache.hadoop.security.token.delegation包,在下文中一共展示了AbstractDelegationTokenIdentifier类的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: testEncodeWritable

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
public static void testEncodeWritable() throws Exception {
  String[] values = new String[]{"", "a", "bb", "ccc", "dddd", "eeeee",
      "ffffff", "ggggggg", "hhhhhhhh", "iiiiiiiii",
      "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLM" +
           "[email protected]#$%^&*()-=_+[]{}|;':,./<>?"};
  Token<AbstractDelegationTokenIdentifier> orig;
  Token<AbstractDelegationTokenIdentifier> copy = 
    new Token<AbstractDelegationTokenIdentifier>();
  // ensure that for each string the input and output values match
  for(int i=0; i< values.length; ++i) {
    String val = values[i];
    System.out.println("Input = " + val);
    orig = new Token<AbstractDelegationTokenIdentifier>(val.getBytes(),
        val.getBytes(), new Text(val), new Text(val));
    String encode = orig.encodeToUrlString();
    copy.decodeFromUrlString(encode);
    assertEquals(orig, copy);
    checkUrlSafe(encode);
  }
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:21,代码来源:TestToken.java

示例2: DelegationTokenToRenew

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
public DelegationTokenToRenew(Collection<ApplicationId> applicationIds,
    Token<?> token,
    Configuration conf, long expirationDate, boolean shouldCancelAtEnd,
    String user) {
  this.token = token;
  this.user = user;
  if (token.getKind().equals(new Text("HDFS_DELEGATION_TOKEN"))) {
    try {
      AbstractDelegationTokenIdentifier identifier =
          (AbstractDelegationTokenIdentifier) token.decodeIdentifier();
      maxDate = identifier.getMaxDate();
    } catch (IOException e) {
      throw new YarnRuntimeException(e);
    }
  }
  this.referringAppIds = Collections.synchronizedSet(
      new HashSet<ApplicationId>(applicationIds));
  this.conf = conf;
  this.expirationDate = expirationDate;
  this.timerTask = null;
  this.shouldCancelAtEnd = shouldCancelAtEnd;
}
 
开发者ID:naver,项目名称:hadoop,代码行数:23,代码来源:DelegationTokenRenewer.java

示例3: testFcDelegationToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
/**
 * Tests delegation token APIs in FileContext for Hdfs; and renew and cancel
 * APIs in Hdfs.
 * 
 * @throws UnsupportedFileSystemException
 * @throws IOException
 * @throws InterruptedException
 */
@SuppressWarnings({ "unchecked", "deprecation" })
@Test
public void testFcDelegationToken() throws UnsupportedFileSystemException,
    IOException, InterruptedException {
  FileContext fcHdfs = FileContext.getFileContext(cluster.getFileSystem()
      .getUri());
  final AbstractFileSystem afs = fcHdfs.getDefaultFileSystem();
  final List<Token<?>> tokenList =
      afs.getDelegationTokens(UserGroupInformation.getCurrentUser()
          .getUserName());
  ((Hdfs) afs).renewDelegationToken((Token<DelegationTokenIdentifier>) tokenList
      .get(0));
  ((Hdfs) afs).cancelDelegationToken(
      (Token<? extends AbstractDelegationTokenIdentifier>) tokenList.get(0));
}
 
开发者ID:naver,项目名称:hadoop,代码行数:24,代码来源:TestResolveHdfsSymlink.java

示例4: DelegationTokenToRenew

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
public DelegationTokenToRenew(Collection<ApplicationId> applicationIds,
    Token<?> token,
    Configuration conf, long expirationDate, boolean shouldCancelAtEnd,
    String user) {
  this.token = token;
  this.user = user;
  if (token.getKind().equals(HDFS_DELEGATION_KIND)) {
    try {
      AbstractDelegationTokenIdentifier identifier =
          (AbstractDelegationTokenIdentifier) token.decodeIdentifier();
      maxDate = identifier.getMaxDate();
    } catch (IOException e) {
      throw new YarnRuntimeException(e);
    }
  }
  this.referringAppIds = Collections.synchronizedSet(
      new HashSet<ApplicationId>(applicationIds));
  this.conf = conf;
  this.expirationDate = expirationDate;
  this.timerTask = null;
  this.shouldCancelAtEnd = shouldCancelAtEnd;
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:23,代码来源:DelegationTokenRenewer.java

示例5: getDelegationToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
/**
 * Requests a delegation token using the configured <code>Authenticator</code>
 * for authentication.
 *
 * @param url the URL to get the delegation token from. Only HTTP/S URLs are
 * supported.
 * @param token the authentication token being used for the user where the
 * Delegation token will be stored.
 * @param renewer the renewer user.
 * @param doAsUser the user to do as, which will be the token owner.
 * @throws IOException if an IO error occurred.
 * @throws AuthenticationException if an authentication exception occurred.
 */
public Token<AbstractDelegationTokenIdentifier> getDelegationToken(URL url,
    AuthenticatedURL.Token token, String renewer, String doAsUser)
    throws IOException, AuthenticationException {
  Map json = doDelegationTokenOperation(url, token,
      DelegationTokenOperation.GETDELEGATIONTOKEN, renewer, null, true,
      doAsUser);
  json = (Map) json.get(DELEGATION_TOKEN_JSON);
  String tokenStr = (String) json.get(DELEGATION_TOKEN_URL_STRING_JSON);
  Token<AbstractDelegationTokenIdentifier> dToken =
      new Token<AbstractDelegationTokenIdentifier>();
  dToken.decodeFromUrlString(tokenStr);
  InetSocketAddress service = new InetSocketAddress(url.getHost(),
      url.getPort());
  SecurityUtil.setTokenService(dToken, service);
  return dToken;
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:30,代码来源:DelegationTokenAuthenticator.java

示例6: createToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
@SuppressWarnings("unchecked")
public Token<? extends AbstractDelegationTokenIdentifier> createToken(
    UserGroupInformation ugi, String renewer) {
  renewer = (renewer == null) ? ugi.getShortUserName() : renewer;
  String user = ugi.getUserName();
  Text owner = new Text(user);
  Text realUser = null;
  if (ugi.getRealUser() != null) {
    realUser = new Text(ugi.getRealUser().getUserName());
  }
  AbstractDelegationTokenIdentifier tokenIdentifier =
      (AbstractDelegationTokenIdentifier) secretManager.createIdentifier();
  tokenIdentifier.setOwner(owner);
  tokenIdentifier.setRenewer(new Text(renewer));
  tokenIdentifier.setRealUser(realUser);
  return new Token(tokenIdentifier, secretManager);
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:18,代码来源:DelegationTokenManager.java

示例7: DelegationTokenToRenew

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
public DelegationTokenToRenew(ApplicationId jId, Token<?> token,
    Configuration conf, long expirationDate, boolean shouldCancelAtEnd,
    String user) {
  this.token = token;
  this.user = user;
  if (token.getKind().equals(HDFS_DELEGATION_KIND)) {
    try {
      AbstractDelegationTokenIdentifier identifier =
          (AbstractDelegationTokenIdentifier) token.decodeIdentifier();
      maxDate = identifier.getMaxDate();
    } catch (IOException e) {
      throw new YarnRuntimeException(e);
    }
  }
  this.applicationId = jId;
  this.conf = conf;
  this.expirationDate = expirationDate;
  this.timerTask = null;
  this.shouldCancelAtEnd = shouldCancelAtEnd;
}
 
开发者ID:Nextzero,项目名称:hadoop-2.6.0-cdh5.4.3,代码行数:21,代码来源:DelegationTokenRenewer.java

示例8: getDelegationToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
public static Token<?> getDelegationToken(URI fsURI,
    InetSocketAddress httpFSAddr, AuthenticatedURL.Token token,
    String renewer) throws IOException {
  DelegationTokenOperation op = DelegationTokenOperation.GETDELEGATIONTOKEN;
  Map<String, String> params = new HashMap<>();
  params.put(OP_PARAM, op.toString());
  params.put(RENEWER_PARAM, renewer);
  URL url = HttpFSUtils.createHttpURL(new Path(fsURI), params);
  AuthenticatedURL aUrl =
      new AuthenticatedURL(new HttpFSKerberosAuthenticator());
  try {
    HttpURLConnection conn = aUrl.openConnection(url, token);
    conn.setRequestMethod(op.getHttpMethod());
    HttpFSUtils.validateResponse(conn, HttpURLConnection.HTTP_OK);
    JSONObject json = (JSONObject) ((JSONObject) HttpFSUtils.jsonParse(conn))
        .get(DELEGATION_TOKEN_JSON);
    String tokenStr = (String) json.get(DELEGATION_TOKEN_URL_STRING_JSON);
    Token<AbstractDelegationTokenIdentifier> dToken =
        new Token<>();
    dToken.decodeFromUrlString(tokenStr);
    SecurityUtil.setTokenService(dToken, httpFSAddr);
    return dToken;
  } catch (AuthenticationException ex) {
    throw new IOException(ex.toString(), ex);
  }
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:27,代码来源:HttpFSKerberosAuthenticator.java

示例9: createToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
@SuppressWarnings("unchecked")
public Token<? extends AbstractDelegationTokenIdentifier> createToken(
    UserGroupInformation ugi, String renewer) {
  LOG.debug("Creating token with ugi:{}, renewer:{}.", ugi, renewer);
  renewer = (renewer == null) ? ugi.getShortUserName() : renewer;
  String user = ugi.getUserName();
  Text owner = new Text(user);
  Text realUser = null;
  if (ugi.getRealUser() != null) {
    realUser = new Text(ugi.getRealUser().getUserName());
  }
  AbstractDelegationTokenIdentifier tokenIdentifier =
      (AbstractDelegationTokenIdentifier) secretManager.createIdentifier();
  tokenIdentifier.setOwner(owner);
  tokenIdentifier.setRenewer(new Text(renewer));
  tokenIdentifier.setRealUser(realUser);
  return new Token(tokenIdentifier, secretManager);
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:19,代码来源:DelegationTokenManager.java

示例10: cancelDelegationToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
/**
 * Cancels a delegation token from the server end-point. It does not require
 * being authenticated by the configured <code>Authenticator</code>.
 *
 * @param url the URL to cancel the delegation token from. Only HTTP/S URLs
 * are supported.
 * @param token the authentication token with the Delegation Token to cancel.
 * @param doAsUser the user to do as, which will be the token owner.
 * @throws IOException if an IO error occurred.
 */
public void cancelDelegationToken(URL url,
    AuthenticatedURL.Token token,
    Token<AbstractDelegationTokenIdentifier> dToken, String doAsUser)
    throws IOException {
  try {
    doDelegationTokenOperation(url, token,
        DelegationTokenOperation.CANCELDELEGATIONTOKEN, null, dToken, false,
        doAsUser);
  } catch (AuthenticationException ex) {
    throw new IOException("This should not happen: " + ex.getMessage(), ex);
  }
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:23,代码来源:DelegationTokenAuthenticator.java

示例11: cancelToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
@SuppressWarnings("unchecked")
public void cancelToken(
    Token<? extends AbstractDelegationTokenIdentifier> token,
    String canceler) throws IOException {
  canceler = (canceler != null) ? canceler :
             verifyToken(token).getShortUserName();
  secretManager.cancelToken(token, canceler);
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:9,代码来源:DelegationTokenManager.java

示例12: verifyToken

import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier; //导入依赖的package包/类
@SuppressWarnings("unchecked")
public UserGroupInformation verifyToken(
    Token<? extends AbstractDelegationTokenIdentifier> token)
        throws IOException {
  AbstractDelegationTokenIdentifier id = secretManager.decodeTokenIdentifier(token);
  secretManager.verifyToken(id, token.getPassword());
  return id.getUser();
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:9,代码来源:DelegationTokenManager.java


注:本文中的org.apache.hadoop.security.token.delegation.AbstractDelegationTokenIdentifier类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。