Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
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.dynamodb.kotlin.inputs
import com.pulumi.awsnative.dynamodb.inputs.TableGlobalSecondaryIndexArgs.builder
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiNullFieldException
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName
/**
* Represents the properties of a global secondary index.
* @property contributorInsightsSpecification The settings used to enable or disable CloudWatch Contributor Insights for the specified global secondary index.
* @property indexName The name of the global secondary index. The name must be unique among all other indexes on this table.
* @property keySchema The complete key schema for a global secondary index, which consists of one or more pairs of attribute names and key types:
* + ``HASH`` - partition key
* + ``RANGE`` - sort key
* The partition key of an item is also known as its *hash attribute*. The term "hash attribute" derives from DynamoDB's usage of an internal hash function to evenly distribute data items across partitions, based on their partition key values.
* The sort key of an item is also known as its *range attribute*. The term "range attribute" derives from the way DynamoDB stores items with the same partition key physically close together, in sorted order by the sort key value.
* @property onDemandThroughput The maximum number of read and write units for the specified global secondary index. If you use this parameter, you must specify ``MaxReadRequestUnits``, ``MaxWriteRequestUnits``, or both.
* @property projection Represents attributes that are copied (projected) from the table into the global secondary index. These are in addition to the primary key attributes and index key attributes, which are automatically projected.
* @property provisionedThroughput Represents the provisioned throughput settings for the specified global secondary index.
* For current minimum and maximum provisioned throughput values, see [Service, Account, and Table Quotas](https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Limits.html) in the *Amazon DynamoDB Developer Guide*.
*/
public data class TableGlobalSecondaryIndexArgs(
public val contributorInsightsSpecification: Output? =
null,
public val indexName: Output,
public val keySchema: Output>,
public val onDemandThroughput: Output? = null,
public val projection: Output,
public val provisionedThroughput: Output? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.awsnative.dynamodb.inputs.TableGlobalSecondaryIndexArgs =
com.pulumi.awsnative.dynamodb.inputs.TableGlobalSecondaryIndexArgs.builder()
.contributorInsightsSpecification(
contributorInsightsSpecification?.applyValue({ args0 ->
args0.let({ args0 -> args0.toJava() })
}),
)
.indexName(indexName.applyValue({ args0 -> args0 }))
.keySchema(
keySchema.applyValue({ args0 ->
args0.map({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
})
}),
)
.onDemandThroughput(
onDemandThroughput?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.projection(projection.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.provisionedThroughput(
provisionedThroughput?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
).build()
}
/**
* Builder for [TableGlobalSecondaryIndexArgs].
*/
@PulumiTagMarker
public class TableGlobalSecondaryIndexArgsBuilder internal constructor() {
private var contributorInsightsSpecification: Output? =
null
private var indexName: Output? = null
private var keySchema: Output>? = null
private var onDemandThroughput: Output? = null
private var projection: Output? = null
private var provisionedThroughput: Output? = null
/**
* @param value The settings used to enable or disable CloudWatch Contributor Insights for the specified global secondary index.
*/
@JvmName("pdsheetuiubawuix")
public suspend fun contributorInsightsSpecification(`value`: Output) {
this.contributorInsightsSpecification = value
}
/**
* @param value The name of the global secondary index. The name must be unique among all other indexes on this table.
*/
@JvmName("dxbmaakucibvefhd")
public suspend fun indexName(`value`: Output) {
this.indexName = value
}
/**
* @param value The complete key schema for a global secondary index, which consists of one or more pairs of attribute names and key types:
* + ``HASH`` - partition key
* + ``RANGE`` - sort key
* The partition key of an item is also known as its *hash attribute*. The term "hash attribute" derives from DynamoDB's usage of an internal hash function to evenly distribute data items across partitions, based on their partition key values.
* The sort key of an item is also known as its *range attribute*. The term "range attribute" derives from the way DynamoDB stores items with the same partition key physically close together, in sorted order by the sort key value.
*/
@JvmName("fgnaqkxcvrspssuo")
public suspend fun keySchema(`value`: Output>) {
this.keySchema = value
}
@JvmName("iuhebojmofitqowg")
public suspend fun keySchema(vararg values: Output) {
this.keySchema = Output.all(values.asList())
}
/**
* @param values The complete key schema for a global secondary index, which consists of one or more pairs of attribute names and key types:
* + ``HASH`` - partition key
* + ``RANGE`` - sort key
* The partition key of an item is also known as its *hash attribute*. The term "hash attribute" derives from DynamoDB's usage of an internal hash function to evenly distribute data items across partitions, based on their partition key values.
* The sort key of an item is also known as its *range attribute*. The term "range attribute" derives from the way DynamoDB stores items with the same partition key physically close together, in sorted order by the sort key value.
*/
@JvmName("hnfapjbbxmbnqcbw")
public suspend fun keySchema(values: List