Class DynamoDBAction
- All Implemented Interfaces:
- Serializable,- SdkPojo,- ToCopyableBuilder<DynamoDBAction.Builder,- DynamoDBAction> 
Defines an action to write to the Amazon DynamoDB table that you created. The standard action payload contains all the information about the detector model instance and the event that triggered the action. You can customize the payload. One column of the DynamoDB table receives all attribute-value pairs in the payload that you specify.
 You must use expressions for all parameters in DynamoDBAction. The expressions accept literals,
 operators, functions, references, and substitution templates.
 
Examples
- 
 For literal values, the expressions must contain single quotes. For example, the value for the hashKeyTypeparameter can be'STRING'.
- 
 For references, you must specify either variables or input values. For example, the value for the hashKeyFieldparameter can be$input.GreenhouseInput.name.
- 
 For a substitution template, you must use ${}, and the template must be in single quotes. A substitution template can also contain a combination of literals, operators, functions, references, and substitution templates.In the following example, the value for the hashKeyValueparameter uses a substitution template.'${$input.GreenhouseInput.temperature * 6 / 5 + 32} in Fahrenheit'
- 
 For a string concatenation, you must use +. A string concatenation can also contain a combination of literals, operators, functions, references, and substitution templates.In the following example, the value for the tableNameparameter uses a string concatenation.'GreenhouseTemperatureTable ' + $input.GreenhouseInput.date
For more information, see Expressions in the AWS IoT Events Developer Guide.
 If the defined payload type is a string, DynamoDBAction writes non-JSON data to the DynamoDB table as
 binary data. The DynamoDB console displays the data as Base64-encoded text. The value for the
 payloadField parameter is <payload-field>_raw.
 
- See Also:
- 
Nested Class SummaryNested Classes
- 
Method SummaryModifier and TypeMethodDescriptionstatic DynamoDBAction.Builderbuilder()final booleanfinal booleanequalsBySdkFields(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final <T> Optional<T> getValueForField(String fieldName, Class<T> clazz) final inthashCode()final StringThe name of the hash key (also called the partition key).final StringThe data type for the hash key (also called the partition key).final StringThe value of the hash key (also called the partition key).final StringThe type of operation to perform.final Payloadpayload()Returns the value of the Payload property for this object.final StringThe name of the DynamoDB column that receives the action payload.final StringThe name of the range key (also called the sort key).final StringThe data type for the range key (also called the sort key), You can specify the following values:final StringThe value of the range key (also called the sort key).static Class<? extends DynamoDBAction.Builder> final StringThe name of the DynamoDB table.Take this object and create a builder that contains all of the current property values of this object.final StringtoString()Returns a string representation of this object.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuildercopy
- 
Method Details- 
hashKeyTypeThe data type for the hash key (also called the partition key). You can specify the following values: - 
 'STRING'- The hash key is a string.
- 
 'NUMBER'- The hash key is a number.
 If you don't specify hashKeyType, the default value is'STRING'.- Returns:
- The data type for the hash key (also called the partition key). You can specify the following values:
         - 
         'STRING'- The hash key is a string.
- 
         'NUMBER'- The hash key is a number.
 If you don't specify hashKeyType, the default value is'STRING'.
- 
         
 
- 
 
- 
hashKeyFieldThe name of the hash key (also called the partition key). The hashKeyFieldvalue must match the partition key of the target DynamoDB table.- Returns:
- The name of the hash key (also called the partition key). The hashKeyFieldvalue must match the partition key of the target DynamoDB table.
 
- 
hashKeyValueThe value of the hash key (also called the partition key). - Returns:
- The value of the hash key (also called the partition key).
 
- 
rangeKeyTypeThe data type for the range key (also called the sort key), You can specify the following values: - 
 'STRING'- The range key is a string.
- 
 'NUMBER'- The range key is number.
 If you don't specify rangeKeyField, the default value is'STRING'.- Returns:
- The data type for the range key (also called the sort key), You can specify the following values:
         - 
         'STRING'- The range key is a string.
- 
         'NUMBER'- The range key is number.
 If you don't specify rangeKeyField, the default value is'STRING'.
- 
         
 
- 
 
- 
rangeKeyFieldThe name of the range key (also called the sort key). The rangeKeyFieldvalue must match the sort key of the target DynamoDB table.- Returns:
- The name of the range key (also called the sort key). The rangeKeyFieldvalue must match the sort key of the target DynamoDB table.
 
- 
rangeKeyValueThe value of the range key (also called the sort key). - Returns:
- The value of the range key (also called the sort key).
 
- 
operationThe type of operation to perform. You can specify the following values: - 
 'INSERT'- Insert data as a new item into the DynamoDB table. This item uses the specified hash key as a partition key. If you specified a range key, the item uses the range key as a sort key.
- 
 'UPDATE'- Update an existing item of the DynamoDB table with new data. This item's partition key must match the specified hash key. If you specified a range key, the range key must match the item's sort key.
- 
 'DELETE'- Delete an existing item of the DynamoDB table. This item's partition key must match the specified hash key. If you specified a range key, the range key must match the item's sort key.
 If you don't specify this parameter, AWS IoT Events triggers the 'INSERT'operation.- Returns:
- The type of operation to perform. You can specify the following values: 
         - 
         'INSERT'- Insert data as a new item into the DynamoDB table. This item uses the specified hash key as a partition key. If you specified a range key, the item uses the range key as a sort key.
- 
         'UPDATE'- Update an existing item of the DynamoDB table with new data. This item's partition key must match the specified hash key. If you specified a range key, the range key must match the item's sort key.
- 
         'DELETE'- Delete an existing item of the DynamoDB table. This item's partition key must match the specified hash key. If you specified a range key, the range key must match the item's sort key.
 If you don't specify this parameter, AWS IoT Events triggers the 'INSERT'operation.
- 
         
 
- 
 
- 
payloadFieldThe name of the DynamoDB column that receives the action payload. If you don't specify this parameter, the name of the DynamoDB column is payload.- Returns:
- The name of the DynamoDB column that receives the action payload.
         If you don't specify this parameter, the name of the DynamoDB column is payload.
 
- 
tableNameThe name of the DynamoDB table. The tableNamevalue must match the table name of the target DynamoDB table.- Returns:
- The name of the DynamoDB table. The tableNamevalue must match the table name of the target DynamoDB table.
 
- 
payloadReturns the value of the Payload property for this object.- Returns:
- The value of the Payload property for this object.
 
- 
toBuilderDescription copied from interface:ToCopyableBuilderTake this object and create a builder that contains all of the current property values of this object.- Specified by:
- toBuilderin interface- ToCopyableBuilder<DynamoDBAction.Builder,- DynamoDBAction> 
- Returns:
- a builder for type T
 
- 
builder
- 
serializableBuilderClass
- 
hashCode
- 
equals
- 
equalsBySdkFieldsDescription copied from interface:SdkPojoIndicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojoclass, and is generated based on a service model.If an SdkPojoclass does not have any inherited fields,equalsBySdkFieldsandequalsare essentially the same.- Specified by:
- equalsBySdkFieldsin interface- SdkPojo
- Parameters:
- obj- the object to be compared with
- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
 
- 
toString
- 
getValueForField
- 
sdkFields
- 
sdkFieldNameToField- Specified by:
- sdkFieldNameToFieldin interface- SdkPojo
- Returns:
- The mapping between the field name and its corresponding field.
 
 
-