Class HttpDigestAuthProvider.Builder
java.lang.Object
io.helidon.security.providers.httpauth.HttpDigestAuthProvider.Builder
- All Implemented Interfaces:
- Builder<HttpDigestAuthProvider.Builder,,- HttpDigestAuthProvider> - Supplier<HttpDigestAuthProvider>
- Enclosing class:
- HttpDigestAuthProvider
public static final class HttpDigestAuthProvider.Builder
extends Object
implements Builder<HttpDigestAuthProvider.Builder,HttpDigestAuthProvider> 
HttpDigestAuthProvider fluent API builder.- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final longDefault is 24 hours.
- 
Method SummaryModifier and TypeMethodDescriptionDigest QOP to support.build()Build the instance from this builder.Update builder from configuration.digestAlgorithm(HttpDigest.Algorithm algorithm) Digest algorithm to use.digestNonceTimeout(long duration, TimeUnit unit) How long will the nonce value be valid.digestServerSecret(char[] serverSecret) The nonce is encrypted using this secret - to make sure the nonce we get back was generated by us and to make sure we can safely time-out nonce values.Do not use qop in challenge (will fallback to legacy RFC-2069 instead of RFC-2617.optional(boolean optional) Whether authentication is required.Set the realm to use when challenging users.subjectType(SubjectType subjectType) Principal type this provider extracts (and also propagates).userStore(SecureUserStore store) Set user store to obtain passwords and roles based on logins.
- 
Field Details- 
DEFAULT_DIGEST_NONCE_TIMEOUTpublic static final long DEFAULT_DIGEST_NONCE_TIMEOUTDefault is 24 hours.- See Also:
 
 
- 
- 
Method Details- 
configUpdate builder from configuration.- Parameters:
- config- to read configuration from, located on the node of the provider
- Returns:
- updated builder instance
 
- 
buildDescription copied from interface:BuilderBuild the instance from this builder.- Specified by:
- buildin interface- Builder<HttpDigestAuthProvider.Builder,- HttpDigestAuthProvider> 
- Returns:
- instance of the built type
 
- 
subjectTypePrincipal type this provider extracts (and also propagates).- Parameters:
- subjectType- type of principal
- Returns:
- updated builder instance
 
- 
userStoreSet user store to obtain passwords and roles based on logins.- Parameters:
- store- User store to use
- Returns:
- updated builder instance
 
- 
optionalWhether authentication is required. By default, request will fail if the authentication cannot be verified. If set to false, request will process and this provider will abstain.- Parameters:
- optional- whether authentication is optional (true) or required (false)
- Returns:
- updated builder instance
 
- 
realmSet the realm to use when challenging users.- Parameters:
- realm- security realm name to send to browser (or any other client) when unauthenticated
- Returns:
- updated builder instance
 
- 
digestAlgorithmDigest algorithm to use.- Parameters:
- algorithm- Algorithm to use, default is- HttpDigest.Algorithm.MD5
- Returns:
- updated builder instance
 
- 
digestNonceTimeoutHow long will the nonce value be valid. When timed-out, browser will re-request username/password. Defaults toDEFAULT_DIGEST_NONCE_TIMEOUTTimeUnit.MILLISECONDS.- Parameters:
- duration- Duration value
- unit- Duration time unit
- Returns:
- updated builder instance
 
- 
digestServerSecretThe nonce is encrypted using this secret - to make sure the nonce we get back was generated by us and to make sure we can safely time-out nonce values. This secret must be the same for all service instances (or all services that want to share the same authentication). Defaults to a random password - e.g. if deployed to multiple servers, the authentication WILL NOT WORK. You MUST provide your own password to work in a distributed environment with non-sticky load balancing.- Parameters:
- serverSecret- a password to encrypt our nonce values with
- Returns:
- updated builder instance
 
- 
addDigestQopDigest QOP to support.- Parameters:
- qop- qop to add to list of supported qops
- Returns:
- updated builder instance
 
- 
noDigestQopDo not use qop in challenge (will fallback to legacy RFC-2069 instead of RFC-2617.- Returns:
- updated builder instance
 
 
-