Module io.helidon.common.tls
Package io.helidon.common.tls
Class TlsConfig.BuilderBase.TlsConfigImpl
java.lang.Object
io.helidon.common.tls.TlsConfig.BuilderBase.TlsConfigImpl
- All Implemented Interfaces:
- Prototype.Api,- Prototype.Factory<Tls>,- TlsConfig,- Supplier<Tls>
- Enclosing class:
- TlsConfig.BuilderBase<BUILDER extends TlsConfig.BuilderBase<BUILDER,- PROTOTYPE>, - PROTOTYPE extends TlsConfig> 
protected static class TlsConfig.BuilderBase.TlsConfigImpl
extends Object
implements TlsConfig, Supplier<Tls>
Generated implementation of the prototype, can be extended by descendant prototype implementations.
- 
Nested Class SummaryNested classes/interfaces inherited from interface io.helidon.common.tls.TlsConfigTlsConfig.Builder, TlsConfig.BuilderBase<BUILDER extends TlsConfig.BuilderBase<BUILDER,PROTOTYPE>, PROTOTYPE extends TlsConfig> 
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe default protocol is set to "TLS".static final intThe default session cache size as defined for unset value inSSLSessionContext.getSessionCacheSize().static final StringThe default session timeout as defined for unset value inSSLSessionContext.getSessionTimeout().
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedTlsConfigImpl(TlsConfig.BuilderBase<?, ?> builder) Create an instance providing a builder.
- 
Method SummaryModifier and TypeMethodDescriptionConfigure list of supported application protocols (such ash2) for application layer protocol negotiation (ALPN).build()Create a new instance of the runtime type from this config object.Configure requirement for mutual TLS.booleanenabled()Flag indicating whether Tls is enabled.Enabled cipher suites for TLS communication.Enabled protocols for TLS communication.Identification algorithm for SSL endpoints.booleanget()inthashCode()Provider of the key stores used internally to create a key and trust manager factories.Type of the key stores used internally to create a key and trust manager factories.Algorithm of the key manager factory used when private key is defined.Key manager factory provider.manager()The Tls manager.Private key to use.Certificate chain of the private key.protocol()Configure the protocol used to obtain an instance ofSSLContext.provider()Use explicit provider to obtain an instance ofSSLContext.Certificate revocation check configuration.Explicit secure random to use.Algorithm to use when creating a new secure random.Provider to use when creating a new secure random.intSSL session cache size.SSL session timeout.Provide a fully configuredSSLContext.Configure SSL parameters.toString()trust()List of certificates that form the trust manager.booleantrustAll()Trust any certificate provided by the other side of communication.Trust manager factory algorithm.Trust manager factory provider to use.
- 
Field Details- 
DEFAULT_PROTOCOLThe default protocol is set to "TLS".- See Also:
 
- 
DEFAULT_SESSION_CACHE_SIZEstatic final int DEFAULT_SESSION_CACHE_SIZEThe default session cache size as defined for unset value inSSLSessionContext.getSessionCacheSize().- See Also:
 
- 
DEFAULT_SESSION_TIMEOUTThe default session timeout as defined for unset value inSSLSessionContext.getSessionTimeout().- See Also:
 
 
- 
- 
Constructor Details- 
TlsConfigImplCreate an instance providing a builder.- Parameters:
- builder- extending builder base of this prototype
 
 
- 
- 
Method Details- 
buildDescription copied from interface:Prototype.FactoryCreate a new instance of the runtime type from this config object.- Specified by:
- buildin interface- Prototype.Factory<Tls>
- Returns:
- new configured runtime instance
 
- 
get
- 
sslContextDescription copied from interface:TlsConfigProvide a fully configuredSSLContext. If defined, context related configuration is ignored.- Specified by:
- sslContextin interface- TlsConfig
- Returns:
- SSL context to use
 
- 
privateKeyDescription copied from interface:TlsConfigPrivate key to use. For server side TLS, this is required. For client side TLS, this is optional (used when mutual TLS is enabled).- Specified by:
- privateKeyin interface- TlsConfig
- Returns:
- private key to use
 
- 
privateKeyCertChainDescription copied from interface:TlsConfigCertificate chain of the private key.- Specified by:
- privateKeyCertChainin interface- TlsConfig
- Returns:
- private key certificate chain, only used when private key is configured
 
- 
trustDescription copied from interface:TlsConfigList of certificates that form the trust manager.
- 
managerDescription copied from interface:TlsConfigThe Tls manager. If one is not explicitly defined in the config then a default manager will be created.
- 
secureRandomDescription copied from interface:TlsConfigExplicit secure random to use.- Specified by:
- secureRandomin interface- TlsConfig
- Returns:
- secure random to use
 
- 
sslParametersDescription copied from interface:TlsConfigConfigure SSL parameters. This will always have a value, as we compute ssl parameters in a builder interceptor from configured options.- Specified by:
- sslParametersin interface- TlsConfig
- Returns:
- SSL parameters to use
 
- 
secureRandomProviderDescription copied from interface:TlsConfigProvider to use when creating a new secure random. When defined,TlsConfig.secureRandomAlgorithm()must be defined as well.- Specified by:
- secureRandomProviderin interface- TlsConfig
- Returns:
- provider to use, by default no provider is specified
 
- 
secureRandomAlgorithmDescription copied from interface:TlsConfigAlgorithm to use when creating a new secure random.- Specified by:
- secureRandomAlgorithmin interface- TlsConfig
- Returns:
- algorithm to use, by default uses SecureRandomconstructor
 
- 
keyManagerFactoryAlgorithmDescription copied from interface:TlsConfigAlgorithm of the key manager factory used when private key is defined. Defaults toKeyManagerFactory.getDefaultAlgorithm().- Specified by:
- keyManagerFactoryAlgorithmin interface- TlsConfig
- Returns:
- algorithm to use
 
- 
keyManagerFactoryProviderDescription copied from interface:TlsConfigKey manager factory provider.- Specified by:
- keyManagerFactoryProviderin interface- TlsConfig
- Returns:
- provider to use
 
- 
trustManagerFactoryAlgorithmDescription copied from interface:TlsConfigTrust manager factory algorithm.- Specified by:
- trustManagerFactoryAlgorithmin interface- TlsConfig
- Returns:
- algorithm to use
 
- 
trustManagerFactoryProviderDescription copied from interface:TlsConfigTrust manager factory provider to use.- Specified by:
- trustManagerFactoryProviderin interface- TlsConfig
- Returns:
- provider to use
 
- 
applicationProtocolsDescription copied from interface:TlsConfigConfigure list of supported application protocols (such ash2) for application layer protocol negotiation (ALPN).- Specified by:
- applicationProtocolsin interface- TlsConfig
- Returns:
- application protocols
 
- 
endpointIdentificationAlgorithmDescription copied from interface:TlsConfigIdentification algorithm for SSL endpoints.- Specified by:
- endpointIdentificationAlgorithmin interface- TlsConfig
- Returns:
- configure endpoint identification algorithm, or set to NONEto disable endpoint identification (equivalent to hostname verification). Defaults to "HTTPS"
 
- 
enabledpublic boolean enabled()Description copied from interface:TlsConfigFlag indicating whether Tls is enabled.
- 
trustAllpublic boolean trustAll()Description copied from interface:TlsConfigTrust any certificate provided by the other side of communication.This is a dangerous setting: if set to true, any certificate will be accepted, throwing away most of the security advantages of TLS. NEVER do this in production.
- 
clientAuthDescription copied from interface:TlsConfigConfigure requirement for mutual TLS.- Specified by:
- clientAuthin interface- TlsConfig
- Returns:
- what type of mutual TLS to use, defaults to TlsClientAuth.NONE
 
- 
protocolDescription copied from interface:TlsConfigConfigure the protocol used to obtain an instance ofSSLContext.
- 
providerDescription copied from interface:TlsConfigUse explicit provider to obtain an instance ofSSLContext.- Specified by:
- providerin interface- TlsConfig
- Returns:
- provider to use, defaults to none (only TlsConfig.protocol()is used by default)
 
- 
enabledCipherSuitesDescription copied from interface:TlsConfigEnabled cipher suites for TLS communication.- Specified by:
- enabledCipherSuitesin interface- TlsConfig
- Returns:
- cipher suites to enable, by default (or if list is empty), all available cipher suites are enabled
 
- 
enabledProtocolsDescription copied from interface:TlsConfigEnabled protocols for TLS communication. Example of valid values forTLSprotocol:TLSv1.3,TLSv1.2- Specified by:
- enabledProtocolsin interface- TlsConfig
- Returns:
- protocols to enable, by default (or if list is empty), all available protocols are enabled
 
- 
sessionCacheSizepublic int sessionCacheSize()Description copied from interface:TlsConfigSSL session cache size.- Specified by:
- sessionCacheSizein interface- TlsConfig
- Returns:
- session cache size, defaults to 20480.
 
- 
sessionTimeoutDescription copied from interface:TlsConfigSSL session timeout.- Specified by:
- sessionTimeoutin interface- TlsConfig
- Returns:
- session timeout, defaults to "PT24H".
 
- 
internalKeystoreTypeDescription copied from interface:TlsConfigType of the key stores used internally to create a key and trust manager factories.- Specified by:
- internalKeystoreTypein interface- TlsConfig
- Returns:
- keystore type, defaults to KeyStore.getDefaultType()
 
- 
internalKeystoreProviderDescription copied from interface:TlsConfigProvider of the key stores used internally to create a key and trust manager factories.- Specified by:
- internalKeystoreProviderin interface- TlsConfig
- Returns:
- keystore provider, if not defined, provider is not specified
 
- 
revocationDescription copied from interface:TlsConfigCertificate revocation check configuration.- Specified by:
- revocationin interface- TlsConfig
- Returns:
- certificate revocation configuration
 
- 
toString
- 
equals
- 
hashCodepublic int hashCode()
 
-