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

com.pulumi.vault.database.kotlin.outputs.SecretsMountCouchbase.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 6.4.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.vault.database.kotlin.outputs

import kotlin.Any
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.collections.List
import kotlin.collections.Map

/**
 *
 * @property allowedRoles A list of roles that are allowed to use this
 * connection.
 * @property base64Pem Required if `tls` is `true`. Specifies the certificate authority of the Couchbase server, as a PEM certificate that has been base64 encoded.
 * @property bucketName Required for Couchbase versions prior to 6.5.0. This is only used to verify vault's connection to the server.
 * @property data A map of sensitive data to pass to the endpoint. Useful for templated connection strings.
 * Supported list of database secrets engines that can be configured:
 * @property hosts A set of Couchbase URIs to connect to. Must use `couchbases://` scheme if `tls` is `true`.
 * @property insecureTls Specifies whether to skip verification of the server certificate when using TLS.
 * @property name Name of the database connection.
 * @property password Specifies the password corresponding to the given username.
 * @property pluginName Specifies the name of the plugin to use.
 * @property rootRotationStatements A list of database statements to be executed to rotate the root user's credentials.
 * @property tls Specifies whether to use TLS when connecting to Couchbase.
 * @property username Specifies the username for Vault to use.
 * @property usernameTemplate Template describing how dynamic usernames are generated.
 * @property verifyConnection Whether the connection should be verified on
 * initial configuration or not.
 */
public data class SecretsMountCouchbase(
    public val allowedRoles: List? = null,
    public val base64Pem: String? = null,
    public val bucketName: String? = null,
    public val `data`: Map? = null,
    public val hosts: List,
    public val insecureTls: Boolean? = null,
    public val name: String,
    public val password: String,
    public val pluginName: String? = null,
    public val rootRotationStatements: List? = null,
    public val tls: Boolean? = null,
    public val username: String,
    public val usernameTemplate: String? = null,
    public val verifyConnection: Boolean? = null,
) {
    public companion object {
        public fun toKotlin(javaType: com.pulumi.vault.database.outputs.SecretsMountCouchbase): SecretsMountCouchbase = SecretsMountCouchbase(
            allowedRoles = javaType.allowedRoles().map({ args0 -> args0 }),
            base64Pem = javaType.base64Pem().map({ args0 -> args0 }).orElse(null),
            bucketName = javaType.bucketName().map({ args0 -> args0 }).orElse(null),
            `data` = javaType.`data`().map({ args0 -> args0.key.to(args0.value) }).toMap(),
            hosts = javaType.hosts().map({ args0 -> args0 }),
            insecureTls = javaType.insecureTls().map({ args0 -> args0 }).orElse(null),
            name = javaType.name(),
            password = javaType.password(),
            pluginName = javaType.pluginName().map({ args0 -> args0 }).orElse(null),
            rootRotationStatements = javaType.rootRotationStatements().map({ args0 -> args0 }),
            tls = javaType.tls().map({ args0 -> args0 }).orElse(null),
            username = javaType.username(),
            usernameTemplate = javaType.usernameTemplate().map({ args0 -> args0 }).orElse(null),
            verifyConnection = javaType.verifyConnection().map({ args0 -> args0 }).orElse(null),
        )
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy