
com.pulumi.awsnative.ecs.kotlin.outputs.TaskDefinitionEfsVolumeConfiguration.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-aws-native-kotlin Show documentation
Show all versions of pulumi-aws-native-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.awsnative.ecs.kotlin.outputs
import com.pulumi.awsnative.ecs.kotlin.enums.TaskDefinitionEfsVolumeConfigurationTransitEncryption
import kotlin.Int
import kotlin.String
import kotlin.Suppress
/**
* This parameter is specified when you're using an Amazon Elastic File System file system for task storage. For more information, see [Amazon EFS volumes](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/efs-volumes.html) in the *Amazon Elastic Container Service Developer Guide*.
* @property authorizationConfig The authorization configuration details for the Amazon EFS file system.
* @property filesystemId The Amazon EFS file system ID to use.
* @property rootDirectory The directory within the Amazon EFS file system to mount as the root directory inside the host. If this parameter is omitted, the root of the Amazon EFS volume will be used. Specifying ``/`` will have the same effect as omitting this parameter.
* If an EFS access point is specified in the ``authorizationConfig``, the root directory parameter must either be omitted or set to ``/`` which will enforce the path set on the EFS access point.
* @property transitEncryption Determines whether to use encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server. Transit encryption must be turned on if Amazon EFS IAM authorization is used. If this parameter is omitted, the default value of ``DISABLED`` is used. For more information, see [Encrypting data in transit](https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html) in the *Amazon Elastic File System User Guide*.
* @property transitEncryptionPort The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server. If you do not specify a transit encryption port, it will use the port selection strategy that the Amazon EFS mount helper uses. For more information, see [EFS mount helper](https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html) in the *Amazon Elastic File System User Guide*.
*/
public data class TaskDefinitionEfsVolumeConfiguration(
public val authorizationConfig: TaskDefinitionAuthorizationConfig? = null,
public val filesystemId: String,
public val rootDirectory: String? = null,
public val transitEncryption: TaskDefinitionEfsVolumeConfigurationTransitEncryption? = null,
public val transitEncryptionPort: Int? = null,
) {
public companion object {
public fun toKotlin(javaType: com.pulumi.awsnative.ecs.outputs.TaskDefinitionEfsVolumeConfiguration): TaskDefinitionEfsVolumeConfiguration = TaskDefinitionEfsVolumeConfiguration(
authorizationConfig = javaType.authorizationConfig().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.ecs.kotlin.outputs.TaskDefinitionAuthorizationConfig.Companion.toKotlin(args0)
})
}).orElse(null),
filesystemId = javaType.filesystemId(),
rootDirectory = javaType.rootDirectory().map({ args0 -> args0 }).orElse(null),
transitEncryption = javaType.transitEncryption().map({ args0 ->
args0.let({ args0 ->
com.pulumi.awsnative.ecs.kotlin.enums.TaskDefinitionEfsVolumeConfigurationTransitEncryption.Companion.toKotlin(args0)
})
}).orElse(null),
transitEncryptionPort = javaType.transitEncryptionPort().map({ args0 -> args0 }).orElse(null),
)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy