apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: avro-deserialize-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Deserialize Action" description: "Deserialize payload to Avro." type: object properties: schema: title: Schema description: The Avro schema to use during serialization (as single-line, using JSON format) type: string example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' validate: title: Validate description: Indicates if the content must be validated against the schema type: boolean default: true dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson-avro" template: beans: - name: schemaResolver type: "#class:org.apache.camel.component.jackson.avro.transform.AvroSchemaResolver" properties: validate: "{{validate}}" schema: "{{schema:}}" from: uri: kamelet:source steps: - unmarshal: avro: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#bean:{{schemaResolver}}" - removeHeader: name: "Content-Type" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: avro-serialize-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Serialize Action" description: "Serialize payload to Avro." type: object properties: schema: title: Schema description: The Avro schema to use during serialization (as single-line, using JSON format) type: string example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' validate: title: Validate description: Indicates if the content must be validated against the schema type: boolean default: true dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson-avro" template: beans: - name: schemaResolver type: "#class:org.apache.camel.component.jackson.avro.transform.AvroSchemaResolver" properties: validate: "{{validate}}" schema: "{{schema:}}" from: uri: kamelet:source steps: - marshal: avro: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#bean:{{schemaResolver}}" - setHeader: name: "Content-Type" constant: "application/avro" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-bedrock-agent-runtime-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Bedrock" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Bedrock Agent Runtime Sink" description: Send data for invoking a knowledge base from AWS Bedrock. required: - modelId - knowledgeBaseId - region type: object properties: modelId: title: Model Id description: The model Id to be used to generate responses. type: string enum: ["anthropic.claude-instant-v1", "anthropic.claude-v2", "anthropic.claude-v2:1", "anthropic.claude-3-sonnet-20240229-v1:0"] knowledgeBaseId: title: Knowledge Base Id description: The Knowledge Base Id to be used to retrieve and generate responses. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["us-east-1", "us-west-1"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Bedrock client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Bedrock client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Bedrock client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Bedrock. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws-bedrock" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "aws-bedrock-agent-runtime:bedrock-knowledge" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" modelId: "{{modelId}}" knowledgeBaseId: "{{knowledgeBaseId}}" operation: retrieveAndGenerate useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-bedrock-text-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Bedrock" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Bedrock Text Sink" description: Send data for invoking a text model of Amazon Bedrock. required: - modelId - region type: object properties: modelId: title: Model Id description: The model Id to be used. type: string enum: ["amazon.titan-text-express-v1", "amazon.titan-text-lite-v1", "ai21.j2-ultra-v1", "ai21.j2-mid-v1", "anthropic.claude-instant-v1", "anthropic.claude-v2", "anthropic.claude-v2:1", "anthropic.claude-3-sonnet-20240229-v1:0"] accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["us-east-1", "us-west-1", "ap-southeast-1", "ap-northeast-1", "eu-central-1"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Bedrock client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Bedrock client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Bedrock client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Bedrock. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws-bedrock" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - setHeader: name: "CamelAwsBedrockContentType" constant: "application/json" - setHeader: name: "CamelAwsBedrockAcceptContentType" constant: "application/json" - to: uri: "aws-bedrock:bedrock-text" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" modelId: "{{modelId}}" operation: invokeTextModel useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-cloudtrail-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Cloudtrail" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS Cloudtrail Source" description: Receive data from an AWS Cloudtrail. required: - region type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Cloudtrail client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Cloudtrail client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the CloudTrail client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in CloudTrail. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false maxResults: title: Max Results description: Maximum number of records that are fetched in each poll. type: integer default: 1 eventSource: title: Event Source description: Specify an event source to select events. type: string example: secretsmanager.amazonaws.com dataTypes: out: default: text headers: CamelAwsCloudTrailEventId: title: Cloudtrail Event Id description: The event ID of the cloud trail event consumed type: string CamelAwsCloudTrailEventName: title: Cloudtrail Event Name description: The event Name of the cloud trail event consumed type: string CamelAwsCloudTrailEventSource: title: Cloudtrail Event Source description: The event Source of the cloud trail event consumed type: string CamelAwsCloudTrailEventUsername: title: Cloudtrail Event Username description: The associated username of the event of the cloud trail event consumed type: string types: text: format: "text-plain" description: Default text representation of the Cloudtrail Event mediaType: text/plain cloudevents: format: "aws-cloudtrail:application-cloudevents" description: Data type transformer converts AWS Cloudtrail lookup events response to CloudEvent v1_0 data format. The data type sets Camel specific CloudEvent headers with values extracted from AWS Cloudtrail lookup events response. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.aws.cloudtrail.lookupEvents" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Cloudtrail event source name with prefix "aws.cloudtrail.event.source.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The Cloudtrail Event Id. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:core" - "camel:aws-cloudtrail" - "camel:kamelet" template: from: uri: "aws-cloudtrail:cloudtrail" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" eventSource: "{{?eventSource}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" maxResults: "{{maxResults}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-cloudwatch-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Cloudwatch" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS CloudWatch Metrics Sink" description: Send data to Amazon CloudWatch metrics. required: - cwNamespace - region type: object properties: cwNamespace: title: Cloud Watch Namespace description: The CloudWatch metric namespace. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Cloudwatch client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Cloudwatch client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Cloudwatch client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Cloudwatch. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws2-cw" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[metric-name]}" steps: - setHeader: name: CamelAwsCwMetricName simple: "${header[metric-name]}" - simple: "${header[ce-metricname]}" steps: - setHeader: name: CamelAwsCwMetricName simple: "${header[ce-metricname]}" - choice: when: - simple: "${header[metric-value]}" steps: - setHeader: name: CamelAwsCwMetricValue simple: "${header[metric-value]}" - simple: "${header[ce-metricvalue]}" steps: - setHeader: name: CamelAwsCwMetricValue simple: "${header[ce-metricvalue]}" - choice: when: - simple: "${header[metric-unit]}" steps: - setHeader: name: CamelAwsCwMetricUnit simple: "${header[metric-unit]}" - simple: "${header[ce-metricunit]}" steps: - setHeader: name: CamelAwsCwMetricUnit simple: "${header[ce-metricunit]}" - choice: when: - simple: "${header[metric-timestamp]}" steps: - setHeader: name: CamelAwsCwMetricTimestamp simple: "${header[metric-timestamp]}" - simple: "${header[ce-metrictimestamp]}" steps: - setHeader: name: CamelAwsCwMetricTimestamp simple: "${header[ce-metrictimestamp]}" - choice: when: - simple: "${header[metric-dimension-name]}" steps: - setHeader: name: CamelAwsCwMetricDimensionName simple: "${header[metric-dimension-name]}" - simple: "${header[ce-metricdimensionname]}" steps: - setHeader: name: CamelAwsCwMetricDimensionName simple: "${header[ce-metricdimensionname]}" - choice: when: - simple: "${header[metric-dimension-value]}" steps: - setHeader: name: CamelAwsCwMetricDimensionValue simple: "${header[metric-dimension-value]}" - simple: "${header[ce-metricdimensionvalue]}" steps: - setHeader: name: CamelAwsCwMetricDimensionValue simple: "${header[ce-metricdimensionvalue]}" - to: uri: "aws2-cw:{{cwNamespace}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-ddb-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS DynamoDB Streams" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS DynamoDB Sink" description: Send data to Amazon DynamoDB. The sent data inserts, updates, or deletes an item on the specified AWS DynamoDB table. required: - table - region type: object properties: table: title: Table description: The name of the DynamoDB table. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] operation: title: Operation description: "The operation to perform." type: string enum: ["PutItem", "UpdateItem", "DeleteItem"] default: PutItem example: PutItem useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the DynamoDB client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the DynamoDB client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the DynamoDB client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in DynamoDB. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dataTypes: in: default: json types: json: format: "aws2-ddb:application-json" description: Json representation of a DDB operation. The input type supports the operations PutItem, UpdateItem, DeleteItem. For PutItem operation the Json body defines all item attributes. For DeleteItem operation the Json body defines only the primary key attributes that identify the item to delete. For UpdateItem operation the Json body defines both key attributes to identify the item to be updated and all item attributes that get updated on the item. headers: CamelAwsDdbOperation: title: Operation description: "The operation to perform. Overwrites the operation given in the Json body. One of PutItem, UpdateItem, DeleteItem." default: PutItem type: string CamelAwsDdbReturnValues: title: Return Values description: Use this parameter if you want to get the attribute name-value pairs before or after they are modified. Possible values are NONE, ALL_OLD, UPDATED_OLD, ALL_NEW, UPDATED_NEW. type: string mediaType: application/json schema: type: object required: [ "key" ] properties: operation: type: string description: The operator to perform. One of PutItem, UpdateItem, DeleteItem key: type: object description: The primary key specifies the selection criteria for the query. item: type: object description: Attribute value map specifies all attributes to change with the given operation. dependencies: - "camel:core" - "camel:jackson" - "camel:aws2-ddb" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - setProperty: name: operation constant: "{{operation}}" - transform: toType: "aws2-ddb:application-json" - to: uri: "aws2-ddb:{{table}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" operation: "{{operation}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-ddb-streams-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS DynamoDB Streams" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS DynamoDB Streams Source" description: Receive events from Amazon DynamoDB Streams. required: - table - region type: object properties: table: title: Table description: The name of the DynamoDB table. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] streamIteratorType: title: Stream Iterator Type description: Defines where in the DynamoDB stream to start getting records. There are two enums and the value can be one of FROM_LATEST and FROM_START. Note that using FROM_START can cause a significant delay before the stream has caught up to real-time. type: string default: FROM_LATEST useDefaultCredentialsProvider: title: Default Credentials Provider description: If `true`, the DynamoDB client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the DynamoDB client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the DynamoDB client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in DynamoDB. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false delay: title: Delay description: The number of milliseconds before the next poll from the database. type: integer default: 500 dataTypes: out: default: json headers: CamelAwsDdbStreamEventSource: title: The DDB Stream Event Source description: The Amazon Web Services service from which the stream record originated. For DynamoDB Streams, this is aws:dynamodb. type: string CamelAwsDdbStreamEventId: title: The DDB Stream Event Id description: A globally unique identifier for the event that was recorded in this stream record. type: string types: json: format: "application-json" description: Default Json representation of a DDB Stream Event. mediaType: application/json cloudevents: format: "aws2-ddbstream:application-cloudevents" description: Data type transformer converts AWS Dynamo DB Streams get records response to CloudEvent v1_0 data format. The data type sets Camel specific CloudEvent headers with values extracted from AWS Dynamo DB Streams get records. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id. type: string CamelCloudEventType: title: CloudEvent Type description: The event type. default: "org.apache.camel.event.aws.ddbstream.getRecords" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the DDB Stream Event source receipt handle with prefix "aws.ddbstream.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The DDB Stream Event Id. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:gson" - "camel:aws2-ddb" - "camel:kamelet" template: from: uri: "aws2-ddbstream:{{table}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" streamIteratorType: "{{streamIteratorType}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" delay: "{{delay}}" steps: - transform: toType: "aws2-ddb:application-x-struct" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-ec2-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS EC2" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS EC2 Sink" description: Check the status of EC2 instances required: - region type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the EC2 client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the EC2 client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the EC2 client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in EC2. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws2-ec2" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[instanceIds]}" steps: - setHeader: name: CamelAwsEC2InstancesIds simple: "${header[instanceIds]}" - simple: "${header[ce-instanceids]}" steps: - setHeader: name: CamelAwsEC2InstancesIds simple: "${header[ce-instanceids]}" - to: uri: "aws2-ec2:ec2-route" parameters: accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" operation: "describeInstancesStatus" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-eventbridge-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Eventbridge" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Eventbridge Sink" description: Send events to an Amazon Eventbridge Eventbus. In the headers, you can set the `resources-arn` / `ce-resources-arn` property to specify the ARN of resources related to the event. In the headers, you can set the `detail-type` / `ce-detail-type` property to specify the detail type related to the event. In the headers, you can set the `event-source` / `ce-event-source` property to specify the event source related to the event. If you do not set the property in the header, the Kamelet uses the given Kamelet properties as a default. required: - eventbusNameOrArn - region type: object properties: eventbusNameOrArn: title: Eventbus Name description: The Eventbridge Eventbus name or Amazon Resource Name (ARN). type: string resourcesArn: title: Event Resource ARN description: The ARN of resources related to the AWS event (e.g. `arn:aws:s3:eu-east-1:000000000001:test`). type: string eventSourcePrefix: title: Event Source Prefix description: The event source prefix set for all events sent to the eventbus. type: string default: "" eventSource: title: Event Source description: The event source related to the AWS event (e.g. `aws.s3`). type: string detailType: title: Event Detail Type description: The event detail type related to the AWS event. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Eventbridge client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Eventbridge client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Eventbridge client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Eventbridge. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws2-eventbridge" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[resources-arn]}" steps: - setHeader: name: CamelAwsEventbridgeResourcesArn simple: "${header[resources-arn]}" - simple: "${header[ce-resources-arn]}" steps: - setHeader: name: CamelAwsEventbridgeResourcesArn simple: "${header[ce-resources-arn]}" otherwise: steps: - setHeader: name: CamelAwsEventbridgeResourcesArn simple: "{{?resourcesArn}}" - choice: when: - simple: "${header[detail-type]}" steps: - setHeader: name: CamelAwsEventbridgeDetailType simple: "${header[detail-type]}" - simple: "${header[ce-detail-type]}" steps: - setHeader: name: CamelAwsEventbridgeDetailType simple: "${header[ce-detail-type]}" otherwise: steps: - setHeader: name: CamelAwsEventbridgeDetailType simple: "{{?detailType}}" - choice: when: - simple: "${header[event-source]}" steps: - setHeader: name: CamelAwsEventbridgeSource simple: "{{?eventSourcePrefix}}${header[event-source]}" - simple: "${header[ce-event-source]}" steps: - setHeader: name: CamelAwsEventbridgeSource simple: "{{?eventSourcePrefix}}${header[ce-event-source]}" - simple: "${header[ce-source]}" steps: - setHeader: name: CamelAwsEventbridgeSource simple: "{{?eventSourcePrefix}}${header[ce-source]}" otherwise: steps: - setHeader: name: CamelAwsEventbridgeSource simple: "{{?eventSourcePrefix}}{{?eventSource}}" - to: uri: "aws2-eventbridge:{{eventbusNameOrArn}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" operation: "putEvent" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-kinesis-firehose-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Kinesis Firehose" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Kinesis Firehose Sink" description: Send message to an AWS Kinesis Firehose Stream. required: - streamName - region type: object properties: streamName: title: Stream Name description: The name of the stream we want to send to data to. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the Kinesis Firehose client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Kinesis Firehose client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Kinesis Firehose client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Kinesis Firehose. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:aws2-kinesis" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: "aws2-kinesis-firehose:{{streamName}}" parameters: accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-kinesis-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Kinesis" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Kinesis Sink" description: Send data to AWS Kinesis. required: - stream - region type: object properties: stream: title: Stream Name description: The Kinesis stream that you want to access. The Kinesis stream that you specify must already exist. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Kinesis client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Kinesis client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Kinesis client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Kinesis. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false types: in: mediaType: application/octet-stream dependencies: - "camel:core" - "camel:aws2-kinesis" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[partition]}" steps: - setHeader: name: CamelAwsKinesisPartitionKey simple: "${header[partition]}" - simple: "${header[ce-partition]}" steps: - setHeader: name: CamelAwsKinesisPartitionKey simple: "${header[ce-partition]}" otherwise: steps: - setHeader: name: CamelAwsKinesisPartitionKey simple: "${exchangeId}" - choice: when: - simple: "${header[sequence-number]}" steps: - setHeader: name: CamelAwsKinesisSequenceNumber simple: "${header[sequence-number]}" - simple: "${header[ce-sequencenumber]}" steps: - setHeader: name: CamelAwsKinesisSequenceNumber simple: "${header[ce-sequencenumber]}" - to: uri: "aws2-kinesis:{{stream}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-kinesis-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Kinesis" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS Kinesis Source" description: Receive data from AWS Kinesis. required: - stream - region type: object properties: stream: title: Stream Name description: The Kinesis stream that you want to access. The Kinesis stream that you specify must already exist. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Kinesis client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Kinesis client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Kinesis client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Kinesis. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false delay: title: Delay description: The number of milliseconds before the next poll of the selected stream. type: integer default: 500 asyncClient: title: Async Client description: If we want a KinesisAsyncClient instance set it to true. type: boolean default: false useKclConsumers: title: KCL Consumer description: If we want to a KCL Consumer set it to true type: boolean default: false kclDisableCloudwatchMetricsExport: title: KCL Disable Cloudwatch Metrics Export description: Define if we want to use a KCL Consumer and disable the CloudWatch Metrics Export type: boolean default: false types: out: mediaType: application/octet-stream dependencies: - "camel:aws2-kinesis" - "camel:kamelet" - "camel:core" template: from: uri: aws2-kinesis:{{stream}} parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" delay: "{{delay}}" useKclConsumers: "{{useKclConsumers}}" asyncClient: "{{asyncClient}}" kclDisableCloudwatchMetricsExport: "{{kclDisableCloudwatchMetricsExport}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-lambda-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Lambda" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Lambda Sink" description: Send a payload to an AWS Lambda function. required: - function - region type: object properties: function: title: Function Name description: The Lambda Function name. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the Lambda client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Lambda client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Lambda client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Lambda. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:aws2-lambda" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: "aws2-lambda:{{function}}" parameters: accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-redshift-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Redshift" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Redshift Sink" description: Send data to an AWS Redshift Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the AWS RedShi data source. type: string default: 5439 username: title: Username description: The username to access a secured AWS Redshift Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured AWS Redshift Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the AWS Redshift Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the AWS RedShift Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:com.amazon.redshift:redshift-jdbc42:2.1.0.34" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-redshift-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:redshift://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'com.amazon.redshift.jdbc.Driver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-redshift-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-redshift-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Redshift" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS Redshift Source" description: Query data from an AWS RedShift Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 5439 username: title: Username description: The username to access a secured AWS RedShift Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured AWS RedShift Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the AWS RedShift Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the AWS RedShift Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' delay: title: Delay description: The number of milliseconds before the next poll from the AWS RedShift database. type: integer default: 500 types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:com.amazon.redshift:redshift-jdbc42:2.1.0.34" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-redshift-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:redshift://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'com.amazon.redshift.jdbc.Driver' from: uri: "{{local-sql-redshift-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-s3-event-based-source annotations: camel.apache.org/kamelet.support.level: Preview camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: >-  camel.apache.org/provider: Apache Software Foundation camel.apache.org/kamelet.group: AWS S3 Event-Based camel.apache.org/kamelet.namespace: "AWS" camel.apache.org/keda.type: aws-s3-event-based-queue labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS S3 Event Based Source" description: Receive data from AWS SQS subscribed to Eventbridge Bus reporting events related to an S3 bucket or multiple buckets. required: - accessKey - secretKey - queueNameOrArn - region type: object properties: queueNameOrArn: title: Queue Name description: The SQS Queue Name or ARN type: string deleteAfterRead: title: Auto-delete Messages description: Delete messages after consuming them type: boolean default: true accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - 'urn:camel:group:credentials' - 'urn:keda:authentication:awsAccessKeyID' - 'urn:keda:required' secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - 'urn:camel:group:credentials' - 'urn:keda:authentication:awsSecretAccessKey' - 'urn:keda:required' region: title: AWS Region description: The AWS region to access. type: string x-descriptors: - 'urn:keda:metadata:awsRegion' - 'urn:keda:required' enum: - ap-south-1 - eu-south-1 - us-gov-east-1 - me-central-1 - ca-central-1 - eu-central-1 - us-iso-west-1 - us-west-1 - us-west-2 - af-south-1 - eu-north-1 - eu-west-3 - eu-west-2 - eu-west-1 - ap-northeast-3 - ap-northeast-2 - ap-northeast-1 - me-south-1 - sa-east-1 - ap-east-1 - cn-north-1 - us-gov-west-1 - ap-southeast-1 - ap-southeast-2 - us-iso-east-1 - ap-southeast-3 - us-east-1 - us-east-2 - cn-northwest-1 - us-isob-east-1 - aws-global - aws-cn-global - aws-us-gov-global - aws-iso-global - aws-iso-b-global autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. type: boolean default: false amazonAWSHost: title: AWS Host description: The hostname of the Amazon AWS cloud. type: string default: amazonaws.com protocol: title: Protocol description: The underlying protocol used to communicate with SQS type: string example: http or https default: https queueURL: title: Queue URL description: The full SQS Queue URL (required if using KEDA) type: string x-descriptors: - 'urn:keda:metadata:queueURL' - 'urn:keda:required' uriEndpointOverride: title: Overwrite Endpoint URI description: >- The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: >- Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false delay: title: Delay description: The number of milliseconds before the next poll of the selected stream type: integer default: 500 greedy: title: Greedy Scheduler description: >- If greedy is enabled, then the polling will happen immediately again, if the previous run polled 1 or more messages. type: boolean default: false getObject: title: Greedy Object in Bucket description: >- If `getObject` is enabled, then the file created in the bucket is retrieved and returned as body. If not, only the event will returned as body. type: boolean default: false dependencies: - 'camel:core' - 'camel:aws2-sqs' - 'camel:aws2-s3' - 'camel:jsonpath' - 'camel:kamelet' - 'camel:jackson' template: from: uri: 'aws2-sqs:{{queueNameOrArn}}' parameters: autoCreateQueue: '{{autoCreateQueue}}' secretKey: '{{?secretKey}}' accessKey: '{{?accessKey}}' region: '{{region}}' deleteAfterRead: '{{deleteAfterRead}}' amazonAWSHost: '{{?amazonAWSHost}}' protocol: '{{?protocol}}' uriEndpointOverride: '{{?uriEndpointOverride}}' overrideEndpoint: '{{overrideEndpoint}}' delay: '{{delay}}' greedy: '{{greedy}}' steps: - choice: precondition: true when: - simple: '${properties:getObject:true}' steps: - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: s3-event-name jsonpath: $.detail.reason - choice: when: - simple: '${exchangeProperty.s3-event-name} == "PutObject"' steps: - setProperty: name: aws-s3-name jsonpath: $.detail.object.key - setProperty: name: aws-s3-bucket jsonpath: $.detail.bucket.name - toD: >- aws2-s3:${exchangeProperty.aws-s3-bucket}?accessKey={{accessKey}}&secretKey={{secretKey}}®ion={{region}}&operation=getObject&keyName=${exchangeProperty.aws-s3-name} - to: 'kamelet:sink' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-s3-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS S3" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS S3 Sink" description: Upload data to an Amazon S3 Bucket. required: - bucketNameOrArn - region type: object properties: bucketNameOrArn: title: Bucket Name description: The S3 Bucket name or Amazon Resource Name (ARN). type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the S3 bucket. type: boolean default: false useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the S3 client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the S3 client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the S3 client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in S3. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false forcePathStyle: title: Force Path Style description: Forces path style when accessing AWS S3 buckets. type: boolean default: false keyName: title: Key Name description: The key name for saving an element in the bucket. type: string dependencies: - "camel:core" - "camel:aws2-s3" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: precondition: true when: - simple: '${propertiesExist:!keyName}' steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelAwsS3Key simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelAwsS3Key simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelAwsS3Key simple: "${exchangeId}" - to: uri: "aws2-s3:{{bucketNameOrArn}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" autoCreateBucket: "{{autoCreateBucket}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" forcePathStyle: "{{forcePathStyle}}" keyName: "{{?keyName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-s3-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS S3" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS S3 Source" description: Receive data from an Amazon S3 Bucket. required: - bucketNameOrArn - region type: object properties: bucketNameOrArn: title: Bucket Name description: The S3 Bucket name or Amazon Resource Name (ARN). type: string deleteAfterRead: title: Auto-delete Objects description: Specifies to delete objects after consuming them. type: boolean default: true moveAfterRead: title: Move Objects After Delete description: Move objects from S3 bucket to a different bucket after they have been retrieved. type: boolean default: false destinationBucket: title: Destination Bucket description: Define the destination bucket where an object must be moved when moveAfterRead is set to true. type: string destinationBucketPrefix: title: Destination Bucket Prefix description: Define the destination bucket prefix to use when an object must be moved, and moveAfterRead is set to true. type: string destinationBucketSuffix: title: Destination Bucket Suffix description: Define the destination bucket suffix to use when an object must be moved, and moveAfterRead is set to true. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the S3 bucket. type: boolean default: false prefix: title: Prefix description: The AWS S3 bucket prefix to consider while searching. type: string example: 'folder/' ignoreBody: title: Ignore Body description: If true, the S3 Object body is ignored. Setting this to true overrides any behavior defined by the `includeBody` option. If false, the S3 object is put in the body. type: boolean default: false useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the S3 client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the S3 client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the S3 client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in S3. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false forcePathStyle: title: Force Path Style description: Forces path style when accessing AWS S3 buckets. type: boolean default: false delay: title: Delay description: The number of milliseconds before the next poll of the selected bucket. type: integer default: 500 maxMessagesPerPoll: title: Max Messages Per Poll description: Gets the maximum number of messages as a limit to poll at each polling. Gets the maximum number of messages as a limit to poll at each polling. The default value is 10. Use 0 or a negative number to set it as unlimited. type: integer default: 10 dataTypes: out: default: binary headers: CamelAwsS3BucketName: title: S3 Bucket Name description: The bucket name which has been used to retrieve objects type: string CamelAwsS3Key: title: S3 Key description: The key under which the retrieved object is stored. type: string CamelAwsS3ContentType: title: Content Type description: The content type of the retrieved object. default: application/octet-stream type: string CamelAwsS3ETag: title: ETag Value description: The hex encoded 128-bit MD5 digest of the associated object according to RFC 1864. type: string types: binary: format: "application-octet-stream" description: Default binary representation of the S3 object retrieved from the bucket. mediaType: application/octet-stream cloudevents: format: "aws2-s3:application-cloudevents" description: Output data type represents AWS S3 get object response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the S3 bucket and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.aws.s3.getObject" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the S3 bucket name with prefix "aws.s3.bucket.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the S3 key. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:core" - "camel:aws2-s3" - "camel:kamelet" template: from: uri: "aws2-s3:{{bucketNameOrArn}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" ignoreBody: "{{ignoreBody}}" deleteAfterRead: "{{deleteAfterRead}}" moveAfterRead: "{{moveAfterRead}}" destinationBucket: "{{?destinationBucket}}" destinationBucketPrefix: "{{?destinationBucketPrefix}}" destinationBucketSuffix: "{{?destinationBucketSuffix}}" prefix: "{{?prefix}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" forcePathStyle: "{{forcePathStyle}}" delay: "{{delay}}" maxMessagesPerPoll: "{{maxMessagesPerPoll}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-s3-streaming-upload-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS S3" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS S3 Streaming upload Sink" description: Upload data to AWS S3 in streaming upload mode. required: - bucketNameOrArn - region - keyName type: object properties: bucketNameOrArn: title: Bucket Name description: The S3 Bucket name or Amazon Resource Name (ARN). type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateBucket: title: Autocreate Bucket description: Setting the autocreation of the S3 bucket bucketName. type: boolean default: false restartingPolicy: title: Restarting Policy description: The restarting policy to use in streaming upload mode. There are 2 enums and the value can be one of `override`, `lastPart`. type: string default: "lastPart" batchMessageNumber: title: Batch Message Number description: The number of messages composing a batch in streaming upload mode. type: integer default: 10 batchSize: title: Batch Size description: The batch size (in bytes) in streaming upload mode. type: integer default: 1000000 streamingUploadTimeout: title: Streaming Upload Timeout description: While streaming upload mode is true, this option set the timeout to complete upload. type: integer namingStrategy: title: Naming Strategy description: The naming strategy to use in streaming upload mode. There are 2 enums and the value can be one of progressive, random. type: string default: "progressive" keyName: title: Key Name description: Setting the key name for an element in the bucket through endpoint parameter. In Streaming Upload, with the default configuration, this is the base for the progressive creation of files. type: string useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the S3 client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the S3 client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the S3 client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in S3. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false forcePathStyle: title: Force Path Style description: Forces path style when accessing AWS S3 buckets. type: boolean default: false dependencies: - "camel:aws2-s3" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "aws2-s3:{{bucketNameOrArn}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" autoCreateBucket: "{{autoCreateBucket}}" streamingUploadMode: "true" restartingPolicy: "{{restartingPolicy}}" batchMessageNumber: "{{batchMessageNumber}}" batchSize: "{{batchSize}}" namingStrategy: "{{namingStrategy}}" keyName: "{{keyName}}" streamingUploadTimeout: "{{?streamingUploadTimeout}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" forcePathStyle: "{{forcePathStyle}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-secrets-manager-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Secrets Manager" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Secrets Manager Sink" description: Create a secret in AWS Secrets Manager. required: - region type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the Secrets Manager client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Secrets Manager client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Secrets Manager client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Secrets Manager. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:core" - "camel:aws-secrets-manager" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[secret-name]}" steps: - setHeader: name: CamelAwsSecretsManagerSecretName simple: "${header[secret-name]}" - simple: "${header[ce-secret-name]}" steps: - setHeader: name: CamelAwsSecretsManagerSecretName simple: "${header[ce-secret-name]}" otherwise: steps: - setHeader: name: CamelAwsSecretsManagerSecretName simple: "${exchangeId}" - to: uri: "aws-secrets-manager:kamelet" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" operation: "createSecret" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-ses-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SES" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SES Sink" description: Send email through the Amazon Simple Email Service (SES). required: - from - region type: object properties: from: title: From description: From address type: string example: user@example.com accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the SES client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SES client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SES client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SES. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:core" - "camel:aws2-ses" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[subject]}" steps: - setHeader: name: CamelAwsSesSubject simple: "${header[subject]}" - simple: "${header[ce-subject]}" steps: - setHeader: name: CamelAwsSesSubject simple: "${header[ce-subject]}" otherwise: steps: - setHeader: name: CamelAwsSesSubject simple: "${exchangeId}" - choice: when: - simple: "${header[to]}" steps: - setHeader: name: CamelAwsSesTo simple: "${header[to]}" - simple: "${header[ce-to]}" steps: - setHeader: name: CamelAwsSesTo simple: "${header[ce-to]}" - choice: when: - simple: "${header[reply-to-addresses]}" steps: - setHeader: name: CamelAwsSesReplyToAddresses simple: "${header[reply-to-addresses]}" - simple: "${header[ce-reply-to-addresses]}" steps: - setHeader: name: CamelAwsSesReplyToAddresses simple: "${header[ce-reply-to-addresses]}" - to: uri: "aws2-ses://{{from}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sns-fifo-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SNS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SNS FIFO Sink" description: Send message to an AWS SNS FIFO Topic. required: - topicNameOrArn - region type: object properties: topicNameOrArn: title: Topic Name description: The SNS Topic name or ARN. type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] contentBasedDeduplication: title: Content-Based Deduplication description: Use content-based deduplication (should be enabled in the SQS FIFO queue first). type: boolean default: false autoCreateTopic: title: Autocreate Topic description: Setting the autocreation of the SNS topic. type: boolean default: false useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the SNS client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SNS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SNS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SNS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:aws2-sns" - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[subject]}" steps: - setHeader: name: CamelAwsSnsSubject simple: "${header[subject]}" - simple: "${header[ce-subject]}" steps: - setHeader: name: CamelAwsSnsSubject simple: "${header[ce-subject]}" - setProperty: name: contentBasedDeduplication constant: "{{contentBasedDeduplication}}" - choice: when: - simple: "${header[group]}" steps: - setProperty: name: CamelAwsSnsMessageGroupId simple: "${header[group]}" - simple: "${header[ce-group]}" steps: - setProperty: name: CamelAwsSnsMessageGroupId simple: "${header[ce-group]}" otherwise: steps: - setProperty: name: CamelAwsSnsMessageGroupId simple: "${exchangeId}" - choice: when: - simple: "${exchangeProperty.contentBasedDeduplication} == 'true'" steps: - to: uri: "aws2-sns:{{topicNameOrArn}}" parameters: autoCreateTopic: "{{autoCreateTopic}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" messageGroupIdStrategy: "usePropertyValue" messageDeduplicationIdStrategy: "useContentBasedDeduplication" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" uriEndpointOverride: "{{?uriEndpointOverride}}" overrideEndpoint: "{{overrideEndpoint}}" otherwise: steps: - to: uri: "aws2-sns:{{topicNameOrArn}}" parameters: autoCreateTopic: "{{autoCreateTopic}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" messageGroupIdStrategy: "usePropertyValue" messageDeduplicationIdStrategy: "useExchangeId" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" uriEndpointOverride: "{{?uriEndpointOverride}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sns-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SNS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SNS Sink" description: Send message to an Amazon Simple Notification Service (SNS) topic. required: - topicNameOrArn - region type: object properties: topicNameOrArn: title: Topic Name description: The SNS topic name name or Amazon Resource Name (ARN). type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateTopic: title: Autocreate Topic description: Setting the autocreation of the SNS topic. type: boolean default: false useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the SNS client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SNS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SNS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SNS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws2-sns" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[subject]}" steps: - setHeader: name: CamelAwsSnsSubject simple: "${header[subject]}" - simple: "${header[ce-subject]}" steps: - setHeader: name: CamelAwsSnsSubject simple: "${header[ce-subject]}" - to: uri: "aws2-sns:{{topicNameOrArn}}" parameters: autoCreateTopic: "{{autoCreateTopic}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sqs-batch-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SQS Batch Sink" description: Send Batch message to an AWS SQS Queue. required: - queueNameOrArn - region - batchSeparator type: object properties: queueNameOrArn: title: Queue Name description: The SQS Queue name or ARN type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. type: boolean default: false batchSeparator: title: Batch Separator description: The batch separator string type: string example: "," amazonAWSHost: title: AWS Host description: The hostname of the Amazon AWS cloud. type: string default: amazonaws.com protocol: title: Protocol description: The underlying protocol used to communicate with SQS type: string example: http or https default: https useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the SQS client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SQS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SQS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SQS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:aws2-sqs" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: "aws2-sqs:{{queueNameOrArn}}" parameters: autoCreateQueue: "{{autoCreateQueue}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" batchSeparator: "{{batchSeparator}}" operation: "sendBatchMessage" amazonAWSHost: "{{?amazonAWSHost}}" protocol: "{{?protocol}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sqs-fifo-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SQS FIFO Sink" description: Send message to an AWS SQS FIFO Queue. required: - queueNameOrArn - region type: object properties: queueNameOrArn: title: Queue Name description: The SQS Queue name or ARN type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] contentBasedDeduplication: title: Content-Based Deduplication description: Use content-based deduplication (should be enabled in the SQS FIFO queue first) type: boolean default: false autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. type: boolean default: false amazonAWSHost: title: AWS Host description: The hostname of the Amazon AWS cloud. type: string default: amazonaws.com protocol: title: Protocol description: The underlying protocol used to communicate with SQS type: string example: http or https default: https useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the SQS client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SQS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SQS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SQS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:aws2-sqs" - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - setProperty: name: contentBasedDeduplication constant: "{{contentBasedDeduplication}}" - choice: when: - simple: "${header[group]}" steps: - setProperty: name: CamelAwsMessageGroupId simple: "${header[group]}" - simple: "${header[ce-group]}" steps: - setProperty: name: CamelAwsMessageGroupId simple: "${header[ce-group]}" otherwise: steps: - setProperty: name: CamelAwsMessageGroupId simple: "${exchangeId}" - choice: when: - simple: "${exchangeProperty.contentBasedDeduplication} == 'true'" steps: - to: uri: "aws2-sqs:{{queueNameOrArn}}" parameters: autoCreateQueue: "{{autoCreateQueue}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" messageGroupIdStrategy: "usePropertyValue" messageDeduplicationIdStrategy: "useContentBasedDeduplication" amazonAWSHost: "{{?amazonAWSHost}}" protocol: "{{?protocol}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" otherwise: steps: - to: uri: "aws2-sqs:{{queueNameOrArn}}" parameters: autoCreateQueue: "{{autoCreateQueue}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" messageGroupIdStrategy: "usePropertyValue" messageDeduplicationIdStrategy: "useExchangeId" amazonAWSHost: "{{?amazonAWSHost}}" protocol: "{{?protocol}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sqs-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS SQS Sink" description: Send messages to an Amazon Simple Queue Service (SQS) queue. required: - queueNameOrArn - region type: object properties: queueNameOrArn: title: Queue Name description: The SQS Queue name or or Amazon Resource Name (ARN). type: string accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateQueue: title: Autocreate Queue description: Automatically create the SQS queue. type: boolean default: false amazonAWSHost: title: AWS Host description: The hostname of the Amazon AWS cloud. type: string default: amazonaws.com protocol: title: Protocol description: The underlying protocol used to communicate with SQS. type: string example: http or https default: https useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the SQS client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SQS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SQS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SQS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:aws2-sqs" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: "aws2-sqs:{{queueNameOrArn}}" parameters: autoCreateQueue: "{{autoCreateQueue}}" accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" amazonAWSHost: "{{?amazonAWSHost}}" protocol: "{{?protocol}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sqs-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" camel.apache.org/keda.type: "aws-sqs-queue" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "AWS SQS Source" description: Receive data from AWS SQS. required: - queueNameOrArn - region type: object properties: queueNameOrArn: title: Queue Name description: The SQS Queue Name or ARN. type: string deleteAfterRead: title: Auto-delete Messages description: Delete messages after consuming them. type: boolean default: true accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:awsAccessKeyID - urn:keda:required secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:awsSecretAccessKey - urn:keda:required region: title: AWS Region description: The AWS region to access. type: string x-descriptors: - urn:keda:metadata:awsRegion - urn:keda:required enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. type: boolean default: false amazonAWSHost: title: AWS Host description: The hostname of the Amazon AWS cloud. type: string default: amazonaws.com protocol: title: Protocol description: The underlying protocol used to communicate with SQS. type: string example: http or https default: https queueURL: title: Queue URL description: The full SQS Queue URL (required if using KEDA). type: string x-descriptors: - urn:keda:metadata:queueURL - urn:keda:required useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the SQS client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the SQS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the SQS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in SQS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false delay: title: Delay description: The number of milliseconds before the next poll of the selected stream. type: integer default: 500 greedy: title: Greedy Scheduler description: If greedy is enabled, then the polling will happen immediately again, if the previous run polled 1 or more messages. type: boolean default: false maxMessagesPerPoll: title: Max Messages Per Poll description: The maximum number of messages to return. Amazon SQS never returns more messages than this value (however, fewer messages might be returned). Valid values 1 to 10. Default 1. type: integer minimum: "1" maximum: "10" default: 1 waitTimeSeconds: title: Wait Time Seconds description: The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. If a message is available, the call returns sooner than WaitTimeSeconds. If no messages are available and the wait time expires, the call does not return a message list. type: integer minimum: "0" visibilityTimeout: title: Visibility Timeout description: The duration (in seconds) that the received messages are hidden from subsequent retrieve requests after being retrieved by a ReceiveMessage request. type: integer minimum: "0" dataTypes: out: default: text headers: CamelAwsSqsMessageId: title: The SQS Message Id description: The Amazon SQS message ID. type: string CamelAwsSqsReceiptHandle: title: The SQS Message Receipt Handle description: The Amazon SQS message receipt handle. type: string CamelAwsSqsMD5OfBody: title: The SQS Message MD5 Checksum description: The content type of the retrieved object. default: application/octet-stream type: string CamelAwsSqsAttributes: title: The SQS Message System Attributes description: A map of the attributes requested in ReceiveMessage to their respective values, the Map type is Map type: object CamelAwsSqsMessageAttributes: title: The SQS Message Attributes description: The Amazon SQS message attributes, the Map type is Map type: object types: text: format: "text-plain" description: Default String representation of the SQS message received from the queue. mediaType: text/plain cloudevents: format: "aws2-sqs:application-cloudevents" description: Output data type represents AWS SQS receive message response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the SQS message and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id. type: string CamelCloudEventType: title: CloudEvent Type description: The event type. default: "org.apache.camel.event.aws.sqs.receiveMessage" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the SQS Received message receipt handle with prefix "aws.sqs.queue.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The SQS message ID. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:core" - "camel:aws2-sqs" - "camel:kamelet" template: from: uri: "aws2-sqs:{{queueNameOrArn}}" parameters: autoCreateQueue: "{{autoCreateQueue}}" secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" deleteAfterRead: "{{deleteAfterRead}}" amazonAWSHost: "{{?amazonAWSHost}}" protocol: "{{?protocol}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" delay: "{{delay}}" greedy: "{{greedy}}" maxMessagesPerPoll: "{{maxMessagesPerPoll}}" waitTimeSeconds: "{{?waitTimeSeconds}}" visibilityTimeout: "{{?visibilityTimeout}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-sts-assume-role-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS STS" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "AWS STS Assume Role Action" description: Assume a role through STS required: - region type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the STS client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the STS client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the STS client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in STS. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:kamelet" - "camel:core" - "camel:aws2-sts" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[role-arn]}" steps: - setHeader: name: CamelAwsStsRoleArn simple: "${header[role-arn]}" - simple: "${header[ce-role-arn]}" steps: - setHeader: name: CamelAwsStsRoleArn simple: "${header[ce-role-arn]}" - choice: when: - simple: "${header[role-session-name]}" steps: - setHeader: name: CamelAwsStsRoleSessionName simple: "${header[role-session-name]}" - simple: "${header[ce-role-session-name]}" steps: - setHeader: name: CamelAwsStsRoleSessionName simple: "${header[ce-role-session-name]}" - to: uri: "aws2-sts://default" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" operation: "assumeRole" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-timestream-query-sink annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Timestream" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "AWS Timestream Query Sink" description: Query an AWS Timestream Database required: - region type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] useDefaultCredentialsProvider: title: Default Credentials Provider description: If true, the CloudWatch client loads credentials through a default credentials provider. If false, it uses the basic authentication method (access key and secret key). type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Timestream client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Timestream client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Timestream. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials uriEndpointOverride: title: Overwrite Endpoint URI description: The overriding endpoint URI. To use this option, you must also select the `overrideEndpoint` option. type: string overrideEndpoint: title: Endpoint Overwrite description: Select this option to override the endpoint URI. To use this option, you must also provide a URI for the `uriEndpointOverride` option. type: boolean default: false dependencies: - "camel:core" - "camel:aws2-timestream" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[query]}" steps: - setHeader: name: CamelAwsTimestreamQueryString simple: "${header[query]}" - simple: "${header[ce-query]}" steps: - setHeader: name: CamelAwsTimestreamQueryString simple: "${header[ce-query]}" - to: uri: "aws2-timestream:query" parameters: accessKey: "{{?accessKey}}" secretKey: "{{?secretKey}}" region: "{{region}}" operation: "query" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" uriEndpointOverride: "{{?uriEndpointOverride}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" overrideEndpoint: "{{overrideEndpoint}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: aws-translate-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS Translate" camel.apache.org/kamelet.namespace: "AWS" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "AWS Translate Action" description: Translate a text in a specific language. required: - region - sourceLanguage - targetLanguage type: object properties: accessKey: title: Access Key description: The access key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from AWS. type: string format: password x-descriptors: - urn:camel:group:credentials region: title: AWS Region description: The AWS region to access. type: string enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", "ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", "af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", "ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", "sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", "ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", "cn-northwest-1", "us-isob-east-1", "aws-global", "aws-cn-global", "aws-us-gov-global", "aws-iso-global", "aws-iso-b-global"] sourceLanguage: title: Source Language description: The source language of the translating text. type: string example: it enum: ["ar", "zh", "zh-TW", "cs", "da", "nl", "en", "fi", "fr", "de", "he", "hi", "id", "it", "ja", "ko", "ms", "no", "fa", "pl", "pt", "ru", "es", "sv", "tr"] targetLanguage: title: Target Language description: The target language of the translating text. type: string example: it enum: ["ar", "zh", "zh-TW", "cs", "da", "nl", "en", "fi", "fr", "de", "he", "hi", "id", "it", "ja", "ko", "ms", "no", "fa", "pl", "pt", "ru", "es", "sv", "tr"] useDefaultCredentialsProvider: title: Default Credentials Provider description: Set whether the Translate client should expect to load credentials through a default credentials provider or to expect static credentials to be passed in. type: boolean default: false useProfileCredentialsProvider: title: Profile Credentials Provider description: Set whether the Translate client should expect to load credentials through a profile credentials provider. type: boolean default: false useSessionCredentials: title: Session Credentials description: Set whether the Translate client should expect to use Session Credentials. This is useful in situation in which the user needs to assume a IAM role for doing operations in Translate. type: boolean default: false profileCredentialsName: title: Profile Credentials Name description: If using a profile credentials provider this parameter sets the profile name. type: string sessionToken: title: Session Token description: Amazon AWS Session Token used when the user needs to assume a IAM role. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:dns" - "camel:kamelet" - "camel:aws2-translate" template: from: uri: "kamelet:source" steps: - to: uri: "aws2-translate://translate" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{region}}" sourceLanguage: "{{sourceLanguage}}" targetLanguage: "{{targetLanguage}}" useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}" useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}" useSessionCredentials: "{{useSessionCredentials}}" profileCredentialsName: "{{?profileCredentialsName}}" sessionToken: "{{?sessionToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-cosmosdb-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure CosmosDB" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure CosmosDB Sink" description: Send Data to an Azure CosmosDB instance required: - databaseName - containerName - databaseEndpoint type: object properties: databaseName: title: Database Name description: The Azure Cosmos database name. type: string containerName: title: Container Name description: The Azure Cosmos container name. type: string accountKey: title: Account Key description: The Azure Cosmos account Key. type: string format: password x-descriptors: - urn:camel:group:credentials databaseEndpoint: title: Database Endpoint description: Sets the Azure Cosmos database endpoint the component will connect to. type: string itemPartitionKey: title: Item Partition Key description: Represents a partition key value in the Azure Cosmos DB database service. A partition key identifies the partition where the item is stored in. type: string credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" types: in: mediaType: application/json dependencies: - "camel:azure-cosmosdb" - "camel:kamelet" - "camel:jackson" - "camel:core" template: from: uri: "kamelet:source" steps: - choice: precondition: true when: - simple: '${propertiesExist:!itemPartitionKey}' steps: - choice: when: - simple: "${header[itemPartitionKey]}" steps: - setHeader: name: CamelAzureCosmosDbItemPartitionKey simple: "${header[itemPartitionKey]}" - simple: "${header[ce-itemPartitionKey]}" steps: - setHeader: name: CamelAzureCosmosDbItemPartitionKey simple: "${header[ce-itemPartitionKey]}" - unmarshal: json: library: Jackson - to: uri: "azure-cosmosdb:{{databaseName}}/{{containerName}}" parameters: accountKey: "{{?accountKey}}" databaseEndpoint: "{{databaseEndpoint}}" itemPartitionKey: "{{?itemPartitionKey}}" operation: createItem credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-cosmosdb-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure CosmosDB" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure CosmosDB Source" description: Consume Changes from a CosmosDB instance. required: - databaseName - containerName - databaseEndpoint type: object properties: databaseName: title: Database Name description: The Azure Cosmos database name. type: string containerName: title: Container Name description: The Azure Cosmos container name. type: string accountKey: title: Account Key description: The Azure Cosmos account Key. type: string format: password x-descriptors: - urn:camel:group:credentials leaseDatabaseName: title: Lease Database Name description: Sets the lease container which acts as a state storage and coordinates processing the change feed across multiple workers. type: string leaseContainerName: title: Lease Container Name description: Sets the lease database where the `leaseContainerName` is stored. type: string createLeaseDatabaseIfNotExists: title: Autocreate Lease Database description: Sets if the component should create Cosmos lease database for the consumer automatically in case it doesn’t exist in Cosmos account. type: boolean default: false createLeaseContainerIfNotExists: title: Autocreate Lease Container description: Sets if the component should create Cosmos lease container for the consumer automatically in case it doesn’t exist in Cosmos database. type: boolean default: false databaseEndpoint: title: Database Endpoint description: Sets the Azure Cosmos database endpoint the component will connect to. type: string credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dataTypes: out: default: json headers: types: json: format: "application-json" description: Json mapping of Change Feed records mediaType: application/json cloudevents: format: "azure-cosmosdb:application-cloudevents" description: Data type transformer converts Azure CosmosDB Change Feed processor response to CloudEvent v1_0 data format. The data type sets Camel specific CloudEvent headers with values extracted from Azure CosmosDB Change Feed processor response. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.azure.cosmosdb.changes" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. type: string default: "org.apache.camel.event.azure.cosmosdb.changefeed" CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. type: string default: "org.apache.camel.event.azure.cosmosdb.changefeed" CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-cosmosdb" - "camel:kamelet" - "camel:jackson" template: from: uri: "azure-cosmosdb:{{databaseName}}/{{containerName}}" parameters: leaseDatabaseName: "{{?leaseDatabaseName}}" leaseContainerName: "{{?leaseContainerName}}" accountKey: "{{?accountKey}}" createLeaseDatabaseIfNotExists: "{{createLeaseDatabaseIfNotExists}}" createLeaseContainerIfNotExists: "{{createLeaseContainerIfNotExists}}" databaseEndpoint: "{{databaseEndpoint}}" credentialType: "{{credentialType}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-eventhubs-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Eventhubs" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Eventhubs Sink" description: Send events to Azure Event Hubs. required: - namespaceName - eventhubName type: object properties: namespaceName: title: Eventhubs Namespace description: The Event Hubs namespace. type: string eventhubName: title: Eventhubs Name description: The Event Hub name. type: string sharedAccessName: title: Share Access Name description: The Event Hubs SAS key name. type: string x-descriptors: - urn:camel:group:credentials sharedAccessKey: title: Share Access Key description: The key for the Event Hubs SAS key name. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["CONNECTION_STRING", "AZURE_IDENTITY"] default: "CONNECTION_STRING" dependencies: - "camel:core" - "camel:azure-eventhubs" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[partition-id]}" steps: - setHeader: name: CamelAzureEventHubsPartitionId simple: "${header[partition-id]}" - simple: "${header[ce-partition-id]}" steps: - setHeader: name: CamelAzureEventHubsPartitionId simple: "${header[ce-partition-id]}" - to: uri: "azure-eventhubs://{{namespaceName}}/{{eventhubName}}" parameters: sharedAccessName: "{{?sharedAccessName}}" sharedAccessKey: "{{?sharedAccessKey}}" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-eventhubs-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Eventhubs" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Eventhubs Source" description: Receive events from Azure Event Hubs. required: - namespaceName - eventhubName - blobAccountName - blobAccessKey - blobContainerName type: object properties: namespaceName: title: Eventhubs Namespace description: The Event Hubs namespace. type: string eventhubName: title: Eventhubs Name description: The Event Hub name. type: string sharedAccessName: title: Share Access Name description: The Event Hubs SAS key name. type: string x-descriptors: - urn:camel:group:credentials sharedAccessKey: title: Share Access Key description: The key for the Event Hubs SAS key name. type: string format: password x-descriptors: - urn:camel:group:credentials blobAccountName: title: Azure Storage Blob Account Name description: The name of the Storage Blob account. type: string blobContainerName: title: Azure Storage Blob Container Name description: The name of the Storage Blob container. type: string blobAccessKey: title: Azure Storage Blob Access Key description: The key for the Azure Storage Blob service that is associated with the Storage Blob account name. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["CONNECTION_STRING", "AZURE_IDENTITY"] default: "CONNECTION_STRING" dataTypes: out: default: binary headers: CamelAzureEventHubsPartitionId: title: Azure Storage Event Hubs Partiton Id description: It sets the partition id of the Event Hub. type: string CamelAzureEventHubsOffset : title: Azure Storage Event Hubs Event Offset description: It sets the offset of the event when it was received from the associated Event Hub partition. This is only present on a received EventData. type: string CamelAzureEventHubsEnqueuedTime: title: Azure Event Hubs Event Enqueued Time description: It sets the instant, in UTC, of when the event was enqueued in the Event Hub partition. This is only present on a received EventData. type: java.time.Instant CamelAzureEventHubsSequenceNumber: title: Azure Event Hubs Event Sequence Number description: It sets the sequence number assigned to the event when it was enqueued in the associated Event Hub partition. This is unique for every message received in the Event Hub partition. This is only present on a received EventData. type: long CamelAzureEventHubsMetadata: title: Azure Event Hubs Event Metadata description: The set of free-form event properties which may be used for passing metadata associated with the event with the event body during Event Hubs operations. type: object CamelMessageTimestamp: title: Azure Event Hubs Message Timestamp description: The timestamp of the message. type: long CamelAzureEventHubsCheckpointUpdatedBy: title: Azure Event Hubs Checkpoint Updated By description: It sets the reason for the checkpoint to have been updated. This is only present on a received EventData. type: string types: binary: format: "application-octet-stream" description: Default binary representation of the Azure Event Hubs Event retrieved. mediaType: application/octet-stream cloudevents: format: "azure-eventhubs:application-cloudevents" description: Data type transformer converts Azure Eventhubs consumer response to CloudEvent v1_0 data format. The data type sets headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.azure.eventhubs.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Partition Id with prefix "azure.eventhubs.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The Azure Event Hubs Event Sequence Number. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-eventhubs" - "camel:kamelet" - "camel:jackson" template: from: uri: 'azure-eventhubs://{{namespaceName}}/{{eventhubName}}' parameters: sharedAccessName: "{{?sharedAccessName}}" sharedAccessKey: "{{?sharedAccessKey}}" blobAccountName: "{{blobAccountName}}" blobAccessKey: "{{blobAccessKey}}" blobContainerName: "{{blobContainerName}}" credentialType: "{{credentialType}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-functions-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Functions" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Function Sink" description: Forward data to an Azure Function. required: - url type: object properties: url: title: URL description: The Azure Functions URL you want to send the data to. type: string example: "https://azure-function-demo-12234.azurewebsites.net/api/httpexample" pattern: "^(https)://.*" method: title: Method description: The HTTP method to use. type: string default: POST enum: ["GET", "POST", "PUT", "DELETE", "HEAD", "OPTIONS", "TRACE", "PATCH"] key: title: Key description: A function-specific API key is required, if the authLevel of the function is FUNCTION or master key if the authLevel is ADMIN. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:vertx-http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - removeHeader: name: CamelHttpUri - setHeader: name: CamelHttpMethod constant: "{{method}}" - to: "vertx-http:{{url}}?code={{?key}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-servicebus-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Servicebus" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Servicebus Sink" description: Send Messages to Azure Servicebus. required: - topicOrQueueName - connectionString type: object properties: topicOrQueueName: title: Topic Or Queue Name description: Topic Or Queue Name for the Azure Servicebus instance type: string connectionString: title: Connection String description: Connection String for Azure Servicebus instance type: string format: password x-descriptors: - urn:camel:group:credentials serviceBusType: title: Servicebus Type description: The service bus type of connection to execute. Queue is for typical queue option and topic for subscription based model. type: string default: queue enum: ["queue", "topic"] credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["AZURE_IDENTITY", "CONNECTION_STRING", "TOKEN_CREDENTIAL"] default: "CONNECTION_STRING" types: in: mediaType: application/octet-stream dependencies: - "camel:azure-servicebus" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - to: uri: "azure-servicebus:{{topicOrQueueName}}" parameters: connectionString: "{{connectionString}}" serviceBusType: "{{serviceBusType}}" producerOperation: "sendMessages" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-servicebus-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Servicebus" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Servicebus Source" description: Consume Messages from Azure Servicebus. required: - topicOrQueueName - connectionString type: object properties: topicOrQueueName: title: Topic Or Queue Name description: Topic Or Queue Name for the Azure Servicebus instance type: string connectionString: title: Connection String description: Connection String for Azure Servicebus instance type: string format: password x-descriptors: - urn:camel:group:credentials serviceBusReceiveMode: title: Servicebus Receive Mode description: Sets the receive mode for the receiver type: string default: PEEK_LOCK enum: ["PEEK_LOCK", "RECEIVE_AND_DELETE"] subscriptionName: title: Subscription Name description: Sets the name of the subscription in the topic to listen to. This parameter is mandatory in case of topic. type: string serviceBusType: title: Servicebus Type description: The service bus type of connection to execute. Queue is for typical queue option and topic for subscription based model. type: string default: queue enum: ["queue", "topic"] credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["AZURE_IDENTITY", "CONNECTION_STRING", "TOKEN_CREDENTIAL"] default: "CONNECTION_STRING" types: out: mediaType: application/octet-stream dependencies: - "camel:azure-servicebus" - "camel:kamelet" - "camel:core" template: from: uri: "azure-servicebus:{{topicOrQueueName}}" parameters: connectionString: "{{connectionString}}" serviceBusReceiveMode: "{{serviceBusReceiveMode}}" subscriptionName: "{{?subscriptionName}}" serviceBusType: "{{serviceBusType}}" credentialType: "{{credentialType}}" steps: - setBody: simple: "${body.toBytes()}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-blob-append-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Storage Blob Append Sink" description: Upload data in append mode to Azure Storage Blob. required: - accountName - containerName type: object properties: accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials containerName: title: Container Name description: The Azure Storage Blob container name. type: string accessKey: title: Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dependencies: - "camel:core" - "camel:azure-storage-blob" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${exchangeId}" - to: uri: "azure-storage-blob://{{accountName}}/{{containerName}}" parameters: accessKey: "{{?accessKey}}" operation: "commitAppendBlob" blobType: "appendBlob" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-blob-changefeed-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob Changefeed" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage Blob Changefeed Source" description: Consume events from an Azure Storage Blob change feed. required: - period - accountName - accessKey type: object properties: period: title: Period between Polls description: The interval (in milliseconds) between fetches to the Azure Storage change feed. type: integer default: 10000 accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials accessKey: title: Access Key description: The Azure Storage Blob access Key. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:azure-storage-blob" - "camel:kamelet" - "camel:core" - "camel:jackson" - "camel:jsonpath" - "camel:timer" template: from: uri: "timer:azure-storage-blob-stream" parameters: period: "{{period}}" steps: - to: uri: "azure-storage-blob:{{accountName}}" parameters: operation: "getChangeFeed" accessKey: "{{accessKey}}" credentialType: "SHARED_ACCOUNT_KEY" - split: expression: simple: "${body}" - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "azure-storage-blob-changefeed-topic" jsonpath: suppressExceptions: true expression: $.topic - setHeader: name: "azure-storage-blob-changefeed-subject" jsonpath: suppressExceptions: true expression: $.subject - setHeader: name: "azure-storage-blob-changefeed-eventType" jsonpath: suppressExceptions: true expression: $.eventType - setHeader: name: "azure-storage-blob-changefeed-eventTime" jsonpath: suppressExceptions: true expression: $.eventTime - setHeader: name: "azure-storage-blob-changefeed-id" jsonpath: suppressExceptions: true expression: $.id - setHeader: name: "azure-storage-blob-changefeed-dataVersion" jsonpath: suppressExceptions: true expression: $.dataVersion - setHeader: name: "azure-storage-blob-changefeed-metadataVersion" jsonpath: suppressExceptions: true expression: $.metadataVersion - setBody: jsonpath: expression: $.data - marshal: json: library: Jackson module-class-names: com.fasterxml.jackson.datatype.jsr310.JavaTimeModule - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-blob-event-based-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob Event Based" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage Blob Event-based Source" description: Receive data from Azure Service Bus subscribed to Azure Eventgrid reporting events related to a Azure Storage Blob account. required: - topicOrQueueName - connectionString - accountName - containerName - accessKey type: object properties: topicOrQueueName: title: Topic Or Queue Name description: Topic Or Queue Name for the Azure Servicebus instance type: string connectionString: title: Connection String description: Connection String for Azure Servicebus instance type: string format: password x-descriptors: - urn:camel:group:credentials serviceBusReceiveMode: title: Servicebus Receive Mode description: Sets the receive mode for the receiver. type: string default: RECEIVE_AND_DELETE enum: ["RECEIVE_AND_DELETE", "PEEK_LOCK"] subscriptionName: title: Subscription Name description: Sets the name of the subscription in the topic to listen to. This parameter is mandatory in case of topic. type: string accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials containerName: title: Container Name description: The Azure Storage Blob container name. type: string accessKey: title: Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string default: SHARED_ACCOUNT_KEY enum: ["SHARED_ACCOUNT_KEY", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY"] getBlob: title: Get Object in Container description: >- If `getBlob` is enabled, then the file created in the container is retrieved and returned as body. If not only the event is returned as body. type: boolean default: false types: out: mediaType: application/octet-stream dependencies: - "camel:azure-servicebus" - "camel:azure-storage-blob" - "camel:kamelet" - "camel:core" - 'camel:jsonpath' - 'camel:jackson' template: from: uri: "azure-servicebus:{{topicOrQueueName}}" parameters: connectionString: "{{connectionString}}" serviceBusReceiveMode: "{{serviceBusReceiveMode}}" subscriptionName: "{{?subscriptionName}}" steps: - choice: precondition: true when: - simple: '${properties:getBlob:true}' steps: - setBody: simple: ${body.toString()} - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: azure-storage-blob-event-type jsonpath: $.eventType - setProperty: name: azure-storage-blob-subject jsonpath: $.subject - setProperty: name: azure-storage-blob-blob-name simple: '${exchangeProperty.azure-storage-blob-subject.substring(${exchangeProperty.azure-storage-blob-subject.lastIndexOf("/")}++)}' - log: "${exchangeProperty.azure-storage-blob-event-type} - ${exchangeProperty.azure-storage-blob-subject} - ${exchangeProperty.azure-storage-blob-blob-name}" - choice: when: - simple: '${exchangeProperty.azure-storage-blob-event-type} == "Microsoft.Storage.BlobCreated" && ${exchangeProperty.azure-storage-blob-subject} contains "{{containerName}}"' steps: - toD: >- azure-storage-blob:{{accountName}}/{{containerName}}?accessKey=RAW({{accessKey}})&operation=getBlob&blobName=${exchangeProperty.azure-storage-blob-blob-name}&credentialType={{credentialType}} - to: 'kamelet:sink' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-blob-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Storage Blob Sink" description: Upload data to Azure Storage Blob. required: - accountName - containerName type: object properties: accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials containerName: title: Container Name description: The Azure Storage Blob container name. type: string accessKey: title: Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dependencies: - "camel:core" - "camel:azure-storage-blob" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelAzureStorageBlobBlobName simple: "${exchangeId}" - to: uri: "azure-storage-blob://{{accountName}}/{{containerName}}" parameters: accessKey: "{{?accessKey}}" operation: "uploadBlockBlob" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-blob-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage Blob Source" description: Consume files from Azure Storage Blob. required: - accountName - containerName type: object properties: accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials containerName: title: Container Name description: The Azure Storage Blob container name. type: string accessKey: title: Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll of the selected blob. type: integer default: 500 deleteAfterRead: title: Auto-delete Blob description: Specifies to delete blobs after consuming them type: boolean default: false credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dataTypes: out: default: binary headers: CamelAzureStorageBlobBlobName: title: Azure Storage Blob Name description: The name of the blob retrieved type: string CamelAzureStorageBlobBlobType: title: The Azure Storage Blob Type description: The Blob type, one of blockblob, appendblob or pageblob type: string CamelAzureStorageBlobContentType: title: Content Type description: The content type of the retrieved object. default: application/octet-stream type: string CamelAzureStorageBlobETag: title: ETag Value description: The E tag of the blob type: string CamelAzureStorageBlobCreationTime: title: Creation time description: The Creation time of the blob type: string CamelAzureStorageBlobLastModified: title: Last modification time description: The Last modification time of the blob type: string CamelAzureStorageBlobLeaseStatus: title: Lease status description: Status of the lease on the blob, one of locked or unlocked type: string CamelAzureStorageBlobMetadata: title: Blob Metadata description: Additional Metadata of the blob of type Map type: object types: binary: format: "application-octet-stream" description: Default binary representation of the Blob object retrieved from the container. mediaType: application/octet-stream cloudevents: format: "azure-storage-blob:application-cloudevents" description: Output data type represents Azure Storage Blob get blob response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Azure container and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.azure.storage.blob.getBlob" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the E Tag name of the blob with prefix "azure.storage.blob.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Azure Storage Blob name. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-storage-blob" - "camel:kamelet" - "camel:core" - "camel:jsonpath" - "camel:timer" template: from: uri: "azure-storage-blob:{{accountName}}/{{containerName}}" parameters: accessKey: "{{?accessKey}}" credentialType: "{{credentialType}}" delay: "{{delay}}" steps: - to: "kamelet:sink" - choice: precondition: true when: - simple: '${properties:deleteAfterRead:true}' steps: - to: uri: "azure-storage-blob:{{accountName}}/{{containerName}}" parameters: operation: "deleteBlob" accessKey: "{{?accessKey}}" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-datalake-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob Data Lake" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Storage Blob Data Lake Sink" description: Send data to Azure Storage Blob Data Lake. required: - accountName - clientId - clientSecret - tenantId - fileSystemName type: object properties: accountName: title: Account Name description: The Azure Storage Blob Data lake account name. type: string x-descriptors: - urn:camel:group:credentials clientId: title: Client Id description: The Azure Storage Blob Data lake client Id. type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: The Azure Storage Blob Data lake client secret. type: string format: password x-descriptors: - urn:camel:group:credentials tenantId: title: Tenant Id description: The Azure Storage Blob Data lake tenant id. type: string format: password x-descriptors: - urn:camel:group:credentials fileSystemName: title: File System Name description: The Azure Storage Blob Data lake File system name. type: string x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["CLIENT_SECRET", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY", "AZURE_SAS", "SERVICE_CLIENT_INSTANCE"] default: "CLIENT_SECRET" dependencies: - "camel:azure-storage-datalake" - "camel:kamelet" - "camel:core" - "camel:timer" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelAzureStorageDataLakeFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelAzureStorageDataLakeFileName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelAzureStorageDataLakeFileName simple: "${exchangeId}" - to: uri: "azure-storage-datalake:{{accountName}}/{{fileSystemName}}" parameters: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" tenantId: "{{tenantId}}" operation: "upload" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-datalake-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob Data Lake" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage Blob Data Lake Source" description: Consume files from Azure Storage Blob Data Lake. required: - accountName - clientId - clientSecret - tenantId - fileSystemName type: object properties: accountName: title: Account Name description: The Azure Storage Blob Data lake account name. type: string x-descriptors: - urn:camel:group:credentials clientId: title: Client Id description: The Azure Storage Blob Data lake client Id. type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: The Azure Storage Blob Data lake client secret. type: string format: password x-descriptors: - urn:camel:group:credentials tenantId: title: Tenant Id description: The Azure Storage Blob Data lake tenant id. type: string format: password x-descriptors: - urn:camel:group:credentials fileSystemName: title: File System Name description: The Azure Storage Blob Data lake File system name. type: string x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll of the selected blob. type: integer default: 500 credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["CLIENT_SECRET", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY", "AZURE_SAS", "SERVICE_CLIENT_INSTANCE"] default: "CLIENT_SECRET" dataTypes: out: default: binary headers: CamelAzureStorageDataLakeFileName: title: Azure Storage Datalake File Name description: The name of the file retrieved type: string CamelAzureStorageDataLakeRawHttpHeaders: title: Azure Storage Data Lake Raw Http Headers description: Non parsed http headers that can be used by the user. type: object CamelAzureStorageDataLakeAccessTier: title: Azure Storage Data Lake File Access Tier description: Access tier of file. type: object CamelAzureStorageDataLakeAccessTierChangeTime: title: Azure Storage Data Lake Access Tier Change Time. description: Datetime when the access tier of the blob last changed. type: object CamelAzureStorageDataLakeArchiveStatus: title: Azure Storage Data Lake Archive Status description: Archive status of file type: object CamelAzureStorageDataLakeCacheControl: title: Azure Storage Data Lake File Cache Control description: Cache control specified for the file. type: string CamelAzureStorageDataLakeContentDisposition: title: Azure Storage Data Lake File Content Disposition description: Content disposition specified for the file. type: string CamelAzureStorageDataLakeContentEncoding: title: Azure Storage Data Lake File Content Encoding description: Content encoding specified for the file. type: string CamelAzureStorageDataLakeContentLanguage: title: Azure Storage Data Lake File Content Language description: Content language specified for the file. type: string CamelAzureStorageDataLakeContentType: title: Azure Storage Data Lake File Content Type description: Content Type specified for the file. type: string CamelAzureStorageDataLakeCopyCompletionTime: title: Azure Storage Data Lake File Copy Completion time description: Conclusion time of the last attempted Copy Blob operation where this file was the destination file. type: object CamelAzureStorageDataLakeCopyId: title: Azure Storage Data Lake File Copy Id description: String identifier for this copy operation. type: string amelAzureStorageDataLakeCopyProgress: title: Azure Storage Data Lake File Copy Progress description: Contains the number of bytes copied and the total bytes in the source in the last attempted Copy Blob operation where this file was the destination file. type: string CamelAzureStorageDataLakeCopySource: title: Azure Storage Data Lake File Copy Source description: URL up to 2 KB in length that specifies the source file or file used in the last attempted Copy Blob operation where this file was the destination file. type: string CamelAzureStorageDataLakeCopyStatus: title: Azure Storage Data Lake File Copy Status description: Status of the last copy operation performed on the file. type: object CamelAzureStorageDataLakeCopyStatusDescription: title: Azure Storage Data Lake File Copy Status Description description: The description of the copy’s status. type: string CamelAzureStorageDataLakeCreationTime: title: Azure Storage Data Lake File Creation Time. description: Creation time of the file. type: object CamelAzureStorageDataLakeEncryptionKeySha256: title: Azure Storage Data Lake File SHA-256 Hash description: The SHA-256 hash of the encryption key used to encrypt the file. type: string CamelAzureStorageDataLakeETag: title: Azure Storage Data Lake File E Tag description: The E Tag of the file. type: string CamelAzureStorageDataLakeFileSize: title: Azure Storage Data Lake File Size description: The File Size type: long CamelAzureStorageDataLakeLastModified: title: Azure Storage Data Lake File Last Modified Date description: Datetime when the file was last modified. type: object CamelAzureStorageDataLakeLeaseDuration: title: Azure Storage Data Lake File Lease Duration description: Type of lease on the file. type: object CamelAzureStorageDataLakeLeaseState: title: Azure Storage Data Lake File Lease State description: State of the lease on the file. type: object CamelAzureStorageDataLakeLeaseStatus: title: Azure Storage Data Lake File Lease Status description: Status of the lease on the file. type: object CamelAzureStorageDataLakeServerEncrypted: title: Azure Storage Data Lake File Content Encrypted description: Flag indicating if the file’s content is encrypted on the server. type: boolean CamelAzureStorageDataLakeDownloadLink: title: Azure Storage Data Lake File Download Link description: The link that can be used to download the file from data lake. type: string types: binary: format: "application-octet-stream" description: Default binary representation of the object retrieved from the Azure Data Lake. mediaType: application/octet-stream cloudevents: format: "azure-storage-datalake:application-cloudevents" description: Data type transformer converts Azure Data Lake consumer response to CloudEvent v1_0 data format. The data type sets Camel specific CloudEvent headers with values extracted from Azure Data Lake consumer response. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.azure.storage.datalake.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Archive Status of the file with prefix "azure.storage.datalake.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Azure Storage Datalake E Tag of file. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-storage-datalake" - "camel:kamelet" - "camel:core" - "camel:timer" template: from: uri: "azure-storage-datalake:{{accountName}}/{{fileSystemName}}" parameters: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" tenantId: "{{tenantId}}" delay: "{{delay}}" credentialType: "{{credentialType}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-files-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Storage Files Sink" description: Upload data to Azure Storage Files Share. required: - accountName - shareName type: object properties: accountName: title: Account Name description: The Azure Storage Blob account name. type: string x-descriptors: - urn:camel:group:credentials shareName: title: Share Name description: The Azure Storage File Share share name. type: string sharedKey: title: Shared Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY", "SHARED_KEY_CREDENTIAL", "AZURE_SAS"] default: "SHARED_ACCOUNT_KEY" directoryName: title: Directory Name description: The directory from where the producer will upload the file. type: string default: "." dependencies: - "camel:core" - "camel:azure-storage-blob" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelFileName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelFileName simple: "${exchangeId}" - to: uri: "azure-files://{{accountName}}/{{shareName}}/{{directoryName}}" parameters: sharedKey: "{{?sharedKey}}" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-files-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Blob" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage File Source" description: Consume files from Azure Storage File Shares. required: - accountName - shareName type: object properties: accountName: title: Account Name description: The Azure Storage File Share account name. type: string x-descriptors: - urn:camel:group:credentials shareName: title: Share Name description: The Azure Storage File Share share name. type: string sharedKey: title: Shared Access Key description: The Azure Storage Blob access key. type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll of the selected blob. type: integer default: 500 deleteAfterRead: title: Auto-delete Blob description: Specifies to delete blobs after consuming them type: boolean default: false credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY", "SHARED_KEY_CREDENTIAL", "AZURE_SAS"] default: "SHARED_ACCOUNT_KEY" directoryName: title: Directory Name description: The directory from where the consumer will start reading files. type: string default: "." recursive: title: Recursive Mode description: If a directory, the consumer will look for files in all the sub-directories as well. type: boolean default: false dataTypes: out: default: binary headers: CamelFileLength: title: Azure Storage Files File Length description: A long value containing the file size type: long CamelFileLastModified: title: Azure Storage Files File Last Modified Date description: A Long value containing the last modified timestamp of the file. type: long CamelFileNameOnly: title: Azure Storage Files File Name Only description: Only the file name (the name with no leading paths). type: string CamelFileName: title: Azure Storage Files File Name description: Name of the consumed file as a relative file path with offset from the starting directory configured on the endpoint. type: string CamelFileNameConsumed: title: Azure Storage Files Consumed File Name description: The name of the file that has been consumed. type: string CamelFileAbsolute: title: Azure Storage Files Consumed Absolute Format description: A boolean option specifying whether the consumed file denotes an absolute path or not. type: boolean CamelFileAbsolutePath: title: Azure Storage Files Consumed Absolute Path description: The absolute path to the file. For relative files this path holds the relative path instead. type: string CamelFileExtendedAttributes: title: Azure Storage Files Extended Attributes description: Additional Metadata of the file of type Map type: object CamelFileContentType: title: Content Type description: The content type of the retrieved object. default: application/octet-stream type: string CamelFilePath: title: Azure Storage Files File Path description: The file path. For relative files this is the starting directory the relative filename. For absolute files this is the absolute path. type: string CamelFileRelativePath: title: Azure Storage Files File Relative Path description: The relative path. type: string CamelFileParent: title: Azure Storage Files File Relative Path description: The parent path. type: string types: binary: format: "application-octet-stream" description: Default binary representation of the File retrieved from Azure Storage Files. mediaType: application/octet-stream cloudevents: format: "azure-files:application-cloudevents" description: Data type transformer converts Azure Storage Files poll response to CloudEvent v1_0 data format. The data type sets Camel specific CloudEvent headers with values extracted from Azure Storage Files poll response. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.azure.storage.files.poll" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Host name of the share with prefix "azure.storage.files.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Azure Storage Files file name. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-files" - "camel:kamelet" - "camel:core" - "camel:timer" template: from: uri: "azure-files:{{accountName}}/{{shareName}}/{{directoryName}}" parameters: sharedKey: "{{?sharedKey}}" credentialType: "{{credentialType}}" delay: "{{delay}}" delete: "{{deleteAfterRead}}" recursive: "{{recursive}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-queue-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Queue" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Storage Queue Sink" description: Send events to Azure Storage queues. required: - accountName - queueName - accessKey type: object properties: accountName: title: Account Name description: The Azure Storage Queue account name. type: string x-descriptors: - urn:camel:group:credentials queueName: title: Queue Name description: The Azure Storage Queue container name. type: string accessKey: title: Access Key description: The Azure Storage Queue access key. type: string format: password x-descriptors: - urn:camel:group:credentials credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dependencies: - "camel:core" - "camel:azure-storage-queue" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[expiration]}" steps: - setHeader: name: CamelAzureStorageQueueTimeToLive simple: "${header[expiration]}" - simple: "${header[ce-expiration]}" steps: - setHeader: name: CamelAzureStorageQueueTimeToLive simple: "${header[ce-expiration]}" - to: uri: "azure-storage-queue://{{accountName}}/{{queueName}}" parameters: accessKey: "{{accessKey}}" credentialType: "{{credentialType}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: azure-storage-queue-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Azure Storage Queue" camel.apache.org/kamelet.namespace: "Azure" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Storage Queue Source" description: Receive events from Azure Storage queues. required: - accountName - queueName - accessKey type: object properties: accountName: title: Account Name description: The Azure Storage Queue account name. type: string x-descriptors: - urn:camel:group:credentials queueName: title: Queue Name description: The Azure Storage Queue container name. type: string accessKey: title: Access Key description: The Azure Storage Queue access key. type: string format: password x-descriptors: - urn:camel:group:credentials maxMessages: title: Maximum Messages description: The maximum number of messages to get. You can specify a value between 1 and 32. The default is 1 (one message). If there are fewer than the maximum number of messages in the queue, then all the messages are returned. type: integer default: 1 credentialType: title: Credential Type description: Determines the credential strategy to adopt. type: string enum: ["SHARED_ACCOUNT_KEY", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY"] default: "SHARED_ACCOUNT_KEY" dataTypes: out: default: text headers: CamelAzureStorageQueueMessageId: title: Azure Storage Queue Message Id description: The id of the message. type: string CamelAzureStorageQueueInsertionTime: title: Azure Storage Queue Message Insertion Time description: The time the Message was inserted into the Queue. type: OffsetDateTime CamelAzureStorageQueueExpirationTime: title: Azure Storage Queue Message Expiration Time description: The time that the Message will expire and be automatically deleted. type: OffsetDateTime CamelAzureStorageQueuePopReceipt: title: Pop Receipt description: Unique identifier that must match for the message to be deleted or updated. If deletion fails using this pop receipt then the message has been dequeued by another client. type: string CamelAzureStorageQueueTimeNextVisible: title: Azure Storage Queue Message Time Next Visible description: The time that the message will again become visible in the Queue. type: OffsetDateTime CamelAzureStorageQueueDequeueCount: title: Dequeue Count description: The number of times the message has been dequeued. type: long types: text: format: "text-plain" description: Default text representation of the Message dequeued from the queue. mediaType: text/plain cloudevents: format: "azure-storage-queue:application-cloudevents" description: Output data type represents Azure Storage Queue receive messages operation as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id. type: string CamelCloudEventType: title: CloudEvent Type description: The event type. default: "org.apache.camel.event.azure.storage.queue.receiveMessages" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Message Id of the message received with prefix "azure.storage.queue.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Pop receipt of the message dequeued. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:azure-storage-queue" - "camel:kamelet" - "camel:core" template: from: uri: "azure-storage-queue://{{accountName}}/{{queueName}}" parameters: accessKey: "{{accessKey}}" maxMessages: "{{maxMessages}}" credentialType: "{{credentialType}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: bitcoin-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Bitcoin" camel.apache.org/kamelet.namespace: "Bitcoin" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Bitcoin Source" description: Provides a feed of the value of the Bitcoin compared to USDT using the Binance service. type: object properties: period: title: Period between Updates description: The interval between updates in milliseconds. type: integer default: 10000 types: out: mediaType: application/json schema: type: object properties: currencyPair: type: string open: type: number last: type: number bid: type: number ask: type: number high: type: number low: type: number vwap: type: number volume: type: number quoteVolume: type: number bidSize: type: number askSize: type: number dependencies: - "camel:xchange" - "camel:kamelet" - "camel:jackson" - "camel:timer" template: from: uri: "timer:update" parameters: period: "{{period}}" steps: - to: "xchange:binance?service=marketdata&method=ticker¤cyPair=BTC/USDT" - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: caffeine-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Caffeine" camel.apache.org/kamelet.namespace: "Cache" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Caffeine Action" description: Perform operations on a caffeine cache required: - cacheName type: object properties: cacheName: title: Cache name description: The name of the cache we want to use type: string default: caffeine-cache dependencies: - "camel:core" - "camel:caffeine" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[caffeine-key]}" steps: - setHeader: name: CamelCaffeineKey simple: "${header[caffeine-key]}" - simple: "${header[ce-caffeinekey]}" steps: - setHeader: name: CamelCaffeineKey simple: "${header[ce-caffeinekey]}" otherwise: steps: - setHeader: name: CamelCaffeineKey simple: "${body}" - choice: when: - simple: "${header[caffeine-operation]}" steps: - setHeader: name: CamelCaffeineAction simple: "${header[caffeine-operation]}" - simple: "${header[ce-caffeineoperation]}" steps: - setHeader: name: CamelCaffeineAction simple: "${header[ce-caffeineoperation]}" otherwise: steps: - setHeader: name: CamelCaffeineAction constant: "GET" - to: uri: "caffeine-cache:{{cacheName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: cassandra-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Cassandra" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Cassandra Sink" description: Send data to an Apache Cassandra cluster. required: - connectionHost - connectionPort - keyspace - query type: object properties: connectionHost: title: Connection Host description: The hostname(s) for the Cassandra server(s). Use a comma to separate multiple hostnames. type: string example: localhost connectionPort: title: Connection Port description: The port number(s) of the cassandra server(s). Use a comma to separate multiple port numbers. type: string example: 9042 keyspace: title: Keyspace description: The keyspace to use. type: string example: customers username: title: Username description: The username for accessing a secured Cassandra cluster. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password for accessing a secured Cassandra cluster. type: string format: password x-descriptors: - urn:camel:group:credentials consistencyLevel: title: Consistency Level description: The consistency level to use. type: string default: ANY enum: ["ANY", "ONE", "TWO", "THREE", "QUORUM", "ALL", "LOCAL_QUORUM", "EACH_QUORUM", "LOCAL_ONE"] prepareStatements: title: Prepare Statements description: If true, specifies to use PreparedStatements as the query. If false, specifies to use regular Statements as the query. type: boolean default: true query: title: Query description: The query to execute against the Cassandra cluster table. type: string extraTypeCodecs: title: Extra Type Codecs description: To use a specific comma separated list of Extra Type codecs. type: string enum: ["BLOB_TO_ARRAY", "BOOLEAN_LIST_TO_ARRAY", "BYTE_LIST_TO_ARRAY", "SHORT_LIST_TO_ARRAY", "INT_LIST_TO_ARRAY", "LONG_LIST_TO_ARRAY", "FLOAT_LIST_TO_ARRAY", "DOUBLE_LIST_TO_ARRAY", "TIMESTAMP_UTC", "TIMESTAMP_MILLIS_SYSTEM", "TIMESTAMP_MILLIS_UTC", "ZONED_TIMESTAMP_SYSTEM", "ZONED_TIMESTAMP_UTC", "ZONED_TIMESTAMP_PERSISTED", "LOCAL_TIMESTAMP_SYSTEM", "LOCAL_TIMESTAMP_UTC"] jsonPayload: title: JSON Payload description: If we want to transform the payload in json or not type: boolean default: true types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:cassandraql" - "camel:core" template: beans: - name: local-sql-cassandraql-sink type: "#class:org.apache.camel.component.cassandra.CassandraComponent" properties: autowiredEnabled: "false" from: uri: "kamelet:source" steps: - choice: precondition: true when: - simple: '${properties:jsonPayload:true}' steps: - unmarshal: json: library: Jackson useList: true - to: uri: "{{local-sql-cassandraql-sink}}://{{connectionHost}}:{{connectionPort}}/{{keyspace}}" parameters: username: "{{?username}}" password: "{{?password}}" prepareStatements: "{{prepareStatements}}" consistencyLevel: "{{consistencyLevel}}" cql: "{{query}}" extraTypeCodecs: "{{?extraTypeCodecs}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: cassandra-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Cassandra" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Cassandra Source" description: Send a query to an Apache Cassandra cluster table. required: - connectionHost - connectionPort - keyspace - query type: object properties: connectionHost: title: Connection Host description: The hostname(s) for the Cassandra server(s). Use a comma to separate multiple hostnames. type: string example: localhost connectionPort: title: Connection Port description: The port number(s) of the cassandra server(s). Use a comma to separate multiple port numbers. type: string example: 9042 keyspace: title: Keyspace description: The keyspace to use. type: string example: customers username: title: Username description: The username for accessing a secured Cassandra cluster. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password for accessing a secured Cassandra cluster. type: string format: password x-descriptors: - urn:camel:group:credentials resultStrategy: title: Result Strategy description: The strategy to convert the result set of the query. type: string default: ALL enum: ["ALL", "ONE", "LIMIT_10", "LIMIT_100"] consistencyLevel: title: Consistency Level description: The consistency level to use. type: string default: QUORUM enum: ["ONE", "TWO", "THREE", "QUORUM", "ALL", "LOCAL_QUORUM", "EACH_QUORUM", "SERIAL", "LOCAL_SERIAL", "LOCAL_ONE"] query: title: Query description: The query to execute against the Cassandra cluster table. type: string extraTypeCodecs: title: Extra Type Codecs description: To use a specific comma separated list of Extra Type codecs. type: string enum: ["BLOB_TO_ARRAY", "BOOLEAN_LIST_TO_ARRAY", "BYTE_LIST_TO_ARRAY", "SHORT_LIST_TO_ARRAY", "INT_LIST_TO_ARRAY", "LONG_LIST_TO_ARRAY", "FLOAT_LIST_TO_ARRAY", "DOUBLE_LIST_TO_ARRAY", "TIMESTAMP_UTC", "TIMESTAMP_MILLIS_SYSTEM", "TIMESTAMP_MILLIS_UTC", "ZONED_TIMESTAMP_SYSTEM", "ZONED_TIMESTAMP_UTC", "ZONED_TIMESTAMP_PERSISTED", "LOCAL_TIMESTAMP_SYSTEM", "LOCAL_TIMESTAMP_UTC"] types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:cassandraql" template: beans: - name: local-sql-cassandraql-source type: "#class:org.apache.camel.component.cassandra.CassandraComponent" properties: autowiredEnabled: "false" from: uri: "{{local-sql-cassandraql-source}}://{{connectionHost}}:{{connectionPort}}/{{keyspace}}" parameters: username: "{{?username}}" password: "{{?password}}" cql: "{{query}}" consistencyLevel: "{{consistencyLevel}}" resultSetConversionStrategy: "{{resultStrategy}}" extraTypeCodecs: "{{?extraTypeCodecs}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ceph-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Ceph" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Ceph Sink" description: Upload data to an Ceph Bucket managed by a Object Storage Gateway. required: - cephUrl - accessKey - secretKey - bucketName - zoneGroup type: object properties: bucketName: title: Bucket Name description: The Ceph Bucket name. type: string accessKey: title: Access Key description: The access key. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key. type: string format: password x-descriptors: - urn:camel:group:credentials zoneGroup: title: Bucket Zone Group description: The bucket zone group. type: string autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the bucket. type: boolean default: false cephUrl: title: Ceph Url Address description: Set the Ceph Object Storage Address Url. type: string example: "http://ceph-storage-address.com" keyName: title: Key Name description: The key name for saving an element in the bucket. type: string dependencies: - "camel:core" - "camel:aws2-s3" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelAwsS3Key simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelAwsS3Key simple: "${header[ce-file]}" - simple: "'{{?keyName}}' == ''" steps: - setHeader: name: CamelAwsS3Key simple: "${exchangeId}" - to: uri: "aws2-s3:{{bucketName}}" parameters: secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{zoneGroup}}" autoCreateBucket: "{{autoCreateBucket}}" uriEndpointOverride: "{{?cephUrl}}" overrideEndpoint: "true" keyName: "{{?keyName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ceph-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Ceph" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Ceph Source" description: Receive data from an Ceph Bucket, managed by a Object Storage Gateway. required: - cephUrl - accessKey - secretKey - bucketName - zoneGroup type: object properties: bucketName: title: Bucket Name description: The Ceph Bucket name. type: string deleteAfterRead: title: Auto-delete Objects description: Specifies to delete objects after consuming them. type: boolean default: true accessKey: title: Access Key description: The access key. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key. type: string format: password x-descriptors: - urn:camel:group:credentials zoneGroup: title: Bucket Zone Group description: The bucket zone group. type: string autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the bucket. type: boolean default: false includeBody: title: Include Body description: If true, the exchange is consumed and put into the body and closed. If false, the Object stream is put raw into the body and the headers are set with the object metadata. type: boolean default: true prefix: title: Prefix description: The bucket prefix to consider while searching. type: string example: 'folder/' ignoreBody: title: Ignore Body description: If true, the Object body is ignored. Setting this to true overrides any behavior defined by the `includeBody` option. If false, the object is put in the body. type: boolean default: false cephUrl: title: Ceph Url Address description: Set the Ceph Object Storage Address Url. type: string example: "http://ceph-storage-address.com" delay: title: Delay description: The number of milliseconds before the next poll of the selected bucket. type: integer default: 500 dependencies: - "camel:aws2-s3" - "camel:kamelet" template: from: uri: "aws2-s3:{{bucketName}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" secretKey: "{{?secretKey}}" accessKey: "{{?accessKey}}" region: "{{zoneGroup}}" includeBody: "{{includeBody}}" ignoreBody: "{{ignoreBody}}" deleteAfterRead: "{{deleteAfterRead}}" prefix: "{{?prefix}}" uriEndpointOverride: "{{cephUrl}}" overrideEndpoint: "true" delay: "{{delay}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: chuck-norris-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon:  camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Chuck Norris" camel.apache.org/kamelet.namespace: "Dataset" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Chuck Norris Source" description: Gets periodically Chuck Norris jokes type: object properties: period: title: Period description: The interval (msec) to wait before getting the next joke type: integer default: 10000 types: out: mediaType: text/plain dependencies: - "camel:kamelet" - "camel:timer" - "camel:http" - "camel:jsonpath" template: from: uri: "timer:chuck" parameters: period: "{{period}}" steps: - to: "https://api.chucknorris.io/jokes/random" - removeHeaders: pattern: '*' - setBody: jsonpath: "$.value" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: chunk-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Chunk Template Action" description: Apply a Chunk Template. required: - template type: object properties: template: title: Template description: The inline template type: binary dependencies: - "camel:chunk" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "chunk:" parameters: resourceUri: "base64:{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: couchbase-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Couchbase" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Couchbase Sink" description: Send documents to Couchbase. required: - protocol - couchbaseHostname - bucket type: object properties: protocol: title: Protocol description: The protocol to use type: string couchbaseHostname: title: Hostname description: The hostname to use type: string couchbasePort: title: Port description: The port to use type: integer default: 8091 bucket: title: Bucket description: The bucket to use type: string username: title: Username description: Username to connect to Couchbase. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to Couchbase. type: string format: password x-descriptors: - urn:camel:group:credentials startingId: title: Starting Id description: The starting id type: integer default: 1 autoStartId: title: Auto Start Id description: Auto Start Id or not type: boolean default: true dependencies: - "camel:couchbase" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "couchbase:{{protocol}}://{{couchbaseHostname}}:{{couchbasePort}}" parameters: bucket: "{{bucket}}" autoStartIdForInserts: "{{autoStartId}}" startingIdForInsertsFrom: "{{startingId}}" username: "{{username}}" password: "{{password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: counter-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon:  camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Timer" camel.apache.org/kamelet.namespace: "Scheduling" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/kamelet.verified: "true" spec: definition: title: "Counter Source" description: Generates sequential number events starting from a configurable value, incrementing by a specified step. Useful for testing, scheduled tasks, or creating ordered event sequences. type: object properties: period: title: Period description: The time interval between two numbers type: integer default: 1000 start: title: Starting Number description: The starting number type: integer default: 1 numbers: title: Numbers description: How many numbers to generate type: integer dependencies: - "camel:timer" - "camel:core" - "camel:bean" - "camel:kamelet" template: beans: - name: counter type: java.util.concurrent.atomic.AtomicInteger constructors: "0": "{{start}}" from: uri: timer:counter parameters: period: "{{period}}" repeatCount: "{{?numbers}}" steps: - bean: ref: "{{counter}}" method: getAndIncrement - setHeader: name: "Content-Type" constant: "text/plain" - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: cron-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Cron" camel.apache.org/kamelet.namespace: "Scheduling" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Cron Source" description: Send events at specific time. required: - schedule - message type: object properties: schedule: title: Cron Schedule description: A cron expression that is used to trigger events generation. type: string example: "0/3 10 * * * ?" message: title: Message description: The message to generate type: string example: hello world types: out: mediaType: text/plain dependencies: - "camel:quartz" - "camel:core" - "camel:cron" - "camel:kamelet" template: from: uri: "cron:tick" parameters: schedule: "{{schedule}}" steps: - setBody: constant: "{{message}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: data-type-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Data Type Action" description: Applies a given data type with respective data transformation. required: - format type: object properties: scheme: title: Component Scheme description: The data type component scheme enables users to apply Camel component specific data type conversions. type: string format: title: Data Type Format description: Defines the data type that is applied by this action. Apache Camel and the Kamelet catalog support different data types and performs automatic message conversion according to the given type. type: string dependencies: - "camel:kamelet" - "camel:core" template: beans: - name: dataTypeProcessor type: "#class:org.apache.camel.processor.transformer.DataTypeProcessor" from: uri: "kamelet:source" steps: - choice: when: - simple: "'{{?scheme}}' != ''" steps: - setProperty: name: CamelDataType simple: "{{?scheme}}:{{format}}" otherwise: steps: - setProperty: name: CamelDataType simple: "{{format}}" - bean: ref: "{{dataTypeProcessor}}" method: process --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: delay-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Delay" camel.apache.org/kamelet.namespace: "EIP" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Delay Action" description: Delay the processing using a specific amount of time required: - milliseconds type: object properties: milliseconds: title: Milliseconds description: The number of milliseconds of delay type: integer example: 1000 dependencies: - "camel:core" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - delay: constant: "{{milliseconds}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: djl-image-to-text-action annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "AI" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Image-to-Text Action" description: Detect and classify objects in an image into texts using the SSD and ResNet models and the ImageNet dataset. type: object types: out: mediaType: application/json dependencies: - "mvn:ai.djl.pytorch:pytorch-engine:0.29.0" - "mvn:ai.djl.pytorch:pytorch-model-zoo:0.29.0" - "camel:core" - "camel:kamelet" - "camel:jackson" - "camel:djl" template: beans: - name: imageNetUtil type: "#class:org.apache.camel.component.djl.ImageNetUtil" from: uri: "kamelet:source" steps: - to: "djl:cv/object_detection?artifactId=ssd" - convertBodyTo: "ai.djl.modality.cv.Image[]" - split: expression: simple: "${body}" aggregationStrategy: "#class:org.apache.camel.processor.aggregate.GroupedBodyAggregationStrategy" steps: - to: "djl:cv/image_classification?artifactId=resnet" # The output from the image classification model is classified # as one of 1000 labels from WordNet. # Since it's too fine-grained, we want to find the higher-level # group (= hypernym) for the classification using the WordNet # dictionary. - bean: ref: "{{imageNetUtil}}" method: extractClassName - bean: ref: "{{imageNetUtil}}" method: addHypernym - marshal: json: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: dns-dig-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "DNS" camel.apache.org/kamelet.namespace: "Networking" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "DNS DIG Action" description: Query a DNS through Dig. type: object dependencies: - "camel:core" - "camel:dns" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[domain-name]}" steps: - setHeader: name: dns.name simple: "${header[domain-name]}" - simple: "${header[ce-domainname]}" steps: - setHeader: name: dns.name simple: "${header[ce-domainname]}" otherwise: steps: - setHeader: name: dns.name simple: "${body}" - choice: when: - simple: "${header[dns-type]}" steps: - setHeader: name: dns.type simple: "${header[dns-type]}" - simple: "${header[ce-dnstype]}" steps: - setHeader: name: dns.type simple: "${header[ce-dnstype]}" otherwise: steps: - setHeader: name: dns.type constant: "A" - to: uri: "dns:dig" - convertBodyTo: type: "java.lang.String" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: dns-ip-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "DNS" camel.apache.org/kamelet.namespace: "Networking" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "DNS IP Action" description: Get an IP from a DNS type: object dependencies: - "camel:core" - "camel:dns" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[domain]}" steps: - setHeader: name: dns.domain simple: "${header[domain]}" - simple: "${header[ce-domain]}" steps: - setHeader: name: dns.domain simple: "${header[ce-domain]}" otherwise: steps: - setHeader: name: dns.domain simple: "${body}" - to: uri: "dns:ip" - convertBodyTo: type: "java.lang.String" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: dns-lookup-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "DNS" camel.apache.org/kamelet.namespace: "Networking" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "DNS Lookup Action" description: Lookup for a domain type: object types: out: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:dns" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[domain-name]}" steps: - setHeader: name: dns.domain simple: "${header[domain-name]}" - simple: "${header[ce-domainname]}" steps: - setHeader: name: dns.domain simple: "${header[ce-domainname]}" otherwise: steps: - setHeader: name: dns.domain simple: "${body}" - to: uri: "dns:lookup" - marshal: json: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: drop-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Drop Field Action" description: Removes a custom field by given name from the message in transit. required: - field properties: field: title: Field description: The name of the field to be removed type: string type: object dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:kafka" template: beans: - name: dropField type: "#class:org.apache.camel.component.kafka.transform.DropField" properties: field: '{{field}}' from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - process: ref: "{{dropField}}" - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: drop-header-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Drop Header Action" description: "Remove an header from the message in transit." required: - name properties: name: title: Name description: The name of the header to be removed. type: string example: headername type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - removeHeader: name: "{{name}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: drop-headers-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Drop Headers Action" description: "Remove headers from the message in transit based on a pattern." required: - pattern properties: pattern: title: Pattern description: Name or pattern of headers to remove. The pattern is matched in the following order, 1 = exact match 2 = wildcard (pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive). type: string example: Camel* excludePattern: title: Exclusion Pattern description: Name or pattern of headers to not remove. The pattern is matched in the following order, 1 = exact match 2 = wildcard (pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive). type: string example: Camel* type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - removeHeaders: pattern: "{{pattern}}" excludePattern: "{{?excludePattern}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: dropbox-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Dropbox" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Dropbox Sink" description: Upload Files to Dropbox. required: - accessToken - clientIdentifier - remotePath - uploadMode type: object properties: accessToken: title: Dropbox Access Token description: The access Token to use to access Dropbox type: string format: password x-descriptors: - urn:camel:group:credentials clientIdentifier: title: Client Identifier description: Dropbox App client Identifier type: string x-descriptors: - urn:camel:group:credentials remotePath: title: Remote Path description: Original file or folder to work with type: string uploadMode: title: Upload Mode description: The uploading mode in case a file with the same name exists on Dropbox. Choose `add` or `force`. With `add`, the new file is renamed. With `force`, the existing file is overwritten. type: string default: add dependencies: - "camel:core" - "camel:dropbox" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelDropboxPutFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelDropboxPutFileName simple: "${header[ce-file]}" - to: uri: 'dropbox:put' parameters: accessToken: '{{accessToken}}' remotePath: '{{remotePath}}' clientIdentifier: '{{clientIdentifier}}' uploadMode: '{{uploadMode}}' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: dropbox-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Dropbox" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Dropbox Source" description: Consume Files from Dropbox. required: - period - accessToken - clientIdentifier - remotePath - query type: object properties: period: title: Period between Polls description: The interval between fetches to the Dropbox remote path in milliseconds type: integer default: 10000 accessToken: title: Dropbox Access Token description: The access Token to use to access Dropbox type: string format: password x-descriptors: - urn:camel:group:credentials clientIdentifier: title: Client Identifier description: Dropbox App client Identifier type: string x-descriptors: - urn:camel:group:credentials remotePath: title: Remote Path description: Original file or folder to work with type: string query: title: Queries description: A space-separated list of sub-strings to search for. A file matches only if it contains all the sub-strings. If this option is not set, all files is matched. type: string dependencies: - "camel:dropbox" - "camel:kamelet" - "camel:core" - "camel:jsonpath" - "camel:timer" template: from: uri: "timer:dropbox-stream" parameters: period: "{{period}}" steps: - to: uri: "dropbox:search" parameters: accessToken: "{{accessToken}}" remotePath: "{{remotePath}}" clientIdentifier: "{{clientIdentifier}}" query: "{{query}}" - split: jsonpath: "$.*" steps: - setProperty: name: dropboxFileName simple: ${body.metadata.pathDisplay} - toD: "dropbox:get?accessToken={{accessToken}}&clientIdentifier={{clientIdentifier}}&remotePath=${exchangeProperty.dropboxFileName}" - to: "kamelet:sink" - toD: "dropbox:del?accessToken={{accessToken}}&clientIdentifier={{clientIdentifier}}&remotePath=${exchangeProperty.dropboxFileName}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: earthquake-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Earthquake" camel.apache.org/kamelet.namespace: "Dataset" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/kamelet.verified: "true" spec: definition: title: "Earthquake Source" description: Get data about current earthquake events happening in the world using the USGS API type: object properties: period: title: Period between Polls description: The interval between fetches to the earthquake API in milliseconds. type: integer default: 60000 lookAhead: title: Look-ahead Minutes description: The amount of minutes to look ahead when starting the integration afresh. type: integer default: 120 types: out: mediaType: application/json dependencies: - "camel:caffeine" - "camel:http" - "camel:kamelet" - "camel:core" - "camel:jackson" - "camel:jsonpath" - "camel:timer" template: from: uri: "timer:earthquake" parameters: period: "{{period}}" steps: - setHeader: name: CamelCaffeineAction constant: GET - toD: "caffeine-cache:cache-${routeId}?key=lastUpdate" - choice: when: - simple: "${header.CamelCaffeineActionHasResult}" steps: - setProperty: name: lastUpdate simple: "${body}" otherwise: steps: - setProperty: name: lastUpdate simple: "${date-with-timezone:now-{{lookAhead}}m:UTC:yyyy-MM-dd'T'HH:mm:ss.SSS}" - setHeader: name: CamelHttpMethod constant: GET - toD: "https://earthquake.usgs.gov/fdsnws/event/1/query?format=geojson&updatedafter=${exchangeProperty.lastUpdate}&orderby=time-asc" - removeHeader: name: CamelHttpMethod - unmarshal: json: {} - setProperty: name: generated simple: "${body[metadata][generated]}" - setProperty: name: lastUpdate simple: "${date-with-timezone:exchangeProperty.generated:UTC:yyyy-MM-dd'T'HH:mm:ss.SSS}" - claimCheck: operation: Push - setBody: exchange-property: lastUpdate - setHeader: name: CamelCaffeineAction constant: PUT - toD: "caffeine-cache:cache-${routeId}?key=lastUpdate" - claimCheck: operation: Pop - split: jsonpath: "$.features[*]" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: elasticsearch-index-sink labels: camel.apache.org/kamelet.type: "sink" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "ElasticSearch" camel.apache.org/kamelet.namespace: "Search" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.icon: "" spec: definition: title: "ElasticSearch Index Sink" description: Stores JSON-formatted data into ElasticSearch. required: - clusterName - hostAddresses type: object properties: user: title: Username description: The username to connect to ElasticSearch. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to connect to ElasticSearch. type: string format: password x-descriptors: - urn:camel:group:credentials enableSSL: title: Enable SSL description: Specifies to connect by using SSL. type: boolean default: true hostAddresses: title: Host Addresses description: A comma-separated list of remote transport addresses in `ip:port format`. type: string example: quickstart-es-http:9200 clusterName: title: ElasticSearch Cluster Name description: The name of the ElasticSearch cluster. type: string example: quickstart indexName: title: Index in ElasticSearch description: The name of the ElasticSearch index. type: string example: data certificate: title: Certificate description: The Certificate for accessing the Elasticsearch cluster. You must encode this value in base64. type: string types: out: mediaType: text/plain in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:elasticsearch" - "camel:gson" - "camel:bean" template: beans: - name: local-es type: "#class:org.apache.camel.component.es.ElasticsearchComponent" properties: user: "{{?user}}" password: "{{?password}}" from: uri: kamelet:source steps: - choice: when: - simple: "${header[indexId]}" steps: - setHeader: name: "indexId" simple: "${header[indexId]}" - simple: "${header[ce-indexid]}" steps: - setHeader: name: "indexId" simple: "${header[ce-indexid]}" - choice: when: - simple: "${header[indexName]}" steps: - setHeader: name: "indexName" simple: "${header[indexName]}" - simple: "${header[ce-indexname]}" steps: - setHeader: name: "indexName" simple: "${header[ce-indexname]}" - unmarshal: json: {} - to: uri: "{{local-es}}:{{clusterName}}" parameters: operation: "INDEX" hostAddresses: "{{hostAddresses}}" enableSSL: "{{enableSSL}}" indexName: "{{?indexName}}" certificatePath: "base64:{{?certificate}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: elasticsearch-search-source labels: camel.apache.org/kamelet.type: "source" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "ElasticSearch" camel.apache.org/kamelet.namespace: "Search" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.icon: "" spec: definition: title: "ElasticSearch Search Source" description: Search data on ElasticSearch required: - query - clusterName - indexName - hostAddresses type: object properties: period: title: Period description: The time interval between two searches type: integer default: 1000 query: title: Query description: The query we want to use to search on ElasticSearch. type: string user: title: Username description: Username to connect to ElasticSearch. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to ElasticSearch. type: string format: password x-descriptors: - urn:camel:group:credentials enableSSL: title: Enable SSL description: Do we want to connect using SSL? type: boolean default: true hostAddresses: title: Host Addresses description: Comma separated list with ip:port formatted remote transport addresses to use. type: string indexName: title: Index in ElasticSearch description: The name of the index to act against. type: string clusterName: title: ElasticSearch Cluster Name description: The name of the cluster. type: string certificate: title: Certificate description: The Certificate for accessing the Elasticsearch cluster. You must encode this value in base64. type: string types: out: mediaType: application/json dependencies: - "camel:core" - "camel:kamelet" - "camel:timer" - "camel:elasticsearch" - "camel:gson" template: beans: - name: local-es type: "#class:org.apache.camel.component.es.ElasticsearchComponent" properties: user: "{{?user}}" password: "{{?password}}" from: uri: timer:tick parameters: period: "{{period}}" steps: - setBody: constant: "{{query?nested=false}}" - to: uri: "{{local-es}}:{{clusterName}}" parameters: operation: "SEARCH" indexName: "{{indexName}}" hostAddresses: "{{hostAddresses}}" enableSSL: "{{enableSSL}}" certificatePath: "base64:{{?certificate}}" - marshal: json: library: Gson - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: exec-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Exec" camel.apache.org/kamelet.namespace: "System" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Exec Sink" description: Execute system commands required: - executable type: object properties: executable: title: Executable Command description: The command to execute type: string dependencies: - "camel:core" - "camel:exec" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[args]}" steps: - setHeader: name: CamelExecCommandArgs simple: "${header[args]}" - simple: "${header[ce-args]}" steps: - setHeader: name: CamelExecCommandArgs simple: "${header[ce-args]}" - to: uri: "exec:{{executable}}" - setBody: simple: "${body.stdout}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: extract-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Extract Field Action" description: Extract a field from the message body. required: - field properties: field: title: Field description: The name of the field to extract type: string headerOutput: title: Header Output description: If enable the action will store the extracted field in an header named CamelKameletsExtractFieldName type: boolean default: false headerOutputName: title: Header Output Name description: A custom name for the header containing the extracted field default: "none" type: string strictHeaderCheck: title: Strict Header Check description: If enabled the action will check if the header output name (custom or default) has been used already in the exchange. If so, the extracted field is stored in the message body, if not, the extracted field is stored in the selected header (custom or default). type: boolean default: false trimField: title: Trim Field description: If enabled we return the Raw extracted field type: boolean default: false type: object dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson" - "camel:kafka" template: beans: - name: extractField type: "#class:org.apache.camel.component.kafka.transform.ExtractField" properties: field: '{{field}}' headerOutput: '{{headerOutput}}' headerOutputName: '{{headerOutputName}}' strictHeaderCheck: '{{strictHeaderCheck}}' trimField: '{{trimField}}' from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - process: ref: "{{extractField}}" - choice: when: - simple: "${exchangeProperty[trimField]} == 'false'" steps: - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: fhir-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FHIR" camel.apache.org/kamelet.namespace: "API" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "FHIR Sink" description: Forward data to a FHIR endpoint. required: - serverUrl - methodName type: object properties: apiName: title: API Name description: "What kind of operation to perform." type: string enum: ["CAPABILITIES", "CREATE", "DELETE", "HISTORY", "LOAD_PAGE", "META", "OPERATION", "PATCH", "READ", "SEARCH", "TRANSACTION", "UPDATE", "VALIDATE"] methodName: title: Method Name description: "What sub operation to use for the selected operation." type: string encoding: title: Encoding description: "Encoding to use for all request. One of: [JSON] [XML]." type: string default: "JSON" fhirVersion: title: FHIR Version description: "The FHIR Version to use." type: string enum: ["DSTU2", "DSTU2_HL7ORG", "DSTU2_1", "DSTU3", "R4", "R5"] default: "R4" log: title: Log description: "Will log every requests and responses." type: boolean default: false prettyPrint: title: Pretty Print description: "Pretty print all request." type: boolean default: false serverUrl: title: Server URL description: The FHIR server base URL. type: string lazyStartProducer: title: Lazy Start Producer description: "Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel’s routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing." type: boolean default: false proxyHost: title: Proxy Host description: The proxy host. type: string proxyPassword: title: Proxy Password description: The proxy password. type: string format: password x-descriptors: - urn:camel:group:credentials proxyPort: title: Proxy Port description: The proxy port. type: integer proxyUser: title: Proxy User description: The proxy username. type: string x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: OAuth access token. type: string format: password x-descriptors: - urn:camel:group:credentials username: title: Username description: Username to use for basic authentication. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to use for basic authentication. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:fhir" - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - choice: precondition: true when: - simple: "${properties:encoding} =~ 'JSON'" steps: - unmarshal: fhirJson: fhirVersion: "{{fhirVersion}}" prettyPrint: "{{prettyPrint}}" - simple: "${properties:encoding} =~ 'XML'" steps: - unmarshal: fhirXml: fhirVersion: "{{fhirVersion}}" prettyPrint: "{{prettyPrint}}" - to: uri: "fhir://{{apiName}}/{{methodName}}" parameters: serverUrl: "{{serverUrl}}" inBody: "resource" encoding: "{{encoding}}" fhirVersion: "{{fhirVersion}}" log: "{{log}}" prettyPrint: "{{prettyPrint}}" lazyStartProducer: "{{lazyStartProducer}}" proxyHost: "{{?proxyHost}}" proxyPassword: "{{?proxyPassword}}" proxyPort: "{{?proxyPort}}" proxyUser: "{{?proxyUser}}" accessToken: "{{?accessToken}}" username: "{{?username}}" password: "{{?password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: fhir-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FHIR" camel.apache.org/kamelet.namespace: "API" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "FHIR Source" description: Receive data from FHIR server. required: - serverUrl - username - password type: object properties: serverUrl: title: Server URL description: The FHIR server url. type: string url: title: URL description: The FHIR resource type url. type: string default: "/Patient" encoding: title: Encoding description: Encoding to use for all request. type: string default: "JSON" enum: ["JSON", "XML"] fhirVersion: title: FHIR Version description: The FHIR Version to use. type: string default: "R4" enum: ["DSTU2", "DSTU2_HL7ORG", "DSTU2_1", "DSTU3", "R4", "R5"] username: title: Username description: The username to access the FHIR server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FHIR server. type: string format: password x-descriptors: - urn:camel:group:credentials prettyPrint: title: Json Pretty Print description: Define if the Json must be pretty print or not. type: boolean default: true types: out: mediaType: application/json dependencies: - "camel:fhir" - "camel:kamelet" template: from: uri: "fhir://search/searchByUrl" parameters: serverUrl: "{{serverUrl}}" url: "{{url}}" encoding: "{{encoding}}" fhirVersion: "{{fhirVersion}}" prettyPrint: "{{prettyPrint}}" username: "{{username}}" password: "{{password}}" steps: - marshal: fhirJson: fhirVersion: "{{fhirVersion}}" prettyPrint: "{{prettyPrint}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: file-watch-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "File Watch" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "File Watch Source" description: Receive events related to a file or folder. It may require a volume mounting on Kubernetes. required: - filePath - events type: object properties: filePath: title: Path to Watch description: Path of file or folder to watch type: string events: title: Events description: The type of events to consume type: string default: "CREATE,MODIFY,DELETE" dependencies: - "camel:file-watch" - "camel:kamelet" template: from: uri: "file-watch:{{filePath}}" parameters: events: "{{events}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: freemarker-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Freemarker Template Action" description: Apply a Freemarker Template. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.ftl" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:freemarker" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "freemarker:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ftp-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "FTP Sink" description: Send data to an FTP server. required: - connectionHost - connectionPort - username - password - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the FTP server. type: string connectionPort: title: Connection Port description: The port of the FTP server. type: string default: 21 username: title: Username description: The username to access the FTP server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FTP server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory. type: string passiveMode: title: Passive Mode description: Specifies to use passive mode connection. type: boolean default: false fileExist: title: File Existence description: How to behave in case of file already existent. type: string default: Override enum: ["Override", "Append", "Fail", "Ignore"] binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false autoCreate: title: Autocreate Missing Directories description: Automatically create the directory the files should be written to. type: boolean default: true dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelFileName simple: "${header[ce-file]}" - to: uri: "ftp:{{username}}@{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: password: "{{password}}" passiveMode: "{{passiveMode}}" fileExist: "{{fileExist}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ftp-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "FTP Source" description: Receive data from an FTP server. required: - connectionHost - connectionPort - username - password - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the FTP server. type: string connectionPort: title: Connection Port description: The port of the FTP server. type: string default: 21 username: title: Username description: The username to access the FTP server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FTP server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory type: string passiveMode: title: Passive Mode description: Specifes to use passive mode connection. type: boolean default: false recursive: title: Recursive description: If a directory, look for files in all the sub-directories as well. type: boolean default: false idempotent: title: Idempotency description: Skip already-processed files. type: boolean default: true binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false autoCreate: title: Autocreate Missing Directories description: Automatically create starting directory. type: boolean default: true delete: title: Delete description: If true, the file is deleted after it is processed successfully. type: boolean default: false dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "ftp:{{username}}@{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: password: "{{password}}" passiveMode: "{{passiveMode}}" recursive: "{{recursive}}" idempotent: "{{idempotent}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" delete: "{{delete}}" steps: - setHeader: name: file simple: "${header[CamelFileName]}" - setHeader: name: ce-file simple: "${header[CamelFileName]}" - convertBodyTo: type: "java.io.InputStream" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ftps-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "FTPS Sink" description: Send data to an FTPS server. required: - connectionHost - connectionPort - username - password - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the FTP server. type: string connectionPort: title: Connection Port description: The port of the FTP server. type: string default: 21 username: title: Username description: The username to access the FTP server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FTP server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory. type: string passiveMode: title: Passive Mode description: Set the passive mode connection. type: boolean default: false fileExist: title: File Existence description: "Specifies how the Kamelet behaves if the file already exists." type: string default: Override enum: ["Override", "Append", "Fail", "Ignore"] binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false autoCreate: title: Autocreate Missing Directories description: Automatically create the directory the files should be written to. type: boolean default: true dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelFileName simple: "${header[ce-file]}" - to: uri: "ftps:{{username}}@{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: password: "{{password}}" passiveMode: "{{passiveMode}}" fileExist: "{{fileExist}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ftps-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "FTPS Source" description: Receive data from an FTPS server. required: - connectionHost - connectionPort - username - password - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the FTPS server. type: string connectionPort: title: Connection Port description: The port of the FTPS server. type: string default: 21 username: title: Username description: The username to access the FTPS server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FTPS server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory. type: string passiveMode: title: Passive Mode description: Specifies to use passive mode connection. type: boolean default: false recursive: title: Recursive description: If a directory, look for files in all sub-directories as well. type: boolean default: false idempotent: title: Idempotency description: Skip already-processed files. type: boolean default: true binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false autoCreate: title: Autocreate Missing Directories description: Automatically create starting directory. type: boolean default: true delete: title: Delete description: If true, the file is deleted after it is processed successfully. type: boolean default: false dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "ftps:{{username}}@{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: password: "{{password}}" passiveMode: "{{passiveMode}}" recursive: "{{recursive}}" idempotent: "{{idempotent}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" delete: "{{delete}}" steps: - setHeader: name: file simple: "${header[CamelFileName]}" - setHeader: name: ce-file simple: "${header[CamelFileName]}" - convertBodyTo: type: "java.io.InputStream" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: github-commit-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "GitHub" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "GitHub Commit Source" description: Receive commit From GitHub. required: - repoName - repoOwner - oauthToken - startingSha - branch type: object properties: repoName: title: Repository Name description: The GitHub Repository name type: string repoOwner: title: Repository Owner description: The repository owner type: string oauthToken: title: OAuth Token description: OAuth token type: string format: password x-descriptors: - urn:camel:group:credentials startingSha: title: Starting SHA description: The SHA from which we want to consume, possible values beginning, last or a specific SHA type: string default: last branch: title: Branch description: The branch we want to consume commit from type: string types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:github" - "camel:kamelet" template: from: uri: "github://commit/{{branch}}" parameters: repoName: "{{repoName}}" repoOwner: "{{repoOwner}}" oauthToken: "{{oauthToken}}" startingSha: "{{startingSha}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: github-event-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "GitHub" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "GitHub Event Source" description: Receive Events From a GitHub Repository. required: - repoName - repoOwner - oauthToken type: object properties: repoName: title: Repository Name description: The GitHub Repository name. type: string repoOwner: title: Repository Owner description: The repository owner. type: string oauthToken: title: OAuth Token description: OAuth token. type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:github" - "camel:kamelet" template: from: uri: "github://event" parameters: repoName: "{{repoName}}" repoOwner: "{{repoOwner}}" oauthToken: "{{oauthToken}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: github-pullrequest-comment-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "GitHub" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "GitHub Pull Request Comments Source" description: Receive pull request Comments From GitHub. required: - repoName - repoOwner - oauthToken type: object properties: repoName: title: Repository Name description: The GitHub Repository name type: string repoOwner: title: Repository Owner description: The repository owner type: string oauthToken: title: OAuth Token description: OAuth token type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:github" - "camel:kamelet" template: from: uri: "github://pullRequestComment" parameters: repoName: "{{repoName}}" repoOwner: "{{repoOwner}}" oauthToken: "{{oauthToken}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: github-pullrequest-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "GitHub" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "GitHub Pull Request Source" description: Receive pull request From GitHub. required: - repoName - repoOwner - oauthToken type: object properties: repoName: title: Repository Name description: The GitHub Repository name type: string repoOwner: title: Repository Owner description: The repository owner type: string oauthToken: title: OAuth Token description: OAuth token type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:github" - "camel:kamelet" template: from: uri: "github://pullRequest" parameters: repoName: "{{repoName}}" repoOwner: "{{repoOwner}}" oauthToken: "{{oauthToken}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: github-tag-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "GitHub" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "GitHub Tag Source" description: Receive Tags From a GitHub Repository. required: - repoName - repoOwner - oauthToken type: object properties: repoName: title: Repository Name description: The GitHub Repository name type: string repoOwner: title: Repository Owner description: The repository owner type: string oauthToken: title: OAuth Token description: OAuth token type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:github" - "camel:kamelet" template: from: uri: "github://tag" parameters: repoName: "{{repoName}}" repoOwner: "{{repoOwner}}" oauthToken: "{{oauthToken}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-bigquery-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Big Query" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Google Big Query Sink" description: Send data to a Google Big Query table. required: - projectId - dataset - table - serviceAccountKey type: object properties: projectId: title: Google Cloud Project Id description: The Google Cloud Project ID. type: string dataset: title: Big Query Dataset Id description: The Big Query Dataset ID. type: string table: title: Big Query Table Id description: The Big Query Table ID. type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for the BigQuery Service. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:kamelet" - "camel:google-bigquery" - "camel:jackson" template: from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "google-bigquery:{{projectId}}:{{dataset}}:{{table}}" parameters: serviceAccountKey: "base64:{{serviceAccountKey}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-calendar-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Calendar" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Calendar Source" description: Receive event data from Google Calendar. required: - index - calendarId - clientId - accessToken - refreshToken - clientSecret - applicationName type: object properties: index: title: Index description: An index for the Google Calendar endpoint. type: string calendarId: title: Calendar ID description: The calendar ID to use as the source of event data. type: string clientId: title: Client Id description: The Client ID of the Google Calendar application. type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: The Client secret of the Google Calendar application. type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: The OAuth 2 access token for the Google Calendar application. This token typically expires after an hour. For long term usage, set the `refreshToken` property. type: string format: password x-descriptors: - urn:camel:group:credentials refreshToken: title: Refresh Token description: The OAuth 2 refresh token for the Google Calendar application. The Google Calendar component can obtain a new `accessToken` whenever the current one expires. Set this value for long term usage. type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll. type: integer default: 500 applicationName: title: Application name description: The Google Calendar application name. type: string syncFlow: title: Sync Flow description: Specifies to sync events for incremental synchronization. type: boolean default: false consumeFromNow: title: Consume from now description: Specfies to consume events in the calendar from now on. type: boolean default: true dataTypes: out: default: json headers: CamelGoogleCalendarEventId: title: Camel Google Calendar Event Id description: The calendar event id type: string types: json: format: "application-json" description: Json representation of a Google Calendar event object. mediaType: application/json cloudevents: format: "google-calendar-stream:application-cloudevents" description: Output data type represents Google Calendar Stream response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Calendar Events and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.google.calendar.stream.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Calendar Event Id with prefix "google.calendar.stream.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The Calendar event type. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:jackson" - "camel:google-calendar" - "camel:kamelet" template: from: uri: "google-calendar-stream://{{index}}" parameters: clientId: "{{clientId}}" calendarId: "{{calendarId}}" accessToken: "{{accessToken}}" refreshToken: "{{refreshToken}}" clientSecret: "{{clientSecret}}" delay: "{{delay}}" applicationName: "{{applicationName}}" syncFlow: "{{syncFlow}}" consumeFromNow: "{{consumeFromNow}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-functions-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Functions" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Google Functions Sink" description: Send data to Google Functions. required: - projectId - functionName - region - serviceAccountKey type: object properties: projectId: title: Project Id description: The Google Cloud Functions Project ID. type: string region: title: Region description: The region where Google Cloud Functions has been deployed. type: string functionName: title: Function Name description: The Function name. type: string serviceAccountKey: title: Service Account Key description: The path to the service account key file that provides credentials for the Google Cloud Functions platform. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials dependencies: - "camel:kamelet" - "camel:google-functions" - "camel:jackson" template: from: uri: kamelet:source steps: - to: uri: "google-functions://{{functionName}}" parameters: serviceAccountKey: "base64:{{serviceAccountKey}}" project: "{{projectId}}" location: "{{region}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-mail-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Mail" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Mail Source" description: Receive data from Google Mail. required: - index - clientId - accessToken - refreshToken - clientSecret - applicationName type: object properties: index: title: Index description: An index for the google mail endpoint. type: string clientId: title: Client ID description: Client ID of the gmail application. type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: Client Secret of the gmail application. type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: OAuth 2 access token for google mail application. This typically expires after an hour so refreshToken is recommended for long term usage. type: string format: password x-descriptors: - urn:camel:group:credentials refreshToken: title: Refresh Token description: OAuth 2 refresh token for google mail application. Using this, the Google Calendar component can obtain a new accessToken whenever the current one expires - a necessity if the application is long-lived. type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 applicationName: title: Application name description: Google Mail application name type: string markAsRead: title: Mark as Read description: Mark the message as read once it has been consumed type: boolean default: true labels: title: Gmail Labels description: Comma separated list of labels to take into account type: string example: "inbox" query: title: Gmail Query description: The query to execute on gmail box type: string example: "is:unread -category:(promotions OR social)" default: "is:unread" dataTypes: out: default: json headers: CamelGoogleMailId: title: Camel Google Mail Id description: The ID of the message type: string CamelGoogleMailStreamTo: title: Camel Google Mail To Address description: The recipient of the message type: string CamelGoogleMailStreamFrom: title: Camel Google Mail From Address description: The emitter of the message type: string CamelGoogleMailStreamCc: title: Camel Google Mail Cc description: The carbon copy of the message type: string CamelGoogleMailStreamBcc: title: Camel Google Mail Bcc description: The blind carbon cpoy of the message type: string CamelGoogleMailStreamSubject: title: Camel Google Mail Subject description: The subject of the message type: string types: json: format: "application-json" description: Json representation of a Google Mail event object. mediaType: application/json cloudevents: format: "google-mail-stream:application-cloudevents" description: Output data type represents Google Mail Streams response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Mail and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.google.mail.stream.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Mail From with prefix "google.mail.stream.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The Calendar event type. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:jackson" - "camel:kamelet" - "camel:google-mail" template: from: uri: "google-mail-stream://{{index}}" parameters: clientId: "{{clientId}}" accessToken: "{{accessToken}}" refreshToken: "{{refreshToken}}" clientSecret: "{{clientSecret}}" delay: "{{delay}}" applicationName: "{{applicationName}}" markAsRead: "{{markAsRead}}" labels: "{{labels}}" query: "{{query}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-pubsub-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Pubsub" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Google Pubsub Sink" description: Send messages to Google Cloud Pub/Sub. required: - projectId - destinationName type: object properties: projectId: title: Project Id description: The Google Cloud Pub/Sub Project ID. type: string destinationName: title: Destination Name description: The destination name. type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for the Pub/Sub publisher/subscriber. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials dependencies: - "camel:kamelet" - "camel:google-pubsub" - "camel:jackson" template: from: uri: kamelet:source steps: - to: uri: "google-pubsub://{{projectId}}:{{destinationName}}" parameters: serviceAccountKey: "base64:{{?serviceAccountKey}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-pubsub-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Pubsub" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Pubsub Source" description: Consume messages from Google Cloud Pub/Sub. required: - projectId - subscriptionName type: object properties: projectId: title: Project Id description: The Google Cloud Pub/Sub Project ID. type: string subscriptionName: title: Subscription Name description: The subscription name. type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for the Pub/Sub publisher/subscriber. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials synchronousPull: title: Synchronous Pull description: Specifies to synchronously pull batches of messages. type: boolean default: false maxMessagesPerPoll: title: Max Messages Per Poll description: The maximum number of messages to receive from the server in a single API call. type: integer default: 1 concurrentConsumers: title: Concurrent Consumers description: The number of parallel streams to consume from the subscription. type: integer default: 1 dependencies: - "camel:kamelet" - "camel:google-pubsub" - "camel:jackson" template: from: uri: "google-pubsub://{{projectId}}:{{subscriptionName}}" parameters: serviceAccountKey: "base64:{{?serviceAccountKey}}" synchronousPull: "{{synchronousPull}}" maxMessagesPerPoll: "{{maxMessagesPerPoll}}" concurrentConsumers: "{{concurrentConsumers}}" steps: - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-sheets-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Sheets" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Google Sheets Sink" description: Send data to Google Sheets and update/append values on a spreadsheet. required: - spreadsheetId - clientId - accessToken - refreshToken - clientSecret type: object properties: spreadsheetId: title: Spreadsheet ID description: The Spreadsheet ID to be used as identifier type: string clientId: title: Client Id description: Client ID of the sheets application type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: Client Secret of the sheets application type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: OAuth 2 access token for google sheets application. This typically expires after an hour so refreshToken is recommended for long term usage. type: string format: password x-descriptors: - urn:camel:group:credentials refreshToken: title: Refresh Token description: OAuth 2 refresh token for google sheets application. Using this, the Google Calendar component can obtain a new accessToken whenever the current one expires - a necessity if the application is long-lived. type: string format: password x-descriptors: - urn:camel:group:credentials applicationName: title: Application Name description: Google Sheets application name type: string operation: title: Operation Mode description: Operation to execute (update or append) type: string enum: [ "update", "append" ] default: append example: append range: title: Cells Range description: The cell range of rows and columns to write data to. type: string example: "A1:B3" majorDimension: title: Major Dimension description: Specifies the major dimension that the given values should use (ROWS or COLUMNS). type: string enum: [ "COLUMNS", "ROWS" ] default: "ROWS" example: "ROWS" columnNames: title: Column Names description: Optional custom column names that map to cell coordinates based on their position. type: string default: "A" valueInputOption: title: Value Input Option description: Controls how the entered values should be be interpreted when adding them. type: string enum: [ "USER_ENTERED", "RAW" ] default: "USER_ENTERED" example: "USER_ENTERED" dataTypes: in: default: json-struct types: json-struct: format: "google-sheets:application-x-struct" description: Special Json representation of Google Sheets ValueRange object with just row and column values as a generic JsonNode. headers: CamelGoogleSheets.range: title: Range description: Cells range to write data to. default: A:A type: string CamelGoogleSheets.spreadsheetId: title: Spreadsheet id description: The Spreadsheet ID to be used as identifier. type: string CamelGoogleSheets.majorDimension: title: Major dimension description: Specifies the major dimension that the given values should use (ROWS or COLUMNS). default: ROWS type: string CamelGoogleSheets.columnNames: title: Column Names description: Optional custom column names that map to cell coordinates based on their position. default: A type: string CamelGoogleSheets.valueInputOption: title: Value Input Option description: Controls how the entered values should be be interpreted when adding them. default: USER_ENTERED type: string mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:google-sheets" template: from: uri: "kamelet:source" steps: - setHeader: name: CamelGoogleSheets.spreadsheetId simple: "{{spreadsheetId}}" - setHeader: name: CamelGoogleSheets.range simple: "{{?range}}" - setHeader: name: CamelGoogleSheets.majorDimension simple: "{{?majorDimension}}" - setHeader: name: CamelGoogleSheets.columnNames simple: "{{?columnNames}}" - setHeader: name: CamelGoogleSheets.valueInputOption simple: "{{?valueInputOption}}" - transform: toType: "google-sheets:application-x-struct" - to: uri: "google-sheets:data/{{operation}}" parameters: spreadsheetId: "{{spreadsheetId}}" clientId: "{{clientId}}" accessToken: "{{accessToken}}" refreshToken: "{{refreshToken}}" clientSecret: "{{clientSecret}}" applicationName: "{{?applicationName}}" range: "{{?range}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-sheets-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Sheets" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Sheets Source" description: Receive data from Google Sheets. required: - spreadsheetId - clientId - accessToken - refreshToken - clientSecret type: object properties: spreadsheetId: title: Spreadsheet ID description: The Spreadsheet ID to be used as events source type: string clientId: title: Client Id description: Client ID of the sheets application type: string format: password x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: Client Secret of the sheets application type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: OAuth 2 access token for google sheets application. This typically expires after an hour so refreshToken is recommended for long term usage. type: string format: password x-descriptors: - urn:camel:group:credentials refreshToken: title: Refresh Token description: OAuth 2 refresh token for google sheets application. Using this, the Google Calendar component can obtain a new accessToken whenever the current one expires - a necessity if the application is long-lived. type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 repeatCount: title: Repeat Count description: Specifies a maximum limit of number of fires type: integer applicationName: title: Application name description: Google Sheets application name type: string splitResults: title: Split Results description: True if value range result should be split into rows or columns to process each of them individually. type: boolean default: true range: title: Cells Range description: The range of rows and columns in a sheet to get data from. type: string example: "A1:B3" majorDimension: title: Major Dimension description: Specifies the major dimension that the given values should use (ROWS or COLUMNS). type: string enum: [ "COLUMNS", "ROWS" ] default: "ROWS" example: "ROWS" columnNames: title: Column Names description: Optional custom column names that map to cell coordinates based on their position. type: string default: "A" dataTypes: out: default: json headers: CamelGoogleSheets.range: title: Range description: Cells range to write data to. default: A:A type: string CamelGoogleSheets.spreadsheetId: title: Spreadsheet id description: The Spreadsheet ID to be used as identifier. type: string CamelGoogleSheets.majorDimension: title: Major dimension description: Specifies the major dimension that the given values should use (ROWS or COLUMNS). default: ROWS type: string CamelGoogleSheets.columnNames: title: Column Names description: Optional custom column names that map to cell coordinates based on their position. default: A type: string CamelGoogleSheets.splitResults: title: Split Results description: True if value range result should be split into rows or columns to process each of them individually. default: "true" type: boolean types: json: format: "application-json" description: Json representation of a GoogleSheets ValueRange object that holds all values for the given cell range. mediaType: application/json json-struct: format: "google-sheets:application-x-struct" description: Special Json representation of Google Sheets ValueRange object with just row and column values as a generic JsonNode. mediaType: application/json cloudevents: format: "google-sheets-stream:application-cloudevents" description: Output data type represents Google Sheets Stream response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Spreadsheet and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.google.sheets.stream.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Spreadsheet Id with prefix "google.sheets.stream.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Spreadsheet URL. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:google-sheets" template: from: uri: "google-sheets-stream://{{spreadsheetId}}" parameters: clientId: "{{clientId}}" accessToken: "{{accessToken}}" refreshToken: "{{refreshToken}}" clientSecret: "{{clientSecret}}" delay: "{{delay}}" applicationName: "{{?applicationName}}" splitResults: "{{splitResults}}" range: "{{?range}}" repeatCount: "{{?repeatCount}}" steps: - marshal: json: {} - setHeader: name: CamelGoogleSheets.spreadsheetId simple: "{{spreadsheetId}}" - setHeader: name: CamelGoogleSheets.range simple: "{{?range}}" - setHeader: name: CamelGoogleSheets.majorDimension simple: "{{?majorDimension}}" - setHeader: name: CamelGoogleSheets.columnNames simple: "{{?columnNames}}" - setHeader: name: CamelGoogleSheets.splitResults simple: "{{?splitResults}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-storage-event-based-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Storage Event-based" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Storage Event-based Source" description: Receive data from Google Pubsub reporting events related to a Google Storage bucket. required: - projectId - subscriptionName - serviceAccountKey - bucketNameOrArn type: object properties: projectId: title: Project Id description: The Google Cloud Pub/Sub Project ID. type: string subscriptionName: title: Subscription Name description: The subscription name. type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for the Pub/Sub publisher/subscriber. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials synchronousPull: title: Synchronous Pull description: Specifies to synchronously pull batches of messages. type: boolean default: false maxMessagesPerPoll: title: Max Messages Per Poll description: The maximum number of messages to receive from the server in a single API call. type: integer default: 1 concurrentConsumers: title: Concurrent Consumers description: The number of parallel streams to consume from the subscription. type: integer default: 1 bucketNameOrArn: title: Bucket Name Or ARN description: The Google Cloud Storage bucket name or Bucket Amazon Resource Name (ARN). type: string getObject: title: Get Object in Bucket description: >- If `getObject` is enabled, then the file created in the Bucket is retreived and returned as body, if not only the event is returned as body. type: boolean default: false dependencies: - "camel:kamelet" - "camel:google-pubsub" - "camel:google-storage" - "camel:jackson" - "camel:core" template: from: uri: "google-pubsub://{{projectId}}:{{subscriptionName}}" parameters: serviceAccountKey: "base64:{{serviceAccountKey}}" synchronousPull: "{{synchronousPull}}" maxMessagesPerPoll: "{{maxMessagesPerPoll}}" concurrentConsumers: "{{concurrentConsumers}}" steps: - choice: precondition: true when: - simple: '${properties:getObject:true}' steps: - setProperty: name: google-storage-event-type simple: "${headers.CamelGooglePubsubAttributes[eventType]}" - setProperty: name: google-storage-object-id simple: "${headers.CamelGooglePubsubAttributes[objectId]}" - setProperty: name: google-storage-bucket-id simple: "${headers.CamelGooglePubsubAttributes[bucketId]}" - choice: when: - simple: '${exchangeProperty.google-storage-event-type} == "OBJECT_FINALIZE" && ${exchangeProperty.google-storage-bucket-id} == "{{bucketNameOrArn}}"' steps: - toD: >- google-storage:{{bucketNameOrArn}}?serviceAccountKey=base64:{{serviceAccountKey}}&operation=getObject&objectName=${exchangeProperty.google-storage-object-id} - to: 'kamelet:sink' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-storage-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Storage" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Google Storage Sink" description: Upload objects to Google Cloud Storage. required: - bucketNameOrArn type: object properties: bucketNameOrArn: title: Bucket Name Or ARN description: The Google Cloud Storage bucket name or Bucket Amazon Resource Name (ARN). type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for Google Cloud Storage access. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the Google Cloud Storage bucket. type: boolean default: false dependencies: - "camel:core" - "camel:kamelet" - "camel:google-storage" - "camel:jackson" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelGoogleCloudStorageObjectName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelGoogleCloudStorageObjectName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelGoogleCloudStorageObjectName simple: "${exchangeId}" - to: uri: "google-storage://{{bucketNameOrArn}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" serviceAccountKey: "base64:{{?serviceAccountKey}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: google-storage-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Storage" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Storage Source" description: Consume objects from Google Cloud Storage. required: - bucketNameOrArn type: object properties: bucketNameOrArn: title: Bucket Name Or ARN description: The Google Cloud Storage bucket name or Bucket Amazon Resource Name (ARN). type: string serviceAccountKey: title: Service Account Key description: The service account key to use as credentials for Google Cloud Storage access. You must encode this value in base64. type: binary x-descriptors: - urn:camel:group:credentials deleteAfterRead: title: Auto-delete Objects description: Specifies to delete objects after consuming them. type: boolean default: true autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the Google Cloud Storage bucket. type: boolean default: false prefix: title: Prefix description: The prefix which is used in the BlobListOptions to only consume objects we are interested in. type: string filter: title: Filter description: A regular expression to include only blobs with name matching it. type: string dataTypes: out: default: binary headers: CamelGoogleCloudStorageBucketName: title: Google Cloud Storage Bucket Name description: The bucket name which has been used to retrieve objects type: string CamelGoogleCloudStorageObjectName: title: Google Cloud Storage Object Name description: The object name under which the retrieved object is stored type: string CamelGoogleCloudStorageContentType: title: Content Type description: The content type of the retrieved object. default: application/octet-stream type: string CamelGoogleCloudStorageETag: title: ETag Value description: The hex encoded 128-bit MD5 digest of the associated object according to RFC 1864. type: string types: binary: format: "application-octet-stream" description: Default binary representation of the Google Storage Cloud object retrieved from the bucket. mediaType: application/octet-stream cloudevents: format: "aws2-s3:application-cloudevents" description: Output data type represents Google Storage download response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Google Storage bucket and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.google.storage.downloadTo" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Google Cloud Storage bucket name with prefix "google.storage.bucket.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. Usually the Google Cloud Storage object name. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string dependencies: - "camel:kamelet" - "camel:google-storage" - "camel:jackson" template: from: uri: "google-storage://{{bucketNameOrArn}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" serviceAccountKey: "base64:{{?serviceAccountKey}}" deleteAfterRead: "{{deleteAfterRead}}" filter: "{{?filter}}" prefix: "{{?prefix}}" steps: - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: graphql-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Graphql" camel.apache.org/kamelet.namespace: "Graphql" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "GraphQL Sink" description: Forward data to a GraphQL endpoint. required: - url type: object properties: url: title: GraphQL Server URL description: The URL to which you want to send data. type: string example: "http://example.com/graphql" pattern: "^(http|https)://.*" accessToken: title: GraphQL Access Token description: The access Token to use to access GraphQL server type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:graphql" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - to: uri: "graphql://{{url}}" parameters: accessToken: "{{?accessToken}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: has-header-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Has Header Filter Action" description: "Filter message based on the presence of one header." required: - name properties: name: title: Header Name description: The header name to evaluate. The header name must be passed by the source Kamelet. For Knative only, the name of the header requires a CloudEvent (ce-) prefix. type: string example: headerName value: title: Header Value description: An optional header value to compare the header to type: string example: headerValue type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - setProperty: name: hasHeaderFilterActionValue constant: "{{value:}}" - choice: when: - simple: "${exchangeProperty[hasHeaderFilterActionValue]} != ''" steps: - filter: simple: "${header[{{name}}]} != ${exchangeProperty[hasHeaderFilterActionValue]}" steps: - stop: {} otherwise: steps: - filter: simple: "${header[{{name}}]} == null" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: header-matches-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Header Matches Filter Action" description: "Filter based on header value compared to regex." required: - regex properties: regex: title: Regex description: The Regex to Evaluate against the Kafka topic name type: string headerName: title: Header Name description: The header name to get the value to compare type: string example: headerName type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - filter: simple: "${header[{{headerName}}]} !regex '{{regex}}'" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: hoist-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Hoist Field Action" description: "Wrap data in a single field." required: - field properties: field: title: Field description: The name of the field that will contain the event. type: string type: object dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:kafka" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: "field" constant: "{{field}}" - bean: "org.apache.camel.component.kafka.transform.HoistField" - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: http-secured-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "HTTP" camel.apache.org/kamelet.namespace: "HTTP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Secured HTTP Sink" description: Forwards an event to a secured HTTP endpoint. Supports Oauth and Basic authentication. required: - url type: object properties: url: title: URL description: The URL to send data to type: string example: "https://my-service/path" pattern: "^(http|https)://.*" method: title: Method description: The HTTP method to use type: string default: POST enum: ["GET", "POST", "PUT", "DELETE", "HEAD", "OPTIONS", "TRACE", "PATCH"] authMethod: title: Authentication Method description: Authentication methods allowed to use as a comma separated list of values Basic, Digest or NTLM. type: string authenticationPreemptive: title: Authentication Preemptive description: If this option is true, camel-http sends preemptive basic authentication to the server. type: boolean default: false authUsername: title: Authentication Username description: Authentication username type: string x-descriptors: - urn:camel:group:credentials authPassword: title: Authentication Password description: Authentication password type: string format: password x-descriptors: - urn:camel:group:credentials oauth2ClientId: title: Oauth2 Client Id description: Oauth2 Client Id type: string format: password x-descriptors: - urn:camel:group:credentials oauth2ClientSecret: title: Oauth2 Client Secret description: Oauth2 Client Secret type: string format: password x-descriptors: - urn:camel:group:credentials oauth2TokenEndpoint: title: Oauth2 Token Endpoint description: Oauth2 Token Endpoint type: string x-descriptors: - urn:camel:group:credentials oauth2Scope: title: Oauth2 Scope description: Oauth2 Scope type: string x-descriptors: - urn:camel:group:credentials dependencies: - "camel:http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - removeHeader: name: CamelHttpUri - setHeader: name: CamelHttpMethod constant: "{{method}}" - to: uri: "{{url}}" parameters: authMethod: "{{?authMethod}}" authUsername: "{{?authUsername}}" authPassword: "{{?authPassword}}" oauth2ClientId: "{{?oauth2ClientId}}" oauth2ClientSecret: "{{?oauth2ClientSecret}}" oauth2Scope: "{{?oauth2Scope}}" oauth2TokenEndpoint: "{{?oauth2TokenEndpoint}}" authenticationPreemptive: "{{authenticationPreemptive}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: http-secured-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "HTTP" camel.apache.org/kamelet.namespace: "HTTP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "HTTP Secured Source" description: Periodically fetches a secured HTTP resource and provides the content as output. Supports Oauth and Basic authentication. required: - url type: object properties: period: title: Period between Updates description: The interval between fetches in milliseconds type: integer default: 10000 contentType: title: Content Type description: The content type accepted for the resource type: string default: "application/json" url: title: URL description: The URL to fetch for data type: string example: "https://gist.githubusercontent.com/nicolaferraro/e3c72ace3c751f9f88273896611ce5fe/raw/3b6f54060bacb56b6719b7386a4645cb59ad6cc1/quote.json" pattern: "^(http|https)://.*" authMethod: title: Authentication Method description: Authentication methods allowed to use as a comma separated list of values Basic, Digest or NTLM. type: string authenticationPreemptive: title: Authentication Preemptive description: If this option is true, camel-http sends preemptive basic authentication to the server. type: boolean default: false authUsername: title: Authentication Username description: Authentication username type: string x-descriptors: - urn:camel:group:credentials authPassword: title: Authentication Password description: Authentication password type: string format: password x-descriptors: - urn:camel:group:credentials oauth2ClientId: title: Oauth2 Client Id description: Oauth2 Client Id type: string format: password x-descriptors: - urn:camel:group:credentials oauth2ClientSecret: title: Oauth2 Client Secret description: Oauth2 Client Secret type: string format: password x-descriptors: - urn:camel:group:credentials oauth2TokenEndpoint: title: Oauth2 Token Endpoint description: Oauth2 Token Endpoint type: string x-descriptors: - urn:camel:group:credentials oauth2Scope: title: Oauth2 Scope description: Oauth2 Scope type: string x-descriptors: - urn:camel:group:credentials dependencies: - "camel:http" - "camel:kamelet" - "camel:core" - "camel:timer" template: from: uri: "timer:fetch" parameters: period: "{{period}}" steps: - setHeader: name: "Accept" constant: "{{contentType}}" - to: uri: "{{url}}" parameters: authMethod: "{{?authMethod}}" authUsername: "{{?authUsername}}" authPassword: "{{?authPassword}}" oauth2ClientId: "{{?oauth2ClientId}}" oauth2ClientSecret: "{{?oauth2ClientSecret}}" oauth2Scope: "{{?oauth2Scope}}" oauth2TokenEndpoint: "{{?oauth2TokenEndpoint}}" authenticationPreemptive: "{{authenticationPreemptive}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: http-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "HTTP" camel.apache.org/kamelet.namespace: "HTTP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "HTTP Sink" description: Forward data to a HTTP or HTTPS endpoint. required: - url type: object properties: url: title: URL description: The URL to which you want to send data. type: string example: "https://my-service/path" pattern: "^(http|https)://.*" method: title: Method description: The HTTP method to use. type: string default: POST enum: ["GET", "POST", "PUT", "DELETE", "HEAD", "OPTIONS", "TRACE", "PATCH"] dependencies: - "camel:http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - removeHeader: name: CamelHttpUri - setHeader: name: CamelHttpMethod constant: "{{method}}" - to: "{{url}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: http-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "HTTP" camel.apache.org/kamelet.namespace: "HTTP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "HTTP Source" description: Periodically fetches an HTTP resource and provides the content as output. required: - url type: object properties: period: title: Period between Updates description: The interval between fetches in milliseconds. type: integer default: 10000 contentType: title: Content Type description: The content type accepted for the resource. type: string default: "application/json" url: title: URL description: The URL to fetch for data. type: string example: "https://gist.githubusercontent.com/nicolaferraro/e3c72ace3c751f9f88273896611ce5fe/raw/3b6f54060bacb56b6719b7386a4645cb59ad6cc1/quote.json" pattern: "^(http|https)://.*" dependencies: - "camel:http" - "camel:kamelet" - "camel:core" - "camel:timer" template: from: uri: "timer:fetch" parameters: period: "{{period}}" steps: - setHeader: name: "Accept" constant: "{{contentType}}" - to: "{{url}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: infinispan-sink labels: camel.apache.org/kamelet.type: "sink" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Infinispan" camel.apache.org/kamelet.namespace: "Cache" camel.apache.org/kamelet.icon: "" spec: definition: title: "Infinispan Sink" description: Write object to an Infinispan cache. required: - cacheName - hosts - username - password type: object properties: cacheName: title: Cache Name description: The name of the Infinispan cache to use type: string hosts: title: Hosts description: Specifies the host of the cache on Infinispan instance type: string secure: title: Secure description: If the Infinispan instance is secured or not type: boolean default: true username: title: Username description: Username to connect to Infinispan. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to Infinispan. type: string format: password x-descriptors: - urn:camel:group:credentials saslMechanism: title: SASL Mechanism description: The SASL Mechanism to use type: string default: "DIGEST-MD5" securityRealm: title: Security Realm description: Define the security realm to access the infinispan instance type: string default: "default" securityServerName: title: Security Server name description: Define the security server name to access the infinispan instance type: string default: "infinispan" dependencies: - "camel:kamelet" - "camel:core" - "camel:infinispan" template: beans: - name: local-infinispan type: "#class:org.apache.camel.component.infinispan.remote.InfinispanRemoteComponent" from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: CamelInfinispanKey simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: CamelInfinispanKey simple: "${header[ce-key]}" otherwise: steps: - setHeader: name: CamelInfinispanKey simple: "${exchangeId}" - setHeader: name: CamelInfinispanValue simple: "${body}" - to: uri: "{{local-infinispan}}:{{cacheName}}" parameters: hosts: "{{hosts}}" secure: "{{secure}}" username: "{{username}}" password: "{{password}}" saslMechanism: "{{saslMechanism}}" securityRealm: "{{securityRealm}}" securityServerName: "{{securityServerName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: infinispan-source labels: camel.apache.org/kamelet.type: "source" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Infinispan" camel.apache.org/kamelet.namespace: "Cache" camel.apache.org/kamelet.icon: "" spec: definition: title: "Infinispan Source" description: Get Events from an Infinispan cache required: - cacheName - hosts - username - password type: object properties: cacheName: title: Cache Name description: The name of the Infinispan cache to use type: string hosts: title: Hosts description: Specifies the host of the cache on Infinispan instance type: string secure: title: Secure description: If the Infinispan instance is secured or not type: boolean default: true username: title: Username description: Username to connect to Infinispan. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to Infinispan. type: string format: password x-descriptors: - urn:camel:group:credentials saslMechanism: title: SASL Mechanism description: The SASL Mechanism to use type: string default: "DIGEST-MD5" securityRealm: title: Security Realm description: Define the security realm to access the infinispan instance type: string default: "default" securityServerName: title: Security Server name description: Define the security server name to access the infinispan instance type: string default: "infinispan" eventTypes: title: Infinispan Cluster Name description: Specifies the set of event types to register by the consumer. Multiple event can be separated by comma without spaces. type: string example: "CLIENT_CACHE_ENTRY_CREATED,CLIENT_CACHE_ENTRY_MODIFIED" default: "CLIENT_CACHE_ENTRY_CREATED,CLIENT_CACHE_ENTRY_MODIFIED,CLIENT_CACHE_ENTRY_REMOVED,CLIENT_CACHE_ENTRY_EXPIRED,CLIENT_CACHE_FAILOVER" enum: ["CLIENT_CACHE_ENTRY_CREATED", "CLIENT_CACHE_ENTRY_MODIFIED", "CLIENT_CACHE_ENTRY_REMOVED", "CLIENT_CACHE_ENTRY_EXPIRED", "CLIENT_CACHE_FAILOVER"] dependencies: - "camel:kamelet" - "camel:core" - "camel:infinispan" template: beans: - name: local-infinispan type: "#class:org.apache.camel.component.infinispan.remote.InfinispanRemoteComponent" from: uri: "{{local-infinispan}}:{{cacheName}}" parameters: hosts: "{{hosts}}" secure: "{{secure}}" username: "{{username}}" password: "{{password}}" saslMechanism: "{{saslMechanism}}" securityRealm: "{{securityRealm}}" securityServerName: "{{securityServerName}}" eventTypes: "{{eventTypes}}" steps: - setHeader: name: infinispan-cache-name simple: "${header[CamelInfinispanCacheName]}" - setHeader: name: ce-infinispancachename simple: "${header[CamelInfinispanCacheName]}" - setHeader: name: infinispan-entry-version simple: "${header[CamelInfinispanEntryVersion]}" - setHeader: name: ce-infinispanentryversion simple: "${header[CamelInfinispanEntryVersion]}" - setHeader: name: infinispan-event-type simple: "${header[CamelInfinispanEventType]}" - setHeader: name: ce-infinispaneventtype simple: "${header[CamelInfinispanEventType]}" - setHeader: name: infinispan-key simple: "${header[CamelInfinispanKey]}" - setHeader: name: ce-infinispankey simple: "${header[CamelInfinispanKey]}" - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: insert-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Insert Field Action" description: Adds a custom field with a simple language parsed value to the message in transit. required: - field - value properties: field: title: Field description: The name of the field to be added. type: string value: title: Value description: The value of the field. type: string type: object dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:kafka" template: beans: - name: insertField type: "#class:org.apache.camel.component.kafka.transform.InsertField" properties: field: '{{field}}' value: '{{value}}' from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - process: ref: "{{insertField}}" - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: insert-header-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Insert Header Action" description: "Adds an header with a simple language parsed expression to the message in transit." required: - name - value properties: name: title: Name description: The name of the header to be added. For Knative only, the name of the header requires a CloudEvent (ce-) prefix. type: string example: headername value: title: Value description: The value of the header to be added type: string type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - setHeader: name: "{{name}}" simple: "{{value}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: is-tombstone-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Is Tombstone Filter Action" description: "Filter based on the presence of body or not." type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - filter: simple: "${body} == null || ${body} == ''" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-add-comment-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Jira Add Comment Sink" description: Add a new comment to an existing issue in Jira. required: - jiraUrl type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira type: string example: http://my_jira.com:8081 username: title: Username description: The username to access Jira type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access Jira type: string format: password x-descriptors: - urn:camel:group:credentials personal-token: title: Personal Token description: Personal Token type: string x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[ce-issueKey]}" steps: - setHeader: name: issueKey simple: "${header[ce-issueKey]}" - to: uri: "jira:AddComment" parameters: jiraUrl: "{{jiraUrl}}" username: "{{?username}}" password: "{{?password}}" accessToken: "{{?personal-token}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-add-issue-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Jira Add Issue Sink" description: Add a new issue to Jira. required: - jiraUrl type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira type: string example: http://my_jira.com:8081 username: title: Username description: The username to access Jira type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access Jira type: string format: password x-descriptors: - urn:camel:group:credentials personal-token: title: Personal Token description: Personal Token type: string x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[ce-projectKey]}" steps: - setHeader: name: projectKey simple: "${header[ce-projectKey]}" - choice: when: - simple: "${header[ce-issueTypeName]}" steps: - setHeader: name: issueTypeName simple: "${header[ce-issueTypeName]}" - choice: when: - simple: "${header[ce-issueSummary]}" steps: - setHeader: name: issueSummary simple: "${header[ce-issueSummary]}" - choice: when: - simple: "${header[ce-issueAssignee]}" steps: - setHeader: name: issueAssignee simple: "${header[ce-issueAssignee]}" - choice: when: - simple: "${header[ce-issuePriorityName]}" steps: - setHeader: name: issuePriorityName simple: "${header[ce-issuePriorityName]}" - choice: when: - simple: "${header[ce-issueComponents]}" steps: - setHeader: name: issueComponents simple: "${header[ce-issueComponents]}" - choice: when: - simple: "${header[ce-issueDescription]}" steps: - setHeader: name: issueDescription simple: "${header[ce-issueDescription]}" - to: uri: "jira:AddIssue" parameters: jiraUrl: "{{jiraUrl}}" username: "{{?username}}" password: "{{?password}}" accessToken: "{{?personal-token}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-oauth-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Jira oauth Source" description: Receive notifications about new issues from Jira through OAuth authentication. required: - jiraUrl - accessToken - verificationCode - consumerKey - privateKey - jql type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira. type: string example: http://my_jira.com:8081 accessToken: title: Username description: The access token generated by the Jira server. type: string format: password x-descriptors: - urn:camel:group:credentials verificationCode: title: Password description: The verification code from Jira generated in the first step of the authorization proccess. type: string format: password x-descriptors: - urn:camel:group:credentials consumerKey: title: Password description: The consumer key from Jira settings. type: string format: password x-descriptors: - urn:camel:group:credentials privateKey: title: Password description: The private key generated by the client to encrypt the conversation to the server. type: string format: password x-descriptors: - urn:camel:group:credentials jql: title: JQL description: A query to filter issues. type: string example: project=MyProject types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "jira:newIssues" parameters: jiraUrl: "{{jiraUrl}}" accessToken: "{{accessToken}}" verificationCode: "{{verificationCode}}" privateKey: "RAW({{privateKey}})" consumerKey: "{{consumerKey}}" jql: "{{jql}}" steps: - marshal: json: library: Jackson moduleClassNames: com.fasterxml.jackson.datatype.joda.JodaModule - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Jira Source" description: Receive notifications about new issues from Jira. required: - jiraUrl type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira. type: string example: http://my_jira.com:8081 username: title: Username description: The username to access Jira. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access Jira. type: string format: password x-descriptors: - urn:camel:group:credentials personal-token: title: Personal Token description: Personal Token type: string x-descriptors: - urn:camel:group:credentials jql: title: JQL description: A query to filter issues. type: string example: project=MyProject types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "jira:newIssues" parameters: jiraUrl: "{{jiraUrl}}" username: "{{?username}}" password: "{{?password}}" accessToken: "{{?personal-token}}" jql: "{{jql}}" steps: - marshal: json: library: Jackson moduleClassNames: com.fasterxml.jackson.datatype.joda.JodaModule - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-transition-issue-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Jira Transition Issue Sink" description: Sets a new status (transition to) of an existing issue in Jira. required: - jiraUrl type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira type: string example: http://my_jira.com:8081 username: title: Username description: The username to access Jira type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access Jira type: string format: password x-descriptors: - urn:camel:group:credentials personal-token: title: Personal Token description: Personal Token type: string x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[ce-issueKey]}" steps: - setHeader: name: issueKey simple: "${header[ce-issueKey]}" - choice: when: - simple: "${header[ce-issueTransitionId]}" steps: - setHeader: name: issueTransitionId simple: "${header[ce-issueTransitionId]}" - to: uri: "jira:transitionIssue" parameters: jiraUrl: "{{jiraUrl}}" username: "{{?username}}" password: "{{?password}}" accessToken: "{{?personal-token}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jira-update-issue-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "JIRA" camel.apache.org/kamelet.namespace: "JIRA" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Jira Update Issue Sink" description: Update fields of an existing issue in Jira. required: - jiraUrl type: object properties: jiraUrl: title: Jira URL description: The URL of your instance of Jira type: string example: http://my_jira.com:8081 username: title: Username description: The username to access Jira type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access Jira type: string format: password x-descriptors: - urn:camel:group:credentials personal-token: title: Personal Token description: Personal Token type: string x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:jira" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[ce-issueKey]}" steps: - setHeader: name: issueKey simple: "${header[ce-issueKey]}" - choice: when: - simple: "${header[ce-issueTypeName]}" steps: - setHeader: name: issueTypeName simple: "${header[ce-issueTypeName]}" - choice: when: - simple: "${header[ce-issueSummary]}" steps: - setHeader: name: issueSummary simple: "${header[ce-issueSummary]}" - choice: when: - simple: "${header[ce-issueAssignee]}" steps: - setHeader: name: issueAssignee simple: "${header[ce-issueAssignee]}" - choice: when: - simple: "${header[ce-issuePriorityName]}" steps: - setHeader: name: issuePriorityName simple: "${header[ce-issuePriorityName]}" - choice: when: - simple: "${header[ce-issueComponents]}" steps: - setHeader: name: issueComponents simple: "${header[ce-issueComponents]}" - choice: when: - simple: "${header[ce-issueDescription]}" steps: - setHeader: name: issueDescription simple: "${header[ce-issueDescription]}" - to: uri: "jira:UpdateIssue" parameters: jiraUrl: "{{jiraUrl}}" username: "{{?username}}" password: "{{?password}}" accessToken: "{{?personal-token}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-amqp-10-sink annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - AMQP 1.0 Sink" description: "Send data to any AMQP 1.0 compliant message broker by using the Apache Qpid JMS client." required: - destinationName - remoteURI type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string remoteURI: title: "Broker URL" description: "The JMS URL." type: string example: "amqp://my-host:31616" dependencies: - "camel:jms" - "camel:amqp" - "camel:kamelet" template: beans: - name: connectionFactoryBean type: "#class:org.apache.qpid.jms.JmsConnectionFactory" properties: remoteURI: '{{remoteURI}}' from: uri: "kamelet:source" steps: - to: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{connectionFactoryBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-amqp-10-source annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - AMQP 1.0 Source" description: "Consume data from any AMQP 1.0 compliant message broker by using the Apache Qpid JMS client." required: - destinationName - remoteURI type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string remoteURI: title: "Broker URL" description: "The JMS URL." type: string example: "amqp://my-host:31616" dependencies: - "camel:jms" - "camel:amqp" - "camel:kamelet" template: beans: - name: connectionFactoryBean type: "#class:org.apache.qpid.jms.JmsConnectionFactory" properties: remoteURI: '{{remoteURI}}' from: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{connectionFactoryBean}}" steps: - to: uri: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-apache-artemis-sink annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - Apache Artemis Sink" description: "Send data to an Apache Artemis message broker by using JMS." required: - destinationName - brokerURL type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string example: person brokerURL: title: "Broker URL" description: "The JMS URL." type: string example: "tcp://my-host:61616" dependencies: - "camel:jms" - "camel:kamelet" - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.42.0" template: beans: - name: connectionFactoryBean type: "#class:org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory" properties: brokerURL: '{{brokerURL}}' from: uri: "kamelet:source" steps: - to: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{connectionFactoryBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-apache-artemis-source annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - Apache Artemis Source" description: "Receive data from an Apache Artemis message broker by using JMS." required: - destinationName - brokerURL type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string brokerURL: title: "Broker URL" description: "The JMS URL." type: string example: "tcp://my-host:61616" dependencies: - "camel:jms" - "camel:kamelet" - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.42.0" template: beans: - name: connectionFactoryBean type: "#class:org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory" properties: brokerURL: '{{brokerURL}}' from: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{connectionFactoryBean}}" steps: - to: uri: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-ibm-mq-sink annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - IBM MQ Sink" description: A Kamelet that can produce events to an IBM MQ message queue using JMS. required: - serverName - serverPort - destinationName - queueManager - channel - username - password type: object properties: serverName: title: "IBM MQ Server name" description: "IBM MQ Server name or address." type: string serverPort: title: "IBM MQ Server Port" description: "IBM MQ Server port." type: integer default: 1414 destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The destination name." type: string queueManager: title: "IBM MQ Queue Manager" description: "Name of the IBM MQ Queue Manager." type: string channel: title: "IBM MQ Channel" description: "Name of the IBM MQ Channel." type: string clientId: title: "IBM MQ Client ID" description: "Name of the IBM MQ Client ID." type: string username: title: "Username" description: "Username to authenticate to IBM MQ server." type: string password: title: "Password" description: "Password to authenticate to IBM MQ server." type: string format: password x-descriptors: - urn:camel:group:credentials sslCipherSuite: title: "CipherSuite" description: "CipherSuite to use for enabling TLS." type: string dependencies: - "camel:jms" - "camel:kamelet" template: beans: - name: wmqConnectionFactory type: "#class:com.ibm.mq.jakarta.jms.MQConnectionFactory" properties: XMSC_WMQ_HOST_NAME: '{{serverName}}' XMSC_WMQ_PORT: '{{serverPort}}' XMSC_WMQ_CHANNEL: '{{channel}}' XMSC_WMQ_QUEUE_MANAGER: '{{queueManager}}' XMSC_WMQ_CONNECTION_MODE: 1 XMSC_USERID: '{{username}}' XMSC_PASSWORD: '{{password}}' XMSC_CLIENT_ID: '{{?clientId}}' XMSC_WMQ_SSL_CIPHER_SUITE: '{{?sslCipherSuite}}' from: uri: "kamelet:source" steps: - to: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{wmqConnectionFactory}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-ibm-mq-source annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS - IBM MQ Source" description: A Kamelet that can read events from an IBM MQ message queue using JMS. required: - serverName - serverPort - destinationName - queueManager - channel - username - password type: object properties: serverName: title: "IBM MQ Server name" description: "IBM MQ Server name or address." type: string serverPort: title: "IBM MQ Server Port" description: "IBM MQ Server port." type: integer default: 1414 destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The destination name." type: string queueManager: title: "IBM MQ Queue Manager" description: "Name of the IBM MQ Queue Manager." type: string channel: title: "IBM MQ Channel" description: "Name of the IBM MQ Channel." type: string clientId: title: "IBM MQ Client ID" description: "Name of the IBM MQ Client ID." type: string username: title: "Username" description: "Username to authenticate to IBM MQ server." type: string password: title: "Password" description: "Password to authenticate to IBM MQ server." type: string format: password x-descriptors: - urn:camel:group:credentials sslCipherSuite: title: "CipherSuite" description: "CipherSuite to use for enabling TLS." type: string dependencies: - "camel:jms" - "camel:kamelet" template: beans: - name: wmqConnectionFactory type: "#class:com.ibm.mq.jakarta.jms.MQConnectionFactory" properties: XMSC_WMQ_HOST_NAME: '{{serverName}}' XMSC_WMQ_PORT: '{{serverPort}}' XMSC_WMQ_CHANNEL: '{{channel}}' XMSC_WMQ_QUEUE_MANAGER: '{{queueManager}}' XMSC_WMQ_CONNECTION_MODE: 1 XMSC_USERID: '{{username}}' XMSC_PASSWORD: '{{password}}' XMSC_CLIENT_ID: '{{?clientId}}' XMSC_WMQ_SSL_CIPHER_SUITE: '{{?sslCipherSuite}}' from: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{wmqConnectionFactory}}" steps: - to: uri: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-pooled-apache-artemis-sink annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS Pooled - Apache Artemis Sink" description: "Send data to an Apache Artemis message broker by using JMS Pooled." required: - destinationName - brokerURL type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string example: person brokerURL: title: "Broker URL" description: "The JMS URL." type: string example: "tcp://my-host:61616" username: title: "Broker Username" description: "The JMS Broker Username." type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required password: title: "Broker Password" description: "The JMS Broker Password." type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required maxSessionsPerConnection: title: "Max Sessions Per Connection" description: "The maximum number of pooled sessions per connection in the pool." type: integer default: 500 maxIdleSessionsPerConnection: title: "Max Idle Sessions Per Connection" description: "The number of idle sessions allowed per connection before they are closed." type: integer default: 500 connectionIdleTimeout: title: "Connection Idle Timeout" description: "The maximum time a pooled Connection can sit unused before it is eligible for removal (in milliseconds)." type: integer default: 30000 dependencies: - "camel:jms" - "camel:kamelet" - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.42.0" - "mvn:org.messaginghub:pooled-jms:3.1.7" template: beans: - name: connectionFactoryBean type: "#class:org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory" properties: brokerURL: '{{brokerURL}}' user: '{{?username}}' password: '{{?password}}' - name: pooledFactoryBean type: "#class:org.messaginghub.pooled.jms.JmsPoolConnectionFactory" properties: connectionFactory: '#bean:{{connectionFactoryBean}}' maxSessionsPerConnection: "{{maxSessionsPerConnection}}" maxIdleSessionsPerConnection: "{{maxIdleSessionsPerConnection}}" connectionIdleTimeout: "{{connectionIdleTimeout}}" from: uri: "kamelet:source" steps: - to: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{pooledFactoryBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jms-pooled-apache-artemis-source annotations: camel.apache.org/kamelet.icon: "" camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "JMS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/requires.runtime: camel-k spec: definition: title: "JMS Pooled - Apache Artemis Source" description: "Receive data from an Apache Artemis message broker by using JMS Pooled Connection." required: - destinationName - brokerURL type: object properties: destinationType: title: "Destination Type" description: "The JMS destination type (queue or topic)." type: string default: queue destinationName: title: "Destination Name" description: "The JMS destination name." type: string brokerURL: title: "Broker URL" description: "The JMS URL." type: string example: "tcp://my-host:61616" username: title: "Broker Username" description: "The JMS Broker Username." type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required password: title: "Broker Password" description: "The JMS Broker Password." type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required maxSessionsPerConnection: title: "Max Session Per Connection" description: "The maximum number of pooled sessions per connection in the pool." type: integer default: 500 maxIdleSessionsPerConnection: title: "Max Idle Sessions Per Connection" description: "The number of idle sessions allowed per connection before they are closed." type: integer default: 500 connectionIdleTimeout: title: "Connection Idle Timeout" description: "The maximum time a pooled Connection can sit unused before it is eligible for removal (in milliseconds)." type: integer default: 30000 dependencies: - "camel:jms" - "camel:kamelet" - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.42.0" - "mvn:org.messaginghub:pooled-jms:3.1.7" template: beans: - name: connectionFactoryBean type: "#class:org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory" properties: brokerURL: '{{brokerURL}}' user: '{{?username}}' password: '{{?password}}' - name: pooledFactoryBean type: "#class:org.messaginghub.pooled.jms.JmsPoolConnectionFactory" properties: connectionFactory: '#bean:{{connectionFactoryBean}}' maxSessionsPerConnection: "{{maxSessionsPerConnection}}" maxIdleSessionsPerConnection: "{{maxIdleSessionsPerConnection}}" connectionIdleTimeout: "{{connectionIdleTimeout}}" from: uri: "jms:{{destinationType}}:{{destinationName}}" parameters: connectionFactory: "#bean:{{pooledFactoryBean}}" steps: - to: uri: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jolt-transformation-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Jolt Transformation Action" description: Apply a Jolt Transformation. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.json" pattern: "^(http|https|file|classpath|ref|bean)://.*" transform: title: Transform DSL description: Specifies the Transform DSL of the endpoint resource. If none is specified, Chainr is used. type: string default: "Chainr" enum: ["Chainr", "Shiftr", "Defaultr", "Removr", "Sortr"] dependencies: - "camel:jolt" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "jolt:" parameters: resourceUri: "{{template}}" transformDsl: "{{transform}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jslt-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "JSLT Action" description: Apply a JSLT query or transformation on JSON. required: - template type: object properties: template: title: Template description: The inline template for JSLT Transformation type: string example: "file://template.json" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:jslt" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "jslt:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: json-deserialize-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "JSON" spec: definition: title: "Json Deserialize Action" description: "Deserialize payload to JSON." type: object dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson" template: from: uri: kamelet:source steps: - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - removeHeader: name: "Content-Type" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: json-patch-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Json Patch Action" description: Apply a Json Patch Transformation. required: - template type: object properties: template: title: Template description: The json patch transformation type: string example: "file:////template.json" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:json-patch" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "json-patch:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: json-schema-validator-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "JSON" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Json Schema Validator Action" description: Apply a Json Schema Template to validate the payload against. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.json" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:json-validator" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "json-validator:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: json-serialize-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "JSON" spec: definition: title: "Json Serialize Action" description: "Serialize payload to JSON." type: object dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson" template: from: uri: kamelet:source steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: jsonata-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "JSON" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Jsonata Action" description: Apply a Jsonata Transformation. required: - template type: object properties: template: title: Template description: The inline template. type: string example: "file:////template.spec" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:jsonata" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "jsonata:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-apicurio-registry-not-secured-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Kafka Not Secured with Apicurio Registry Sink" description: Send data to Kafka topics on an insecure broker with Apicurio Registry. required: - topic - bootstrapServers - apicurioRegistryUrl type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names. type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs. type: string valueSerializer: title: Value Serializer description: Serliazer class for value that implements the Serializer interface. type: string default: "io.apicurio.registry.serde.avro.AvroKafkaSerializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL. type: string x-descriptors: - urn:keda:metadata:apicurioRegistryUrl - urn:keda:required avroDatumProvider: title: Avro Datum Provider description: How to write data with Avro. type: string default: "io.apicurio.registry.serde.avro.ReflectAvroDatumProvider" dependencies: - "camel:core" - "camel:kamelet" - "camel:kafka" - "mvn:io.apicurio:apicurio-registry-serdes-avro-serde:2.4.14.Final" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" valueSerializer: "{{valueSerializer}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.registry.avro-datum-provider: "{{avroDatumProvider}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-apicurio-registry-not-secured-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Not Secured with Apicurio Registry Source" description: Receive data from Kafka topics on an insecure broker combined with Apicurio Registry. required: - topic - bootstrapServers - apicurioRegistryUrl type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "io.apicurio.registry.serde.jsonschema.JsonSchemaKafkaDeserializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "mvn:io.quarkus:quarkus-apicurio-registry-json-schema:3.15.1" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" topicIsPattern: "{{topicIsPattern}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-azure-schema-registry-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Azure Kafka through Eventhubs with Azure Schema Registry Sink" description: Send data to Kafka topics on Azure Eventhubs combined with Azure Schema Registry. required: - topic - bootstrapServers - azureRegistryUrl - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials valueSerializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "com.microsoft.azure.schemaregistry.kafka.avro.KafkaAvroSerializer" azureRegistryUrl: title: Azure Schema Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required specificAvroValueType: title: Specific Avro Value Type description: The Specific Type Avro will have to deal with type: string example: "com.example.Order" dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" - "camel:azure-schema-registry" - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.2" - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.26" - "mvn:com.azure:azure-identity:1.16.2" template: beans: - name: defaultAzureCredential type: "#class:org.apache.camel.component.azure.schema.registry.DefaultAzureCredentialWrapper" from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="$ConnectionString" password={{password}};' valueSerializer: "{{valueSerializer}}" additionalProperties.schema.registry.url: "{{azureRegistryUrl}}" additionalProperties.schema.group: avro additionalProperties.schema.registry.credential: '#bean:defaultAzureCredential' additionalProperties.specific.avro.value.type: '#valueAs(java.lang.Class):{{specificAvroValueType}}' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-azure-schema-registry-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Kafka through Eventhubs with Azure Schema Registry Source" description: Receive data from Kafka topics on Azure Eventhubs combined with Azure Schema Registry. required: - topic - bootstrapServers - azureRegistryUrl - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "com.microsoft.azure.schemaregistry.kafka.avro.KafkaAvroDeserializer" azureRegistryUrl: title: Azure Schema Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required specificAvroValueType: title: Specific Avro Value Type description: The Specific Type Avro will have to deal with type: string example: "com.example.Order" topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "camel:azure-schema-registry" - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.2" - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.26" - "mvn:com.azure:azure-identity:1.16.2" template: beans: - name: defaultAzureCredential type: "#class:org.apache.camel.component.azure.schema.registry.DefaultAzureCredentialWrapper" - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="$ConnectionString" password={{password}};' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" topicIsPattern: "{{topicIsPattern}}" additionalProperties.schema.registry.url: "{{azureRegistryUrl}}" additionalProperties.schema.group: avro additionalProperties.schema.registry.credential: '#bean:defaultAzureCredential' additionalProperties.specific.avro.value.type: '#valueAs(java.lang.Class):{{specificAvroValueType}}' additionalProperties.specific.avro.reader: '#valueAs(boolean):true' steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-apicurio-registry-not-secured-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch Not Secured with Apicurio Registry Source" description: Receive data from Kafka topics in batch on an insecure broker combined with Apicurio Registry and commit them manually through KafkaManualCommit or auto commit. required: - topic - bootstrapServers - apicurioRegistryUrl type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names. type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs. type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer. type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits. type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP`. type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of `latest`, `earliest`, `none`. type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs. type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "io.apicurio.registry.serde.avro.AvroKafkaDeserializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL. type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required avroDatumProvider: title: Avro Datum Provider description: How to read data with Avro. type: string default: "io.apicurio.registry.serde.avro.ReflectAvroDatumProvider" batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll(). type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer. type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management. type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "mvn:io.quarkus:quarkus-apicurio-registry-avro:3.24.2" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.registry.avro-datum-provider: "{{avroDatumProvider}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-apicurio-registry-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch with Apicurio Registry secured with Keycloak Source" description: Receive data from Kafka topics in batch on an insecure broker combined with Apicurio Registry secured with Keycloak and commit them manually through KafkaManualCommit or auto commit. required: - topic - bootstrapServers - apicurioRegistryUrl - apicurioAuthServiceUrl - apicurioAuthRealm - apicurioAuthClientId - apicurioAuthClientSecret - apicurioAuthUsername - apicurioAuthPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "io.apicurio.registry.serde.avro.AvroKafkaDeserializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required avroDatumProvider: title: Avro Datum Provider description: How to read data with Avro type: string default: "io.apicurio.registry.serde.avro.ReflectAvroDatumProvider" batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer apicurioAuthServiceUrl: title: Apicurio Registry Auth Service URL description: The URL for Keycloak instance securing the Apicurio Registry type: string example: "http://my-keycloak.com:8080/" apicurioAuthRealm: title: Apicurio Registry Auth Realm description: The Realm in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientId: title: Apicurio Registry Auth Client ID description: The Client ID in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientSecret: title: Apicurio Registry Auth Client Secret description: The Client Secret in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required apicurioAuthUsername: title: Apicurio Registry Auth Username description: The Username in Keycloak instance securing the Apicurio Registry type: string apicurioAuthPassword: title: Apicurio Registry Auth Password description: The Password in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "mvn:io.quarkus:quarkus-apicurio-registry-avro:3.24.2" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.registry.avro-datum-provider: "{{avroDatumProvider}}" additionalProperties.apicurio.auth.service.url: "{{apicurioAuthServiceUrl}}" additionalProperties.apicurio.auth.realm: "{{apicurioAuthRealm}}" additionalProperties.apicurio.auth.client.id: "{{apicurioAuthClientId}}" additionalProperties.apicurio.auth.client.secret: "{{apicurioAuthClientSecret}}" additionalProperties.apicurio.auth.username: "{{apicurioAuthUsername}}" additionalProperties.apicurio.auth.password: "{{apicurioAuthPassword}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-azure-schema-registry-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Azure Kafka Batch through Eventhubs with Azure Schema Registry Source" description: Receive data from Kafka topics in batch on Azure Eventhubs combined with Azure Schema Registry and commit them manually through KafkaManualCommit or auto commit. required: - topic - bootstrapServers - azureRegistryUrl - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "com.microsoft.azure.schemaregistry.kafka.avro.KafkaAvroDeserializer" azureRegistryUrl: title: Azure Schema Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required specificAvroValueType: title: Specific Avro Value Type description: The Specific Type Avro will have to deal with type: string example: "com.example.Order" batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "camel:azure-schema-registry" - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.2" - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.26" - "mvn:com.azure:azure-identity:1.16.2" template: beans: - name: defaultAzureCredential type: "#class:org.apache.camel.component.azure.schema.registry.DefaultAzureCredentialWrapper" - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="$ConnectionString" password={{password}};' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" additionalProperties.schema.registry.url: "{{azureRegistryUrl}}" additionalProperties.schema.group: avro additionalProperties.schema.registry.credential: '#bean:defaultAzureCredential' additionalProperties.specific.avro.value.type: '#valueAs(java.lang.Class):{{specificAvroValueType}}' additionalProperties.specific.avro.reader: '#valueAs(boolean):true' steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-manual-commit-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Kafka Batch Manual Commit Action" description: "Manually commit Kafka Batch Offset." type: object dependencies: - "camel:kamelet" template: from: uri: kamelet:source steps: - bean: "org.apache.camel.component.kafka.BatchManualCommit" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-not-secured-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch Not Secured Source" description: Receive data from Kafka topics in batch on an insecure broker and commit them manually through KafkaManualCommit. required: - topic - bootstrapServers type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-scram-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" camel.apache.org/keda.authentication.sasl: "scram-sha-512" camel.apache.org/keda.authentication.tls: "enable" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch Scram Source" description: Receive data from Kafka topics in batch through SCRAM login module and commit them manually through KafkaManualCommit. This provides complete control over when messages are committed, allowing for custom processing logic before acknowledgment. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: SCRAM-SHA-512 user: title: Username description: Username to authenticate to Kafka type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:username - urn:keda:required password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{?bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.scram.ScramLoginModule required username="{{user}}" password="{{password}}";' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" camel.apache.org/keda.authentication.sasl: "plaintext" camel.apache.org/keda.authentication.tls: "enable" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch Source" description: Receive data from Kafka topics in batch through Plain Login Module and commit them manually through KafkaManualCommit. This provides complete control over when messages are committed, allowing for custom processing logic before acknowledgment. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN user: title: Username description: Username to authenticate to Kafka type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:username - urn:keda:required password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" from: uri: "kafka:{{topic}}" parameters: brokers: "{{?bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="{{user}}" password="{{password}}";' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-batch-ssl-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Batch SSL Source" description: Receive data from Kafka topics in batch with SSL/TLS support and commit them manually through KafkaManualCommit or automatically. required: - topic - bootstrapServers - sslTruststoreLocation - sslKeyPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: GSSAPI autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true sslKeyPassword: description: The password of the private key in the key store file. title: SSL Key Password type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required sslKeystorePassword: description: The store password for the key store file.This is optional for client and only needed if ssl.keystore.location is configured. title: SSL Keystore Password type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password sslEndpointAlgorithm: description: The endpoint identification algorithm to validate server hostname using server certificate. Use none or false to disable server hostname verification. title: SSL Endpoint Algorithm type: string default: https sslProtocol: description: The SSL protocol used to generate the SSLContext. Default setting is TLS, which is fine for most cases. Allowed values in recent JVMs are TLS, TLSv1.1 and TLSv1.2. SSL, SSLv2 and SSLv3 may be supported in older JVMs, but their usage is discouraged due to known security vulnerabilities. title: SSL Protocol type: string default: TLSv1.2 sslKeystoreLocation: description: The location of the key store file. This is optional for client and can be used for two-way authentication for client. title: SSL Keystore Location type: string sslTruststoreLocation: description: The location of the trust store file. title: SSL Truststore Location type: string sslEnabledProtocols: description: The list of protocols enabled for SSL connections. TLSv1.2, TLSv1.1 and TLSv1 are enabled by default. title: SSL Enabled Protocols type: string default: TLSv1.2,TLSv1.1,TLSv1 saslJaasConfig: description: Java Authentication and Authorization Service (JAAS) for Simple Authentication and Security Layer (SASL) configuration. title: JAAS Configuration type: string batchSize: title: Batch Dimension description: The maximum number of records returned in a single call to poll() type: integer default: 500 pollTimeout: title: Poll Timeout Interval description: The timeout used when polling the KafkaConsumer type: integer default: 5000 maxPollIntervalMs: title: Max Poll Interval description: The maximum delay between invocations of poll() when using consumer group management type: integer batchingIntervalMs: title: Batching Interval description: In consumer batching mode, then this option is specifying a time in millis, to trigger batch completion eager when the current batch size has not reached the maximum size defined by maxPollRecords. Notice the trigger is not exact at the given interval, as this can only happen between kafka polls (see pollTimeoutMs option). type: integer topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafka-ssl-source-local type: '#class:org.apache.camel.component.kafka.KafkaComponent' - name: manualCommitFactory type: "#class:org.apache.camel.component.kafka.consumer.DefaultKafkaManualCommitFactory" - name: kafka-ssl-source-configuration-local properties: brokers: '{{bootstrapServers}}' securityProtocol: '{{securityProtocol}}' sslKeystoreLocation: '{{sslKeystoreLocation}}' sslKeyPassword: '{{sslKeyPassword}}' sslKeystorePassword: '{{sslKeystorePassword}}' sslTruststoreLocation: '{{sslTruststoreLocation}}' sslProtocol: '{{sslProtocol}}' sslEnabledProtocols: '{{sslEnabledProtocols}}' sslEndpointAlgorithm: '{{sslEndpointAlgorithm}}' saslMechanism: '{{saslMechanism}}' groupId: '{{?consumerGroup}}' autoOffsetReset: '{{autoOffsetReset}}' pollOnError: '{{pollOnError}}' allowManualCommit: '{{allowManualCommit}}' autoCommitEnable: '{{autoCommitEnable}}' saslJaasConfig: '{{?saslJaasConfig}}' maxPollRecords: "{{batchSize}}" pollTimeoutMs: "{{pollTimeout}}" maxPollIntervalMs: "{{?maxPollIntervalMs}}" batchingIntervalMs: "{{?batchingIntervalMs}}" batching: true kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" topicIsPattern: "{{topicIsPattern}}" type: '#class:org.apache.camel.component.kafka.KafkaConfiguration' - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "{{kafka-ssl-source-local}}:{{topic}}" parameters: configuration: '#bean:{{kafka-ssl-source-configuration-local}}' steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-manual-commit-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Kafka Manual Commit Action" description: "Manually commit Kafka Offset." type: object dependencies: - "camel:kamelet" template: from: uri: kamelet:source steps: - bean: "org.apache.camel.component.kafka.ManualCommit" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-not-secured-apicurio-registry-json-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka not secured with Apicurio Registry secured with Keycloak for JSON schema support Source" description: Receive data from Kafka topics on an insecure broker combined with Apicurio Registry secured with Keycloak for JSON Schema support. required: - topic - bootstrapServers - apicurioRegistryUrl - apicurioAuthServiceUrl - apicurioAuthRealm - apicurioAuthClientId - apicurioAuthClientSecret - apicurioAuthUsername - apicurioAuthPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "io.apicurio.registry.serde.jsonschema.JsonSchemaKafkaDeserializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required apicurioAuthServiceUrl: title: Apicurio Registry Auth Service URL description: The URL for Keycloak instance securing the Apicurio Registry type: string example: "http://my-keycloak.com:8080/" apicurioAuthRealm: title: Apicurio Registry Auth Realm description: The Realm in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientId: title: Apicurio Registry Auth Client ID description: The Client ID in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientSecret: title: Apicurio Registry Auth Client Secret description: The Client Secret in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required apicurioAuthUsername: title: Apicurio Registry Auth Username description: The Username in Keycloak instance securing the Apicurio Registry type: string apicurioAuthPassword: title: Apicurio Registry Auth Password description: The Password in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "mvn:io.apicurio:apicurio-registry-serdes-jsonschema-serde:2.5.11.Final" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" topicIsPattern: "{{topicIsPattern}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.auth.service.url: "{{apicurioAuthServiceUrl}}" additionalProperties.apicurio.auth.realm: "{{apicurioAuthRealm}}" additionalProperties.apicurio.auth.client.id: "{{apicurioAuthClientId}}" additionalProperties.apicurio.auth.client.secret: "{{apicurioAuthClientSecret}}" additionalProperties.apicurio.auth.username: "{{apicurioAuthUsername}}" additionalProperties.apicurio.auth.password: "{{apicurioAuthPassword}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-not-secured-apicurio-registry-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Kafka Not Secured with Apicurio Registry secured with Keycloak Sink" description: Send data to Kafka topics on an insecure broker with Apicurio Registry secured with Keycloak. required: - topic - bootstrapServers - apicurioRegistryUrl - apicurioAuthServiceUrl - apicurioAuthRealm - apicurioAuthClientId - apicurioAuthClientSecret - apicurioAuthUsername - apicurioAuthPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string valueSerializer: title: Value Serializer description: Serliazer class for value that implements the Serializer interface. type: string default: "io.apicurio.registry.serde.avro.AvroKafkaSerializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:apicurioRegistryUrl - urn:keda:required avroDatumProvider: title: Avro Datum Provider description: How to write data with Avro type: string default: "io.apicurio.registry.serde.avro.ReflectAvroDatumProvider" apicurioAuthServiceUrl: title: Apicurio Registry Auth Service URL description: The URL for Keycloak instance securing the Apicurio Registry type: string example: "http://my-keycloak.com:8080/" apicurioAuthRealm: title: Apicurio Registry Auth Realm description: The Realm in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientId: title: Apicurio Registry Auth Client ID description: The Client ID in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientSecret: title: Apicurio Registry Auth Client Secret description: The Client Secret in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required apicurioAuthUsername: title: Apicurio Registry Auth Username description: The Username in Keycloak instance securing the Apicurio Registry type: string apicurioAuthPassword: title: Apicurio Registry Auth Password description: The Password in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required dependencies: - "camel:core" - "camel:kamelet" - "camel:kafka" - "mvn:io.apicurio:apicurio-registry-serdes-avro-serde:2.4.14.Final" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" valueSerializer: "{{valueSerializer}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.registry.avro-datum-provider: "{{avroDatumProvider}}" additionalProperties.apicurio.auth.service.url: "{{apicurioAuthServiceUrl}}" additionalProperties.apicurio.auth.realm: "{{apicurioAuthRealm}}" additionalProperties.apicurio.auth.client.id: "{{apicurioAuthClientId}}" additionalProperties.apicurio.auth.client.secret: "{{apicurioAuthClientSecret}}" additionalProperties.apicurio.auth.username: "{{apicurioAuthUsername}}" additionalProperties.apicurio.auth.password: "{{apicurioAuthPassword}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-not-secured-apicurio-registry-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka not secured with Apicurio Registry secured with Keycloak Source" description: Receive data from Kafka topics on an insecure broker combined with Apicurio Registry secured with Keycloak. required: - topic - bootstrapServers - apicurioRegistryUrl - apicurioAuthServiceUrl - apicurioAuthRealm - apicurioAuthClientId - apicurioAuthClientSecret - apicurioAuthUsername - apicurioAuthPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true valueDeserializer: title: Value Deserializer description: Deserializer class for value that implements the Deserializer interface. type: string default: "io.apicurio.registry.serde.avro.AvroKafkaDeserializer" apicurioRegistryUrl: title: Apicurio Registry URL description: The Apicurio Schema Registry URL type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required avroDatumProvider: title: Avro Datum Provider description: How to read data with Avro type: string default: "io.apicurio.registry.serde.avro.ReflectAvroDatumProvider" apicurioAuthServiceUrl: title: Apicurio Registry Auth Service URL description: The URL for Keycloak instance securing the Apicurio Registry type: string example: "http://my-keycloak.com:8080/" apicurioAuthRealm: title: Apicurio Registry Auth Realm description: The Realm in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientId: title: Apicurio Registry Auth Client ID description: The Client ID in Keycloak instance securing the Apicurio Registry type: string apicurioAuthClientSecret: title: Apicurio Registry Auth Client Secret description: The Client Secret in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required apicurioAuthUsername: title: Apicurio Registry Auth Username description: The Username in Keycloak instance securing the Apicurio Registry type: string apicurioAuthPassword: title: Apicurio Registry Auth Password description: The Password in Keycloak instance securing the Apicurio Registry type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" - "mvn:io.quarkus:quarkus-apicurio-registry-avro:3.24.2" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" valueDeserializer: "{{valueDeserializer}}" topicIsPattern: "{{topicIsPattern}}" additionalProperties.apicurio.registry.url: "{{apicurioRegistryUrl}}" additionalProperties.apicurio.registry.avro-datum-provider: "{{avroDatumProvider}}" additionalProperties.apicurio.auth.service.url: "{{apicurioAuthServiceUrl}}" additionalProperties.apicurio.auth.realm: "{{apicurioAuthRealm}}" additionalProperties.apicurio.auth.client.id: "{{apicurioAuthClientId}}" additionalProperties.apicurio.auth.client.secret: "{{apicurioAuthClientSecret}}" additionalProperties.apicurio.auth.username: "{{apicurioAuthUsername}}" additionalProperties.apicurio.auth.password: "{{apicurioAuthPassword}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-not-secured-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Kafka Not Secured Sink" description: Send data to Kafka topics on an insecure broker. required: - topic - bootstrapServers type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-not-secured-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Not Secured Source" description: Receive data from Kafka topics on an insecure broker. required: - topic - bootstrapServers type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:kafka" - "camel:core" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-scram-sink annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Kafka Scram Sink" description: Send data to Kafka topics through SCRAM login module. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names. type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs. type: string securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported. type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: SCRAM-SHA-512 user: title: Username description: Username to authenticate to Kafka . type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to authenticate to kafka. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.scram.ScramLoginModule required username="{{user}}" password="{{password}}";' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-scram-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" camel.apache.org/keda.authentication.sasl: "scram-sha-512" camel.apache.org/keda.authentication.tls: "enable" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Scram Source" description: Receive data from Kafka topics through SCRAM login module. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: SCRAM-SHA-512 user: title: Username description: Username to authenticate to Kafka type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:username - urn:keda:required password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{?bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.scram.ScramLoginModule required username="{{user}}" password="{{password}}";' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Kafka Sink" description: Send data to Kafka topics through Plain Login Module. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN user: title: Username description: Username to authenticate to Kafka type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: kafka.KEY simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: kafka.KEY simple: "${header[ce-key]}" - choice: when: - simple: "${header[partition-key]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[partition-key]}" - simple: "${header[ce-partitionkey]}" steps: - setHeader: name: kafka.PARTITION_KEY simple: "${header[ce-partitionkey]}" - to: uri: "kafka:{{topic}}" parameters: brokers: "{{bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="{{user}}" password="{{password}}";' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" camel.apache.org/keda.type: "kafka" camel.apache.org/keda.authentication.sasl: "plaintext" camel.apache.org/keda.authentication.tls: "enable" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka Source" description: Receive data from Kafka topics through Plain Login Module. required: - topic - bootstrapServers - user - password type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported type: string default: SASL_SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: PLAIN user: title: Username description: Username to authenticate to Kafka type: string x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:username - urn:keda:required password: title: Password description: Password to authenticate to kafka type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP` type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "kafka:{{topic}}" parameters: brokers: "{{?bootstrapServers}}" securityProtocol: "{{securityProtocol}}" saslMechanism: "{{saslMechanism}}" saslJaasConfig: 'org.apache.kafka.common.security.plain.PlainLoginModule required username="{{user}}" password="{{password}}";' autoCommitEnable: "{{autoCommitEnable}}" allowManualCommit: "{{allowManualCommit}}" pollOnError: "{{pollOnError}}" autoOffsetReset: "{{autoOffsetReset}}" groupId: "{{?consumerGroup}}" topicIsPattern: "{{topicIsPattern}}" steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-ssl-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "sink" spec: definition: description: Send data to Kafka topics wit TLS/SSL support. required: - topic - bootstrapServers - sslKeystoreLocation - sslKeystorePassword - sslTruststoreLocation - sslTruststorePassword - sslKeyPassword properties: bootstrapServers: description: Comma separated list of Kafka Broker URLs title: Brokers type: string sslKeystoreLocation: description: >- The location of the key store file. This is optional for client and can be used for two-way authentication for client. title: SSL Keystore Location type: string sslProtocol: default: TLSv1.2 description: >- The SSL protocol used to generate the SSLContext. Default setting is TLS, which is fine for most cases. Allowed values in recent JVMs are TLS, TLSv1.1 and TLSv1.2. SSL, SSLv2 and SSLv3 may be supported in older JVMs, but their usage is discouraged due to known security vulnerabilities. title: SSL Protocol type: string saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: GSSAPI sslEnabledProtocols: default: TLSv1.2,TLSv1.1,TLSv1 description: >- The list of protocols enabled for SSL connections. TLSv1.2, TLSv1.1 and TLSv1 are enabled by default. title: SSL Enabled Protocols type: string sslKeystorePassword: description: >- The store password for the key store file.This is optional for client and only needed if ssl.keystore.location is configured. title: SSL Keystore Password type: string format: password x-descriptors: - urn:camel:group:credentials sslTruststoreLocation: description: The location of the trust store file. title: SSL Truststore Location type: string sslTruststorePassword: description: The store password for the trust store file. title: SSL Truststore Password type: string format: password x-descriptors: - urn:camel:group:credentials sslKeyPassword: description: The password of the private key in the key store file. title: SSL Key Password type: string format: password x-descriptors: - urn:camel:group:credentials sslEndpointAlgorithm: description: The endpoint identification algorithm to validate server hostname using server certificate. Use none or false to disable server hostname verification. title: SSL Endpoint Algorithm type: string default: https topic: description: Comma separated list of Kafka topic names title: Topic Names type: string securityProtocol: default: SSL description: >- Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported title: Security Protocol type: string title: Kafka SSL Sink type: object dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafka-ssl-sink-local type: '#class:org.apache.camel.component.kafka.KafkaComponent' - name: kafka-ssl-sink-configuration-local properties: brokers: '{{bootstrapServers}}' securityProtocol: '{{securityProtocol}}' sslKeystoreLocation: '{{sslKeystoreLocation}}' sslKeyPassword: '{{sslKeyPassword}}' sslKeystorePassword: '{{sslKeystorePassword}}' sslTruststoreLocation: '{{sslTruststoreLocation}}' sslTruststorePassword: '{{sslTruststorePassword}}' sslProtocol: '{{sslProtocol}}' sslEnabledProtocols: '{{sslEnabledProtocols}}' sslEndpointAlgorithm: '{{sslEndpointAlgorithm}}' saslMechanism: '{{saslMechanism}}' type: '#class:org.apache.camel.component.kafka.KafkaConfiguration' from: uri: "kamelet:source" steps: - choice: when: - simple: ${header[key]} steps: - setHeader: name: kafka.KEY simple: ${header[key]} - simple: ${header[ce-key]} steps: - setHeader: name: kafka.KEY simple: ${header[ce-key]} - choice: when: - simple: ${header[partition-key]} steps: - setHeader: name: kafka.PARTITION_KEY simple: ${header[partition-key]} - simple: ${header[ce-partitionkey]} steps: - setHeader: name: kafka.PARTITION_KEY simple: ${header[ce-partitionkey]} - to: uri: '{{kafka-ssl-sink-local}}:{{topic}}' parameters: configuration: '#bean:{{kafka-ssl-sink-configuration-local}}' --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kafka-ssl-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/kamelet.namespace: "Kafka" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kafka SSL Source" description: Receive data from Kafka topics with SSL/TLS support required: - topic - bootstrapServers - sslTruststoreLocation - sslTruststorePassword - sslKeyPassword type: object properties: topic: title: Topic Names description: Comma separated list of Kafka topic names. type: string x-descriptors: - urn:keda:metadata:topic - urn:keda:required bootstrapServers: title: Bootstrap Servers description: Comma separated list of Kafka Broker URLs. type: string x-descriptors: - urn:keda:metadata:bootstrapServers - urn:keda:required securityProtocol: title: Security Protocol description: Protocol used to communicate with brokers. `SASL_PLAINTEXT`, `PLAINTEXT`, `SASL_SSL` and `SSL` are supported. type: string default: SSL saslMechanism: title: SASL Mechanism description: The Simple Authentication and Security Layer (SASL) Mechanism used. type: string default: GSSAPI autoCommitEnable: title: Auto Commit Enable description: If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer. type: boolean default: true allowManualCommit: title: Allow Manual Commit description: Whether to allow doing manual commits. type: boolean default: false pollOnError: title: Poll On Error Behavior description: What to do if kafka threw an exception while polling for new messages. There are 5 enums and the value can be one of `DISCARD`, `ERROR_HANDLER`, `RECONNECT`, `RETRY`, `STOP`. type: string default: "ERROR_HANDLER" autoOffsetReset: title: Auto Offset Reset description: What to do when there is no initial offset. There are 3 enums and the value can be one of latest, earliest, none. type: string default: "latest" x-descriptors: - urn:keda:metadata:offsetResetPolicy consumerGroup: title: Consumer Group description: A string that uniquely identifies the group of consumers to which this source belongs. type: string example: "my-group-id" x-descriptors: - urn:keda:metadata:consumerGroup - urn:keda:required deserializeHeaders: title: Automatically Deserialize Headers description: When enabled the Kamelet source will deserialize all message headers to String representation. type: boolean default: true sslKeyPassword: description: The password of the private key in the key store file. title: SSL Key Password type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password - urn:keda:required sslKeystorePassword: description: The store password for the key store file.This is optional for client and only needed if ssl.keystore.location is configured. title: SSL Keystore Password type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password sslEndpointAlgorithm: description: The endpoint identification algorithm to validate server hostname using server certificate. Use none or false to disable server hostname verification. title: SSL Endpoint Algorithm type: string default: https sslProtocol: description: The SSL protocol used to generate the SSLContext. Default setting is TLS, which is fine for most cases. Allowed values in recent JVMs are TLS, TLSv1.1 and TLSv1.2. SSL, SSLv2 and SSLv3 may be supported in older JVMs, but their usage is discouraged due to known security vulnerabilities. title: SSL Protocol type: string default: TLSv1.2 sslKeystoreLocation: description: The location of the key store file. This is optional for client and can be used for two-way authentication for client. title: SSL Keystore Location type: string sslTruststoreLocation: description: The location of the trust store file. title: SSL Truststore Location type: string sslTruststorePassword: description: The store password for the trust store file. title: SSL Truststore Password type: string format: password x-descriptors: - urn:camel:group:credentials - urn:keda:authentication:password sslEnabledProtocols: description: The list of protocols enabled for SSL connections. TLSv1.2, TLSv1.1 and TLSv1 are enabled by default. title: SSL Enabled Protocols type: string default: TLSv1.2,TLSv1.1,TLSv1 saslJaasConfig: description: Java Authentication and Authorization Service (JAAS) for Simple Authentication and Security Layer (SASL) configuration. title: JAAS Configuration type: string topicIsPattern: title: Topic Is Pattern description: Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics matching the pattern. type: boolean default: false dependencies: - "camel:core" - "camel:kafka" - "camel:kamelet" template: beans: - name: kafka-ssl-source-local type: '#class:org.apache.camel.component.kafka.KafkaComponent' - name: kafka-ssl-source-configuration-local properties: brokers: '{{bootstrapServers}}' securityProtocol: '{{securityProtocol}}' sslKeystoreLocation: '{{sslKeystoreLocation}}' sslKeyPassword: '{{sslKeyPassword}}' sslKeystorePassword: '{{sslKeystorePassword}}' sslTruststoreLocation: '{{sslTruststoreLocation}}' sslTruststorePassword: '{{sslTruststorePassword}}' sslProtocol: '{{sslProtocol}}' sslEnabledProtocols: '{{sslEnabledProtocols}}' sslEndpointAlgorithm: '{{sslEndpointAlgorithm}}' saslMechanism: '{{saslMechanism}}' groupId: '{{?consumerGroup}}' autoOffsetReset: '{{autoOffsetReset}}' pollOnError: '{{pollOnError}}' allowManualCommit: '{{allowManualCommit}}' autoCommitEnable: '{{autoCommitEnable}}' saslJaasConfig: '{{?saslJaasConfig}}' topicIsPattern: '{{topicIsPattern}}' type: '#class:org.apache.camel.component.kafka.KafkaConfiguration' - name: kafkaHeaderDeserializer type: "#class:org.apache.camel.component.kafka.KafkaHeaderDeserializer" properties: enabled: '{{deserializeHeaders}}' from: uri: "{{kafka-ssl-source-local}}:{{topic}}" parameters: configuration: '#bean:{{kafka-ssl-source-configuration-local}}' steps: - process: ref: "{{kafkaHeaderDeserializer}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kubernetes-namespaces-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kubernetes" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kubernetes Namespaces Source" description: Consume Events from Kubernetes Namespaces required: - token - masterUrl type: object properties: token: title: Oauth Token description: The Auth Token to connect to Kubernetes Cluster type: string format: password x-descriptors: - urn:camel:group:credentials masterUrl: title: Kubernetes Master URL description: The Kubernetes Cluster Master URL type: string types: out: mediaType: application/json dependencies: - "camel:kubernetes" - "camel:kamelet" - "camel:jackson" template: from: uri: "kubernetes-namespaces://{{masterUrl}}" parameters: oauthToken: "{{token}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kubernetes-nodes-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kubernetes" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kubernetes Nodes Source" description: Consume Events from Kubernetes Nodes required: - token - masterUrl type: object properties: token: title: Oauth Token description: The Auth Token to connect to Kubernetes Cluster type: string format: password x-descriptors: - urn:camel:group:credentials masterUrl: title: Kubernetes Master URL description: The Kubernetes Cluster Master URL type: string resourceName: title: Resource Name description: The Resource Name we want to watch type: string types: out: mediaType: application/json dependencies: - "camel:kubernetes" - "camel:kamelet" - "camel:jackson" template: from: uri: "kubernetes-nodes://{{masterUrl}}" parameters: oauthToken: "{{token}}" resourceName: "{{?resourceName}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: kubernetes-pods-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kubernetes" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Kubernetes Pods Source" description: Consume Events from Kubernetes Pods required: - token - masterUrl type: object properties: token: title: Oauth Token description: The Auth Token to connect to Kubernetes Cluster type: string format: password x-descriptors: - urn:camel:group:credentials masterUrl: title: Kubernetes Master URL description: The Kubernetes Cluster Master URL type: string resourceName: title: Resource Name description: The Resource Name we want to watch type: string types: out: mediaType: application/json dependencies: - "camel:kubernetes" - "camel:kamelet" - "camel:jackson" template: from: uri: "kubernetes-pods://{{masterUrl}}" parameters: oauthToken: "{{token}}" resourceName: "{{?resourceName}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: log-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Logging" camel.apache.org/kamelet.namespace: "Logging" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Log Action" description: Logs all data that flows between source and sink, useful for debugging purposes. type: object properties: loggerName: title: Logger Name description: Name of the logging category to use. type: string default: "log-action" level: title: Log Level description: Logging level to use. type: string default: "INFO" enum: ["TRACE", "DEBUG", "INFO", "WARN", "ERROR", "OFF"] logMask: title: Log Mask description: Mask sensitive information like password or passphrase in the log. type: boolean default: false marker: title: Marker description: An optional Marker name to use. type: string multiline: title: Multiline description: If enabled then each information is outputted on a newline. type: boolean default: false showAllProperties: title: Show All Properties description: Show all of the exchange properties (both internal and custom). type: boolean default: false showBody: title: Show Body description: Show the message body. type: boolean default: true showBodyType: title: Show Body Type description: Show the body Java type type: boolean default: true showExchangePattern: title: Show Exchange Pattern description: Shows the Message Exchange Pattern (or MEP for short) type: boolean default: true showHeaders: title: Show Headers description: Show the headers received type: boolean default: false showProperties: title: Show Properties description: Show the exchange properties (only custom). Use showAllProperties to show both internal and custom properties. type: boolean default: false showStreams: title: Show Streams description: Show the stream bodies (they may not be available in following steps) type: boolean default: false showCachedStreams: title: Show Cached Streams description: Whether Camel should show cached stream bodies or not. type: boolean default: true dependencies: - "camel:kamelet" - "camel:log" template: from: uri: "kamelet:source" steps: - to: uri: "log:{{loggerName}}" parameters: level: "{{?level}}" logMask: "{{?logMask}}" marker: "{{?marker}}" multiline: "{{?multiline}}" showAllProperties: "{{?showAllProperties}}" showBody: "{{?showBody}}" showBodyType: "{{?showBodyType}}" showExchangePattern: "{{?showExchangePattern}}" showHeaders: "{{?showHeaders}}" showProperties: "{{?showProperties}}" showStreams: "{{?showStreams}}" showCachedStreams: "{{?showCachedStreams}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: log-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Logging" camel.apache.org/kamelet.namespace: "Logging" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Log Sink" description: A sink that logs all data that it receives, useful for debugging purposes. type: object properties: loggerName: title: Logger Name description: Name of the logging category to use type: string default: "log-sink" level: title: Log Level description: Logging level to use type: string default: "INFO" enum: ["TRACE", "DEBUG", "INFO", "WARN", "ERROR", "OFF"] logMask: title: Log Mask description: Mask sensitive information like password or passphrase in the log type: boolean default: false marker: title: Marker description: An optional Marker name to use type: string multiline: title: Multiline description: If enabled then each information is outputted on a newline type: boolean default: false showAllProperties: title: Show All Properties description: Show all of the exchange properties (both internal and custom) type: boolean default: false showBody: title: Show Body description: Show the message body type: boolean default: true showBodyType: title: Show Body Type description: Show the body Java type type: boolean default: true showExchangePattern: title: Show Exchange Pattern description: Shows the Message Exchange Pattern (or MEP for short) type: boolean default: true showHeaders: title: Show Headers description: Show the headers received type: boolean default: false showProperties: title: Show Properties description: Show the exchange properties (only custom). Use showAllProperties to show both internal and custom properties. type: boolean default: false showStreams: title: Show Streams description: Show the stream bodies (they may not be available in following steps) type: boolean default: false showCachedStreams: title: Show Cached Streams description: Whether Camel should show cached stream bodies or not. type: boolean default: true dependencies: - "camel:kamelet" - "camel:log" template: from: uri: "kamelet:source" steps: - to: uri: "log:{{loggerName}}" parameters: level: "{{?level}}" logMask: "{{?logMask}}" marker: "{{?marker}}" multiline: "{{?multiline}}" showAllProperties: "{{?showAllProperties}}" showBody: "{{?showBody}}" showBodyType: "{{?showBodyType}}" showExchangePattern: "{{?showExchangePattern}}" showHeaders: "{{?showHeaders}}" showProperties: "{{?showProperties}}" showStreams: "{{?showStreams}}" showCachedStreams: "{{?showCachedStreams}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mail-imap-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Mail" camel.apache.org/kamelet.namespace: "Mail" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Mail IMAP Source" description: Receive unread emails from an IMAP mail server, marking them as read once they are received. required: - connectionHost - connectionPort - username - password type: object properties: connectionHost: title: Connection Host description: The IMAP server host. type: string example: imap.gmail.com connectionPort: title: Connection Port description: The IMAP server port. type: string default: 993 username: title: Username description: The username to access the mail box. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the mail box. type: string format: password x-descriptors: - urn:camel:group:credentials fetchSize: title: Fetch Size description: The number of messages fetched for each poll (-1 for no limits). type: integer default: 10 delay: title: Delay description: The delay between fetches in milliseconds. type: integer default: 60000 dependencies: - "camel:core" - "camel:mail" - "camel:kamelet" template: from: uri: "imaps:{{connectionHost}}:{{connectionPort}}" parameters: username: "{{username}}" password: "{{password}}" fetchSize: "{{fetchSize}}" delay: "{{delay}}" steps: - setHeader: name: "ce-subject" simple: "${header.Subject}" - setHeader: name: "ce-from" simple: "${header.From}" - setHeader: name: "ce-to" simple: "${header.To}" - setHeader: name: "ce-cc" simple: "${header.Cc}" - convertBodyTo: type: "java.lang.String" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mail-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Mail" camel.apache.org/kamelet.namespace: "Mail" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Mail Sink" description: "Send mails to given SMTP server." required: - connectionHost - username - password type: object properties: connectionHost: description: The mail server host example: smtp.gmail.com title: Host type: string connectionPort: description: The mail server port title: Port default: 25 type: string username: title: Username description: The username to access the mail box type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the mail box type: string format: password x-descriptors: - urn:camel:group:credentials from: description: The `from` field of the outgoing mail title: From type: string to: description: The `to` field of the outgoing mail title: To type: string subject: description: The mail subject of the outgoing mail title: Subject type: string dependencies: - "camel:core" - "camel:mail" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[ce-subject]}" steps: - setHeader: name: Subject simple: "${header[ce-subject]}" - choice: when: - simple: "${header[ce-from]}" steps: - setHeader: name: From simple: "${header[ce-from]}" - choice: when: - simple: "${header[ce-to]}" steps: - setHeader: name: To simple: "${header[ce-to]}" - choice: when: - simple: "${header[ce-cc]}" steps: - setHeader: name: Cc simple: "${header[ce-cc]}" - removeHeaders: pattern: "ce-*" - to: uri: "smtp:{{connectionHost}}:{{connectionPort}}" parameters: subject: "{{subject}}" from: "{{from}}" to: "{{to}}" username: "{{username}}" password: "{{password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mariadb-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "MariaDB Sink" description: Send data to a MariaDB Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 3306 username: title: Username description: The username to access a secured MariaDB Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured MariaDB Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the MariaDB Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the MariaDB Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-mariadb-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:mariadb://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'org.mariadb.jdbc.Driver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-mariadb-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mariadb-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MariaDB Source" description: Query data from a MariaDB Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 3306 username: title: Username description: The username to access a secured MariaDB Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured MariaDB Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the MariaDB Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the MariaDB Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-mariadb-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:mariadb://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'org.mariadb.jdbc.Driver' from: uri: "{{local-sql-mariadb-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mask-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Mask Fields Action" description: "Mask fields with a constant value in the message in transit." required: - fields - replacement properties: fields: title: Fields description: Comma separated list of fields to mask type: string replacement: title: Replacement description: Replacement for the fields to be masked type: string type: object dependencies: - "camel:jackson" - "camel:kamelet" - "camel:core" - "camel:kafka" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: "fields" constant: "{{fields}}" - setProperty: name: "replacement" constant: "{{replacement}}" - bean: "org.apache.camel.component.kafka.transform.MaskField" - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: message-timestamp-router-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Message Timestamp Router Action" description: "Update the topic field as a function of the original topic name and the record's timestamp field." required: - timestampKeys properties: topicFormat: title: Topic Format description: Format string which can contain '$[topic]' and '$[timestamp]' as placeholders for the topic and timestamp, respectively. type: string default: "topic-$[timestamp]" timestampFormat: title: Timestamp Format description: Format string for the timestamp that is compatible with java.text.SimpleDateFormat. type: string default: "yyyyMMdd" timestampKeys: title: Timestamp Keys description: Comma separated list of Timestamp keys. The timestamp is taken from the first found field. type: string timestampKeyFormat: title: Timestamp Keys Format description: Format of the timestamp keys. Possible values are `timestamp`, or any format string for the timestamp that is compatible with `java.text.SimpleDateFormat`. In case of `timestamp` the field is evaluated as milliseconds since 1970 (as a UNIX Timestamp). type: string default: "timestamp" type: object dependencies: - "camel:jackson" - "camel:kamelet" - "camel:core" - "camel:kafka" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: "topicFormat" constant: "{{topicFormat}}" - setProperty: name: "timestampFormat" constant: "{{timestampFormat}}" - setProperty: name: "timestampKeys" constant: "{{timestampKeys}}" - setProperty: name: "timestampKeyFormat" constant: "{{timestampKeyFormat}}" - bean: "org.apache.camel.component.kafka.transform.MessageTimestampRouter" - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: minio-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Minio" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Minio Sink" description: Upload data to MinIO. required: - bucketName - accessKey - secretKey - endpoint type: object properties: bucketName: title: Bucket Name description: The Minio Bucket name. type: string accessKey: title: Access Key description: The access key obtained from MinIO. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from MinIO. type: string format: password x-descriptors: - urn:camel:group:credentials endpoint: title: Endpoint description: The MinIO Endpoint. You can specify an URL, domain name, IPv4 address, or IPv6 address. type: string example: http://localhost:9000 autoCreateBucket: title: Autocreate Bucket description: Specify to automatically create the MinIO bucket. type: boolean default: false keyName: title: Key Name description: The key name for saving an element in the bucket. type: string dependencies: - "camel:core" - "camel:minio" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: precondition: true when: - simple: '${propertiesExist:!keyName}' steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelMinioObjectName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelMinioObjectName simple: "${header[ce-file]}" otherwise: steps: - setHeader: name: CamelMinioObjectName simple: "${exchangeId}" - to: uri: "minio:{{bucketName}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" secretKey: "{{secretKey}}" accessKey: "{{accessKey}}" endpoint: "{{endpoint}}" keyName: "{{?keyName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: minio-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Minio" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Minio Source" description: Receive data from MinIO. required: - bucketName - accessKey - secretKey - endpoint type: object properties: bucketName: title: Bucket Name description: The MinIO Bucket name. type: string deleteAfterRead: title: Auto-delete Objects description: Delete objects after consuming them. type: boolean default: true accessKey: title: Access Key description: The access key obtained from MinIO. type: string format: password x-descriptors: - urn:camel:group:credentials secretKey: title: Secret Key description: The secret key obtained from MinIO. type: string format: password x-descriptors: - urn:camel:group:credentials endpoint: title: Endpoint description: The MinIO Endpoint. You can specify an URL, domain name, IPv4 address, or IPv6 address. type: string example: http://localhost:9000 autoCreateBucket: title: Autocreate Bucket description: Specifies to automatically create the MinIO bucket. type: boolean default: false dependencies: - "camel:minio" - "camel:kamelet" template: from: uri: "minio:{{bucketName}}" parameters: autoCreateBucket: "{{autoCreateBucket}}" secretKey: "{{secretKey}}" accessKey: "{{accessKey}}" endpoint: "{{endpoint}}" deleteAfterRead: "{{deleteAfterRead}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mongodb-changes-stream-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MongoDB" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MongoDB Changes Stream Source" description: Consume Changes from MongoDB Collection in streaming mode. required: - hosts - collection - database type: object properties: hosts: title: MongoDB Hosts description: Comma separated list of MongoDB Host Addresses in host:port format. type: string collection: title: MongoDB Collection description: Sets the name of the MongoDB collection to bind to this endpoint. type: string password: title: MongoDB Password description: User password for accessing MongoDB. type: string format: password x-descriptors: - urn:camel:group:credentials username: title: MongoDB Username description: Username for accessing MongoDB. The username must be present in the MongoDB's authentication database (authenticationDatabase). By default, the MongoDB authenticationDatabase is 'admin'. type: string x-descriptors: - urn:camel:group:credentials ssl: title: Enable Ssl for Mongodb Connection description: whether to enable ssl connection to mongodb type: boolean default: true sslValidationEnabled: title: Enables Ssl Certificates Validation and Host name checks. description: IMPORTANT this should be disabled only in test environment since can pose security issues. type: boolean default: true database: title: MongoDB Database description: Sets the name of the MongoDB database to target. type: string streamFilter: title: Stream Filter description: Filter condition for change streams consumer. type: string example: "{ '$match':{'$or':[{'fullDocument.stringValue': 'specificValue'}]} }" dependencies: - "camel:kamelet" - "camel:mongodb" - "camel:jackson" template: beans: - name: local-mongodb type: "#class:org.apache.camel.component.mongodb.MongoDbComponent" - name: mongo-client type: "#class:org.apache.camel.component.mongodb.SslAwareMongoClient" properties: password: "{{?password}}" username: "{{?username}}" hosts: "{{hosts}}" ssl: "{{ssl}}" sslValidationEnabled: "{{sslValidationEnabled}}" from: uri: "{{local-mongodb}}:test" parameters: collection: "{{collection}}" database: "{{database}}" consumerType: "changeStreams" streamFilter: "{{?streamFilter}}" mongoConnection: "#{{mongo-client}}" steps: - marshal: json: {} - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mongodb-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MongoDB" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "MongoDB Sink" description: Send data to MongoDB. required: - hosts - collection - database type: object properties: hosts: title: MongoDB Hosts description: A comma-separated list of MongoDB host addresses in `host:port` format. type: string collection: title: MongoDB Collection description: The name of the MongoDB collection to bind to this endpoint. type: string password: title: MongoDB Password description: A user password for accessing MongoDB. type: string format: password x-descriptors: - urn:camel:group:credentials username: title: MongoDB Username description: A username for accessing MongoDB. type: string x-descriptors: - urn:camel:group:credentials ssl: title: Enable Ssl for Mongodb Connection description: whether to enable ssl connection to mongodb. type: boolean default: true sslValidationEnabled: title: Enables Ssl Certificates Validation and Host name checks. description: IMPORTANT this should be disabled only in test environment since can pose security issues. type: boolean default: true database: title: MongoDB Database description: The name of the MongoDB database. type: string writeConcern: title: Write Concern description: The level of acknowledgment requested from MongoDB for write operations. type: string enum: ["ACKNOWLEDGED", "W1", "W2", "W3", "UNACKNOWLEDGED", "JOURNALED", "MAJORITY"] createCollection: title: Collection description: Create a collection during initialization if it doesn't exist. type: boolean default: false types: in: mediaType: application/json dependencies: - "camel:core" - "camel:kamelet" - "camel:mongodb" - "camel:jackson" template: beans: - name: local-mongodb type: "#class:org.apache.camel.component.mongodb.MongoDbComponent" - name: mongo-client type: "#class:org.apache.camel.component.mongodb.SslAwareMongoClient" properties: password: "{{?password}}" username: "{{?username}}" hosts: "{{hosts}}" ssl: "{{ssl}}" sslValidationEnabled: "{{sslValidationEnabled}}" from: uri: kamelet:source steps: - choice: when: - simple: "${header[db-upsert]}" steps: - setHeader: name: CamelMongoDbUpsert simple: "${header[db-upsert]}" - simple: "${header[ce-dbupsert]}" steps: - setHeader: name: CamelMongoDbUpsert simple: "${header[ce-dbupsert]}" - to: uri: "{{local-mongodb}}:test" parameters: createCollection: "{{?createCollection}}" writeConcern: "{{?writeConcern}}" collection: "{{collection}}" database: "{{database}}" operation: "insert" mongoConnection: "#{{mongo-client}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mongodb-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MongoDB" camel.apache.org/kamelet.namespace: "Nosql" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MongoDB Source" description: Consume data from MongoDB. required: - hosts - collection - database type: object properties: hosts: title: MongoDB Hosts description: A comma-separated list of MongoDB host addresses in `host:port` format. type: string collection: title: MongoDB Collection description: The name of the MongoDB collection to bind to this endpoint. type: string password: title: MongoDB Password description: The user password for accessing MongoDB. type: string format: password x-descriptors: - urn:camel:group:credentials username: title: MongoDB Username description: The username for accessing MongoDB. The username must be present in the MongoDB's authentication database (`authenticationDatabase`). By default, the MongoDB `authenticationDatabase` is 'admin'. type: string x-descriptors: - urn:camel:group:credentials ssl: title: Enable Ssl for Mongodb Connection description: whether to enable ssl connection to mongodb type: boolean default: true sslValidationEnabled: title: Enables Ssl Certificates Validation and Host name checks. description: IMPORTANT this should be disabled only in test environment since can pose security issues. type: boolean default: true database: title: MongoDB Database description: The name of the MongoDB database. type: string persistentTailTracking: title: MongoDB Persistent Tail Tracking description: Specifies to enable persistent tail tracking, which is a mechanism to keep track of the last consumed data across system restarts. The next time the system is up, the endpoint recovers the cursor from the point where it last stopped consuimg data. This option will only work on capped collections. type: boolean default: false tailTrackIncreasingField: title: MongoDB Tail Track Increasing Field description: The correlation field in the incoming data which is of increasing nature and is used to position the tailing cursor every time it is generated. type: string dependencies: - "camel:kamelet" - "camel:mongodb" - "camel:jackson" template: beans: - name: local-mongodb type: "#class:org.apache.camel.component.mongodb.MongoDbComponent" - name: mongo-client type: "#class:org.apache.camel.component.mongodb.SslAwareMongoClient" properties: password: "{{?password}}" username: "{{?username}}" hosts: "{{hosts}}" ssl: "{{ssl}}" sslValidationEnabled: "{{sslValidationEnabled}}" from: uri: "{{local-mongodb}}:test" parameters: collection: "{{collection}}" database: "{{database}}" persistentTailTracking: "{{persistentTailTracking}}" tailTrackIncreasingField: "{{?tailTrackIncreasingField}}" mongoConnection: "#{{mongo-client}}" steps: - marshal: json: {} - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mqtt-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MQTT" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "MQTT Sink" description: Allows sending messages to any endpoint that supports the MQTT protocol, such as a message broker. required: - topic - brokerUrl type: object properties: topic: title: Topic description: The topic to send messages to type: string example: "mytopic" brokerUrl: title: Broker URL description: The URL of the broker where to establish the connection type: string example: "tcp://mosquitto:1883" username: title: Username description: Username to use when connecting to the MQTT broker type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to use when connecting to the MQTT broker type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:paho" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: paho:{{topic}} parameters: brokerUrl: "{{brokerUrl}}" userName: "{{?username}}" password: "{{?password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mqtt-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MQTT" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MQTT Source" description: Allows receiving messages from any endpoint that supports the MQTT protocol, such as a message broker. required: - topic - brokerUrl type: object properties: topic: title: Topic description: The topic to subscribe to type: string example: "mytopic" brokerUrl: title: Broker URL description: The URL of the broker where to establish the connection type: string example: "tcp://mosquitto:1883" clientId: title: Client ID description: The client ID to use when connecting to the resource type: string default: "mqtt-source" username: title: Username description: Username to use when connecting to the MQTT broker type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to use when connecting to the MQTT broker type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:paho" - "camel:kamelet" template: from: uri: paho:{{topic}} parameters: brokerUrl: "{{brokerUrl}}" clientId: "{{clientId}}" userName: "{{?username}}" password: "{{?password}}" steps: - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mqtt5-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MQTT v5" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "MQTT v5 Sink" description: Allows sending messages to any endpoint that supports the MQTT v5 protocol, such as a message broker. required: - topic - brokerUrl type: object properties: topic: title: Topic description: The topic to send messages to. type: string example: "mytopic" brokerUrl: title: Broker URL description: The URL of the broker where to establish the connection. type: string example: "tcp://mosquitto:1883" username: title: Username description: Username to use when connecting to the MQTT v5 compliant broker. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to use when connecting to the MQTT v5 compliant broker. type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:paho-mqtt5" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: paho-mqtt5:{{topic}} parameters: brokerUrl: "{{brokerUrl}}" userName: "{{?username}}" password: "{{?password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mqtt5-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "MQTT 5" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MQTT 5 Source" description: Allows receiving messages from any endpoint that supports the MQTT v5 protocol, such as a message broker. required: - topic - brokerUrl type: object properties: topic: title: Topic description: The topic to subscribe to type: string example: "mytopic" brokerUrl: title: Broker URL description: The URL of the broker where to establish the connection type: string example: "tcp://mosquitto:1883" clientId: title: Client ID description: The client ID to use when connecting to the resource type: string default: "mqtt-source" username: title: Username description: Username to use when connecting to the MQTT v5 compliant broker type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to use when connecting to the MQTT v5 compliant broker type: string format: password x-descriptors: - urn:camel:group:credentials dependencies: - "camel:paho-mqtt5" - "camel:kamelet" template: from: uri: paho-mqtt5:{{topic}} parameters: brokerUrl: "{{brokerUrl}}" clientId: "{{clientId}}" userName: "{{?username}}" password: "{{?password}}" steps: - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ms-exchange-online-imap-oauth-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Mail" camel.apache.org/kamelet.namespace: "Mail" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Microsoft Exchange IMAP OAuth2 Source" description: Receive unread emails from an IMAP Microsoft Exchange mail server, marking them as read once they are received. required: - tenantId - clientId - clientSecret - username type: object properties: connectionHost: title: Connection Host description: The IMAP server host. type: string default: outlook.office365.com connectionPort: title: Connection Port description: The IMAP server port. type: string default: 993 tenantId: title: Tenant ID description: Azure Active Directory Tenant ID. type: string clientId: title: Client ID description: Azure Active Directory Application Client ID. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Client Secret description: The Azure Active Directory Application Client Secret. type: string format: password x-descriptors: - urn:camel:group:credentials username: title: Username description: The username to access the mail box. type: string example: arthur@mycompany.com x-descriptors: - urn:camel:group:credentials fetchSize: title: Fetch Size description: The number of messages fetched for each poll (-1 for no limits). type: integer default: 10 delay: title: Delay description: The delay between fetches in milliseconds. type: integer default: 60000 dependencies: - "camel:core" - "camel:kamelet" - "camel:mail-microsoft-oauth" - "camel:mail" template: beans: - name: exchangeAuthenticator type: "#class:org.apache.camel.component.mail.microsoft.authenticator.MicrosoftExchangeOnlineOAuth2MailAuthenticator({{tenantId}}, {{clientId}}, {{clientSecret}}, {{username}})" from: uri: "imaps:{{connectionHost}}:{{connectionPort}}" parameters: mail.imaps.auth.mechanisms: "XOAUTH2" username: "{{username}}" fetchSize: "{{fetchSize}}" delay: "{{delay}}" authenticator: "#bean:{{exchangeAuthenticator}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mustache-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Mustache Template Action" description: Apply a Mustache Template. required: - template type: object properties: template: title: Template description: The inline template. type: string example: "file:////template.mustache" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:mustache" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "mustache:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mvel-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Mvel Template Action" description: Apply a Mvel Template. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.mvel" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:mvel" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "mvel:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mysql-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "MySQL Sink" description: Send data to a MySQL Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 3306 username: title: Username description: The username to access a secured MySQL Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured MySQL Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the MySQL Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the MySQL Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-mysql-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:mysql://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'com.mysql.cj.jdbc.Driver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-mysql-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: mysql-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "MySQL Source" description: Query data from a MySQL Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 3306 username: title: Username description: The username to access a secured MySQL Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured MySQL Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the MySQL Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the MySQL Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-mysql-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:mysql://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'com.mysql.cj.jdbc.Driver' from: uri: "{{local-sql-mysql-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: nats-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "NATS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "NATS Sink" description: Send data to NATS topics. required: - topic - servers type: object properties: topic: title: Topic description: NATS Topic name type: string servers: title: Servers description: Comma separated list of NATS Servers type: string format: password x-descriptors: - urn:camel:group:credentials jetstreamEnabled: title: Jetstream Enabled description: Sets whether to enable JetStream support for this endpoint. type: boolean default: false jetstreamName: title: Jetstream Stream Name description: Sets the name of the JetStream stream to use. type: string jetstreamAsync: title: Jetstream Async Enabled description: Sets whether to operate JetStream requests asynchronously. type: boolean default: true dependencies: - "camel:nats" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "nats:{{topic}}" parameters: servers: "{{servers}}" jetstreamEnabled: "{{?jetstreamEnabled}}" jetstreamName: "{{?jetstreamName}}" jetstreamAsync: "{{?jetstreamAsync}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: nats-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "NATS" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "NATS Source" description: Receive data from NATS topics. required: - topic - servers type: object properties: topic: title: Topic description: NATS Topic name type: string servers: title: Servers description: Comma separated list of NATS Servers type: string format: password x-descriptors: - urn:camel:group:credentials jetstreamEnabled: title: Jetstream Enabled description: Sets whether to enable JetStream support for this endpoint. type: boolean default: false jetstreamName: title: Jetstream Stream Name description: Sets the name of the JetStream stream to use. type: string jetstreamAsync: title: Jetstream Async Enabled description: Sets whether to operate JetStream requests asynchronously. type: boolean default: true types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:nats" - "camel:kamelet" template: from: uri: "nats:{{topic}}" parameters: servers: "{{servers}}" jetstreamEnabled: "{{?jetstreamEnabled}}" jetstreamName: "{{?jetstreamName}}" jetstreamAsync: "{{?jetstreamAsync}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: nominatim-geocode-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Geospatial" camel.apache.org/kamelet.namespace: "Geo" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Nominatim GeoCode Action" description: Find locations on Earth by name and address. required: - serverUrl type: object properties: serverUrl: title: "Server URL" description: "Url of the Nominatim server." example: "https://nominatim.openstreetmap.org" type: string types: in: mediaType: text/plain out: mediaType: application/json schema: type: object required: ["place_id"] properties: place_id: type: numeric licence: type: string osm_type: type: string osm_id: type: numeric boundingbox: type: array lat: type: numeric lon: type: numeric display_name: type: string place_rank: type: numeric category: type: string address: type: object dependencies: - "camel:core" - "camel:jackson" - "camel:geocoder" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - setHeader: name: CamelGeoCoderAddress simple: "${body}" - to: uri: "geocoder:address:toOverride" parameters: type: "NOMINATIM" serverUrl: "RAW({{serverUrl}})" - marshal: json: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ogcapi-features-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Geospatial" camel.apache.org/kamelet.namespace: "Geo" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "OGC Api Feature Get Item Action" description: Returns the items of the collection provided of an OGC API Features server. required: - url - collection type: object properties: url: title: URL description: The URL to fetch for data type: string example: "https://emotional.byteroad.net" pattern: "^(http|https)://.*" collection: title: "Collection" description: "Name of the collection we want to extract items from." type: string bbox: title: "Bounding Box" description: "Bounding Box of the items we want to retrieve." example: "160.6,-55.95,-170,-25.89" default: "-180,-90,180,90" type: string limit: title: "Limit" description: "Maximum number of items to retrieve. Must be a number between 1 and 10 000." type: integer default: 10 split: title: "Split by Feature" description: "When true, instead of returning the full geojson, split the message into each feature." type: boolean default: false query: title: "Query" description: "Separated list by `&` of properties we want to query." example: "property1=1&property2=dos" default: "" type: string types: in: mediaType: text/plain out: mediaType: application/json dependencies: - "camel:core" - "camel:http" - "camel:kamelet" - "camel:jsonpath" - "camel:jackson" template: from: uri: "kamelet:source" steps: - setHeader: name: "Accept" constant: "application/geo+json" - setHeader: name: "CamelHttpQuery" simple: "limit={{limit}}&bbox={{bbox}}&{{?query}}&${body}" - setBody: simple: "" - to: uri: "{{url}}/collections/{{collection}}/items" - removeHeader: name: "Accept" - removeHeader: name: "CamelHttpQuery" - convertBodyTo: type: "java.lang.String" - choice: when: - simple: "{{split}}" steps: - split: jsonpath: "$.features[*]" steps: - marshal: json: {} - to: "kamelet:sink" otherwise: steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: opensearch-index-sink labels: camel.apache.org/kamelet.type: "sink" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "OpenSearch" camel.apache.org/kamelet.namespace: "Search" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.icon: "" spec: definition: title: "OpenSearch Index Sink" description: Stores JSON-formatted data into Opensearch. required: - clusterName - hostAddresses type: object properties: user: title: Username description: The username to connect to OpenSearch. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to connect to OpenSearch. type: string format: password x-descriptors: - urn:camel:group:credentials enableSSL: title: Enable SSL description: Specifies to connect by using SSL. type: boolean default: false hostAddresses: title: Host Addresses description: A comma-separated list of remote transport addresses in `ip:port format`. type: string example: quickstart-es-http:9200 clusterName: title: OpenSearch Cluster Name description: The name of the OpenSearch cluster. type: string example: quickstart indexName: title: Index in OpenSearch description: The name of the OpenSearch index. type: string example: data certificate: title: Certificate description: The Certificate for accessing the OpenSearch cluster. You must encode this value in base64. type: string types: out: mediaType: text/plain in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:opensearch" - "camel:gson" - "camel:bean" template: beans: - name: local-opensearch type: "#class:org.apache.camel.component.opensearch.OpensearchComponent" properties: user: "{{?user}}" password: "{{?password}}" from: uri: kamelet:source steps: - choice: when: - simple: "${header[indexId]}" steps: - setHeader: name: "indexId" simple: "${header[indexId]}" - simple: "${header[ce-indexid]}" steps: - setHeader: name: "indexId" simple: "${header[ce-indexid]}" - choice: when: - simple: "${header[indexName]}" steps: - setHeader: name: "indexName" simple: "${header[indexName]}" - simple: "${header[ce-indexname]}" steps: - setHeader: name: "indexName" simple: "${header[ce-indexname]}" - unmarshal: json: {} - to: uri: "{{local-opensearch}}:{{clusterName}}" parameters: operation: "INDEX" hostAddresses: "{{hostAddresses}}" enableSSL: "{{enableSSL}}" indexName: "{{?indexName}}" certificatePath: "base64:{{?certificate}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: opensearch-search-source labels: camel.apache.org/kamelet.type: "source" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.group: "OpenSearch" camel.apache.org/kamelet.namespace: "Search" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.icon: "" spec: definition: title: "OpenSearch Search Source" description: Search data on OpenSearch. required: - query - clusterName - indexName - hostAddresses type: object properties: period: title: Period description: The time interval between two searches type: integer default: 1000 query: title: Query description: The query we want to use to search on OpenSearch. type: string user: title: Username description: Username to connect to OpenSearch. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to OpenSearch. type: string format: password x-descriptors: - urn:camel:group:credentials enableSSL: title: Enable SSL description: Do we want to connect using SSL? type: boolean default: false hostAddresses: title: Host Addresses description: Comma separated list with ip:port formatted remote transport addresses to use. type: string indexName: title: Index in OpenSearch description: The name of the index to act against. type: string clusterName: title: OpenSearch Cluster Name description: The name of the cluster. type: string certificate: title: Certificate description: The Certificate for accessing the Opensearch cluster. You must encode this value in base64. type: string types: out: mediaType: application/json dependencies: - "camel:core" - "camel:kamelet" - "camel:timer" - "camel:opensearch" - "camel:gson" template: beans: - name: local-opensearch type: "#class:org.apache.camel.component.opensearch.OpensearchComponent" properties: user: "{{?user}}" password: "{{?password}}" from: uri: timer:tick parameters: period: "{{period}}" steps: - setBody: constant: "{{query?nested=false}}" - to: uri: "{{local-opensearch}}:{{clusterName}}" parameters: operation: "SEARCH" indexName: "{{indexName}}" hostAddresses: "{{hostAddresses}}" enableSSL: "{{enableSSL}}" certificatePath: "base64:{{?certificate}}" - marshal: json: library: Gson - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: oracle-database-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Oracle Database Sink" description: Send data to an Oracle Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 1521 username: title: Username description: The username to access a secured Oracle Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured Oracle Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the Oracle Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the Oracle Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-oracle-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:oracle:thin:@{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'oracle.jdbc.driver.OracleDriver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-oracle-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: oracle-database-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Oracle Database Source" description: Query data from an Oracle Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 1521 username: title: Username description: The username to access a secured Oracle Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured Oracle Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the Oracle Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the Oracle Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-oracle-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:oracle:thin:@{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'oracle.jdbc.driver.OracleDriver' from: uri: "{{local-sql-oracle-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: pdf-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "PDF" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "PDF Action" description: Create a PDF. required: - font - fontSize - pageSize type: object properties: font: title: Font description: The font to use while generating the PDF. One of Courier, Courier-Bold, Courier-Oblique, Courier-BoldOblique, Helvetica, Helvetica-Bold, Helvetica-Oblique, Helvetica-BoldOblique, Times-Roman, Times-Bold, Times-Italic, Times-BoldItalic, Symbol, ZapfDingbats type: string default: Helvetica fontSize: title: Font Size description: The Font size to use while generating the PDF type: string default: 14.0 pageSize: title: Page Size description: The Page size to use while generating the PDF. One of LETTER, LEGAL, A0, A1, A2, A3, A4, A5, A6 type: string default: A4 dependencies: - "camel:pdf" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "pdf://create" parameters: font: "{{font}}" fontSize: "{{fontSize}}" pageSize: "{{pageSize}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: postgresql-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "PostgreSQL Sink" description: Send data to a PostgreSQL Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 5432 username: title: Username description: The username to access a secured PostgreSQL Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured PostgreSQL Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the PostgreSQL Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the PostgreSQL Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.postgresql:postgresql:42.7.7" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-postgres-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:postgresql://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'org.postgresql.Driver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-postgres-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: postgresql-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "PostgreSQL Source" description: Query data from a PostgreSQL Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 5432 username: title: Username description: The username to access a secured PostgreSQL Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured PostgreSQL Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the PostgreSQL Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the PostgreSQL Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.postgresql:postgresql:42.7.7" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-postgres-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:postgresql://{{serverName}}:{{serverPort}}/{{databaseName}}' driverClassName: 'org.postgresql.Driver' from: uri: "{{local-sql-postgres-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: pqc-kem-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "PQC" camel.apache.org/kamelet.namespace: "PQC" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "PQC Key Encapsulation/Decapsulation Action" description: Encapsulate or Decapsulate a secret Key with a PQC KEM algorithm. required: - keyEncapsulationAlgorithm - operation - symmetricKeyAlgorithm type: object properties: keyEncapsulationAlgorithm: title: PQC Key Encapsulation Algorithm description: The PQC Key Encapsulation Algorithm to be used. type: string enum: ["MLKEM","BIKE","HQC","CMCE","SABER","FRODO","NTRU","NTRULPRime"] operation: title: PQC KEM Operation description: The PQC KEM Operation to be performed. type: string enum: ["generateSecretKeyEncapsulation","extractSecretKeyEncapsulation","extractSecretKeyFromEncapsulation"] symmetricKeyAlgorithm: title: Symmetric Key Algorithm description: The Symmetric Key Algorithm to be used in KEM operations. type: string enum: ["AES","RC2","RC5","ARIA","CAMELLIA","CAST5","CAST6","CHACHA7539","DSTU7624","GOST28147","GOST3412_2015","GRAIN128","HC128","HC256","SALSA20","SEED","SM4","DESEDE"] dependencies: - "camel:http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - to: uri: "pqc:kem" parameters: keyEncapsulationAlgorithm: "{{keyEncapsulationAlgorithm}}" operation: "{{operation}}" symmetricKeyAlgorithm: "{{symmetricKeyAlgorithm}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: pqc-signature-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "PQC" camel.apache.org/kamelet.namespace: "PQC" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "PQC Signature Action" description: Sign or verify a payload with a PQC algorithm. required: - signatureAlgorithm - operation type: object properties: signatureAlgorithm: title: PQC Signature Algorithm description: The PQC Signature Algorithm to be used. type: string enum: [MLDSA","SLHDSA","LMS","XMSS","FALCON","PICNIC"] operation: title: PQC Signature Operation description: The PQC Signature Operation to be performed. type: string enum: ["sign","verify"] dependencies: - "camel:http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - to: uri: "pqc:sign" parameters: signatureAlgorithm: "{{signatureAlgorithm}}" operation: "{{operation}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: predicate-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Predicate Filter Action" description: "Filter based on a JSONPath Expression. Since this is a filter, the expression is a negation. This means that if the `foo` field of the example is equal to `John`, the message goes ahead. Otherwise it is filtered out." required: - expression properties: expression: title: Expression description: The JSONPath Expression to evaluate, without the external parenthesis. Since this is a filter, the expression is a negation. This means that if the `foo` field of the example is equal to `John`, the message goes ahead. Otherwise it is filtered out. type: string example: '@.foo =~ /.*John/' type: object dependencies: - "camel:core" - "camel:kamelet" - "camel:jsonpath" template: from: uri: kamelet:source steps: - filter: jsonpath: "$[?(!({{expression}}))]" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: protobuf-deserialize-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Protobuf Deserialize Action" description: "Deserialize payload to Protobuf." type: object properties: schema: title: Schema description: The Protobuf schema to use during serialization (as single-line) type: string example: 'message Person { required string first = 1; required string last = 2; }' dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson-protobuf" template: beans: - name: schemaResolver type: "#class:org.apache.camel.component.jackson.protobuf.transform.ProtobufSchemaResolver" properties: schema: "{{schema:}}" from: uri: kamelet:source steps: - unmarshal: protobuf: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#bean:{{schemaResolver}}" - removeHeader: name: "Content-Type" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: protobuf-serialize-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Protobuf Serialize Action" description: "Serialize payload to Protobuf." type: object properties: schema: title: Schema description: The Protobuf schema to use during serialization (as single-line) type: string example: 'message Person { required string first = 1; required string last = 2; }' dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson-protobuf" template: beans: - name: schemaResolver type: "#class:org.apache.camel.component.jackson.protobuf.transform.ProtobufSchemaResolver" properties: schema: "{{schema:}}" from: uri: kamelet:source steps: - marshal: protobuf: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#bean:{{schemaResolver}}" - setHeader: name: "Content-Type" constant: "application/protobuf" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: pulsar-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Pulsar" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" spec: dependencies: - "camel:pulsar" - "camel:kamelet" - "camel:core" definition: title: "Pulsar Sink" description: "Send documents to Pulsar." required: - topicType - topic - namespaceName - tenant - serviceUrl properties: topic: title: Topic Name description: The topic name or regexp. type: string tenant: title: Tenant Name description: The Tenant Name. type: string topicType: title: Topic Type description: "The topic type." type: string enum: ["persistent", "non-persistent"] namespaceName: title: Pulsar Namespace Name description: The Pulsar Namespace Name. type: string serviceUrl: title: Service URL description: The Pulsar Service URL to point while creating the client from URI. type: string authenticationClass: title: Authentication Class description: The Authentication FQCN to be used while creating the client from URI. type: string authenticationParams: title: Authentication Params description: The Authentication Parameters to be used while creating the client from URI. type: string batchingEnabled: title: Enable Batching description: Control whether automatic batching of messages is enabled for the producer. type: boolean default: true batchingMaxMessages: title: Batching Maximum Messages description: "The maximum size to batch messages." type: integer default: 1000 batchingMaxPublishDelayMicros: title: Batching Maximum Publish Delay in Microsecond description: "Used if `batchingEnabled` is `true`. Sets the maximum time period within which the messages sent are batched." type: integer default: 1000 blockIfQueueFull: title: Block If Queue Full description: "Whether to block the producing thread if pending messages queue is full or to throw a ProducerQueueIsFullError." type: boolean default: false compressionType: title: Compression Type description: "Compression type to use." type: string default: "NONE" enum: ["NONE", "LZ4", "ZLIB", "ZSTD", "SNAPPY"] initialSequenceId: title: Initial SequenceId description: "The first message published will have a sequence Id of initialSequenceId 1." type: integer default: -1 lazyStartProducer: title: Number Of Consumer Threads description: "Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel’s routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing." type: boolean default: false maxPendingMessages: title: Maximum Pending Messages description: "Size of the pending massages queue. When the queue is full, by default, any further sends will fail unless blockIfQueueFull=true." type: integer default: 1000 maxPendingMessagesAcrossPartitions: title: Maximum Pending Messages Across Partitions description: "The maximum number of pending messages for partitioned topics. The `maxPendingMessages` value is reduced if (number of partitions `maxPendingMessages`) exceeds this value. Partitioned topics have a pending message queue for each partition." type: integer default: 50000 messageRoutingMode: title: Message Routing Mode description: "Message Routing Mode to use." type: string default: "RoundRobinPartition" enum: ["SinglePartition", "RoundRobinPartition", "CustomPartition"] producerName: title: Producer Name description: "Name of the producer. If unset, lets Pulsar select a unique identifier." type: string sendTimeoutMs: title: Send Timeout in Milliseconds description: "Send timeout in milliseconds." type: integer default: 30000 type: object template: from: uri: kamelet:source steps: - to: uri: pulsar:{{topicType}}/{{tenant}}/{{namespaceName}}/{{topic}} parameters: serviceUrl: "{{serviceUrl}}" authenticationClass: "{{?authenticationClass}}" authenticationParams: "{{?authenticationParams}}" batchingEnabled: "{{?batchingEnabled}}" batchingMaxMessages: "{{?batchingMaxMessages}}" batchingMaxPublishDelayMicros: "{{?batchingMaxPublishDelayMicros}}" blockIfQueueFull: "{{?blockIfQueueFull}}" compressionType: "{{?compressionType}}" initialSequenceId: "{{?initialSequenceId}}" lazyStartProducer: "{{?lazyStartProducer}}" maxPendingMessages: "{{?maxPendingMessages}}" maxPendingMessagesAcrossPartitions: "{{?maxPendingMessagesAcrossPartitions}}" messageRoutingMode: "{{?messageRoutingMode}}" producerName: "{{?producerName}}" sendTimeoutMs: "{{?sendTimeoutMs}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: pulsar-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Pulsar" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" spec: dependencies: - "camel:pulsar" - "camel:kamelet" - "camel:core" definition: title: "Pulsar Source" description: "Receive data from Pulsar topics." required: - topicType - topic - namespaceName - tenant - serviceUrl properties: topic: title: Topic Name description: The topic name or regexp type: string tenant: title: Tenant Name description: The Tenant Name type: string topicType: title: Topic Type description: "The topic type." type: string enum: ["persistent", "non-persistent"] namespaceName: title: Pulsar Namespace Name description: The Pulsar Namespace Name type: string serviceUrl: title: Service URL description: The Pulsar Service URL to point while creating the client from URI. type: string authenticationClass: title: Authentication Class description: The Authentication FQCN to be used while creating the client from URI. type: string authenticationParams: title: Authentication Params description: The Authentication Parameters to be used while creating the client from URI. type: string consumerNamePrefix: title: Consumer Name Prefix description: Prefix to add to consumer names when a SHARED or FAILOVER subscription is used type: string default: cons consumerQueueSize: title: Consumer Queue Size description: Size of the consumer queue type: integer default: 10 deadLetterTopic: title: Dead Letter Topic description: "Name of the topic where the messages which fail `maxRedeliverCount` times are sent. Note: if not set, default topic name is topicName-subscriptionName-DLQ." type: integer maxRedeliverCount: title: Maximum Redelivery Count description: "Maximum number of times that a message is redelivered before being sent to the dead letter queue. If this value is not set, no Dead Letter Policy is created." type: integer negativeAckRedeliveryDelayMicros: title: Negative Ack Redelivery Delay in Microseconds description: "Set the negative acknowledgement delay." type: integer default: 60000000 messageListener: title: Message Listener description: "Whether to use the messageListener interface, or to receive messages using a separate thread pool." type: boolean default: true numberOfConsumers: title: Number Of Consumers description: "Number of consumers." type: integer default: 1 numberOfConsumerThreads: title: Number Of Consumer Threads description: "Number of threads to receive and handle messages when using a separate thread pool." type: integer default: 1 readCompacted: title: Read Compacted description: "Enable compacted topic reading." type: boolean default: false subscriptionInitialPosition: title: Subscription Initial Position description: "Control the initial position in the topic of a newly created subscription. Default is latest message." type: string default: LATEST enum: ["EARLIEST", "LATEST"] subscriptionName: title: Subscription Name description: "Name of the subscription to use." type: string default: subs subscriptionTopicsMode: title: Subscription Topics Mode description: "Determines to which topics this consumer should be subscribed to - Persistent, Non-Persistent, or both. Only used with pattern subscriptions." type: string default: PersistentOnly enum: ["PersistentOnly", "NonPersistentOnly", "AllTopics"] subscriptionType: title: Subscription Type description: "Type of the subscription." type: string default: EXCLUSIVE enum: ["EXCLUSIVE", "SHARED", "FAILOVER", "KEY_SHARED"] topicsPattern: title: Topic Pattern description: "Whether the topic is a pattern (regular expression) that allows the consumer to subscribe to all matching topics in the namespace." type: boolean default: false type: object template: from: uri: pulsar:{{topicType}}/{{tenant}}/{{namespaceName}}/{{topic}} parameters: serviceUrl: "{{serviceUrl}}" authenticationClass: "{{?authenticationClass}}" authenticationParams: "{{?authenticationParams}}" consumerNamePrefix: "{{?consumerNamePrefix}}" consumerQueueSize: "{{?consumerQueueSize}}" deadLetterTopic: "{{?deadLetterTopic}}" maxRedeliverCount: "{{?maxRedeliverCount}}" negativeAckRedeliveryDelayMicros: "{{?negativeAckRedeliveryDelayMicros}}" messageListener: "{{?messageListener}}" numberOfConsumers: "{{?numberOfConsumers}}" numberOfConsumerThreads: "{{?numberOfConsumerThreads}}" readCompacted: "{{?readCompacted}}" subscriptionInitialPosition: "{{?subscriptionInitialPosition}}" subscriptionName: "{{?subscriptionName}}" subscriptionTopicsMode: "{{?subscriptionTopicsMode}}" subscriptionType: "{{?subscriptionType}}" topicsPattern: "{{?topicsPattern}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: redis-sink labels: camel.apache.org/kamelet.type: "sink" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Redis" camel.apache.org/kamelet.namespace: "Cache" camel.apache.org/kamelet.icon:  spec: definition: title: "Redis Sink" description: "Write object to a Redis cache." required: - redisHost - redisPort - command type: object properties: redisHost: title: Redis Host description: The host where Redis server is running type: string redisPort: title: Redis Port description: The port where Redis server is running type: integer command: title: Command description: Redis Command type: string default: GET channels: title: Channels description: Redis Channels type: string default: one serializer: title: Serializer description: RedisSerializer fully qualified name implementation type: string default: org.springframework.data.redis.serializer.StringRedisSerializer dependencies: - "camel:kamelet" - "camel:core" - "camel:spring-redis" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[key]}" steps: - setHeader: name: CamelRedis.Key simple: "${header[key]}" - simple: "${header[ce-key]}" steps: - setHeader: name: CamelRedis.Key simple: "${header[ce-key]}" - choice: when: - simple: "${header[value]}" steps: - setHeader: name: CamelRedis.Value simple: "${header[value]}" - simple: "${header[ce-value]}" steps: - setHeader: name: CamelRedis.Value simple: "${header[ce-value]}" - choice: when: - simple: "${header[message]}" steps: - setHeader: name: CamelRedis.Message simple: "${header[message]}" - simple: "${header[ce-message]}" steps: - setHeader: name: CamelRedis.Message simple: "${header[ce-message]}" - choice: when: - simple: "${header[channel]}" steps: - setHeader: name: CamelRedis.Channel simple: "${header[channel]}" - simple: "${header[ce-channel]}" steps: - setHeader: name: CamelRedis.Channel simple: "${header[ce-channell]}" - setHeader: name: CamelRedis.Message simple: "${body}" - setHeader: name: CamelRedis.Value simple: "${body}" - to: uri: "spring-redis:{{redisHost}}:{{redisPort}}" parameters: command: "{{command}}" channels: "{{channels}}" serializer: "#class:{{serializer}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: redis-source labels: camel.apache.org/kamelet.type: "source" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Redis" camel.apache.org/kamelet.namespace: "Cache" camel.apache.org/kamelet.icon:  spec: definition: title: "Redis Source" description: "Get Events from a Redis cache." required: - redisHost - redisPort - channels type: object properties: redisHost: title: Redis Host description: The host where Redis server is running type: string redisPort: title: Redis Port description: The port where Redis server is running type: integer command: title: Command description: Redis Command type: string default: SUBSCRIBE channels: title: Channels description: Redis Channels type: string default: one serializer: title: Serializer description: RedisSerializer fully qualified name implementation type: string default: org.springframework.data.redis.serializer.StringRedisSerializer dependencies: - "camel:kamelet" - "camel:core" - "camel:spring-redis" template: from: uri: "spring-redis:{{redisHost}}:{{redisPort}}" parameters: command: "{{command}}" channels: "{{channels}}" serializer: "#class:{{serializer}}" steps: - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: regex-router-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Regex Router Action" description: "Update the destination using the configured regular expression and replacement string." required: - regex - replacement properties: regex: title: Regex description: Regular Expression for destination type: string replacement: title: Replacement description: Replacement when matching type: string type: object dependencies: - "camel:kamelet" - "camel:core" - "camel:kafka" template: from: uri: kamelet:source steps: - setProperty: name: "regex" constant: "{{regex}}" - setProperty: name: "replacement" constant: "{{replacement}}" - bean: "org.apache.camel.component.kafka.transform.RegexRouter" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: replace-field-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Replace Field Action" description: Replace field with a different key in the message in transit. required: - renames properties: enabled: title: Enabled description: Comma separated list of fields to be enabled type: string default: "all" disabled: title: Disabled description: Comma separated list of fields to be disabled type: string default: "none" renames: title: Renames description: Comma separated list of field with new value to be renamed type: string example: "foo:bar,c1:c2" type: object types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:kafka" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: "enabled" constant: "{{enabled}}" - setProperty: name: "disabled" constant: "{{disabled}}" - setProperty: name: "renames" constant: "{{renames}}" - bean: "org.apache.camel.component.kafka.transform.ReplaceField" - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: resolve-pojo-schema-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Resolve Schema Action" description: "Resolves schema from given mime type and payload. Sets the resolved schema, the schema type and its content class as properties for later reference." type: object properties: mimeType: title: Mime Type description: The mime type to determine the schema resolver implementation that should perform the operation. type: string default: "application/json" example: "application/json" schema: title: Schema description: Optional schema content (as single-line, using JSON format). type: string contentClass: title: Content Class description: Type information of the content object. Fully qualified class name. type: string example: "org.apache.camel.content.Foo" targetMimeType: title: Target Mime Type description: Additional mime type information used to determine the schema resolver. Usually only used in combination with mime type "application/x-java-object" type: string example: "application/json" dependencies: - "camel:kamelet" - "camel:core" - "camel:jackson-avro" - "camel:jackson-protobuf" template: beans: - name: schemaResolver type: "#class:org.apache.camel.component.kamelet.utils.format.schema.DelegatingSchemaResolver" properties: mimeType: '{{mimeType}}' schema: '{{schema:}}' contentClass: '{{contentClass:}}' targetMimeType: '{{targetMimeType:}}' from: uri: "kamelet:source" steps: - process: ref: "{{schemaResolver}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: rest-openapi-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "HTTP" camel.apache.org/kamelet.namespace: "HTTP" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "REST OpenAPI Sink" description: Load an OpenAPI specification from a URI and call an operation on a HTTP service. The request that is generated respects the rules given in the OpenAPI specification (for example, path parameters and Content-Type). required: - specification - operation type: object properties: specification: title: Specification URI description: The URI to the OpenApi specification file. type: string example: "https://api.example.com/openapi.json" pattern: "^(http|https|file|classpath|ref|bean)://.*" operation: title: Operation ID description: The operation to call. type: string dependencies: - "camel:rest-openapi" - "camel:http" - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - to: "rest-openapi:{{specification}}#{{operation}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: salesforce-composite-upsert-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Salesforce" camel.apache.org/kamelet.namespace: "Salesforce" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Salesforce composite upsert Sink" description: Upsert Composite List of sObjects in Salesforce. required: - sObjectName - sObjectIdName - clientId - clientSecret - userName - password type: object properties: sObjectName: title: Object Name description: The type of the Salesforce object. Required if using a key-value pair. type: string example: Contact sObjectIdName: title: Object Id Name description: The Field Name of the External ID of the Salesforce object. Required if using a key-value pair. type: string loginUrl: title: Login URL description: The Salesforce instance login URL. type: string default: https://login.salesforce.com clientId: title: Consumer Key description: The Salesforce application consumer key. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Consumer Secret description: The Salesforce application consumer secret. type: string format: password x-descriptors: - urn:camel:group:credentials userName: title: Username description: The Salesforce username. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The Salesforce user password. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jsonpath" - "camel:jackson" - "camel:salesforce" - "camel:kamelet" template: beans: - name: salesforce type: "#class:org.apache.camel.component.salesforce.SalesforceComponent" properties: sObjectName: "{{sObjectName}}" sObjectIdName: "{{sObjectIdName}}" clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" userName: "{{userName}}" password: "{{password}}" loginUrl: "{{loginUrl}}" from: uri: kamelet:source steps: - transform: jsonpath: "$['records']" - to: uri: "{{salesforce}}:compositeUpsertSObjectCollections" parameters: sObjectName: "{{sObjectName}}" sObjectIdName: "{{sObjectIdName}}" rawPayload: "true" allOrNone: "false" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: salesforce-create-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Salesforce" camel.apache.org/kamelet.namespace: "Salesforce" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Salesforce Create Sink" description: Create an object in Salesforce. required: - clientId - clientSecret - userName - password type: object properties: sObjectName: title: Object Name description: The type of the object. type: string example: Contact loginUrl: title: Login URL description: The Salesforce instance login URL. type: string default: https://login.salesforce.com clientId: title: Consumer Key description: The Salesforce application consumer key. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Consumer Secret description: The Salesforce application consumer secret. type: string format: password x-descriptors: - urn:camel:group:credentials userName: title: Username description: The Salesforce username. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The Salesforce user password. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:salesforce" - "camel:kamelet" template: beans: - name: local-salesforce type: "#class:org.apache.camel.component.salesforce.SalesforceComponent" properties: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" userName: "{{userName}}" password: "{{password}}" loginUrl: "{{loginUrl}}" from: uri: kamelet:source steps: - to: uri: "{{local-salesforce}}:createSObject" parameters: sObjectName: "{{sObjectName}}" rawPayload: "true" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: salesforce-delete-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Salesforce" camel.apache.org/kamelet.namespace: "Salesforce" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Salesforce Delete Sink" description: Remove an object from Salesforce. required: - clientId - clientSecret - userName - password type: object properties: loginUrl: title: Login URL description: The Salesforce instance login URL. type: string default: https://login.salesforce.com clientId: title: Consumer Key description: The Salesforce application consumer key. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Consumer Secret description: The Salesforce application consumer secret. type: string format: password x-descriptors: - urn:camel:group:credentials userName: title: Username description: The Salesforce username. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The Salesforce user password. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json schema: type: object required: ["sObjectId", "sObjectName"] properties: sObjectId: type: string sObjectName: type: string dependencies: - "camel:salesforce" - "camel:kamelet" - "camel:core" - "camel:jsonpath" template: beans: - name: local-delete-salesforce type: "#class:org.apache.camel.component.salesforce.SalesforceComponent" properties: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" userName: "{{userName}}" password: "{{password}}" loginUrl: "{{loginUrl}}" from: uri: kamelet:source steps: - setHeader: name: sObjectId jsonpath: "$['sObjectId']" - setHeader: name: sObjectName jsonpath: "$['sObjectName']" - setBody: simple: "${null}" - to: uri: "{{local-delete-salesforce}}:deleteSObject" - removeHeader: name: sObjectId - removeHeader: name: sObjectName --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: salesforce-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Salesforce" camel.apache.org/kamelet.namespace: "Salesforce" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Salesforce Source" description: Receive updates from Salesforce. required: - query - topicName - clientId - clientSecret - userName - password type: object properties: query: title: Query description: The query to execute on Salesforce. type: string example: SELECT Id, Name, Email, Phone FROM Contact topicName: title: Topic Name description: The name of the topic or channel. type: string example: ContactTopic loginUrl: title: Login URL description: The Salesforce instance login URL. type: string default: https://login.salesforce.com notifyForFields: title: Notify For Fields description: Notify for fields. type: string default: ALL enum: [ "ALL", "REFERENCED", "SELECT", "WHERE"] clientId: title: Consumer Key description: The Salesforce application consumer key. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Consumer Secret description: The Salesforce application consumer secret. type: string format: password x-descriptors: - urn:camel:group:credentials userName: title: Username description: The Salesforce username. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The Salesforce user password. type: string format: password x-descriptors: - urn:camel:group:credentials notifyForOperationCreate: title: Notify Operation Create description: Notify for create operation. type: boolean default: true notifyForOperationUpdate: title: Notify Operation Update description: Notify for update operation. type: boolean default: false notifyForOperationDelete: title: Notify Operation Delete description: Notify for delete operation. type: boolean default: false notifyForOperationUndelete: title: Notify Operation Undelete description: Notify for undelete operation. type: boolean default: false operation: title: Operation description: The operation to use type: string default: subscribe rawPayload: title: Raw Payload description: Use raw payload String for request and response (either JSON or XML depending on format), instead of DTOs, false by default. type: boolean default: false replayId: title: Replay Id description: The replayId value to use when subscribing to the Streaming API. type: long types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:salesforce" - "camel:kamelet" template: beans: - name: local-salesforce type: "#class:org.apache.camel.component.salesforce.SalesforceComponent" properties: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" userName: "{{userName}}" password: "{{password}}" loginUrl: "{{loginUrl}}" from: uri: "{{local-salesforce}}:{{operation}}:{{topicName}}" parameters: notifyForFields: "{{notifyForFields}}" updateTopic: "true" notifyForOperationCreate: "{{notifyForOperationCreate}}" notifyForOperationUpdate: "{{notifyForOperationUpdate}}" notifyForOperationDelete: "{{notifyForOperationDelete}}" notifyForOperationUndelete: "{{notifyForOperationUndelete}}" sObjectQuery: "{{query}}" rawPayload: "{{rawPayload}}" replayId: "{{?replayId}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: salesforce-update-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Salesforce" camel.apache.org/kamelet.namespace: "Salesforce" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Salesforce Update Sink" description: Update an object in Salesforce. required: - clientId - clientSecret - userName - password type: object properties: loginUrl: title: Login URL description: The Salesforce instance login URL. type: string default: https://login.salesforce.com clientId: title: Consumer Key description: The Salesforce application consumer key. type: string x-descriptors: - urn:camel:group:credentials clientSecret: title: Consumer Secret description: The Salesforce application consumer secret. type: string format: password x-descriptors: - urn:camel:group:credentials userName: title: Username description: The Salesforce username. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The Salesforce user password. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:core" - "camel:jsonpath" - "camel:jackson" - "camel:salesforce" - "camel:kamelet" template: beans: - name: local-salesforce type: "#class:org.apache.camel.component.salesforce.SalesforceComponent" properties: clientId: "{{clientId}}" clientSecret: "{{clientSecret}}" userName: "{{userName}}" password: "{{password}}" loginUrl: "{{loginUrl}}" from: uri: kamelet:source steps: - setHeader: name: sObjectId jsonpath: "$.sObjectId" - setHeader: name: sObjectName jsonpath: "$.sObjectName" - transform: jsonpath: "$.payload" - marshal: json: {} - to: uri: "{{local-salesforce}}:updateSObject" parameters: rawPayload: "true" - removeHeader: name: sObjectId - removeHeader: name: sObjectName --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: scp-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SCP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "SCP Sink" description: Send file to an FTP Server through Secure Copy Protocol required: - serverName - serverPort type: object properties: serverName: title: Hostname description: The hostname of the FTP server type: string serverPort: title: Port description: The port of the FTP server type: string username: title: Username description: Username for accessing FTP Server type: string password: title: Password description: Password for accessing FTP Server type: string format: password x-descriptors: - urn:camel:group:credentials privateKeyFile: title: Private Key File description: Set the private key file so that the SFTP endpoint can do private key verification. type: string privateKeyPassphrase: title: Private Key Passphrase description: Set the private key file passphrase so that the SFTP endpoint can do private key verification. type: string strictHostKeyChecking: title: Strict Host Checking description: Sets whether to use strict host key checking. type: string default: no useUserKnownHostsFile: title: Use User Known Hosts File description: If knownHostFile has not been explicit configured then use the host file from System.getProperty(user.home)/.ssh/known_hosts. type: boolean default: true dependencies: - "camel:core" - "camel:jsch" - "camel:kamelet" template: from: uri: kamelet:source steps: - to: uri: "scp:{{serverName}}:{{serverPort}}" parameters: username: "{{?username}}" password: "{{?password}}" privateKeyFile: "{{?privateKeyFile}}" privateKeyPassphrase: "{{?privateKeyPassphrase}}" strictHostKeyChecking: "{{?strictHostKeyChecking}}" useUserKnownHostsFile: "{{?useUserKnownHostsFile}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: set-body-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" spec: definition: title: "Set Body Action" description: Sets a simple language parsed value as the new message body in transit. required: - value properties: value: title: Value description: The value to set as new body type: string type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - setBody: simple: "{{value}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: set-kafka-key-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Set Kafka Key Action" description: Set Kafka Key based on a specific incoming header value from the message body. required: - headerName properties: headerName: title: Field description: The name of the header to set as Kafka Key type: string forceHeaderDeletion: title: Force Header Deletion description: If true, it will remove the header with name headerName from the Exchange after setting it as Kafka Key type: boolean default: false type: object dependencies: - "camel:kamelet" - "camel:core" template: from: uri: kamelet:source steps: - setHeader: name: kafka.KEY simple: "${header.{{headerName}}}" - choice: precondition: true when: - simple: '${properties:forceHeaderDeletion:true}' steps: - removeHeader: name: "{{headerName}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: sftp-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "SFTP Sink" description: Send data to an SFTP Server. required: - connectionHost - connectionPort - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the FTP server. type: string connectionPort: title: Connection Port description: The port of the FTP server. type: string default: 22 username: title: Username description: The username to access the FTP server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the FTP server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory. type: string passiveMode: title: Passive Mode description: Specifies to use passive mode connection. type: boolean default: false fileExist: title: File Existence description: How to behave in case of file already existent. type: string default: Override enum: ["Override", "Append", "Fail", "Ignore"] binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false privateKeyFile: title: Private Key File description: Set the private key file so that the SFTP endpoint can do private key verification. type: string privateKeyPassphrase: title: Private Key Passphrase description: Set the private key file passphrase so that the SFTP endpoint can do private key verification. type: string privateKeyUri: title: Private Key URI description: Set the private key file (loaded from classpath by default) so that the SFTP endpoint can do private key verification. type: string pattern: "^(http|https|file|classpath|ref|bean)://.*" strictHostKeyChecking: title: Strict Host Checking description: Sets whether to use strict host key checking. type: string default: no useUserKnownHostsFile: title: Use User Known Hosts File description: If knownHostFile has not been explicit configured then use the host file from System.getProperty(user.home)/.ssh/known_hosts. type: boolean default: true autoCreate: title: Autocreate Missing Directories description: Automatically create the directory the files should be written to. type: boolean default: true dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelFileName simple: "${header[ce-file]}" - to: uri: "sftp:{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: username: "{{?username}}" password: "{{?password}}" privateKeyFile: "{{?privateKeyFile}}" privateKeyPassphrase: "{{?privateKeyPassphrase}}" privateKeyUri: "{{?privateKeyUri}}" strictHostKeyChecking: "{{?strictHostKeyChecking}}" useUserKnownHostsFile: "{{?useUserKnownHostsFile}}" passiveMode: "{{passiveMode}}" fileExist: "{{fileExist}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: sftp-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "FTP" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "SFTP Source" description: Receive data from an SFTP server. required: - connectionHost - connectionPort - directoryName type: object properties: connectionHost: title: Connection Host description: The hostname of the SFTP server. type: string connectionPort: title: Connection Port description: The port of the FTP server. type: string default: 22 username: title: Username description: The username to access the SFTP server. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the SFTP server. type: string format: password x-descriptors: - urn:camel:group:credentials directoryName: title: Directory Name description: The starting directory. type: string passiveMode: title: Passive Mode description: Sets the passive mode connection. type: boolean default: false recursive: title: Recursive description: If a directory, look for files in all sub-directories as well. type: boolean default: false idempotent: title: Idempotency description: Skip already-processed files. type: boolean default: true ignoreFileNotFoundOrPermissionError: title: Ignore File Not Found Or Permission Error description: Whether to ignore when (trying to list files in directories or when downloading a file), which does not exist or due to permission error. By default when a directory or file does not exists or insufficient permission, then an exception is thrown. Setting this option to true allows to ignore that instead. type: boolean default: false binary: title: Binary description: Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false). type: boolean default: false privateKeyFile: title: Private Key File description: Set the private key file so that the SFTP endpoint can do private key verification. type: string privateKeyPassphrase: title: Private Key Passphrase description: Set the private key file passphrase so that the SFTP endpoint can do private key verification. type: string privateKeyUri: title: Private Key URI description: Set the private key file (loaded from classpath by default) so that the SFTP endpoint can do private key verification. type: string pattern: "^(http|https|file|classpath|ref|bean)://.*" strictHostKeyChecking: title: Strict Host Checking description: Sets whether to use strict host key checking. type: string default: no useUserKnownHostsFile: title: Use User Known Hosts File description: If knownHostFile has not been explicit configured then use the host file from System.getProperty(user.home)/.ssh/known_hosts. type: boolean default: true autoCreate: title: Autocreate Missing Directories description: Automatically create starting directory. type: boolean default: true delete: title: Delete description: If true, the file is deleted after it is processed successfully. type: boolean default: false dependencies: - "camel:ftp" - "camel:core" - "camel:kamelet" template: from: uri: "sftp:{{connectionHost}}:{{connectionPort}}/{{directoryName}}" parameters: username: "{{?username}}" password: "{{?password}}" privateKeyFile: "{{?privateKeyFile}}" privateKeyPassphrase: "{{?privateKeyPassphrase}}" privateKeyUri: "{{?privateKeyUri}}" strictHostKeyChecking: "{{?strictHostKeyChecking}}" useUserKnownHostsFile: "{{?useUserKnownHostsFile}}" passiveMode: "{{passiveMode}}" recursive: "{{recursive}}" idempotent: "{{idempotent}}" ignoreFileNotFoundOrPermissionError: "{{ignoreFileNotFoundOrPermissionError}}" binary: "{{binary}}" autoCreate: "{{autoCreate}}" delete: "{{delete}}" steps: - setBody: simple: "${body.getBody()}" - setHeader: name: file simple: "${header[CamelFileName]}" - setHeader: name: ce-file simple: "${header[CamelFileName]}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: simple-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Simple Filter Action" description: "Filter based on simple expression." required: - expression properties: expression: title: Simple Expression description: A simple expression to apply on the exchange to filter out some exchange type: string type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - filter: simple: "{{expression}}" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: slack-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Slack" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Slack Sink" description: Send messages to a Slack channel. required: - channel - webhookUrl type: object properties: channel: title: Channel description: The Slack channel to send messages to. type: string example: "#myroom" webhookUrl: title: Webhook URL description: The webhook URL used by the Slack channel to handle incoming messages. type: string format: password x-descriptors: - urn:camel:group:credentials iconEmoji: title: Icon Emoji description: Use a Slack emoji as an avatar. type: string iconUrl: title: Icon URL description: The avatar to use when sending a message to a channel or user. type: string username: title: Username description: The username for the bot when it sends messages to a channel or user. type: string types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:slack" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "slack:{{channel}}" parameters: webhookUrl: "{{webhookUrl}}" iconEmoji: "{{?iconEmoji}}" iconUrl: "{{?iconUrl}}" username: "{{?username}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: slack-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Slack" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Slack Source" description: Receive messages from a Slack channel. required: - channel - token type: object properties: serverUrl: title: Server URL description: The Slack API server endpoint URL. type: string default: "https://slack.com" example: "https://slack.com" channel: title: Channel description: The Slack channel to receive messages from. type: string example: "#myroom" token: title: Token description: "The Bot User OAuth Access Token to access Slack. A Slack app that has the following permissions is required: `channels:history`, `groups:history`, `im:history`, `mpim:history`, `channels:read`, `groups:read`, `im:read`, and `mpim:read`." type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The delay between polls. If no unit provided, milliseconds is the default. type: string default: "60000" example: "60s or 6000 or 1m" naturalOrder: title: Natural Order description: Create exchanges in natural order (oldest to newest) or not. type: boolean default: false dataTypes: out: default: json headers: types: json: format: "application-json" description: Json mapping of a Slack API Message mediaType: application/json cloudevents: format: "slack:application-cloudevents" description: Output data type represents Slack channel messages as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with respective data from the Slack message and its derived object. headers: CamelCloudEventID: title: CloudEvent ID description: The Camel exchange id set as event id type: string CamelCloudEventType: title: CloudEvent Type description: The event type default: "org.apache.camel.event.slack.consume" type: string CamelCloudEventSource: title: CloudEvent Source description: The event source. By default, the Slack App Id with prefix "slack.". type: string CamelCloudEventSubject: title: CloudEvent Subject description: The event subject. The Slack Channel name. type: string CamelCloudEventTime: title: CloudEvent Time description: The exchange creation timestamp as event time. type: string types: out: mediaType: application/json dependencies: - "camel:gson" - "camel:slack" - "camel:kamelet" template: from: uri: "slack:{{channel}}" parameters: serverUrl: "{{serverUrl}}" token: "{{token}}" delay: "{{delay}}" naturalOrder: "{{naturalOrder}}" steps: - marshal: json: library: "Gson" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: snowflake-sink annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Snowflake Sink" description: Send data to a Snowflake Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - instanceUrl - username - password - query type: object properties: instanceUrl: title: Instance URL description: The Instance url type: string example: instance.snowflakecomputing.com username: title: Username description: The username to access a secured Snowflake Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured Snowflake Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the Snowflake Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the Snowflake Database. type: string types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:net.snowflake:snowflake-jdbc:3.24.2" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-snowflake-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:net.snowflake.client.jdbc.SnowflakeBasicDataSource" properties: user: '{{username}}' password: '{{password}}' url: 'jdbc:snowflake://{{instanceUrl}}' databaseName: '{{?databaseName}}' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sql-snowflake-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: snowflake-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Snowflake Source" description: Query data from a Snowflake Database. required: - instanceUrl - username - password - query type: object properties: instanceUrl: title: Instance URL description: The Instance url type: string example: instance.snowflakecomputing.com username: title: Username description: The username to access a secured Snowflake Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured Snowflake Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the Snowflake Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the Snowflake Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed. type: string example: 'DELETE FROM accounts where user_id = :#user_id' delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:net.snowflake:snowflake-jdbc:3.24.2" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sql-snowflake-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:net.snowflake.client.jdbc.SnowflakeBasicDataSource" properties: user: '{{username}}' password: '{{password}}' url: 'jdbc:snowflake://{{instanceUrl}}' databaseName: '{{?databaseName}}' from: uri: "{{local-sql-snowflake-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: solr-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Solr" camel.apache.org/kamelet.namespace: "Search" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Solr Sink" description: Send documents to Solr Collection. required: - servers - collection type: object properties: collection: title: Collection description: Solr Collection name type: string servers: title: Servers description: Comma separated list of Solr Servers and ports type: string autocommit: title: Autocommit description: If autocommit should be enabled or not type: boolean default: false username: title: Username description: Username to connect to Solr. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to Solr. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:solr" - "camel:core" - "camel:jackson" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - setHeader: name: "CamelSolrOperation" constant: "INSERT" - setHeader: name: "CamelSolrCollection" constant: "{{collection}}" - unmarshal: json: library: Jackson - removeHeader: name: "content-type" - to: uri: "solr:{{servers}}/solr/" parameters: autocommit: "{{autocommit}}" username: "{{?username}}" password: "{{?password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: solr-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Solr" camel.apache.org/kamelet.namespace: "Search" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Solr Source" description: Query for documents to Solr Collection. required: - period - servers - collection - query type: object properties: period: title: Period between Polls description: The interval between fetches to the Solr collection type: integer default: 10000 collection: title: Collection description: Solr Collection name type: string servers: title: Servers description: Comma separated list of Solr Servers and ports type: string query: title: Query description: The query to submit to Solr type: string username: title: Username description: Username to connect to Solr. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: Password to connect to Solr. type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: application/json dependencies: - "camel:solr" - "camel:core" - "camel:timer" - "camel:jackson" - "camel:kamelet" template: from: uri: "timer:solr-stream" parameters: period: "{{period}}" steps: - setHeader: name: "CamelSolrOperation" constant: "QUERY" - setHeader: name: "CamelSolrQueryString" constant: "{{query}}" - setHeader: name: "CamelSolrCollection" constant: "{{collection}}" - removeHeader: name: "content-type" - to: uri: "solr:{{servers}}/solr/" parameters: username: "{{?username}}" password: "{{?password}}" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: splunk-hec-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SPLUNK" camel.apache.org/kamelet.namespace: "Monitoring" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Splunk HEC Sink" description: The Splunk HEC sink allows to send data to Splunk using the https://docs.splunk.com/Documentation/Splunk/latest/Data/UsetheHTTPEventCollector[HTTP Event Collector]. required: - splunkUrl - token type: object properties: splunkUrl: title: Splunk URL description: The URL of your Splunk server. No need to set the protocol prefix. type: string example: my_server.splunkcloud.com:8088 token: title: Token description: The Token of the HEC. Note it is not the user's authentication token. type: string format: password x-descriptors: - urn:camel:group:credentials hostPayload: title: Host of the Event description: The host field set in the data sent to Splunk, it is not related to the Splunk URL or the connection to Splunk server. type: string bodyOnly: title: Body Only description: Send to Splunk only data contained in the body. type: boolean default: false headersOnly: title: Headers Only description: Send to Splunk only data contained in the headers. type: boolean default: false index: title: Index description: Splunk index to write to. type: string source: title: Source description: The source named field of the data. type: string sourceType: title: Source Type description: The source named field of the data. type: string skipTlsVerify: title: Skip TLS Verification description: Skip TLS verification. type: boolean default: false https: title: Secure description: Use a secure HTTPS connection. type: boolean default: true time: title: Time description: Time this event occurred. By default, the time is when this event hits the Splunk server. type: string types: in: mediaType: application/json dependencies: - "camel:core" - "camel:splunk-hec" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "splunk-hec:{{splunkUrl}}" parameters: host: "{{?hostPayload}}" token: "{{token}}" bodyOnly: "{{?bodyOnly}}" headersOnly: "{{?headersOnly}}" index: "{{?index}}" source: "{{?source}}" sourceType: "{{?sourceType}}" skipTlsVerify: "{{?skipTlsVerify}}" https: "{{?https}}" time: "{{?time}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: splunk-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SPLUNK" camel.apache.org/kamelet.namespace: "Monitoring" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Splunk Sink" description: Send data to Splunk either by using "submit" or "stream" mode. required: - serverHostname - username - password type: object properties: serverHostname: title: Splunk Server Address description: The address of your Splunk server. type: string example: my_server_splunk.com serverPort: title: Splunk Server Port description: The address of your Splunk server. type: integer default: 8089 username: title: Username description: The username to authenticate to Splunk Server. type: string password: title: Password description: The password to authenticate to Splunk Server. type: string format: password x-descriptors: - urn:camel:group:credentials index: title: Index description: Splunk index to write to. type: string protocol: title: Protocol description: Connection Protocol to Splunk server. type: string default: https enum: ["http", "https"] source: title: Source description: The source named field of the data. type: string sourceType: title: Source Type description: The source named field of the data. type: string app: title: Splunk App description: The app name in Splunk. type: string connectionTimeout: title: Connection Timeout description: Timeout in milliseconds when connecting to Splunk server type: integer default: 5000 mode: title: Mode description: The mode to publish events to Splunk. type: string default: stream enum: ["submit", "stream"] types: in: mediaType: application/json dependencies: - "camel:core" - "camel:splunk" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "splunk:{{mode}}" parameters: host: "{{serverHostname}}" port: "{{serverPort}}" username: "{{username}}" password: "{{password}}" source: "{{?source}}" sourceType: "{{?sourceType}}" scheme: "{{?protocol}}" index: "{{?index}}" app: "{{?app}}" connectionTimeout: "{{?connectionTimeout}}" raw: true --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: splunk-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SPLUNK" camel.apache.org/kamelet.namespace: "Monitoring" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Splunk Source" description: Retrieve data from Splunk and outputs in json format. required: - serverHostname - username - password - query - initEarliestTime type: object properties: serverHostname: title: Splunk Server Address description: The address of your Splunk server. type: string example: my_server_splunk.com serverPort: title: Splunk Server Port description: The address of your Splunk server. type: integer default: 8089 username: title: Username description: The username to authenticate to Splunk Server. type: string password: title: Password description: The password to authenticate to Splunk Server. type: string format: password x-descriptors: - urn:camel:group:credentials index: title: Index description: Splunk index to write to. type: string protocol: title: Protocol description: Connection Protocol to Splunk server. type: string default: https enum: ["http", "https"] source: title: Source description: The source named field of the data. type: string sourceType: title: Source Type description: The source named field of the data. type: string app: title: Splunk App description: The app name in Splunk. type: string connectionTimeout: title: Connection Timeout description: Timeout in milliseconds when connecting to Splunk server type: integer count: title: Count description: The maximum number of entities to return. type: integer repeat: title: Repeat description: The maximum number of fires. type: integer delay: title: Delay description: The number of milliseconds before the next poll. type: integer query: title: Query description: The Splunk query to run. type: string earliestTime: title: Earliest Time description: Earliest time of the search time window. type: string example: "05/17/22 08:35:46:456" initEarliestTime: title: Init Earliest Time description: Initial start offset of the first search. type: string example: "05/17/22 08:35:46:456" latestTime: title: Latest Time description: Latest time of the search time window. type: string example: "05/17/22 08:35:46:456" types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:core" - "camel:splunk" - "camel:kamelet" - "mvn:com.fasterxml.jackson.datatype:jackson-datatype-joda:2.12.5" template: from: uri: "splunk:normal" parameters: host: "{{serverHostname}}" port: "{{serverPort}}" username: "{{username}}" password: "{{password}}" index: "{{?index}}" scheme: "{{?protocol}}" source: "{{?source}}" sourceType: "{{?sourceType}}" app: "{{?app}}" connectionTimeout: "{{?connectionTimeout}}" count: "{{?count}}" repeatCount: "{{?repeat}}" delay: "{{?delay}}" search: "{{?query}}" earliestTime: "{{?earliestTime}}" initEarliestTime: "{{initEarliestTime}}" latestTime: "{{?latestTime}}" raw: true steps: - marshal: json: library: Jackson moduleClassNames: com.fasterxml.jackson.datatype.joda.JodaModule - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: spring-rabbitmq-sink annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "RabbitMQ" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "RabbitMQ Sink" description: Send data to a RabbitMQ Broker. required: - host - port - exchangeName type: object properties: host: title: Server Address description: RabbitMQ broker address type: string example: "localhost" port: title: Server Port description: RabbitMQ broker port type: integer example: 5672 routingKey: title: Routing Key description: The routing key to use when binding a consumer queue to the exchange type: string username: title: Username description: The username to access the RabbitMQ server type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the RabbitMQ server type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials exchangeName: title: Exchange name description: The exchange name determines the exchange the queue is bound to. type: string queues: title: Queue name description: The queue to receive messages from type: string autoDeclareProducer: title: Auto Declare Producer description: Specifies whether the producer should auto declare binding between exchange, queue and routing key when starting type: boolean default: false vhost: title: Virtual Host description: The virtual host type: string default: "/" protocol: title: Protocol description: The AMQP protocol to use. type: string enum: ["amqp", "amqps"] default: "amqp" dependencies: - "camel:spring-rabbitmq" - "camel:kamelet" template: beans: - name: connectionFactory type: "#class:org.springframework.amqp.rabbit.connection.CachingConnectionFactory" properties: username: '{{?username}}' password: '{{?password}}' uri: '{{protocol}}://{{host}}:{{port}}' virtualHost: "{{vhost}}" from: uri: "kamelet:source" steps: - to: uri: "spring-rabbitmq://{{exchangeName}}" parameters: connectionFactory: "#bean:{{connectionFactory}}" routingKey: "{{?routingKey}}" queues: "{{?queues}}" autoDeclareProducer: "{{autoDeclareProducer}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: spring-rabbitmq-source annotations: camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "RabbitMQ" camel.apache.org/kamelet.namespace: "Messaging" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "RabbitMQ Source" description: Receive data from a RabbitMQ Broker. required: - host - port - exchangeName type: object properties: host: title: Server Address description: RabbitMQ broker address type: string example: "localhost" port: title: Server Port description: RabbitMQ broker port type: integer example: 5672 routingKey: title: Routing Key description: The routing key to use when binding a consumer queue to the exchange type: string username: title: Username description: The username to access the RabbitMQ server type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access the RabbitMQ server type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials exchangeName: title: Exchange name description: The exchange name determines the exchange the queue is bound to. type: string queues: title: Queue name description: The queue to receive messages from type: string autoDeclare: title: Auto Declare description: The routing key to use when binding a consumer queue to the exchange type: boolean default: false vhost: title: Virtual Host description: The virtual host type: string default: "/" protocol: title: Protocol description: The AMQP protocol to use. type: string enum: ["amqp", "amqps"] default: "amqp" dependencies: - "camel:spring-rabbitmq" - "camel:kamelet" template: beans: - name: connectionFactory type: "#class:org.springframework.amqp.rabbit.connection.CachingConnectionFactory" properties: username: '{{?username}}' password: '{{?password}}' uri: '{{protocol}}://{{host}}:{{port}}' virtualHost: "{{vhost}}" from: uri: "spring-rabbitmq://{{exchangeName}}" parameters: connectionFactory: "#bean:{{connectionFactory}}" routingKey: "{{?routingKey}}" queues: "{{?queues}}" autoDeclare: "{{autoDeclare}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: sqlserver-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Microsoft SQL Server Sink" description: Send data to a Microsoft SQL Server Database. This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 1433 username: title: Username description: The username to access a secured SQL Server Database. type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured SQL Server Database. type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the SQL Server Database. type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the SQL Server Database. type: string encrypt: title: Encrypt Connection description: Encrypt the connection to SQL Server. type: boolean default: false trustServerCertificate: title: Trust Server Certificate description: Trust Server Certificate type: boolean default: true types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sqlserver-sink type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:sqlserver://{{serverName}}:{{serverPort}};databaseName={{databaseName}};encrypt={{encrypt}};trustServerCertificate={{trustServerCertificate}};' driverClassName: 'com.microsoft.sqlserver.jdbc.SQLServerDriver' from: uri: "kamelet:source" steps: - unmarshal: json: library: Jackson - to: uri: "{{local-sqlserver-sink}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: sqlserver-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SQL" camel.apache.org/kamelet.namespace: "Database" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Microsoft SQL Server Source" description: Query data from a Microsoft SQL Server Database. required: - serverName - username - password - query - databaseName type: object properties: serverName: title: Server Name description: The server name for the data source. type: string example: localhost serverPort: title: Server Port description: The server port for the data source. type: string default: 1433 username: title: Username description: The username to access a secured SQL Server Database type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The password to access a secured SQL Server Database type: string format: password x-descriptors: - urn:camel:group:credentials query: title: Query description: The query to execute against the SQL Server Database type: string example: 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' databaseName: title: Database Name description: The name of the Database. type: string consumedQuery: title: Consumed Query description: A query to run on a tuple consumed type: string example: 'DELETE FROM accounts where user_id = :#user_id' encrypt: title: Encrypt Connection description: Encrypt the connection to SQL Server. type: boolean default: false trustServerCertificate: title: Trust Server Certificate description: Trust Server Certificate type: boolean default: true delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 types: in: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:sql" - "mvn:org.apache.commons:commons-dbcp2:2.13.0" template: beans: - name: local-sqlserver-source type: "#class:org.apache.camel.component.sql.SqlComponent" properties: autowiredEnabled: "false" - name: dsBean type: "#class:org.apache.commons.dbcp2.BasicDataSource" properties: username: '{{username}}' password: '{{password}}' url: 'jdbc:sqlserver://{{serverName}}:{{serverPort}};databaseName={{databaseName}};encrypt={{encrypt}};trustServerCertificate={{trustServerCertificate}};' driverClassName: 'com.microsoft.sqlserver.jdbc.SQLServerDriver' from: uri: "{{local-sqlserver-source}}:{{query}}" parameters: dataSource: "#bean:{{dsBean}}" onConsume: "{{?consumedQuery}}" delay: "{{delay}}" steps: - marshal: json: library: Jackson - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ssh-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SSH" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "SSH Sink" description: Send command through SSH session. required: - connectionHost - connectionPort - username - password type: object properties: connectionHost: title: Connection Host description: The SSH Host type: string connectionPort: title: Connection Port description: The SSH Port type: string default: 22 username: title: Username description: The SSH username to use type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The SSH password to use type: string format: password x-descriptors: - urn:camel:group:credentials types: in: mediaType: text/plain out: mediaType: text/plain dependencies: - "camel:ssh" - "camel:gson" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "ssh://{{connectionHost}}:{{connectionPort}}" parameters: username: "{{username}}" password: "{{password}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: ssh-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "SSH" camel.apache.org/kamelet.namespace: "File" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "SSH Source" description: Receive data from SSH session. required: - connectionHost - connectionPort - username - password - pollCommand type: object properties: connectionHost: title: Connection Host description: The SSH Host type: string connectionPort: title: Connection Port description: The SSH Port type: string default: 22 username: title: Username description: The SSH username to use type: string x-descriptors: - urn:camel:group:credentials password: title: Password description: The SSH password to use type: string format: password x-descriptors: - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 pollCommand: title: Poll Command description: The command to run while polling the SSH session type: string example: date dependencies: - "camel:ssh" - "camel:kamelet" template: from: uri: "ssh://{{connectionHost}}:{{connectionPort}}" parameters: username: "{{username}}" password: "{{password}}" delay: "{{delay}}" pollCommand: "{{pollCommand}}" steps: - convertBodyTo: type: "java.lang.String" - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: string-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "String Template Action" description: Apply a String Template. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.tm" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:stringtemplate" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "string-template:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: telegram-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Telegram" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Telegram Sink" description: Send a message to a Telegram chat by using your Telegram bot as sender. required: - authorizationToken type: object properties: authorizationToken: title: Token description: "The token to access your bot on Telegram. You you can obtain it from the Telegram @botfather." type: string format: password x-descriptors: - urn:camel:group:credentials chatId: title: Chat ID description: The Chat ID to where you want to send messages by default. type: string types: out: mediaType: application/json dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:telegram" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[Content-Type]} == 'image/png'" steps: - convertBodyTo: type: "byte[]" - setHeader: name: CamelTelegramMediaType constant: PHOTO_PNG - simple: "${header[Content-Type]} == 'image/jpeg'" steps: - convertBodyTo: type: "byte[]" - setHeader: name: CamelTelegramMediaType constant: PHOTO_JPG otherwise: steps: - convertBodyTo: type: "java.lang.String" - choice: when: - simple: "${header[text]}" steps: - setHeader: name: CamelTelegramMediaTitleCaption simple: "${header[text]}" - simple: "${header[ce-text]}" steps: - setHeader: name: CamelTelegramMediaTitleCaption simple: "${header[ce-text]}" - choice: when: - simple: "${header[chat-id]}" steps: - setHeader: name: CamelTelegramChatId simple: "${header[chat-id]}" - simple: "${header[ce-chatid]}" steps: - setHeader: name: CamelTelegramChatId simple: "${header[ce-chatid]}" - to: uri: "telegram:bots" parameters: authorizationToken: "{{authorizationToken}}" chatId: "{{?chatId}}" - marshal: json: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: telegram-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Telegram" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Telegram Source" description: Receive all messages that people send to your Telegram bot. required: - authorizationToken type: object properties: authorizationToken: title: Token description: "The token to access your bot on Telegram. You can obtain it from the Telegram @botfather." type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:telegram" - "camel:core" template: from: uri: telegram:bots parameters: authorizationToken: "{{authorizationToken}}" steps: - setHeader: name: chat-id simple: "${header[CamelTelegramChatId]}" - setHeader: name: ce-chatid simple: "${header[CamelTelegramChatId]}" - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: throttle-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "EIP" spec: definition: title: "Throttle Action" description: "The Throttle action allows you to ensure that a specific sink does not get overloaded." required: - messages properties: messages: title: Messages Number description: The number of messages to send in the time period set type: integer example: 10 timePeriod: title: Time Period description: Sets the time period during which the maximum request count is valid for, in milliseconds type: string default: "1000" type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - throttle: constant: "{{messages}}" timePeriodMillis: "{{timePeriod}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: timer-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon:  camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Timer" camel.apache.org/kamelet.namespace: "Scheduling" labels: camel.apache.org/kamelet.type: "source" camel.apache.org/kamelet.verified: "true" spec: definition: title: "Timer Source" description: Produces periodic messages with a custom payload. required: - message type: object properties: period: title: Period description: "The interval (in milliseconds) to wait between producing the next message." type: integer default: 1000 message: title: Message description: The message to generate. type: string example: hello world contentType: title: Content Type description: The content type of the generated message. type: string default: text/plain repeatCount: title: Repeat Count description: Specifies a maximum limit of number of fires type: integer dependencies: - "camel:core" - "camel:timer" - "camel:kamelet" template: from: uri: timer:tick parameters: period: "{{period}}" repeatCount: "{{?repeatCount}}" steps: - setBody: constant: "{{message}}" - setHeader: name: "Content-Type" constant: "{{contentType}}" - to: kamelet:sink --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: timestamp-router-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Timestamp Router Action" description: "Update the topic field as a function of the original topic name and the record timestamp." properties: topicFormat: title: Topic Format description: Format string which can contain '$[topic]' and '$[timestamp]' as placeholders for the topic and timestamp, respectively. type: string default: "topic-$[timestamp]" timestampFormat: title: Timestamp Format description: Format string for the timestamp that is compatible with java.text.SimpleDateFormat. type: string default: "yyyyMMdd" timestampHeaderName: title: Timestamp Header Name description: The name of the header containing a timestamp type: string default: "kafka.TIMESTAMP" type: object dependencies: - "camel:kamelet" - "camel:core" - "camel:kafka" template: from: uri: kamelet:source steps: - setProperty: name: "topicFormat" constant: "{{topicFormat}}" - setProperty: name: "timestampFormat" constant: "{{timestampFormat}}" - setProperty: name: "timestampHeaderName" constant: "{{timestampHeaderName}}" - bean: "org.apache.camel.component.kafka.transform.TimestampRouter" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: topic-name-matches-filter-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Kafka Topic Name Matches Filter Action" description: "Filter based on kafka topic value compared to regex." required: - regex properties: regex: title: Regex description: The Regex to Evaluate against the Kafka topic name type: string type: object dependencies: - "camel:core" - "camel:kamelet" template: from: uri: kamelet:source steps: - filter: simple: "${header[kafka.TOPIC]} !regex '{{regex}}'" steps: - stop: {} --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: twitter-directmessage-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Twitter" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Twitter Direct Message Source" description: Allows to get all direct messages for your Twitter account. required: - user - apiKey - apiKeySecret - accessToken - accessTokenSecret type: object properties: user: title: User description: The user we want to read the direct messages type: string example: "ApacheCamel" apiKey: title: API Key description: The API Key from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials apiKeySecret: title: API Key Secret description: The API Key Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: The Access Token from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessTokenSecret: title: Access Token Secret description: The Access Token Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:twitter" - "camel:kamelet" template: from: uri: "twitter-directmessage:{{user}}" parameters: accessToken: "{{accessToken}}" accessTokenSecret: "{{accessTokenSecret}}" consumerKey: "{{apiKey}}" consumerSecret: "{{apiKeySecret}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: twitter-search-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Twitter" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Twitter Search Source" description: Allows to get all tweets on particular keywords from Twitter. required: - keywords - apiKey - apiKeySecret - accessToken - accessTokenSecret type: object properties: keywords: title: Keywords description: The keywords to use in the Twitter search (Supports Twitter standard operators) type: string example: "Apache Camel" apiKey: title: API Key description: The API Key from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials apiKeySecret: title: API Key Secret description: The API Key Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: The Access Token from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessTokenSecret: title: Access Token Secret description: The Access Token Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:twitter" - "camel:kamelet" template: from: uri: "twitter-search:{{keywords}}" parameters: accessToken: "{{accessToken}}" accessTokenSecret: "{{accessTokenSecret}}" consumerKey: "{{apiKey}}" consumerSecret: "{{apiKeySecret}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: twitter-timeline-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Twitter" camel.apache.org/kamelet.namespace: "Social" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Twitter Timeline Source" description: Allows to get tweets from the timeline of a specific user from Twitter. required: - user - apiKey - apiKeySecret - accessToken - accessTokenSecret type: object properties: user: title: User description: The user we want to read the timeline type: string example: "ApacheCamel" apiKey: title: API Key description: The API Key from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials apiKeySecret: title: API Key Secret description: The API Key Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessToken: title: Access Token description: The Access Token from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials accessTokenSecret: title: Access Token Secret description: The Access Token Secret from the Twitter application in the developer portal type: string format: password x-descriptors: - urn:camel:group:credentials types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:twitter" - "camel:kamelet" template: from: uri: "twitter-timeline:user" parameters: user: "{{user}}" accessToken: "{{accessToken}}" accessTokenSecret: "{{accessTokenSecret}}" consumerKey: "{{apiKey}}" consumerSecret: "{{apiKeySecret}}" steps: - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: value-to-key-action labels: camel.apache.org/kamelet.type: "action" annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Kafka" spec: definition: title: "Value to Key Action" description: "Replace the Kafka record key with a new key formed from a fields subset coming from the message body." required: - fields properties: fields: title: Fields description: Comma separated list of fields to be used to form the new key. type: string type: object dependencies: - "camel:core" - "camel:jackson" - "camel:kamelet" - "camel:kafka" template: from: uri: kamelet:source steps: - choice: when: - simple: "${header[Content-Type]} == 'application/json'" steps: - setProperty: name: deserialized constant: "true" - unmarshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setProperty: name: "fields" constant: "{{fields}}" - bean: "org.apache.camel.component.kafka.transform.ValueToKey" - choice: when: - simple: "${exchangeProperty[deserialized]} == 'true'" steps: - marshal: json: library: Jackson unmarshalType: com.fasterxml.jackson.databind.JsonNode - setHeader: name: "Content-Type" constant: "application/json" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: velocity-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "Velocity Template Action" description: Apply a Velocity Template. required: - template type: object properties: template: title: Template description: The inline template type: string example: "file:////template.vm" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:velocity" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "velocity:" parameters: resourceUri: "{{template}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: webhook-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Webhook" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Webhook Source" description: Creates an HTTP endpoint that can be used as a bridge to forward data to the Kamelet sink. type: object properties: subpath: title: Subpath description: | The subpath where the webhook is registered type: string default: "webhook" dependencies: - "camel:platform-http" - "camel:kamelet" template: from: uri: "platform-http:///{{subpath}}" steps: - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: wttrin-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Weather" camel.apache.org/kamelet.namespace: "Dataset" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "wttr.in Source" description: Get weather forecasts from the wttr.in weather forecast service type: object properties: period: title: Period description: The interval between fetches to the wttr.in service in milliseconds type: integer default: 60000 wttrLocation: title: Location description: The location to get weather forecasts type: string example: '"paris", "~Eiffel+tower", "Москва", "muc", "@stackoverflow.com", "94107", "-78.46,106.79"' wttrLanguage: title: Language description: The language to use for displaying weather forecasts type: string example: 'am ar af be bn ca da de el et fr fa hi hu ia id it lt mg nb nl oc pl pt-br ro ru ta tr th uk vi zh-cn zh-tw' output: title: Output Type description: The type of output type: string example: 'current, weather, full' default: current types: out: mediaType: application/json dependencies: - "camel:core" - "camel:http" - "camel:jackson" - "camel:jsonpath" - "camel:kamelet" - "camel:timer" template: from: uri: timer:wttr.in parameters: period: "{{period}}" steps: - to: "https://wttr.in/{{?wttrLocation}}?format=j1&lang={{?wttrLanguage}}" - choice: when: - simple: "'{{output}}' == 'current'" steps: - transform: jsonpath: "$.current_condition[0]" - marshal: json: {} - simple: "'{{output}}' == 'weather'" steps: - transform: jsonpath: "$.weather" - marshal: json: {} - to: "kamelet:sink" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: xj-identity-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "XJ Identity Action" description: Apply the XJ Identity Transformation to transform JSON to XML and XML to JSON. required: - direction type: object properties: direction: title: Direction description: The transform direction. type: string enum: ["XML2JSON", "JSON2XML"] dependencies: - "camel:xj" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "xj:identity" parameters: transformDirection: "{{direction}}" --- apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: xj-template-action annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.14.2" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Actions" camel.apache.org/kamelet.namespace: "Transformation" labels: camel.apache.org/kamelet.type: "action" spec: definition: title: "XJ Template Action" description: Apply the XJ Template Transformation to transform JSON to XML and XML to JSON. required: - direction - template type: object properties: direction: title: Direction description: The transform direction. type: string enum: ["XML2JSON", "JSON2XML"] template: title: Template description: The inline template to apply a transformation through template. type: string example: "file:////template.vm" pattern: "^(http|https|file|classpath|ref|bean)://.*" dependencies: - "camel:xj" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - to: uri: "xj:" parameters: resourceUri: "{{template}}" transformDirection: "{{direction}}"