Documentation ¶
Index ¶
- func CfnDatabase_CFN_RESOURCE_TYPE_NAME() *string
- func CfnDatabase_IsCfnElement(x interface{}) *bool
- func CfnDatabase_IsCfnResource(construct constructs.IConstruct) *bool
- func CfnDatabase_IsConstruct(x interface{}) *bool
- func CfnScheduledQuery_CFN_RESOURCE_TYPE_NAME() *string
- func CfnScheduledQuery_IsCfnElement(x interface{}) *bool
- func CfnScheduledQuery_IsCfnResource(construct constructs.IConstruct) *bool
- func CfnScheduledQuery_IsConstruct(x interface{}) *bool
- func CfnTable_CFN_RESOURCE_TYPE_NAME() *string
- func CfnTable_IsCfnElement(x interface{}) *bool
- func CfnTable_IsCfnResource(construct constructs.IConstruct) *bool
- func CfnTable_IsConstruct(x interface{}) *bool
- func NewCfnDatabase_Override(c CfnDatabase, scope awscdk.Construct, id *string, props *CfnDatabaseProps)
- func NewCfnScheduledQuery_Override(c CfnScheduledQuery, scope awscdk.Construct, id *string, ...)
- func NewCfnTable_Override(c CfnTable, scope awscdk.Construct, id *string, props *CfnTableProps)
- type CfnDatabase
- type CfnDatabaseProps
- type CfnScheduledQuery
- type CfnScheduledQueryProps
- type CfnScheduledQuery_DimensionMappingProperty
- type CfnScheduledQuery_ErrorReportConfigurationProperty
- type CfnScheduledQuery_MixedMeasureMappingProperty
- type CfnScheduledQuery_MultiMeasureAttributeMappingProperty
- type CfnScheduledQuery_MultiMeasureMappingsProperty
- type CfnScheduledQuery_NotificationConfigurationProperty
- type CfnScheduledQuery_S3ConfigurationProperty
- type CfnScheduledQuery_ScheduleConfigurationProperty
- type CfnScheduledQuery_SnsConfigurationProperty
- type CfnScheduledQuery_TargetConfigurationProperty
- type CfnScheduledQuery_TimestreamConfigurationProperty
- type CfnTable
- type CfnTableProps
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CfnDatabase_CFN_RESOURCE_TYPE_NAME ¶
func CfnDatabase_CFN_RESOURCE_TYPE_NAME() *string
func CfnDatabase_IsCfnElement ¶
func CfnDatabase_IsCfnElement(x interface{}) *bool
Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).
Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.
Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.
func CfnDatabase_IsCfnResource ¶
func CfnDatabase_IsCfnResource(construct constructs.IConstruct) *bool
Check whether the given construct is a CfnResource. Experimental.
func CfnDatabase_IsConstruct ¶
func CfnDatabase_IsConstruct(x interface{}) *bool
Return whether the given object is a Construct. Experimental.
func CfnScheduledQuery_CFN_RESOURCE_TYPE_NAME ¶
func CfnScheduledQuery_CFN_RESOURCE_TYPE_NAME() *string
func CfnScheduledQuery_IsCfnElement ¶
func CfnScheduledQuery_IsCfnElement(x interface{}) *bool
Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).
Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.
Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.
func CfnScheduledQuery_IsCfnResource ¶
func CfnScheduledQuery_IsCfnResource(construct constructs.IConstruct) *bool
Check whether the given construct is a CfnResource. Experimental.
func CfnScheduledQuery_IsConstruct ¶
func CfnScheduledQuery_IsConstruct(x interface{}) *bool
Return whether the given object is a Construct. Experimental.
func CfnTable_CFN_RESOURCE_TYPE_NAME ¶
func CfnTable_CFN_RESOURCE_TYPE_NAME() *string
func CfnTable_IsCfnElement ¶
func CfnTable_IsCfnElement(x interface{}) *bool
Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).
Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.
Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.
func CfnTable_IsCfnResource ¶
func CfnTable_IsCfnResource(construct constructs.IConstruct) *bool
Check whether the given construct is a CfnResource. Experimental.
func CfnTable_IsConstruct ¶
func CfnTable_IsConstruct(x interface{}) *bool
Return whether the given object is a Construct. Experimental.
func NewCfnDatabase_Override ¶
func NewCfnDatabase_Override(c CfnDatabase, scope awscdk.Construct, id *string, props *CfnDatabaseProps)
Create a new `AWS::Timestream::Database`.
func NewCfnScheduledQuery_Override ¶
func NewCfnScheduledQuery_Override(c CfnScheduledQuery, scope awscdk.Construct, id *string, props *CfnScheduledQueryProps)
Create a new `AWS::Timestream::ScheduledQuery`.
func NewCfnTable_Override ¶
func NewCfnTable_Override(c CfnTable, scope awscdk.Construct, id *string, props *CfnTableProps)
Create a new `AWS::Timestream::Table`.
Types ¶
type CfnDatabase ¶
type CfnDatabase interface { awscdk.CfnResource awscdk.IInspectable // The `arn` of the database. AttrArn() *string // Options for this resource, such as condition, update policy etc. // Experimental. CfnOptions() awscdk.ICfnResourceOptions CfnProperties() *map[string]interface{} // AWS resource type. // Experimental. CfnResourceType() *string // Returns: the stack trace of the point where this Resource was created from, sourced // from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most // node +internal+ entries filtered. // Experimental. CreationStack() *[]*string // The name of the Timestream database. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. DatabaseName() *string SetDatabaseName(val *string) // The identifier of the AWS KMS key used to encrypt the data stored in the database. KmsKeyId() *string SetKmsKeyId(val *string) // The logical ID for this CloudFormation stack element. // // The logical ID of the element // is calculated from the path of the resource node in the construct tree. // // To override this value, use `overrideLogicalId(newLogicalId)`. // // Returns: the logical ID as a stringified token. This value will only get // resolved during synthesis. // Experimental. LogicalId() *string // The construct tree node associated with this construct. // Experimental. Node() awscdk.ConstructNode // Return a string that will be resolved to a CloudFormation `{ Ref }` for this element. // // If, by any chance, the intrinsic reference of a resource is not a string, you could // coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`. // Experimental. Ref() *string // The stack in which this element is defined. // // CfnElements must be defined within a stack scope (directly or indirectly). // Experimental. Stack() awscdk.Stack // The tags to add to the database. Tags() awscdk.TagManager // Return properties modified after initiation. // // Resources that expose mutable properties should override this function to // collect and return the properties object for this resource. // Experimental. UpdatedProperites() *map[string]interface{} // Syntactic sugar for `addOverride(path, undefined)`. // Experimental. AddDeletionOverride(path *string) // Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned. // // This can be used for resources across stacks (or nested stack) boundaries // and the dependency will automatically be transferred to the relevant scope. // Experimental. AddDependsOn(target awscdk.CfnResource) // Add a value to the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. AddMetadata(key *string, value interface{}) // Adds an override to the synthesized CloudFormation resource. // // To add a // property override, either use `addPropertyOverride` or prefix `path` with // "Properties." (i.e. `Properties.TopicName`). // // If the override is nested, separate each nested level using a dot (.) in the path parameter. // If there is an array as part of the nesting, specify the index in the path. // // To include a literal `.` in the property name, prefix with a `\`. In most // programming languages you will need to write this as `"\\."` because the // `\` itself will need to be escaped. // // For example, // “`typescript // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']); // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE'); // “` // would add the overrides // “`json // "Properties": { // "GlobalSecondaryIndexes": [ // { // "Projection": { // "NonKeyAttributes": [ "myattribute" ] // ... // } // ... // }, // { // "ProjectionType": "INCLUDE" // ... // }, // ] // ... // } // “` // // The `value` argument to `addOverride` will not be processed or translated // in any way. Pass raw JSON values in here with the correct capitalization // for CloudFormation. If you pass CDK classes or structs, they will be // rendered with lowercased key names, and CloudFormation will reject the // template. // Experimental. AddOverride(path *string, value interface{}) // Adds an override that deletes the value of a property from the resource definition. // Experimental. AddPropertyDeletionOverride(propertyPath *string) // Adds an override to a resource property. // // Syntactic sugar for `addOverride("Properties.<...>", value)`. // Experimental. AddPropertyOverride(propertyPath *string, value interface{}) // Sets the deletion policy of the resource based on the removal policy specified. // // The Removal Policy controls what happens to this resource when it stops // being managed by CloudFormation, either because you've removed it from the // CDK application or because you've made a change that requires the resource // to be replaced. // // The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS // account for data recovery and cleanup later (`RemovalPolicy.RETAIN`). // Experimental. ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions) // Returns a token for an runtime attribute of this resource. // // Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility // in case there is no generated attribute. // Experimental. GetAtt(attributeName *string) awscdk.Reference // Retrieve a value value from the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. GetMetadata(key *string) interface{} // Examines the CloudFormation resource and discloses attributes. Inspect(inspector awscdk.TreeInspector) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. OnPrepare() // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. OnSynthesize(session constructs.ISynthesisSession) // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. OnValidate() *[]*string // Overrides the auto-generated logical ID with a specific ID. // Experimental. OverrideLogicalId(newLogicalId *string) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. Prepare() RenderProperties(props *map[string]interface{}) *map[string]interface{} // Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template. // // Returns: `true` if the resource should be included or `false` is the resource // should be omitted. // Experimental. ShouldSynthesize() *bool // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. Synthesize(session awscdk.ISynthesisSession) // Returns a string representation of this construct. // // Returns: a string representation of this resource. // Experimental. ToString() *string // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. Validate() *[]*string // Experimental. ValidateProperties(_properties interface{}) }
A CloudFormation `AWS::Timestream::Database`.
Creates a new Timestream database. If the AWS KMS key is not specified, the database will be encrypted with a Timestream managed AWS KMS key located in your account. Refer to [AWS managed AWS KMS keys](https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#aws-managed-cmk) for more info. [Service quotas apply](https://docs.aws.amazon.com/timestream/latest/developerguide/ts-limits.html) . See [code sample](https://docs.aws.amazon.com/timestream/latest/developerguide/code-samples.create-db.html) for details.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" cfnDatabase := awscdk.Aws_timestream.NewCfnDatabase(this, jsii.String("MyCfnDatabase"), &cfnDatabaseProps{ databaseName: jsii.String("databaseName"), kmsKeyId: jsii.String("kmsKeyId"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, })
func NewCfnDatabase ¶
func NewCfnDatabase(scope awscdk.Construct, id *string, props *CfnDatabaseProps) CfnDatabase
Create a new `AWS::Timestream::Database`.
type CfnDatabaseProps ¶
type CfnDatabaseProps struct { // The name of the Timestream database. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. DatabaseName *string `field:"optional" json:"databaseName" yaml:"databaseName"` // The identifier of the AWS KMS key used to encrypt the data stored in the database. KmsKeyId *string `field:"optional" json:"kmsKeyId" yaml:"kmsKeyId"` // The tags to add to the database. Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"` }
Properties for defining a `CfnDatabase`.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" cfnDatabaseProps := &cfnDatabaseProps{ databaseName: jsii.String("databaseName"), kmsKeyId: jsii.String("kmsKeyId"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, }
type CfnScheduledQuery ¶
type CfnScheduledQuery interface { awscdk.CfnResource awscdk.IInspectable // The `ARN` of the scheduled query. AttrArn() *string // The scheduled query error reporting configuration. AttrSqErrorReportConfiguration() *string // The KMS key used to encrypt the query resource, if a customer managed KMS key was provided. AttrSqKmsKeyId() *string // The scheduled query name. AttrSqName() *string // The scheduled query notification configuration. AttrSqNotificationConfiguration() *string // The scheduled query string.. AttrSqQueryString() *string // The scheduled query schedule configuration. AttrSqScheduleConfiguration() *string // The ARN of the IAM role that will be used by Timestream to run the query. AttrSqScheduledQueryExecutionRoleArn() *string // The configuration for query output. AttrSqTargetConfiguration() *string // Options for this resource, such as condition, update policy etc. // Experimental. CfnOptions() awscdk.ICfnResourceOptions CfnProperties() *map[string]interface{} // AWS resource type. // Experimental. CfnResourceType() *string // Using a ClientToken makes the call to CreateScheduledQuery idempotent, in other words, making the same request repeatedly will produce the same result. // // Making multiple identical CreateScheduledQuery requests has the same effect as making a single request. // // - If CreateScheduledQuery is called without a `ClientToken` , the Query SDK generates a `ClientToken` on your behalf. // - After 8 hours, any request with the same `ClientToken` is treated as a new request. ClientToken() *string SetClientToken(val *string) // Returns: the stack trace of the point where this Resource was created from, sourced // from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most // node +internal+ entries filtered. // Experimental. CreationStack() *[]*string // Configuration for error reporting. // // Error reports will be generated when a problem is encountered when writing the query results. ErrorReportConfiguration() interface{} SetErrorReportConfiguration(val interface{}) // The Amazon KMS key used to encrypt the scheduled query resource, at-rest. // // If the Amazon KMS key is not specified, the scheduled query resource will be encrypted with a Timestream owned Amazon KMS key. To specify a KMS key, use the key ID, key ARN, alias name, or alias ARN. When using an alias name, prefix the name with *alias/* // // If ErrorReportConfiguration uses `SSE_KMS` as encryption type, the same KmsKeyId is used to encrypt the error report at rest. KmsKeyId() *string SetKmsKeyId(val *string) // The logical ID for this CloudFormation stack element. // // The logical ID of the element // is calculated from the path of the resource node in the construct tree. // // To override this value, use `overrideLogicalId(newLogicalId)`. // // Returns: the logical ID as a stringified token. This value will only get // resolved during synthesis. // Experimental. LogicalId() *string // The construct tree node associated with this construct. // Experimental. Node() awscdk.ConstructNode // Notification configuration for the scheduled query. // // A notification is sent by Timestream when a query run finishes, when the state is updated or when you delete it. NotificationConfiguration() interface{} SetNotificationConfiguration(val interface{}) // The query string to run. // // Parameter names can be specified in the query string `@` character followed by an identifier. The named Parameter `@scheduled_runtime` is reserved and can be used in the query to get the time at which the query is scheduled to run. // // The timestamp calculated according to the ScheduleConfiguration parameter, will be the value of `@scheduled_runtime` paramater for each query run. For example, consider an instance of a scheduled query executing on 2021-12-01 00:00:00. For this instance, the `@scheduled_runtime` parameter is initialized to the timestamp 2021-12-01 00:00:00 when invoking the query. QueryString() *string SetQueryString(val *string) // Return a string that will be resolved to a CloudFormation `{ Ref }` for this element. // // If, by any chance, the intrinsic reference of a resource is not a string, you could // coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`. // Experimental. Ref() *string // Schedule configuration. ScheduleConfiguration() interface{} SetScheduleConfiguration(val interface{}) // The ARN for the IAM role that Timestream will assume when running the scheduled query. ScheduledQueryExecutionRoleArn() *string SetScheduledQueryExecutionRoleArn(val *string) // A name for the query. // // Scheduled query names must be unique within each Region. ScheduledQueryName() *string SetScheduledQueryName(val *string) // The stack in which this element is defined. // // CfnElements must be defined within a stack scope (directly or indirectly). // Experimental. Stack() awscdk.Stack // A list of key-value pairs to label the scheduled query. Tags() awscdk.TagManager // Scheduled query target store configuration. TargetConfiguration() interface{} SetTargetConfiguration(val interface{}) // Return properties modified after initiation. // // Resources that expose mutable properties should override this function to // collect and return the properties object for this resource. // Experimental. UpdatedProperites() *map[string]interface{} // Syntactic sugar for `addOverride(path, undefined)`. // Experimental. AddDeletionOverride(path *string) // Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned. // // This can be used for resources across stacks (or nested stack) boundaries // and the dependency will automatically be transferred to the relevant scope. // Experimental. AddDependsOn(target awscdk.CfnResource) // Add a value to the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. AddMetadata(key *string, value interface{}) // Adds an override to the synthesized CloudFormation resource. // // To add a // property override, either use `addPropertyOverride` or prefix `path` with // "Properties." (i.e. `Properties.TopicName`). // // If the override is nested, separate each nested level using a dot (.) in the path parameter. // If there is an array as part of the nesting, specify the index in the path. // // To include a literal `.` in the property name, prefix with a `\`. In most // programming languages you will need to write this as `"\\."` because the // `\` itself will need to be escaped. // // For example, // “`typescript // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']); // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE'); // “` // would add the overrides // “`json // "Properties": { // "GlobalSecondaryIndexes": [ // { // "Projection": { // "NonKeyAttributes": [ "myattribute" ] // ... // } // ... // }, // { // "ProjectionType": "INCLUDE" // ... // }, // ] // ... // } // “` // // The `value` argument to `addOverride` will not be processed or translated // in any way. Pass raw JSON values in here with the correct capitalization // for CloudFormation. If you pass CDK classes or structs, they will be // rendered with lowercased key names, and CloudFormation will reject the // template. // Experimental. AddOverride(path *string, value interface{}) // Adds an override that deletes the value of a property from the resource definition. // Experimental. AddPropertyDeletionOverride(propertyPath *string) // Adds an override to a resource property. // // Syntactic sugar for `addOverride("Properties.<...>", value)`. // Experimental. AddPropertyOverride(propertyPath *string, value interface{}) // Sets the deletion policy of the resource based on the removal policy specified. // // The Removal Policy controls what happens to this resource when it stops // being managed by CloudFormation, either because you've removed it from the // CDK application or because you've made a change that requires the resource // to be replaced. // // The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS // account for data recovery and cleanup later (`RemovalPolicy.RETAIN`). // Experimental. ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions) // Returns a token for an runtime attribute of this resource. // // Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility // in case there is no generated attribute. // Experimental. GetAtt(attributeName *string) awscdk.Reference // Retrieve a value value from the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. GetMetadata(key *string) interface{} // Examines the CloudFormation resource and discloses attributes. Inspect(inspector awscdk.TreeInspector) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. OnPrepare() // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. OnSynthesize(session constructs.ISynthesisSession) // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. OnValidate() *[]*string // Overrides the auto-generated logical ID with a specific ID. // Experimental. OverrideLogicalId(newLogicalId *string) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. Prepare() RenderProperties(props *map[string]interface{}) *map[string]interface{} // Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template. // // Returns: `true` if the resource should be included or `false` is the resource // should be omitted. // Experimental. ShouldSynthesize() *bool // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. Synthesize(session awscdk.ISynthesisSession) // Returns a string representation of this construct. // // Returns: a string representation of this resource. // Experimental. ToString() *string // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. Validate() *[]*string // Experimental. ValidateProperties(_properties interface{}) }
A CloudFormation `AWS::Timestream::ScheduledQuery`.
Create a scheduled query that will be run on your behalf at the configured schedule. Timestream assumes the execution role provided as part of the `ScheduledQueryExecutionRoleArn` parameter to run the query. You can use the `NotificationConfiguration` parameter to configure notification for your scheduled query operations.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" cfnScheduledQuery := awscdk.Aws_timestream.NewCfnScheduledQuery(this, jsii.String("MyCfnScheduledQuery"), &cfnScheduledQueryProps{ errorReportConfiguration: &errorReportConfigurationProperty{ s3Configuration: &s3ConfigurationProperty{ bucketName: jsii.String("bucketName"), // the properties below are optional encryptionOption: jsii.String("encryptionOption"), objectKeyPrefix: jsii.String("objectKeyPrefix"), }, }, notificationConfiguration: ¬ificationConfigurationProperty{ snsConfiguration: &snsConfigurationProperty{ topicArn: jsii.String("topicArn"), }, }, queryString: jsii.String("queryString"), scheduleConfiguration: &scheduleConfigurationProperty{ scheduleExpression: jsii.String("scheduleExpression"), }, scheduledQueryExecutionRoleArn: jsii.String("scheduledQueryExecutionRoleArn"), // the properties below are optional clientToken: jsii.String("clientToken"), kmsKeyId: jsii.String("kmsKeyId"), scheduledQueryName: jsii.String("scheduledQueryName"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, targetConfiguration: &targetConfigurationProperty{ timestreamConfiguration: ×treamConfigurationProperty{ databaseName: jsii.String("databaseName"), dimensionMappings: []interface{}{ &dimensionMappingProperty{ dimensionValueType: jsii.String("dimensionValueType"), name: jsii.String("name"), }, }, tableName: jsii.String("tableName"), timeColumn: jsii.String("timeColumn"), // the properties below are optional measureNameColumn: jsii.String("measureNameColumn"), mixedMeasureMappings: []interface{}{ &mixedMeasureMappingProperty{ measureValueType: jsii.String("measureValueType"), // the properties below are optional measureName: jsii.String("measureName"), multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, sourceColumn: jsii.String("sourceColumn"), targetMeasureName: jsii.String("targetMeasureName"), }, }, multiMeasureMappings: &multiMeasureMappingsProperty{ multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, // the properties below are optional targetMultiMeasureName: jsii.String("targetMultiMeasureName"), }, }, }, })
func NewCfnScheduledQuery ¶
func NewCfnScheduledQuery(scope awscdk.Construct, id *string, props *CfnScheduledQueryProps) CfnScheduledQuery
Create a new `AWS::Timestream::ScheduledQuery`.
type CfnScheduledQueryProps ¶
type CfnScheduledQueryProps struct { // Configuration for error reporting. // // Error reports will be generated when a problem is encountered when writing the query results. ErrorReportConfiguration interface{} `field:"required" json:"errorReportConfiguration" yaml:"errorReportConfiguration"` // Notification configuration for the scheduled query. // // A notification is sent by Timestream when a query run finishes, when the state is updated or when you delete it. NotificationConfiguration interface{} `field:"required" json:"notificationConfiguration" yaml:"notificationConfiguration"` // The query string to run. // // Parameter names can be specified in the query string `@` character followed by an identifier. The named Parameter `@scheduled_runtime` is reserved and can be used in the query to get the time at which the query is scheduled to run. // // The timestamp calculated according to the ScheduleConfiguration parameter, will be the value of `@scheduled_runtime` paramater for each query run. For example, consider an instance of a scheduled query executing on 2021-12-01 00:00:00. For this instance, the `@scheduled_runtime` parameter is initialized to the timestamp 2021-12-01 00:00:00 when invoking the query. QueryString *string `field:"required" json:"queryString" yaml:"queryString"` // Schedule configuration. ScheduleConfiguration interface{} `field:"required" json:"scheduleConfiguration" yaml:"scheduleConfiguration"` // The ARN for the IAM role that Timestream will assume when running the scheduled query. ScheduledQueryExecutionRoleArn *string `field:"required" json:"scheduledQueryExecutionRoleArn" yaml:"scheduledQueryExecutionRoleArn"` // Using a ClientToken makes the call to CreateScheduledQuery idempotent, in other words, making the same request repeatedly will produce the same result. // // Making multiple identical CreateScheduledQuery requests has the same effect as making a single request. // // - If CreateScheduledQuery is called without a `ClientToken` , the Query SDK generates a `ClientToken` on your behalf. // - After 8 hours, any request with the same `ClientToken` is treated as a new request. ClientToken *string `field:"optional" json:"clientToken" yaml:"clientToken"` // The Amazon KMS key used to encrypt the scheduled query resource, at-rest. // // If the Amazon KMS key is not specified, the scheduled query resource will be encrypted with a Timestream owned Amazon KMS key. To specify a KMS key, use the key ID, key ARN, alias name, or alias ARN. When using an alias name, prefix the name with *alias/* // // If ErrorReportConfiguration uses `SSE_KMS` as encryption type, the same KmsKeyId is used to encrypt the error report at rest. KmsKeyId *string `field:"optional" json:"kmsKeyId" yaml:"kmsKeyId"` // A name for the query. // // Scheduled query names must be unique within each Region. ScheduledQueryName *string `field:"optional" json:"scheduledQueryName" yaml:"scheduledQueryName"` // A list of key-value pairs to label the scheduled query. Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"` // Scheduled query target store configuration. TargetConfiguration interface{} `field:"optional" json:"targetConfiguration" yaml:"targetConfiguration"` }
Properties for defining a `CfnScheduledQuery`.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" cfnScheduledQueryProps := &cfnScheduledQueryProps{ errorReportConfiguration: &errorReportConfigurationProperty{ s3Configuration: &s3ConfigurationProperty{ bucketName: jsii.String("bucketName"), // the properties below are optional encryptionOption: jsii.String("encryptionOption"), objectKeyPrefix: jsii.String("objectKeyPrefix"), }, }, notificationConfiguration: ¬ificationConfigurationProperty{ snsConfiguration: &snsConfigurationProperty{ topicArn: jsii.String("topicArn"), }, }, queryString: jsii.String("queryString"), scheduleConfiguration: &scheduleConfigurationProperty{ scheduleExpression: jsii.String("scheduleExpression"), }, scheduledQueryExecutionRoleArn: jsii.String("scheduledQueryExecutionRoleArn"), // the properties below are optional clientToken: jsii.String("clientToken"), kmsKeyId: jsii.String("kmsKeyId"), scheduledQueryName: jsii.String("scheduledQueryName"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, targetConfiguration: &targetConfigurationProperty{ timestreamConfiguration: ×treamConfigurationProperty{ databaseName: jsii.String("databaseName"), dimensionMappings: []interface{}{ &dimensionMappingProperty{ dimensionValueType: jsii.String("dimensionValueType"), name: jsii.String("name"), }, }, tableName: jsii.String("tableName"), timeColumn: jsii.String("timeColumn"), // the properties below are optional measureNameColumn: jsii.String("measureNameColumn"), mixedMeasureMappings: []interface{}{ &mixedMeasureMappingProperty{ measureValueType: jsii.String("measureValueType"), // the properties below are optional measureName: jsii.String("measureName"), multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, sourceColumn: jsii.String("sourceColumn"), targetMeasureName: jsii.String("targetMeasureName"), }, }, multiMeasureMappings: &multiMeasureMappingsProperty{ multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, // the properties below are optional targetMultiMeasureName: jsii.String("targetMultiMeasureName"), }, }, }, }
type CfnScheduledQuery_DimensionMappingProperty ¶
type CfnScheduledQuery_DimensionMappingProperty struct { // Type for the dimension. DimensionValueType *string `field:"required" json:"dimensionValueType" yaml:"dimensionValueType"` // Column name from query result. Name *string `field:"required" json:"name" yaml:"name"` }
This type is used to map column(s) from the query result to a dimension in the destination table.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" dimensionMappingProperty := &dimensionMappingProperty{ dimensionValueType: jsii.String("dimensionValueType"), name: jsii.String("name"), }
type CfnScheduledQuery_ErrorReportConfigurationProperty ¶
type CfnScheduledQuery_ErrorReportConfigurationProperty struct {
// The S3 configuration for the error reports.
S3Configuration interface{} `field:"required" json:"s3Configuration" yaml:"s3Configuration"`
}
Configuration required for error reporting.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" errorReportConfigurationProperty := &errorReportConfigurationProperty{ s3Configuration: &s3ConfigurationProperty{ bucketName: jsii.String("bucketName"), // the properties below are optional encryptionOption: jsii.String("encryptionOption"), objectKeyPrefix: jsii.String("objectKeyPrefix"), }, }
type CfnScheduledQuery_MixedMeasureMappingProperty ¶
type CfnScheduledQuery_MixedMeasureMappingProperty struct { // Type of the value that is to be read from sourceColumn. // // If the mapping is for MULTI, use MeasureValueType.MULTI. MeasureValueType *string `field:"required" json:"measureValueType" yaml:"measureValueType"` // Refers to the value of measure_name in a result row. // // This field is required if MeasureNameColumn is provided. MeasureName *string `field:"optional" json:"measureName" yaml:"measureName"` // Required when measureValueType is MULTI. // // Attribute mappings for MULTI value measures. MultiMeasureAttributeMappings interface{} `field:"optional" json:"multiMeasureAttributeMappings" yaml:"multiMeasureAttributeMappings"` // This field refers to the source column from which measure-value is to be read for result materialization. SourceColumn *string `field:"optional" json:"sourceColumn" yaml:"sourceColumn"` // Target measure name to be used. // // If not provided, the target measure name by default would be measure-name if provided, or sourceColumn otherwise. TargetMeasureName *string `field:"optional" json:"targetMeasureName" yaml:"targetMeasureName"` }
MixedMeasureMappings are mappings that can be used to ingest data into a mixture of narrow and multi measures in the derived table.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" mixedMeasureMappingProperty := &mixedMeasureMappingProperty{ measureValueType: jsii.String("measureValueType"), // the properties below are optional measureName: jsii.String("measureName"), multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, sourceColumn: jsii.String("sourceColumn"), targetMeasureName: jsii.String("targetMeasureName"), }
type CfnScheduledQuery_MultiMeasureAttributeMappingProperty ¶
type CfnScheduledQuery_MultiMeasureAttributeMappingProperty struct { // Type of the attribute to be read from the source column. MeasureValueType *string `field:"required" json:"measureValueType" yaml:"measureValueType"` // Source column from where the attribute value is to be read. SourceColumn *string `field:"required" json:"sourceColumn" yaml:"sourceColumn"` // Custom name to be used for attribute name in derived table. // // If not provided, source column name would be used. TargetMultiMeasureAttributeName *string `field:"optional" json:"targetMultiMeasureAttributeName" yaml:"targetMultiMeasureAttributeName"` }
Attribute mapping for MULTI value measures.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" multiMeasureAttributeMappingProperty := &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }
type CfnScheduledQuery_MultiMeasureMappingsProperty ¶
type CfnScheduledQuery_MultiMeasureMappingsProperty struct { // Required. // // Attribute mappings to be used for mapping query results to ingest data for multi-measure attributes. MultiMeasureAttributeMappings interface{} `field:"required" json:"multiMeasureAttributeMappings" yaml:"multiMeasureAttributeMappings"` // The name of the target multi-measure name in the derived table. // // This input is required when measureNameColumn is not provided. If MeasureNameColumn is provided, then value from that column will be used as multi-measure name. TargetMultiMeasureName *string `field:"optional" json:"targetMultiMeasureName" yaml:"targetMultiMeasureName"` }
Only one of MixedMeasureMappings or MultiMeasureMappings is to be provided.
MultiMeasureMappings can be used to ingest data as multi measures in the derived table.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" multiMeasureMappingsProperty := &multiMeasureMappingsProperty{ multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, // the properties below are optional targetMultiMeasureName: jsii.String("targetMultiMeasureName"), }
type CfnScheduledQuery_NotificationConfigurationProperty ¶
type CfnScheduledQuery_NotificationConfigurationProperty struct {
// Details on SNS configuration.
SnsConfiguration interface{} `field:"required" json:"snsConfiguration" yaml:"snsConfiguration"`
}
Notification configuration for a scheduled query.
A notification is sent by Timestream when a scheduled query is created, its state is updated or when it is deleted.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" notificationConfigurationProperty := ¬ificationConfigurationProperty{ snsConfiguration: &snsConfigurationProperty{ topicArn: jsii.String("topicArn"), }, }
type CfnScheduledQuery_S3ConfigurationProperty ¶
type CfnScheduledQuery_S3ConfigurationProperty struct { // Name of the S3 bucket under which error reports will be created. BucketName *string `field:"required" json:"bucketName" yaml:"bucketName"` // Encryption at rest options for the error reports. // // If no encryption option is specified, Timestream will choose SSE_S3 as default. EncryptionOption *string `field:"optional" json:"encryptionOption" yaml:"encryptionOption"` // Prefix for the error report key. // // Timestream by default adds the following prefix to the error report path. ObjectKeyPrefix *string `field:"optional" json:"objectKeyPrefix" yaml:"objectKeyPrefix"` }
Details on S3 location for error reports that result from running a query.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" s3ConfigurationProperty := &s3ConfigurationProperty{ bucketName: jsii.String("bucketName"), // the properties below are optional encryptionOption: jsii.String("encryptionOption"), objectKeyPrefix: jsii.String("objectKeyPrefix"), }
type CfnScheduledQuery_ScheduleConfigurationProperty ¶
type CfnScheduledQuery_ScheduleConfigurationProperty struct { // An expression that denotes when to trigger the scheduled query run. // // This can be a cron expression or a rate expression. ScheduleExpression *string `field:"required" json:"scheduleExpression" yaml:"scheduleExpression"` }
Configuration of the schedule of the query.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" scheduleConfigurationProperty := &scheduleConfigurationProperty{ scheduleExpression: jsii.String("scheduleExpression"), }
type CfnScheduledQuery_SnsConfigurationProperty ¶
type CfnScheduledQuery_SnsConfigurationProperty struct { // SNS topic ARN that the scheduled query status notifications will be sent to. TopicArn *string `field:"required" json:"topicArn" yaml:"topicArn"` }
Details on SNS that are required to send the notification.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" snsConfigurationProperty := &snsConfigurationProperty{ topicArn: jsii.String("topicArn"), }
type CfnScheduledQuery_TargetConfigurationProperty ¶
type CfnScheduledQuery_TargetConfigurationProperty struct {
// Configuration needed to write data into the Timestream database and table.
TimestreamConfiguration interface{} `field:"required" json:"timestreamConfiguration" yaml:"timestreamConfiguration"`
}
Configuration used for writing the output of a query.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" targetConfigurationProperty := &targetConfigurationProperty{ timestreamConfiguration: ×treamConfigurationProperty{ databaseName: jsii.String("databaseName"), dimensionMappings: []interface{}{ &dimensionMappingProperty{ dimensionValueType: jsii.String("dimensionValueType"), name: jsii.String("name"), }, }, tableName: jsii.String("tableName"), timeColumn: jsii.String("timeColumn"), // the properties below are optional measureNameColumn: jsii.String("measureNameColumn"), mixedMeasureMappings: []interface{}{ &mixedMeasureMappingProperty{ measureValueType: jsii.String("measureValueType"), // the properties below are optional measureName: jsii.String("measureName"), multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, sourceColumn: jsii.String("sourceColumn"), targetMeasureName: jsii.String("targetMeasureName"), }, }, multiMeasureMappings: &multiMeasureMappingsProperty{ multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, // the properties below are optional targetMultiMeasureName: jsii.String("targetMultiMeasureName"), }, }, }
type CfnScheduledQuery_TimestreamConfigurationProperty ¶
type CfnScheduledQuery_TimestreamConfigurationProperty struct { // Name of Timestream database to which the query result will be written. DatabaseName *string `field:"required" json:"databaseName" yaml:"databaseName"` // This is to allow mapping column(s) from the query result to the dimension in the destination table. DimensionMappings interface{} `field:"required" json:"dimensionMappings" yaml:"dimensionMappings"` // Name of Timestream table that the query result will be written to. // // The table should be within the same database that is provided in Timestream configuration. TableName *string `field:"required" json:"tableName" yaml:"tableName"` // Column from query result that should be used as the time column in destination table. // // Column type for this should be TIMESTAMP. TimeColumn *string `field:"required" json:"timeColumn" yaml:"timeColumn"` // Name of the measure column. MeasureNameColumn *string `field:"optional" json:"measureNameColumn" yaml:"measureNameColumn"` // Specifies how to map measures to multi-measure records. MixedMeasureMappings interface{} `field:"optional" json:"mixedMeasureMappings" yaml:"mixedMeasureMappings"` // Multi-measure mappings. MultiMeasureMappings interface{} `field:"optional" json:"multiMeasureMappings" yaml:"multiMeasureMappings"` }
Configuration to write data into Timestream database and table.
This configuration allows the user to map the query result select columns into the destination table columns.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" timestreamConfigurationProperty := ×treamConfigurationProperty{ databaseName: jsii.String("databaseName"), dimensionMappings: []interface{}{ &dimensionMappingProperty{ dimensionValueType: jsii.String("dimensionValueType"), name: jsii.String("name"), }, }, tableName: jsii.String("tableName"), timeColumn: jsii.String("timeColumn"), // the properties below are optional measureNameColumn: jsii.String("measureNameColumn"), mixedMeasureMappings: []interface{}{ &mixedMeasureMappingProperty{ measureValueType: jsii.String("measureValueType"), // the properties below are optional measureName: jsii.String("measureName"), multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, sourceColumn: jsii.String("sourceColumn"), targetMeasureName: jsii.String("targetMeasureName"), }, }, multiMeasureMappings: &multiMeasureMappingsProperty{ multiMeasureAttributeMappings: []interface{}{ &multiMeasureAttributeMappingProperty{ measureValueType: jsii.String("measureValueType"), sourceColumn: jsii.String("sourceColumn"), // the properties below are optional targetMultiMeasureAttributeName: jsii.String("targetMultiMeasureAttributeName"), }, }, // the properties below are optional targetMultiMeasureName: jsii.String("targetMultiMeasureName"), }, }
type CfnTable ¶
type CfnTable interface { awscdk.CfnResource awscdk.IInspectable // The `arn` of the table. AttrArn() *string // The name of the table. AttrName() *string // Options for this resource, such as condition, update policy etc. // Experimental. CfnOptions() awscdk.ICfnResourceOptions CfnProperties() *map[string]interface{} // AWS resource type. // Experimental. CfnResourceType() *string // Returns: the stack trace of the point where this Resource was created from, sourced // from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most // node +internal+ entries filtered. // Experimental. CreationStack() *[]*string // The name of the Timestream database that contains this table. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. DatabaseName() *string SetDatabaseName(val *string) // The logical ID for this CloudFormation stack element. // // The logical ID of the element // is calculated from the path of the resource node in the construct tree. // // To override this value, use `overrideLogicalId(newLogicalId)`. // // Returns: the logical ID as a stringified token. This value will only get // resolved during synthesis. // Experimental. LogicalId() *string // Contains properties to set on the table when enabling magnetic store writes. // // This object has the following attributes: // // - *EnableMagneticStoreWrites* : A `boolean` flag to enable magnetic store writes. // - *MagneticStoreRejectedDataLocation* : The location to write error reports for records rejected, asynchronously, during magnetic store writes. Only `S3Configuration` objects are allowed. The `S3Configuration` object has the following attributes: // // - *BucketName* : The name of the S3 bucket. // - *EncryptionOption* : The encryption option for the S3 location. Valid values are S3 server-side encryption with an S3 managed key ( `SSE_S3` ) or AWS managed key ( `SSE_KMS` ). // - *KmsKeyId* : The AWS KMS key ID to use when encrypting with an AWS managed key. // - *ObjectKeyPrefix* : The prefix to use option for the objects stored in S3. // // Both `BucketName` and `EncryptionOption` are *required* when `S3Configuration` is specified. If you specify `SSE_KMS` as your `EncryptionOption` then `KmsKeyId` is *required* . // // `EnableMagneticStoreWrites` attribute is *required* when `MagneticStoreWriteProperties` is specified. `MagneticStoreRejectedDataLocation` attribute is *required* when `EnableMagneticStoreWrites` is set to `true` . // // See the following examples: // // *JSON* // // “`json // { "Type" : AWS::Timestream::Table", "Properties":{ "DatabaseName":"TestDatabase", "TableName":"TestTable", "MagneticStoreWriteProperties":{ "EnableMagneticStoreWrites":true, "MagneticStoreRejectedDataLocation":{ "S3Configuration":{ "BucketName":"testbucket", "EncryptionOption":"SSE_KMS", "KmsKeyId":"1234abcd-12ab-34cd-56ef-1234567890ab", "ObjectKeyPrefix":"prefix" } } } } // } // “` // // *YAML* // // “` // Type: AWS::Timestream::Table // DependsOn: TestDatabase // Properties: TableName: "TestTable" DatabaseName: "TestDatabase" MagneticStoreWriteProperties: EnableMagneticStoreWrites: true MagneticStoreRejectedDataLocation: S3Configuration: BucketName: "testbucket" EncryptionOption: "SSE_KMS" BucketName: "1234abcd-12ab-34cd-56ef-1234567890ab" EncryptionOption: "prefix" // “`. MagneticStoreWriteProperties() interface{} SetMagneticStoreWriteProperties(val interface{}) // The construct tree node associated with this construct. // Experimental. Node() awscdk.ConstructNode // Return a string that will be resolved to a CloudFormation `{ Ref }` for this element. // // If, by any chance, the intrinsic reference of a resource is not a string, you could // coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`. // Experimental. Ref() *string // The retention duration for the memory store and magnetic store. This object has the following attributes:. // // - *MemoryStoreRetentionPeriodInHours* : Retention duration for memory store, in hours. // - *MagneticStoreRetentionPeriodInDays* : Retention duration for magnetic store, in days. // // Both attributes are of type `string` . Both attributes are *required* when `RetentionProperties` is specified. // // See the following examples: // // *JSON* // // `{ "Type" : AWS::Timestream::Table", "Properties" : { "DatabaseName" : "TestDatabase", "TableName" : "TestTable", "RetentionProperties" : { "MemoryStoreRetentionPeriodInHours": "24", "MagneticStoreRetentionPeriodInDays": "7" } } }` // // *YAML* // // “` // Type: AWS::Timestream::Table // DependsOn: TestDatabase // Properties: TableName: "TestTable" DatabaseName: "TestDatabase" RetentionProperties: MemoryStoreRetentionPeriodInHours: "24" MagneticStoreRetentionPeriodInDays: "7" // “`. RetentionProperties() interface{} SetRetentionProperties(val interface{}) // The stack in which this element is defined. // // CfnElements must be defined within a stack scope (directly or indirectly). // Experimental. Stack() awscdk.Stack // The name of the Timestream table. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. TableName() *string SetTableName(val *string) // The tags to add to the table. Tags() awscdk.TagManager // Return properties modified after initiation. // // Resources that expose mutable properties should override this function to // collect and return the properties object for this resource. // Experimental. UpdatedProperites() *map[string]interface{} // Syntactic sugar for `addOverride(path, undefined)`. // Experimental. AddDeletionOverride(path *string) // Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned. // // This can be used for resources across stacks (or nested stack) boundaries // and the dependency will automatically be transferred to the relevant scope. // Experimental. AddDependsOn(target awscdk.CfnResource) // Add a value to the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. AddMetadata(key *string, value interface{}) // Adds an override to the synthesized CloudFormation resource. // // To add a // property override, either use `addPropertyOverride` or prefix `path` with // "Properties." (i.e. `Properties.TopicName`). // // If the override is nested, separate each nested level using a dot (.) in the path parameter. // If there is an array as part of the nesting, specify the index in the path. // // To include a literal `.` in the property name, prefix with a `\`. In most // programming languages you will need to write this as `"\\."` because the // `\` itself will need to be escaped. // // For example, // “`typescript // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']); // cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE'); // “` // would add the overrides // “`json // "Properties": { // "GlobalSecondaryIndexes": [ // { // "Projection": { // "NonKeyAttributes": [ "myattribute" ] // ... // } // ... // }, // { // "ProjectionType": "INCLUDE" // ... // }, // ] // ... // } // “` // // The `value` argument to `addOverride` will not be processed or translated // in any way. Pass raw JSON values in here with the correct capitalization // for CloudFormation. If you pass CDK classes or structs, they will be // rendered with lowercased key names, and CloudFormation will reject the // template. // Experimental. AddOverride(path *string, value interface{}) // Adds an override that deletes the value of a property from the resource definition. // Experimental. AddPropertyDeletionOverride(propertyPath *string) // Adds an override to a resource property. // // Syntactic sugar for `addOverride("Properties.<...>", value)`. // Experimental. AddPropertyOverride(propertyPath *string, value interface{}) // Sets the deletion policy of the resource based on the removal policy specified. // // The Removal Policy controls what happens to this resource when it stops // being managed by CloudFormation, either because you've removed it from the // CDK application or because you've made a change that requires the resource // to be replaced. // // The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS // account for data recovery and cleanup later (`RemovalPolicy.RETAIN`). // Experimental. ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions) // Returns a token for an runtime attribute of this resource. // // Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility // in case there is no generated attribute. // Experimental. GetAtt(attributeName *string) awscdk.Reference // Retrieve a value value from the CloudFormation Resource Metadata. // See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html // // Note that this is a different set of metadata from CDK node metadata; this // metadata ends up in the stack template under the resource, whereas CDK // node metadata ends up in the Cloud Assembly. // // Experimental. GetMetadata(key *string) interface{} // Examines the CloudFormation resource and discloses attributes. Inspect(inspector awscdk.TreeInspector) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. OnPrepare() // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. OnSynthesize(session constructs.ISynthesisSession) // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. OnValidate() *[]*string // Overrides the auto-generated logical ID with a specific ID. // Experimental. OverrideLogicalId(newLogicalId *string) // Perform final modifications before synthesis. // // This method can be implemented by derived constructs in order to perform // final changes before synthesis. prepare() will be called after child // constructs have been prepared. // // This is an advanced framework feature. Only use this if you // understand the implications. // Experimental. Prepare() RenderProperties(props *map[string]interface{}) *map[string]interface{} // Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template. // // Returns: `true` if the resource should be included or `false` is the resource // should be omitted. // Experimental. ShouldSynthesize() *bool // Allows this construct to emit artifacts into the cloud assembly during synthesis. // // This method is usually implemented by framework-level constructs such as `Stack` and `Asset` // as they participate in synthesizing the cloud assembly. // Experimental. Synthesize(session awscdk.ISynthesisSession) // Returns a string representation of this construct. // // Returns: a string representation of this resource. // Experimental. ToString() *string // Validate the current construct. // // This method can be implemented by derived constructs in order to perform // validation logic. It is called on all constructs before synthesis. // // Returns: An array of validation error messages, or an empty array if the construct is valid. // Experimental. Validate() *[]*string // Experimental. ValidateProperties(_properties interface{}) }
A CloudFormation `AWS::Timestream::Table`.
The CreateTable operation adds a new table to an existing database in your account. In an AWS account, table names must be at least unique within each Region if they are in the same database. You may have identical table names in the same Region if the tables are in separate databases. While creating the table, you must specify the table name, database name, and the retention properties. [Service quotas apply](https://docs.aws.amazon.com/timestream/latest/developerguide/ts-limits.html) . See [code sample](https://docs.aws.amazon.com/timestream/latest/developerguide/code-samples.create-table.html) for details.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" var magneticStoreWriteProperties interface{} var retentionProperties interface{} cfnTable := awscdk.Aws_timestream.NewCfnTable(this, jsii.String("MyCfnTable"), &cfnTableProps{ databaseName: jsii.String("databaseName"), // the properties below are optional magneticStoreWriteProperties: magneticStoreWriteProperties, retentionProperties: retentionProperties, tableName: jsii.String("tableName"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, })
func NewCfnTable ¶
func NewCfnTable(scope awscdk.Construct, id *string, props *CfnTableProps) CfnTable
Create a new `AWS::Timestream::Table`.
type CfnTableProps ¶
type CfnTableProps struct { // The name of the Timestream database that contains this table. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. DatabaseName *string `field:"required" json:"databaseName" yaml:"databaseName"` // Contains properties to set on the table when enabling magnetic store writes. // // This object has the following attributes: // // - *EnableMagneticStoreWrites* : A `boolean` flag to enable magnetic store writes. // - *MagneticStoreRejectedDataLocation* : The location to write error reports for records rejected, asynchronously, during magnetic store writes. Only `S3Configuration` objects are allowed. The `S3Configuration` object has the following attributes: // // - *BucketName* : The name of the S3 bucket. // - *EncryptionOption* : The encryption option for the S3 location. Valid values are S3 server-side encryption with an S3 managed key ( `SSE_S3` ) or AWS managed key ( `SSE_KMS` ). // - *KmsKeyId* : The AWS KMS key ID to use when encrypting with an AWS managed key. // - *ObjectKeyPrefix* : The prefix to use option for the objects stored in S3. // // Both `BucketName` and `EncryptionOption` are *required* when `S3Configuration` is specified. If you specify `SSE_KMS` as your `EncryptionOption` then `KmsKeyId` is *required* . // // `EnableMagneticStoreWrites` attribute is *required* when `MagneticStoreWriteProperties` is specified. `MagneticStoreRejectedDataLocation` attribute is *required* when `EnableMagneticStoreWrites` is set to `true` . // // See the following examples: // // *JSON* // // “`json // { "Type" : AWS::Timestream::Table", "Properties":{ "DatabaseName":"TestDatabase", "TableName":"TestTable", "MagneticStoreWriteProperties":{ "EnableMagneticStoreWrites":true, "MagneticStoreRejectedDataLocation":{ "S3Configuration":{ "BucketName":"testbucket", "EncryptionOption":"SSE_KMS", "KmsKeyId":"1234abcd-12ab-34cd-56ef-1234567890ab", "ObjectKeyPrefix":"prefix" } } } } // } // “` // // *YAML* // // “` // Type: AWS::Timestream::Table // DependsOn: TestDatabase // Properties: TableName: "TestTable" DatabaseName: "TestDatabase" MagneticStoreWriteProperties: EnableMagneticStoreWrites: true MagneticStoreRejectedDataLocation: S3Configuration: BucketName: "testbucket" EncryptionOption: "SSE_KMS" BucketName: "1234abcd-12ab-34cd-56ef-1234567890ab" EncryptionOption: "prefix" // “`. MagneticStoreWriteProperties interface{} `field:"optional" json:"magneticStoreWriteProperties" yaml:"magneticStoreWriteProperties"` // The retention duration for the memory store and magnetic store. This object has the following attributes:. // // - *MemoryStoreRetentionPeriodInHours* : Retention duration for memory store, in hours. // - *MagneticStoreRetentionPeriodInDays* : Retention duration for magnetic store, in days. // // Both attributes are of type `string` . Both attributes are *required* when `RetentionProperties` is specified. // // See the following examples: // // *JSON* // // `{ "Type" : AWS::Timestream::Table", "Properties" : { "DatabaseName" : "TestDatabase", "TableName" : "TestTable", "RetentionProperties" : { "MemoryStoreRetentionPeriodInHours": "24", "MagneticStoreRetentionPeriodInDays": "7" } } }` // // *YAML* // // “` // Type: AWS::Timestream::Table // DependsOn: TestDatabase // Properties: TableName: "TestTable" DatabaseName: "TestDatabase" RetentionProperties: MemoryStoreRetentionPeriodInHours: "24" MagneticStoreRetentionPeriodInDays: "7" // “`. RetentionProperties interface{} `field:"optional" json:"retentionProperties" yaml:"retentionProperties"` // The name of the Timestream table. // // *Length Constraints* : Minimum length of 3 bytes. Maximum length of 256 bytes. TableName *string `field:"optional" json:"tableName" yaml:"tableName"` // The tags to add to the table. Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"` }
Properties for defining a `CfnTable`.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import "github.com/aws/aws-cdk-go/awscdk" var magneticStoreWriteProperties interface{} var retentionProperties interface{} cfnTableProps := &cfnTableProps{ databaseName: jsii.String("databaseName"), // the properties below are optional magneticStoreWriteProperties: magneticStoreWriteProperties, retentionProperties: retentionProperties, tableName: jsii.String("tableName"), tags: []cfnTag{ &cfnTag{ key: jsii.String("key"), value: jsii.String("value"), }, }, }