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

androidMain.aws.sdk.kotlin.crt.io.TlsContextJVM.kt Maven / Gradle / Ivy

There is a newer version: 0.8.9
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * SPDX-License-Identifier: Apache-2.0
 */

package aws.sdk.kotlin.crt.io

import aws.sdk.kotlin.crt.Closeable
import software.amazon.awssdk.crt.io.TlsCipherPreference as TlsCipherPreferenceJni
import software.amazon.awssdk.crt.io.TlsContext as TlsContextJni
import software.amazon.awssdk.crt.io.TlsContextOptions as TlsContextOptionsJni
import software.amazon.awssdk.crt.io.TlsContextOptions.TlsVersions as TlsVersionJni

public actual class TlsContext actual constructor(options: TlsContextOptions?) : Closeable {
    internal val jniCtx = if (options != null) TlsContextJni(options.into()) else TlsContextJni()

    public actual companion object {
    }

    actual override fun close() {
        jniCtx.close()
    }
}

internal actual fun isCipherSupported(cipher: TlsCipherPreference): Boolean =
    TlsContextOptionsJni.isCipherPreferenceSupported(cipher.into())

internal actual fun isAlpnSupported(): Boolean = TlsContextOptionsJni.isAlpnSupported()

@Suppress("DEPRECATION")
private fun TlsCipherPreference.into(): TlsCipherPreferenceJni = when (this) {
    TlsCipherPreference.SYSTEM_DEFAULT -> TlsCipherPreferenceJni.TLS_CIPHER_SYSTEM_DEFAULT
    TlsCipherPreference.KMS_PQ_TLS_V1_0_2019_06 -> TlsCipherPreferenceJni.TLS_CIPHER_KMS_PQ_TLSv1_0_2019_06
    TlsCipherPreference.KMS_PQ_SIKE_TLS_V1_0_2019_11 -> TlsCipherPreferenceJni.TLS_CIPHER_PREF_KMS_PQ_SIKE_TLSv1_0_2019_11
    TlsCipherPreference.KMS_PQ_TLS_V1_0_2020_02 -> TlsCipherPreferenceJni.TLS_CIPHER_PREF_KMS_PQ_TLSv1_0_2020_02
    TlsCipherPreference.KMS_PQ_SIKE_TLS_V1_0_2020_02 -> TlsCipherPreferenceJni.TLS_CIPHER_PREF_KMS_PQ_SIKE_TLSv1_0_2020_02
    TlsCipherPreference.KMS_PQ_TLS_V1_0_2020_07 -> TlsCipherPreferenceJni.TLS_CIPHER_PREF_KMS_PQ_TLSv1_0_2020_07
    TlsCipherPreference.PQ_TLS_V1_0_2021_05 -> TlsCipherPreferenceJni.TLS_CIPHER_PREF_PQ_TLSv1_0_2021_05
}

private fun TlsVersion.into(): TlsVersionJni = when (this) {
    TlsVersion.SSLv3 -> TlsVersionJni.SSLv3
    TlsVersion.TLSv1 -> TlsVersionJni.TLSv1
    TlsVersion.TLS_V1_1 -> TlsVersionJni.TLSv1_1
    TlsVersion.TLS_V1_2 -> TlsVersionJni.TLSv1_2
    TlsVersion.TLS_V1_3 -> TlsVersionJni.TLSv1_3
    TlsVersion.SYS_DEFAULT -> TlsVersionJni.TLS_VER_SYS_DEFAULTS
}

private fun TlsContextOptions.into(): TlsContextOptionsJni {
    val kopts = this
    val jniOpts: TlsContextOptionsJni

    // Certs or paths will cause an init, which overwrites other fields, so do those first
    if (kopts.certificate != null && kopts.privateKey != null) {
        jniOpts = TlsContextOptionsJni.createWithMtls(kopts.certificate, kopts.privateKey)
    } else if (kopts.certificatePath != null && kopts.privateKeyPath != null) {
        jniOpts = TlsContextOptionsJni.createWithMtlsFromPath(kopts.certificatePath, kopts.privateKeyPath)
    } else {
        jniOpts = TlsContextOptionsJni.createDefaultClient()
    }

    if (kopts.caRoot != null) {
        jniOpts.withCertificateAuthority(kopts.caRoot)
    } else if (kopts.caFile != null || kopts.caDir != null) {
        jniOpts.withCertificateAuthorityFromPath(kopts.caFile, kopts.caDir)
    }

    jniOpts.withMinimumTlsVersion(kopts.minTlsVersion.into())
        .withCipherPreference(kopts.tlsCipherPreference.into())
        .withVerifyPeer(kopts.verifyPeer)

    if (kopts.alpn.isNotEmpty()) {
        jniOpts.withAlpnList(kopts.alpn)
    }

    return jniOpts
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy