com.pulumi.gcp.logging.kotlin.outputs.ProjectBucketConfigCmekSettings.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gcp-kotlin Show documentation
Show all versions of pulumi-gcp-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.logging.kotlin.outputs
import kotlin.String
import kotlin.Suppress
/**
*
* @property kmsKeyName The resource name for the configured Cloud KMS key.
* KMS key name format:
* `'projects/[PROJECT_ID]/locations/[LOCATION]/keyRings/[KEYRING]/cryptoKeys/[KEY]'`
* To enable CMEK for the bucket, set this field to a valid kmsKeyName for which the associated service account has the required cloudkms.cryptoKeyEncrypterDecrypter roles assigned for the key.
* The Cloud KMS key used by the bucket can be updated by changing the kmsKeyName to a new valid key name. Encryption operations that are in progress will be completed with the key that was in use when they started. Decryption operations will be completed using the key that was used at the time of encryption unless access to that key has been revoked.
* See [Enabling CMEK for Logging Buckets](https://cloud.google.com/logging/docs/routing/managed-encryption-storage) for more information.
* @property kmsKeyVersionName The CryptoKeyVersion resource name for the configured Cloud KMS key.
* KMS key name format:
* `'projects/[PROJECT_ID]/locations/[LOCATION]/keyRings/[KEYRING]/cryptoKeys/[KEY]/cryptoKeyVersions/[VERSION]'`
* For example:
* "projects/my-project/locations/us-central1/keyRings/my-ring/cryptoKeys/my-key/cryptoKeyVersions/1"
* This is a read-only field used to convey the specific configured CryptoKeyVersion of kms_key that has been configured. It will be populated in cases where the CMEK settings are bound to a single key version.
* @property name The resource name of the CMEK settings.
* @property serviceAccountId The service account associated with a project for which CMEK will apply.
* Before enabling CMEK for a logging bucket, you must first assign the cloudkms.cryptoKeyEncrypterDecrypter role to the service account associated with the project for which CMEK will apply. Use [v2.getCmekSettings](https://cloud.google.com/logging/docs/reference/v2/rest/v2/TopLevel/getCmekSettings#google.logging.v2.ConfigServiceV2.GetCmekSettings) to obtain the service account ID.
* See [Enabling CMEK for Logging Buckets](https://cloud.google.com/logging/docs/routing/managed-encryption-storage) for more information.
*/
public data class ProjectBucketConfigCmekSettings(
public val kmsKeyName: String,
public val kmsKeyVersionName: String? = null,
public val name: String? = null,
public val serviceAccountId: String? = null,
) {
public companion object {
public fun toKotlin(javaType: com.pulumi.gcp.logging.outputs.ProjectBucketConfigCmekSettings): ProjectBucketConfigCmekSettings = ProjectBucketConfigCmekSettings(
kmsKeyName = javaType.kmsKeyName(),
kmsKeyVersionName = javaType.kmsKeyVersionName().map({ args0 -> args0 }).orElse(null),
name = javaType.name().map({ args0 -> args0 }).orElse(null),
serviceAccountId = javaType.serviceAccountId().map({ args0 -> args0 }).orElse(null),
)
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy