case class SecurityConfig(tlsEnabled: Option[Boolean] = None, nativeTlsEnabled: Option[Boolean] = None, trustCertificates: Option[Seq[X509Certificate]] = None, trustManagerFactory: Option[TrustManagerFactory] = None, enableHostnameVerification: Option[Boolean] = None, trustCertificate: Option[Path] = None, ciphers: Option[Seq[String]] = None, trustKeyStore: Option[KeyStore] = None, trustStoreFile: Option[TrustStoreFile] = None) extends Product with Serializable
- Alphabetic
- By Inheritance
- SecurityConfig
- Serializable
- Product
- Equals
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Instance Constructors
- new SecurityConfig(tlsEnabled: Option[Boolean] = None, nativeTlsEnabled: Option[Boolean] = None, trustCertificates: Option[Seq[X509Certificate]] = None, trustManagerFactory: Option[TrustManagerFactory] = None, enableHostnameVerification: Option[Boolean] = None, trustCertificate: Option[Path] = None, ciphers: Option[Seq[String]] = None, trustKeyStore: Option[KeyStore] = None, trustStoreFile: Option[TrustStoreFile] = None)
Value Members
- def ciphers(value: Seq[String]): SecurityConfig
Customize the list of ciphers that is negotiated with the cluster.
Customize the list of ciphers that is negotiated with the cluster.
Note that this method is considered advanced API, please only customize the cipher list if you know what you are doing (for example if you want to shrink the cipher list down to a very specific subset for security or compliance reasons).
If no custom ciphers are configured, the default set will be used.
- returns
this for chaining purposes.
- def enableHostnameVerification(value: Boolean): SecurityConfig
Enables or disable hostname verification (enabled by default).
Enables or disable hostname verification (enabled by default).
Note that disabling hostname verification will cause the TLS connection to not verify that the hostname/ip is actually part of the certificate and as a result not detect certain kinds of attacks. Only disable if you understand the impact and risks!
- returns
this for chaining purposes.
- def enableNativeTls(value: Boolean): SecurityConfig
Enables/disables native TLS (enabled by default).
Enables/disables native TLS (enabled by default).
- returns
this for chaining purposes.
- def enableTls(value: Boolean): SecurityConfig
Enables TLS for all client/server communication (disabled by default).
Enables TLS for all client/server communication (disabled by default).
- returns
this for chaining purposes.
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- def productIterator: Iterator[Any]
- Definition Classes
- Product
- def trustCertificate(value: Path): SecurityConfig
Loads a X.509 trust certificate from the given path and uses it.
Loads a X.509 trust certificate from the given path and uses it.
- returns
this for chaining purposes.
- def trustCertificates(values: Seq[X509Certificate]): SecurityConfig
Loads the given list of X.509 certificates into the trust store.
Loads the given list of X.509 certificates into the trust store.
- returns
this for chaining purposes.
- def trustManagerFactory(value: TrustManagerFactory): SecurityConfig
Provide a trust manager factory directly for maximum flexibility.
Provide a trust manager factory directly for maximum flexibility.
While providing the most flexibility, most users will find the other overloads more convenient, like passing in a trustStore directly or via filepath String, Optional).
- returns
this for chaining purposes.
- def trustStore(trustStorePath: Path, trustStorePassword: String, trustStoreType: Option[String] = None): SecurityConfig
- def trustStore(value: KeyStore): SecurityConfig