This library provides an API for creating basic SSL/TLS connections with standard Java Secure Socket Extension, JSSE. The Library is implemented in Kotlin. The Kotlin API is implemented with a "type-safe builder" approach, which is quite popular in the Groovy community.
Disclaimer: The current Version is not optimized for Java yet.
If you also find it hard to use the complex JSSE structure to create your SSL sockets, which also generates lots of boilerplate when used directly, this tool is what you've been looking for.
The library provides means for creating SSLSocketFactories
that can be used for most use cases where TLS/SSL connections are required. It's also supposed to provide usage examples and even sample implementations like SSL enabled servers, Apache HTTP Clients and others, which you can use directly in your application.
In the following you can see some basic examples of using the Kotlin DSL for setting up ssl-(server)-socket-factories.
val fac = createSocketFactory {
keyManager {
open("certsandstores/clientkeystore") withPass "123456" ofType "jks"
}
trustManager {
open("certsandstores/myTruststore") withPass "123456" ofType "jks"
}
sockets {
cipherSuites = listOf("TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256", "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384",
"TLS_DHE_RSA_WITH_AES_128_CBC_SHA", "TLS_DHE_RSA_WITH_AES_256_CBC_SHA")
timeout = 10_000
}
}
val socket = fac.createSocket("192.168.3.10", 443)
val fac = createServerSocketFactory {
keyManager {
open("certsandstores/clientkeystore") withPass "123456" ofType "jks"
}
}
val accept = fac.createServerSocket(443).accept()
}
In your Gradle build, simply include the following repo as well as dependency:
maven {
setUrl("https://simon-wirtz.bintray.com/SeKurity"
}
compile("de.swirtz:sekurity:0.0.1")
You can read about TLS and Keystores here.