@InterfaceStability.Unstable @InterfaceAudience.Private public class ZKSignerSecretProvider extends RolloverSignerSecretProvider
 It works by storing the secrets and next rollover time in a ZooKeeper znode.
 All ZKSignerSecretProviders looking at that znode will use those
 secrets and next rollover time to ensure they are synchronized.  There is no
 "leader" -- any of the ZKSignerSecretProviders can choose the next secret;
 which one is indeterminate.  Kerberos-based ACLs can also be enforced to
 prevent a malicious third-party from getting or setting the secrets.  It uses
 its own CuratorFramework client for talking to ZooKeeper.  If you want to use
 your own Curator client, you can pass it to ZKSignerSecretProvider; see
 AuthenticationFilter
 for more details.
 
Details of the configurations are listed on Configuration Page
| Modifier and Type | Field and Description | 
|---|---|
| static String | DISCONNECT_FROM_ZOOKEEPER_ON_SHUTDOWNConstant for the property that specifies whether or not the Curator client
 should disconnect from ZooKeeper on shutdown. | 
| static String | ZOOKEEPER_AUTH_TYPEConstant for the property that specifies the auth type to use. | 
| static String | ZOOKEEPER_CONNECTION_STRINGConstant for the property that specifies the ZooKeeper connection string. | 
| static String | ZOOKEEPER_KERBEROS_KEYTABConstant for the property that specifies the Kerberos keytab file. | 
| static String | ZOOKEEPER_KERBEROS_PRINCIPALConstant for the property that specifies the Kerberos principal. | 
| static String | ZOOKEEPER_PATHConstant for the property that specifies the ZooKeeper path. | 
| static String | ZOOKEEPER_SIGNER_SECRET_PROVIDER_CURATOR_CLIENT_ATTRIBUTEConstant for the ServletContext attribute that can be used for providing a
 custom CuratorFramework client. | 
| static String | ZOOKEEPER_SSL_ENABLED | 
| static String | ZOOKEEPER_SSL_KEYSTORE_LOCATION | 
| static String | ZOOKEEPER_SSL_KEYSTORE_PASSWORD | 
| static String | ZOOKEEPER_SSL_TRUSTSTORE_LOCATION | 
| static String | ZOOKEEPER_SSL_TRUSTSTORE_PASSWORD | 
| Constructor and Description | 
|---|
| ZKSignerSecretProvider() | 
| ZKSignerSecretProvider(long seed)This constructor lets you set the seed of the Random Number Generator and
 is meant for testing. | 
| Modifier and Type | Method and Description | 
|---|---|
| protected org.apache.curator.framework.CuratorFramework | createCuratorClient(Properties config)This method creates the Curator client and connects to ZooKeeper. | 
| void | destroy()Disconnects from ZooKeeper unless told not to. | 
| protected byte[] | generateNewSecret()Subclasses should implement this to return a new secret. | 
| protected byte[] | generateRandomSecret() | 
| void | init(Properties config,
    javax.servlet.ServletContext servletContext,
    long tokenValidity)Initialize the SignerSecretProvider. | 
| protected void | rollSecret()Rolls the secret. | 
getAllSecrets, getCurrentSecret, initSecrets, startSchedulerpublic static final String ZOOKEEPER_CONNECTION_STRING
public static final String ZOOKEEPER_PATH
public static final String ZOOKEEPER_AUTH_TYPE
public static final String ZOOKEEPER_KERBEROS_KEYTAB
public static final String ZOOKEEPER_KERBEROS_PRINCIPAL
public static final String ZOOKEEPER_SSL_ENABLED
public static final String ZOOKEEPER_SSL_KEYSTORE_LOCATION
public static final String ZOOKEEPER_SSL_KEYSTORE_PASSWORD
public static final String ZOOKEEPER_SSL_TRUSTSTORE_LOCATION
public static final String ZOOKEEPER_SSL_TRUSTSTORE_PASSWORD
public static final String DISCONNECT_FROM_ZOOKEEPER_ON_SHUTDOWN
public static final String ZOOKEEPER_SIGNER_SECRET_PROVIDER_CURATOR_CLIENT_ATTRIBUTE
public ZKSignerSecretProvider()
@VisibleForTesting public ZKSignerSecretProvider(long seed)
seed - the seed for the random number generatorpublic void init(Properties config, javax.servlet.ServletContext servletContext, long tokenValidity) throws Exception
RolloverSignerSecretProviderinit in class RolloverSignerSecretProviderconfig - configuration propertiesservletContext - servlet contexttokenValidity - The amount of time a token is valid forException - thrown if an error occurredpublic void destroy()
destroy in class RolloverSignerSecretProviderprotected void rollSecret()
RolloverSignerSecretProviderrollSecret in class RolloverSignerSecretProviderprotected byte[] generateNewSecret()
RolloverSignerSecretProvidergenerateNewSecret in class RolloverSignerSecretProvider@VisibleForTesting protected byte[] generateRandomSecret()
protected org.apache.curator.framework.CuratorFramework createCuratorClient(Properties config)
config - configuration propertiesCopyright © 2008–2024 Apache Software Foundation. All rights reserved.