Class OidcConfig.Builder
java.lang.Object
io.helidon.security.providers.oidc.common.BaseBuilder<OidcConfig.Builder,OidcConfig>
io.helidon.security.providers.oidc.common.OidcConfig.Builder
- All Implemented Interfaces:
Builder<OidcConfig.Builder,,OidcConfig> Supplier<OidcConfig>
- Enclosing class:
OidcConfig
A fluent API
Builder to build instances of OidcConfig.-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionaccessTokenIpCheck(boolean enabled) Whether to check if current IP address matches the one access token was issued for.addTenantConfig(TenantConfig tenantConfig) Add specificTenantConfiginstance.build()Build the instance from this builder.clientCredentialsConfig(ClientCredentialsConfig clientCredentialsConfig) Set the configuration related to the client credentials flow.clientCredentialsConfig(Consumer<ClientCredentialsConfig.Builder> builderConsumer) Configure client credentials configuration over the builder consumer.clientTimeout(Duration duration) Timeout of calls using web client.Update this builder with values from configuration.cookieDomain(String domain) Domain the cookie is valid for.cookieEncryptionEnabled(boolean cookieEncryptionEnabled) Whether to encrypt token cookie created by this microservice.cookieEncryptionEnabledIdToken(boolean cookieEncryptionEnabled) Whether to encrypt id token cookie created by this microservice.cookieEncryptionEnabledRefreshToken(boolean cookieEncryptionEnabled) Whether to encrypt refresh token cookie created by this microservice.cookieEncryptionEnabledState(boolean cookieEncryptionEnabled) Whether to encrypt state cookie created by this microservice.cookieEncryptionEnabledTenantName(boolean cookieEncryptionEnabled) Whether to encrypt tenant name cookie created by this microservice.cookieEncryptionName(String cookieEncryptionName) Name of the encryption configuration available throughSecurity.encrypt(String, byte[])andSecurity.decrypt(String, String).cookieEncryptionPassword(char[] cookieEncryptionPassword) Master password for encryption/decryption of cookies.cookieHttpOnly(Boolean httpOnly) When using cookie, if set to true, the HttpOnly attribute will be configured.cookieMaxAgeSeconds(long age) When using cookie, used to set MaxAge attribute of the cookie, defining how long the cookie is valid.cookieName(String cookieName) Name of the cookie to use.cookieNameIdToken(String cookieName) Name of the cookie to use for id token.cookieNameRefreshToken(String cookieName) The name of the cookie to use for the refresh token.cookieNameState(String cookieName) The name of the cookie to use for the state storage.cookiePath(String path) Path the cookie is valid for.cookieSameSite(SetCookie.SameSite sameSite) When using cookie, used to set the SameSite cookie value.cookieSameSite(String sameSite) When using cookie, used to set the SameSite cookie value.cookieSecure(Boolean secure) When using cookie, if set to true, the Secure attribute will be configured.cookieTenantName(String cookieName) The name of the cookie to use for the tenant name.crossOriginConfig(CrossOriginConfig crossOriginConfig) Assign cross-origin resource sharing settings.forceHttpsRedirects(boolean forceHttpsRedirects) Force HTTPS for redirects to identity provider.frontendUri(String uri) Full URI of this application that is visible from user browser.headerTokenHandler(TokenHandler tokenHandler) ATokenHandlerto process header containing a JWT.idTokenParamName(String idTokenParamName) Name of a query parameter that contains the JWT id token when parameter is used.idTokenSignatureValidation(boolean enabled) Whether id token signature check should be enabled.logoutEnabled(Boolean logoutEnabled) Whether to enable logout support.Path to register web server for logout link.maxRedirects(int maxRedirects) Configure maximal number of redirects when redirecting to an OIDC provider within a single authentication attempt.Name of a query parameter that contains the JWT access token when parameter is used.paramTenantName(String paramName) Name of a query parameter that contains the tenant name when the parameter is used.pkceChallengeMethod(PkceChallengeMethod pkceChallengeMethod) Proof Key Code Exchange (PKCE) challenge creation method.pkceEnabled(boolean enabled) Whether this provider should support PKCE.postLogoutUri(URI uri) URI to redirect to once the logout process is done.Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient.proxyPort(int proxyPort) Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient.proxyProtocol(String protocol) Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient.redirect(boolean redirect) By default, the client should redirect to the identity server for the user to log in.redirectAttemptParam(String paramName) Configure the parameter used to store the number of attempts in redirect.redirectUri(String redirectUri) URI to register web server component on, used by the OIDC server to redirect authorization requests to after a user logs in or approves scopes.relativeUris(boolean relativeUris) Deprecated, for removal: This API element is subject to removal in a future version.use OIDC webclient configuration instead.tokenRefreshSkew(Duration tokenRefreshSkew) Amount of time access token should be refreshed before its expiration time.tokenSignatureValidation(boolean enabled) Whether access token signature check should be enabled.Whether to use cookie to store JWT between requests.Whether to expect JWT in a header field.Whether to use a query parameter to send JWT token from application to this server.webclient(Consumer<WebClientConfig.Builder> builderConsumer) WebClient configuration consumer.Methods inherited from class io.helidon.security.providers.oidc.common.BaseBuilder
audience, authorizationEndpointUri, baseScopes, checkAudience, clientId, clientSecret, decryptionKeys, decryptionKeys, identityUri, introspectEndpointUri, issuer, logoutEndpointUri, oidcMetadata, oidcMetadata, oidcMetadataWellKnown, optionalAudience, realm, scopeAudience, serverType, signJwk, signJwk, tokenEndpointAuthentication, tokenEndpointUri, validateJwtWithJwk
-
Constructor Details
-
Builder
protected Builder()
-
-
Method Details
-
build
Description copied from interface:BuilderBuild the instance from this builder.- Returns:
- instance of the built type
-
config
Update this builder with values from configuration.- Overrides:
configin classBaseBuilder<OidcConfig.Builder,OidcConfig> - Parameters:
config- configuration located on node with OIDC configuration keys (e.g. client-id)- Returns:
- updated builder instance
-
tokenRefreshSkew
Amount of time access token should be refreshed before its expiration time. Default is 5 seconds.- Parameters:
tokenRefreshSkew- time to refresh token before expiration- Returns:
- updated builder
-
crossOriginConfig
Assign cross-origin resource sharing settings.- Parameters:
crossOriginConfig- cross-origin settings to apply to the redirect endpoint- Returns:
- updated builder instance
-
logoutEnabled
Whether to enable logout support. When logout is enabled, we use two cookies (User token and user ID token) and we expose an endpointlogoutUri(String)that can be used to log the user out from Helidon session and also from OIDC session (usesBaseBuilder.logoutEndpointUri(java.net.URI)on OIDC server). Logout support is disabled by default.- Parameters:
logoutEnabled- whether to enable logout- Returns:
- updated builder instance
-
redirect
By default, the client should redirect to the identity server for the user to log in. This behavior can be overridden by setting redirect to false. When token is not present in the request, the client will not redirect and just return appropriate error response code.- Parameters:
redirect- Whether to redirect to OIDC server in case the request does not contain sufficient information to authenticate the user, defaults to true- Returns:
- updated builder instance
-
frontendUri
Full URI of this application that is visible from user browser. Used to redirect request back from identity server after successful login.- Parameters:
uri- the frontend URI, such as "http://my.server.com/myApp- Returns:
- updated builder instance
-
forceHttpsRedirects
Force HTTPS for redirects to identity provider. Defaults tofalse.- Parameters:
forceHttpsRedirects- flag to redirect with https- Returns:
- updated builder instance
-
relativeUris
@Deprecated(since="4.2.1", forRemoval=true) public OidcConfig.Builder relativeUris(boolean relativeUris) Deprecated, for removal: This API element is subject to removal in a future version.use OIDC webclient configuration instead. Seewebclient(Consumer)Can be set totrueto force the use of relative URIs in all requests, regardless of the presence or absence of proxies or no-proxy lists. By default, requests that use the Proxy will have absolute URIs. Set this flag totrueif the host is unable to accept absolute URIs. Defaults to false.- Parameters:
relativeUris- relative URIs flag- Returns:
- updated builder instance
-
redirectUri
URI to register web server component on, used by the OIDC server to redirect authorization requests to after a user logs in or approves scopes. Note that usually the redirect URI configured here must be the same one as configured on OIDC server.Defaults to "/oidc/redirect"
- Parameters:
redirectUri- the URI (path without protocol, host and port) used to redirect requests back to us- Returns:
- updated builder instance
-
logoutUri
Path to register web server for logout link. This should be used by application to redirect user to logout the current user from Helidon based session (when using cookies and redirection). This endpoint will logout user from Helidon session (remove Helidon cookies) and redirect user to logout screen of the OIDC server.- Parameters:
logoutUri- URI path for logout component- Returns:
- updated builder instance
-
postLogoutUri
URI to redirect to once the logout process is done. The endpoint should not be protected by OIDC (as this would serve no purpose, just to log the user in again). This endpoint usually must be registered with the application as the allowed post-logout redirect URI. Note that the URI should not contain any query parameters. You can obtain state using the state query parameter that must be provided tologoutUri(String).- Parameters:
uri- this will be used by the OIDC server to redirect user to once logout is done, can define just path, in which case the scheme, host and port will be taken from request.- Returns:
- updated builder instance
-
redirectAttemptParam
Configure the parameter used to store the number of attempts in redirect.Defaults to "h_ra"
- Parameters:
paramName- name of the parameter used in the state parameter- Returns:
- updated builder instance
-
maxRedirects
Configure maximal number of redirects when redirecting to an OIDC provider within a single authentication attempt.Defaults to 5
- Parameters:
maxRedirects- maximal number of redirects from Helidon to OIDC provider- Returns:
- updated builder instance
-
proxyProtocol
@Deprecated(since="4.2.1", forRemoval=true) public OidcConfig.Builder proxyProtocol(String protocol) Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient. Seewebclient(Consumer)Proxy protocol to use when proxy is used. Defaults to "http".- Parameters:
protocol- protocol to use (such as https)- Returns:
- updated builder instance
-
proxyHost
Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient. Seewebclient(Consumer)Proxy host to use. When defined, triggers usage of proxy for HTTP requests. Setting to empty String has the same meaning as setting to null - disables proxy.- Parameters:
proxyHost- host of the proxy- Returns:
- updated builder instance
- See Also:
-
proxyPort
Deprecated, for removal: This API element is subject to removal in a future version.use proxy configuration on the webclient. Seewebclient(Consumer)Proxy port. Defaults to 80- Parameters:
proxyPort- port of the proxy server to use- Returns:
- updated builder instance
-
headerTokenHandler
ATokenHandlerto process header containing a JWT. Default is "Authorization" header with a prefix "bearer ".- Parameters:
tokenHandler- token handler to use- Returns:
- updated builder instance
-
useHeader
Whether to expect JWT in a header field.- Parameters:
useHeader- set to true to use a header extracted withheaderTokenHandler(TokenHandler)- Returns:
- updated builder instance
-
paramName
Name of a query parameter that contains the JWT access token when parameter is used.- Parameters:
paramName- name of the query parameter to expect- Returns:
- updated builder instance
-
idTokenParamName
Name of a query parameter that contains the JWT id token when parameter is used.- Parameters:
idTokenParamName- name of the query parameter to expect- Returns:
- updated builder instance
-
paramTenantName
Name of a query parameter that contains the tenant name when the parameter is used. Defaults toOidcConfig.DEFAULT_TENANT_PARAM_NAME.- Parameters:
paramName- name of the query parameter to expect- Returns:
- updated builder instance
-
useParam
Whether to use a query parameter to send JWT token from application to this server.- Parameters:
useParam- whether to use a query parameter (true) or not (false)- Returns:
- updated builder instance
- See Also:
-
cookieEncryptionName
Name of the encryption configuration available throughSecurity.encrypt(String, byte[])andSecurity.decrypt(String, String). If configured and encryption is enabled for any cookie, Security MUST be configured in global or currentio.helidon.common.context.Context(this is done automatically in Helidon MP).- Parameters:
cookieEncryptionName- name of the encryption configuration in security used to encrypt/decrypt cookies- Returns:
- updated builder
-
cookieEncryptionPassword
Master password for encryption/decryption of cookies. This must be configured to the same value on each microservice using the cookie.- Parameters:
cookieEncryptionPassword- encryption password- Returns:
- updated builder
-
cookieEncryptionEnabled
Whether to encrypt token cookie created by this microservice. Defaults tofalse.- Parameters:
cookieEncryptionEnabled- whether cookie should be encryptedtrue, or as obtained from OIDC serverfalse- Returns:
- updated builder instance
-
cookieEncryptionEnabledIdToken
Whether to encrypt id token cookie created by this microservice. Defaults totrue.- Parameters:
cookieEncryptionEnabled- whether cookie should be encryptedtrue, or as obtained from OIDC serverfalse- Returns:
- updated builder instance
-
cookieEncryptionEnabledTenantName
Whether to encrypt tenant name cookie created by this microservice. Defaults totrue.- Parameters:
cookieEncryptionEnabled- whether cookie should be encryptedtrue, or as plain text namefalse- Returns:
- updated builder instance
-
cookieEncryptionEnabledRefreshToken
Whether to encrypt refresh token cookie created by this microservice. Defaults totrue.- Parameters:
cookieEncryptionEnabled- whether cookie should be encryptedtrue, or as obtained from OIDC serverfalse- Returns:
- updated builder instance
-
cookieEncryptionEnabledState
Whether to encrypt state cookie created by this microservice. Defaults totrue.- Parameters:
cookieEncryptionEnabled- whether cookie should be encryptedtrue, or as sent to OIDC serverfalse- Returns:
- updated builder instance
-
cookieSameSite
When using cookie, used to set the SameSite cookie value. Can be "Strict" or "Lax"- Parameters:
sameSite- SameSite cookie attribute value- Returns:
- updated builder instance
-
cookieSameSite
When using cookie, used to set the SameSite cookie value. Can be "Strict" or "Lax".- Parameters:
sameSite- SameSite cookie attribute- Returns:
- updated builder instance
-
cookieSecure
When using cookie, if set to true, the Secure attribute will be configured. Defaults to false.- Parameters:
secure- whether the cookie should be secure (true) or not (false)- Returns:
- updated builder instance
-
cookieHttpOnly
When using cookie, if set to true, the HttpOnly attribute will be configured. Defaults to true.- Parameters:
httpOnly- whether the cookie should be HttpOnly (true) or not (false)- Returns:
- updated builder instance
-
cookieMaxAgeSeconds
When using cookie, used to set MaxAge attribute of the cookie, defining how long the cookie is valid. Not used by default.- Parameters:
age- age in seconds- Returns:
- updated builder instance
-
cookiePath
Path the cookie is valid for. Defaults to "/".- Parameters:
path- the path to use as value of cookie "Path" attribute- Returns:
- updated builder instance
-
cookieDomain
Domain the cookie is valid for. Not used by default.- Parameters:
domain- domain to use as value of cookie "Domain" attribute- Returns:
- updated builder instance
-
cookieName
Name of the cookie to use. Defaults to "JSESSIONID".- Parameters:
cookieName- name of a cookie- Returns:
- updated builder instance
-
cookieNameIdToken
Name of the cookie to use for id token. Defaults to "JSESSIONID"_2. This cookie is only used when logout is enabled, as otherwise it is not needed. Content of this cookie is encrypted.- Parameters:
cookieName- name of a cookie- Returns:
- updated builder instance
-
cookieTenantName
The name of the cookie to use for the tenant name. Defaults to "HELIDON_TENANT".- Parameters:
cookieName- name of a cookie- Returns:
- updated builder instance
-
cookieNameRefreshToken
The name of the cookie to use for the refresh token. Defaults to "JSESSIONID_3".- Parameters:
cookieName- name of a cookie- Returns:
- updated builder instance
-
cookieNameState
The name of the cookie to use for the state storage. Defaults to "OIDC_STATE".- Parameters:
cookieName- name of a cookie- Returns:
- updated builder instance
-
useCookie
Whether to use cookie to store JWT between requests. Defaults to true.- Parameters:
useCookie- whether to use cookie to store JWT (true) or not (false))- Returns:
- updated builder instance
-
addTenantConfig
Add specificTenantConfiginstance.- Parameters:
tenantConfig- tenant configuration- Returns:
- updated builder instance
-
tokenSignatureValidation
Whether access token signature check should be enabled. Signature check is enabled by default, and it is highly recommended to not change that. Change this setting only when you really know what you are doing, otherwise it could case security issues.- Parameters:
enabled- whether access token signature check is enabled- Returns:
- updated builder instance
-
idTokenSignatureValidation
Whether id token signature check should be enabled. Signature check is enabled by default, and it is highly recommended to not change that. Change this setting only when you really know what you are doing, otherwise it could case security issues.- Parameters:
enabled- whether id token signature check is enabled- Returns:
- updated builder instance
-
accessTokenIpCheck
Whether to check if current IP address matches the one access token was issued for. This check helps with cookie replay attack prevention.- Parameters:
enabled- whether to check if current IP address matches the one access token was issued for- Returns:
- updated builder instance
-
pkceEnabled
Whether this provider should support PKCE. Default value isfalse.- Parameters:
enabled- PKCE enabled- Returns:
- updated builder instance
-
pkceChallengeMethod
Proof Key Code Exchange (PKCE) challenge creation method. Default value isPkceChallengeMethod.S256.- Parameters:
pkceChallengeMethod- challenge creation method- Returns:
- updated builder instance
-
webclient
WebClient configuration consumer. This configuration is used for outbound requests to the identity server.- Parameters:
builderConsumer- webclient config builder consumer- Returns:
- updated builder instance
-
clientTimeout
Description copied from class:BaseBuilderTimeout of calls using web client.- Overrides:
clientTimeoutin classBaseBuilder<OidcConfig.Builder,OidcConfig> - Parameters:
duration- timeout- Returns:
- updated builder
-
clientCredentialsConfig
Set the configuration related to the client credentials flow.- Parameters:
clientCredentialsConfig- client credentials configuration- Returns:
- updated builder instance
-
clientCredentialsConfig
public OidcConfig.Builder clientCredentialsConfig(Consumer<ClientCredentialsConfig.Builder> builderConsumer) Configure client credentials configuration over the builder consumer.- Parameters:
builderConsumer- builder consumer- Returns:
- updated builder instance
-