public class WorkerTokenManager extends Object
The WorkerTokenManager manages the life cycle of worker tokens in nimbus.
Constructor and Description |
---|
WorkerTokenManager(Map<String,Object> daemonConf,
IStormClusterState state)
Constructor.
|
Modifier and Type | Method and Description |
---|---|
WorkerToken |
createOrUpdateTokenFor(WorkerTokenServiceType serviceType,
String user,
String topologyId)
Create or update an existing key.
|
protected SecretKey |
generateSecret()
Generate a new random secret key.
|
protected SecretKey |
getCurrentSecret()
Get the secret that should be used to sign a token.
|
boolean |
shouldRenewWorkerToken(Map<String,String> creds,
WorkerTokenServiceType type) |
void |
upsertWorkerTokensInCredsForTopo(Map<String,String> creds,
String user,
String topologyId)
Create or renew WorkerToken credentials for a topology.
|
public WorkerTokenManager(Map<String,Object> daemonConf, IStormClusterState state)
Constructor. This assumes that state can store the tokens securely, and that they should be enabled at all. Please use ClientAuthUtils.areWorkerTokensEnabledServer to validate this first.
daemonConf
- the config for nimbus.state
- the state used to store private keys.protected SecretKey generateSecret()
Generate a new random secret key.
protected SecretKey getCurrentSecret()
Get the secret that should be used to sign a token. This may either reuse a secret or generate a new one so any user should call this once and save the result.
public WorkerToken createOrUpdateTokenFor(WorkerTokenServiceType serviceType, String user, String topologyId)
Create or update an existing key.
serviceType
- the type of service to create a token foruser
- the user the token is fortopologyId
- the topology the token is forpublic void upsertWorkerTokensInCredsForTopo(Map<String,String> creds, String user, String topologyId)
Create or renew WorkerToken credentials for a topology.
creds
- the map of credentials for.user
- the user the credentials are fortopologyId
- the topology the credentials are forpublic boolean shouldRenewWorkerToken(Map<String,String> creds, WorkerTokenServiceType type)
Copyright © 2022 The Apache Software Foundation. All rights reserved.