All Downloads are FREE. Search and download functionalities are using the official Maven repository.

main.wisp.security.ssl.KeyStoreX509KeyManager.kt Maven / Gradle / Ivy

There is a newer version: 2025.01.16.154437-45e6601
Show newest version
package wisp.security.ssl

import java.net.Socket
import java.security.KeyStore
import java.security.Principal
import java.security.PrivateKey
import java.security.cert.X509Certificate
import javax.net.ssl.X509ExtendedKeyManager

/**
 * An [X509ExtendedKeyManager] that loads certificates from a [KeyStore]. The [KeyStore]
 * should contain one and only one alias. The [KeyStore] can be lazily supplied, allowing
 * for periodically reloading from disk if needed
 */
internal class KeyStoreX509KeyManager(
    private val passphrase: CharArray,
    private val lazyKeyStore: () -> KeyStore
) : X509ExtendedKeyManager() {

    constructor(passphrase: CharArray, keyStore: KeyStore) : this(passphrase, { keyStore })

    override fun chooseServerAlias(
        keyType: String,
        issuers: Array,
        socket: Socket
    ) = getPrivateKeyAlias()

    override fun chooseClientAlias(
        keyTypes: Array,
        issuers: Array,
        socket: Socket
    ) = getPrivateKeyAlias()

    override fun getClientAliases(keyType: String, issuers: Array): Array {
        return arrayOf(getPrivateKeyAlias())
    }

    override fun getServerAliases(keyType: String, issuers: Array): Array {
        return arrayOf(getPrivateKeyAlias())
    }

    override fun getCertificateChain(alias: String): Array {
        return lazyKeyStore().getX509CertificateChain(alias)
    }

    override fun getPrivateKey(alias: String): PrivateKey {
        return lazyKeyStore().getPrivateKey(alias, passphrase)
    }

    private fun getPrivateKeyAlias(): String {
        return lazyKeyStore().aliasesOfType().single()
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy