blob: 79b81ea3e48be481c1fb5c265c18c36c84e9c169 [file] [log] [blame]
apiVersion: camel.apache.org/v1alpha1
kind: Kamelet
metadata:
name: aws-ddb-streams-source
annotations:
camel.apache.org/catalog.version: "v0.1.0"
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Apache Software Foundation"
labels:
camel.apache.org/kamelet.type: "source"
spec:
definition:
title: "AWS DynamoDB Streams Source"
description: |-
Receive events from AWS DynamoDB Streams.
required:
- table
- accessKey
- secretKey
- region
properties:
table:
title: Table
description: Name of the DynamoDB table to look at
type: string
accessKey:
title: Access Key
description: The access key obtained from AWS
type: string
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
secretKey:
title: Secret Key
description: The secret key obtained from AWS
type: string
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
region:
title: AWS Region
description: The AWS region to connect to
type: string
example: eu-west-1
iteratorType:
title: Iterator Type
description: Defines where in the DynaboDB stream to start getting records. Note that using TRIM_HORIZON can cause a significant delay before the stream has caught up to real-time. if {AT,AFTER}_SEQUENCE_NUMBER are used, then a sequenceNumberProvider MUST be supplied. There are 4 enums and the value can be one of TRIM_HORIZON, LATEST, AT_SEQUENCE_NUMBER, AFTER_SEQUENCE_NUMBER
type: string
default: LATEST
sequenceNumberProvider:
title: Sequence Number Provider
description: Provider for the sequence number when using one of the two ShardIteratorType AT_SEQUENCE_NUMBER or AFTER_SEQUENCE_NUMBER iterator types. Can be a registry reference or a literal sequence number.
type: string
example: "900000000005745712447"
default: "000000000000000000000"
types:
out:
mediaType: application/json
dependencies:
- "camel:gson"
flow:
from:
uri: "aws2-ddbstream:{{table}}"
parameters:
secretKey: "{{secretKey}}"
accessKey: "{{accessKey}}"
region: "{{region}}"
iteratorType: "{{iteratorType}}"
sequenceNumberProvider: "{{sequenceNumberProvider}}"
steps:
- marshal:
json:
library: Gson
- to: "kamelet:sink"