Documentation ¶
Index ¶
- func NewAwsApi_Override(a AwsApi, props *AwsApiProps)
- func NewBatchJob_Override(b BatchJob, jobQueue awsbatch.IJobQueue, jobDefinition awsbatch.IJobDefinition, ...)
- func NewCloudWatchLogGroup_Override(c CloudWatchLogGroup, logGroup awslogs.ILogGroup, props *LogGroupProps)
- func NewCodeBuildProject_Override(c CodeBuildProject, project awscodebuild.IProject, ...)
- func NewCodePipeline_Override(c CodePipeline, pipeline awscodepipeline.IPipeline, ...)
- func NewEcsTask_Override(e EcsTask, props *EcsTaskProps)
- func NewEventBus_Override(e EventBus, eventBus awsevents.IEventBus, props *EventBusProps)
- func NewKinesisFirehoseStream_Override(k KinesisFirehoseStream, stream awskinesisfirehose.CfnDeliveryStream, ...)
- func NewKinesisStream_Override(k KinesisStream, stream awskinesis.IStream, props *KinesisStreamProps)
- func NewLambdaFunction_Override(l LambdaFunction, handler awslambda.IFunction, props *LambdaFunctionProps)
- func NewSfnStateMachine_Override(s SfnStateMachine, machine awsstepfunctions.IStateMachine, ...)
- func NewSnsTopic_Override(s SnsTopic, topic awssns.ITopic, props *SnsTopicProps)
- func NewSqsQueue_Override(s SqsQueue, queue awssqs.IQueue, props *SqsQueueProps)
- type AwsApi
- type AwsApiInput
- type AwsApiProps
- type BatchJob
- type BatchJobProps
- type CloudWatchLogGroup
- type CodeBuildProject
- type CodeBuildProjectProps
- type CodePipeline
- type CodePipelineTargetOptions
- type ContainerOverride
- type EcsTask
- type EcsTaskProps
- type EventBus
- type EventBusProps
- type KinesisFirehoseStream
- type KinesisFirehoseStreamProps
- type KinesisStream
- type KinesisStreamProps
- type LambdaFunction
- type LambdaFunctionProps
- type LogGroupProps
- type SfnStateMachine
- type SfnStateMachineProps
- type SnsTopic
- type SnsTopicProps
- type SqsQueue
- type SqsQueueProps
- type TargetBaseProps
- type TaskEnvironmentVariable
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewBatchJob_Override ¶
func NewBatchJob_Override(b BatchJob, jobQueue awsbatch.IJobQueue, jobDefinition awsbatch.IJobDefinition, props *BatchJobProps)
Experimental.
func NewCloudWatchLogGroup_Override ¶
func NewCloudWatchLogGroup_Override(c CloudWatchLogGroup, logGroup awslogs.ILogGroup, props *LogGroupProps)
Experimental.
func NewCodeBuildProject_Override ¶
func NewCodeBuildProject_Override(c CodeBuildProject, project awscodebuild.IProject, props *CodeBuildProjectProps)
Experimental.
func NewCodePipeline_Override ¶
func NewCodePipeline_Override(c CodePipeline, pipeline awscodepipeline.IPipeline, options *CodePipelineTargetOptions)
Experimental.
func NewEventBus_Override ¶
func NewEventBus_Override(e EventBus, eventBus awsevents.IEventBus, props *EventBusProps)
Experimental.
func NewKinesisFirehoseStream_Override ¶
func NewKinesisFirehoseStream_Override(k KinesisFirehoseStream, stream awskinesisfirehose.CfnDeliveryStream, props *KinesisFirehoseStreamProps)
Experimental.
func NewKinesisStream_Override ¶
func NewKinesisStream_Override(k KinesisStream, stream awskinesis.IStream, props *KinesisStreamProps)
Experimental.
func NewLambdaFunction_Override ¶
func NewLambdaFunction_Override(l LambdaFunction, handler awslambda.IFunction, props *LambdaFunctionProps)
Experimental.
func NewSfnStateMachine_Override ¶
func NewSfnStateMachine_Override(s SfnStateMachine, machine awsstepfunctions.IStateMachine, props *SfnStateMachineProps)
Experimental.
func NewSnsTopic_Override ¶
func NewSnsTopic_Override(s SnsTopic, topic awssns.ITopic, props *SnsTopicProps)
Experimental.
func NewSqsQueue_Override ¶
func NewSqsQueue_Override(s SqsQueue, queue awssqs.IQueue, props *SqsQueueProps)
Experimental.
Types ¶
type AwsApi ¶
type AwsApi interface { awsevents.IRuleTarget Bind(rule awsevents.IRule, id *string) *awsevents.RuleTargetConfig }
Use an AWS Lambda function that makes API calls as an event rule target. Experimental.
type AwsApiInput ¶
type AwsApiInput struct { // The service action to call. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Action *string `json:"action"` // The service to call. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Service *string `json:"service"` // API version to use for the service. // See: https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/locking-api-versions.html // // Experimental. ApiVersion *string `json:"apiVersion"` // The regex pattern to use to catch API errors. // // The `code` property of the // `Error` object will be tested against this pattern. If there is a match an // error will not be thrown. // Experimental. CatchErrorPattern *string `json:"catchErrorPattern"` // The parameters for the service action. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Parameters interface{} `json:"parameters"` }
Rule target input for an AwsApi target. Experimental.
type AwsApiProps ¶
type AwsApiProps struct { // The service action to call. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Action *string `json:"action"` // The service to call. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Service *string `json:"service"` // API version to use for the service. // See: https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/locking-api-versions.html // // Experimental. ApiVersion *string `json:"apiVersion"` // The regex pattern to use to catch API errors. // // The `code` property of the // `Error` object will be tested against this pattern. If there is a match an // error will not be thrown. // Experimental. CatchErrorPattern *string `json:"catchErrorPattern"` // The parameters for the service action. // See: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html // // Experimental. Parameters interface{} `json:"parameters"` // The IAM policy statement to allow the API call. // // Use only if // resource restriction is needed. // Experimental. PolicyStatement awsiam.PolicyStatement `json:"policyStatement"` }
Properties for an AwsApi target. Experimental.
type BatchJob ¶
type BatchJob interface { awsevents.IRuleTarget Bind(rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use an AWS Batch Job / Queue as an event rule target. Experimental.
func NewBatchJob ¶
func NewBatchJob(jobQueue awsbatch.IJobQueue, jobDefinition awsbatch.IJobDefinition, props *BatchJobProps) BatchJob
Experimental.
type BatchJobProps ¶
type BatchJobProps struct { // The number of times to attempt to retry, if the job fails. // // Valid values are 1–10. // Experimental. Attempts *float64 `json:"attempts"` // The event to send to the Lambda. // // This will be the payload sent to the Lambda Function. // Experimental. Event awsevents.RuleTargetInput `json:"event"` // The name of the submitted job. // Experimental. JobName *string `json:"jobName"` // The size of the array, if this is an array batch job. // // Valid values are integers between 2 and 10,000. // Experimental. Size *float64 `json:"size"` }
Customize the Batch Job Event Target. Experimental.
type CloudWatchLogGroup ¶
type CloudWatchLogGroup interface { awsevents.IRuleTarget Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use an AWS CloudWatch LogGroup as an event rule target. Experimental.
func NewCloudWatchLogGroup ¶
func NewCloudWatchLogGroup(logGroup awslogs.ILogGroup, props *LogGroupProps) CloudWatchLogGroup
Experimental.
type CodeBuildProject ¶
type CodeBuildProject interface { awsevents.IRuleTarget Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Start a CodeBuild build when an Amazon EventBridge rule is triggered. Experimental.
func NewCodeBuildProject ¶
func NewCodeBuildProject(project awscodebuild.IProject, props *CodeBuildProjectProps) CodeBuildProject
Experimental.
type CodeBuildProjectProps ¶
type CodeBuildProjectProps struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` // The event to send to CodeBuild. // // This will be the payload for the StartBuild API. // Experimental. Event awsevents.RuleTargetInput `json:"event"` // The role to assume before invoking the target (i.e., the codebuild) when the given rule is triggered. // Experimental. EventRole awsiam.IRole `json:"eventRole"` }
Customize the CodeBuild Event Target. Experimental.
type CodePipeline ¶
type CodePipeline interface { awsevents.IRuleTarget Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Allows the pipeline to be used as an EventBridge rule target. Experimental.
func NewCodePipeline ¶
func NewCodePipeline(pipeline awscodepipeline.IPipeline, options *CodePipelineTargetOptions) CodePipeline
Experimental.
type CodePipelineTargetOptions ¶
type CodePipelineTargetOptions struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` // The role to assume before invoking the target (i.e., the pipeline) when the given rule is triggered. // Experimental. EventRole awsiam.IRole `json:"eventRole"` }
Customization options when creating a {@link CodePipeline} event target. Experimental.
type ContainerOverride ¶
type ContainerOverride struct { // Name of the container inside the task definition. // Experimental. ContainerName *string `json:"containerName"` // Command to run inside the container. // Experimental. Command *[]*string `json:"command"` // The number of cpu units reserved for the container. // Experimental. Cpu *float64 `json:"cpu"` // Variables to set in the container's environment. // Experimental. Environment *[]*TaskEnvironmentVariable `json:"environment"` // Hard memory limit on the container. // Experimental. MemoryLimit *float64 `json:"memoryLimit"` // Soft memory limit on the container. // Experimental. MemoryReservation *float64 `json:"memoryReservation"` }
Experimental.
type EcsTask ¶
type EcsTask interface { awsevents.IRuleTarget SecurityGroups() *[]awsec2.ISecurityGroup Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Start a task on an ECS cluster. Experimental.
type EcsTaskProps ¶
type EcsTaskProps struct { // Cluster where service will be deployed. // Experimental. Cluster awsecs.ICluster `json:"cluster"` // Task Definition of the task that should be started. // Experimental. TaskDefinition awsecs.ITaskDefinition `json:"taskDefinition"` // Container setting overrides. // // Key is the name of the container to override, value is the // values you want to override. // Experimental. ContainerOverrides *[]*ContainerOverride `json:"containerOverrides"` // The platform version on which to run your task. // // Unless you have specific compatibility requirements, you don't need to specify this. // See: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html // // Experimental. PlatformVersion awsecs.FargatePlatformVersion `json:"platformVersion"` // Existing IAM role to run the ECS task. // Experimental. Role awsiam.IRole `json:"role"` // Existing security groups to use for the task's ENIs. // // (Only applicable in case the TaskDefinition is configured for AwsVpc networking) // Experimental. SecurityGroups *[]awsec2.ISecurityGroup `json:"securityGroups"` // In what subnets to place the task's ENIs. // // (Only applicable in case the TaskDefinition is configured for AwsVpc networking) // Experimental. SubnetSelection *awsec2.SubnetSelection `json:"subnetSelection"` // How many tasks should be started when this event is triggered. // Experimental. TaskCount *float64 `json:"taskCount"` }
Properties to define an ECS Event Task. Experimental.
type EventBus ¶
type EventBus interface { awsevents.IRuleTarget Bind(rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Notify an existing Event Bus of an event. Experimental.
func NewEventBus ¶
func NewEventBus(eventBus awsevents.IEventBus, props *EventBusProps) EventBus
Experimental.
type EventBusProps ¶
type EventBusProps struct { // Role to be used to publish the event. // Experimental. Role awsiam.IRole `json:"role"` }
Configuration properties of an Event Bus event. Experimental.
type KinesisFirehoseStream ¶
type KinesisFirehoseStream interface { awsevents.IRuleTarget Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Customize the Firehose Stream Event Target. Experimental.
func NewKinesisFirehoseStream ¶
func NewKinesisFirehoseStream(stream awskinesisfirehose.CfnDeliveryStream, props *KinesisFirehoseStreamProps) KinesisFirehoseStream
Experimental.
type KinesisFirehoseStreamProps ¶
type KinesisFirehoseStreamProps struct { // The message to send to the stream. // // Must be a valid JSON text passed to the target stream. // Experimental. Message awsevents.RuleTargetInput `json:"message"` }
Customize the Firehose Stream Event Target. Experimental.
type KinesisStream ¶
type KinesisStream interface { awsevents.IRuleTarget Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use a Kinesis Stream as a target for AWS CloudWatch event rules.
TODO: EXAMPLE
Experimental.
func NewKinesisStream ¶
func NewKinesisStream(stream awskinesis.IStream, props *KinesisStreamProps) KinesisStream
Experimental.
type KinesisStreamProps ¶
type KinesisStreamProps struct { // The message to send to the stream. // // Must be a valid JSON text passed to the target stream. // Experimental. Message awsevents.RuleTargetInput `json:"message"` // Partition Key Path for records sent to this stream. // Experimental. PartitionKeyPath *string `json:"partitionKeyPath"` }
Customize the Kinesis Stream Event Target. Experimental.
type LambdaFunction ¶
type LambdaFunction interface { awsevents.IRuleTarget Bind(rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use an AWS Lambda function as an event rule target. Experimental.
func NewLambdaFunction ¶
func NewLambdaFunction(handler awslambda.IFunction, props *LambdaFunctionProps) LambdaFunction
Experimental.
type LambdaFunctionProps ¶
type LambdaFunctionProps struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` // The event to send to the Lambda. // // This will be the payload sent to the Lambda Function. // Experimental. Event awsevents.RuleTargetInput `json:"event"` }
Customize the Lambda Event Target. Experimental.
type LogGroupProps ¶
type LogGroupProps struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` // The event to send to the CloudWatch LogGroup. // // This will be the event logged into the CloudWatch LogGroup // Experimental. Event awsevents.RuleTargetInput `json:"event"` }
Customize the CloudWatch LogGroup Event Target. Experimental.
type SfnStateMachine ¶
type SfnStateMachine interface { awsevents.IRuleTarget Machine() awsstepfunctions.IStateMachine Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use a StepFunctions state machine as a target for Amazon EventBridge rules. Experimental.
func NewSfnStateMachine ¶
func NewSfnStateMachine(machine awsstepfunctions.IStateMachine, props *SfnStateMachineProps) SfnStateMachine
Experimental.
type SfnStateMachineProps ¶
type SfnStateMachineProps struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` // The input to the state machine execution. // Experimental. Input awsevents.RuleTargetInput `json:"input"` // The IAM role to be assumed to execute the State Machine. // Experimental. Role awsiam.IRole `json:"role"` }
Customize the Step Functions State Machine target. Experimental.
type SnsTopic ¶
type SnsTopic interface { awsevents.IRuleTarget Topic() awssns.ITopic Bind(_rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use an SNS topic as a target for Amazon EventBridge rules.
TODO: EXAMPLE
Experimental.
func NewSnsTopic ¶
func NewSnsTopic(topic awssns.ITopic, props *SnsTopicProps) SnsTopic
Experimental.
type SnsTopicProps ¶
type SnsTopicProps struct { // The message to send to the topic. // Experimental. Message awsevents.RuleTargetInput `json:"message"` }
Customize the SNS Topic Event Target. Experimental.
type SqsQueue ¶
type SqsQueue interface { awsevents.IRuleTarget Queue() awssqs.IQueue Bind(rule awsevents.IRule, _id *string) *awsevents.RuleTargetConfig }
Use an SQS Queue as a target for Amazon EventBridge rules.
TODO: EXAMPLE
Experimental.
func NewSqsQueue ¶
func NewSqsQueue(queue awssqs.IQueue, props *SqsQueueProps) SqsQueue
Experimental.
type SqsQueueProps ¶
type SqsQueueProps struct { // The message to send to the queue. // // Must be a valid JSON text passed to the target queue. // Experimental. Message awsevents.RuleTargetInput `json:"message"` // Message Group ID for messages sent to this queue. // // Required for FIFO queues, leave empty for regular queues. // Experimental. MessageGroupId *string `json:"messageGroupId"` }
Customize the SQS Queue Event Target. Experimental.
type TargetBaseProps ¶
type TargetBaseProps struct { // The SQS queue to be used as deadLetterQueue. Check out the [considerations for using a dead-letter queue](https://docs.aws.amazon.com/eventbridge/latest/userguide/rule-dlq.html#dlq-considerations). // // The events not successfully delivered are automatically retried for a specified period of time, // depending on the retry policy of the target. // If an event is not delivered before all retry attempts are exhausted, it will be sent to the dead letter queue. // Experimental. DeadLetterQueue awssqs.IQueue `json:"deadLetterQueue"` // The maximum age of a request that Lambda sends to a function for processing. // // Minimum value of 60. // Maximum value of 86400. // Experimental. MaxEventAge awscdk.Duration `json:"maxEventAge"` // The maximum number of times to retry when the function returns an error. // // Minimum value of 0. // Maximum value of 185. // Experimental. RetryAttempts *float64 `json:"retryAttempts"` }
The generic properties for an RuleTarget. Experimental.
type TaskEnvironmentVariable ¶
type TaskEnvironmentVariable struct { // Name for the environment variable. // // Exactly one of `name` and `namePath` must be specified. // Experimental. Name *string `json:"name"` // Value of the environment variable. // // Exactly one of `value` and `valuePath` must be specified. // Experimental. Value *string `json:"value"` }
An environment variable to be set in the container run as a task. Experimental.