This is an automated email from the ASF dual-hosted git repository.
acosentino pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel-kamelets.git
The following commit(s) were added to refs/heads/main by this push:
new df07f8e8f Create an AWS comprehend Sink Kamelet (#2724)
df07f8e8f is described below
commit df07f8e8ff8a83bebc616cead9283e234fa7f3c9
Author: Andrea Cosentino <[email protected]>
AuthorDate: Tue Feb 17 11:22:41 2026 +0100
Create an AWS comprehend Sink Kamelet (#2724)
Signed-off-by: Andrea Cosentino <[email protected]>
---
docs/modules/ROOT/nav.adoc | 1 +
.../partials/aws-comprehend-sink-description.adoc | 42 +++++++
kamelets/aws-comprehend-sink.kamelet.yaml | 130 +++++++++++++++++++++
.../kamelets/catalog/KameletsCatalogTest.java | 2 +-
.../kamelets/aws-comprehend-sink.kamelet.yaml | 130 +++++++++++++++++++++
.../pipes/camel-k/aws-comprehend-sink-pipe.yaml | 19 +++
templates/pipes/core/aws-comprehend-sink-pipe.yaml | 13 +++
7 files changed, 336 insertions(+), 1 deletion(-)
diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc
index 62b60c6e1..8d4451ae5 100644
--- a/docs/modules/ROOT/nav.adoc
+++ b/docs/modules/ROOT/nav.adoc
@@ -5,6 +5,7 @@
* xref:aws-bedrock-text-sink.adoc[]
* xref:aws-cloudtrail-source.adoc[]
* xref:aws-cloudwatch-sink.adoc[]
+* xref:aws-comprehend-sink.adoc[]
* xref:aws-ddb-sink.adoc[]
* xref:aws-ddb-streams-source.adoc[]
* xref:aws-ec2-sink.adoc[]
diff --git a/docs/modules/ROOT/partials/aws-comprehend-sink-description.adoc
b/docs/modules/ROOT/partials/aws-comprehend-sink-description.adoc
new file mode 100644
index 000000000..5bfd9810b
--- /dev/null
+++ b/docs/modules/ROOT/partials/aws-comprehend-sink-description.adoc
@@ -0,0 +1,42 @@
+== AWS Comprehend Sink Kamelet Description
+
+=== Authentication methods
+
+In this Kamelet you can avoid using explicit static credentials by specifying
the `useDefaultCredentialsProvider` option and set it to `true`.
+
+The order of evaluation for Default Credentials Provider is the following:
+
+ - Java system properties - `aws.accessKeyId` and `aws.secretKey`.
+ - Environment variables - `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY`.
+ - Web Identity Token from AWS STS.
+ - The shared credentials and config files.
+ - Amazon ECS container credentials - loaded from the Amazon ECS if the
environment variable `AWS_CONTAINER_CREDENTIALS_RELATIVE_URI` is set.
+ - Amazon EC2 Instance profile credentials.
+
+You can also use the Profile Credentials Provider, by setting the
`useProfileCredentialsProvider` option to `true` and `profileCredentialsName`
to the profile name.
+
+Only one of access key/secret key or default credentials provider could be used
+
+For more information, see the
https://docs.aws.amazon.com/sdk-for-java/latest/developer-guide/credentials.html[AWS
credentials documentation]
+
+=== Operations
+
+The kamelet supports the following operations:
+
+ - *detectDominantLanguage* (default) - Detects the dominant language of the
input text.
+ - *detectEntities* - Detects named entities (people, places, organizations,
etc.) in the input text.
+ - *detectKeyPhrases* - Detects key noun phrases in the input text.
+ - *detectSentiment* - Detects the sentiment (positive, negative, neutral,
mixed) of the input text.
+ - *detectSyntax* - Detects the parts of speech (nouns, verbs, adjectives,
etc.) in the input text.
+ - *detectPiiEntities* - Detects personally identifiable information (PII) in
the input text.
+ - *detectToxicContent* - Detects toxic content in the input text.
+ - *classifyDocument* - Classifies the input text using a custom document
classifier endpoint.
+ - *containsPiiEntities* - Checks whether the input text contains PII entities.
+
+=== Language Code
+
+The `languageCode` parameter is required for all operations except
`detectDominantLanguage`. Use a 2-letter ISO 639-1 code (e.g., `en` for
English, `es` for Spanish).
+
+=== Document Classification
+
+For the `classifyDocument` operation, you must provide the `endpointArn`
parameter pointing to your custom classifier endpoint.
diff --git a/kamelets/aws-comprehend-sink.kamelet.yaml
b/kamelets/aws-comprehend-sink.kamelet.yaml
new file mode 100644
index 000000000..798f5bc76
--- /dev/null
+++ b/kamelets/aws-comprehend-sink.kamelet.yaml
@@ -0,0 +1,130 @@
+# ---------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+# ---------------------------------------------------------------------------
+
+apiVersion: camel.apache.org/v1
+kind: Kamelet
+metadata:
+ name: aws-comprehend-sink
+ annotations:
+ camel.apache.org/kamelet.support.level: "Preview"
+ camel.apache.org/catalog.version: "4.18.0-SNAPSHOT"
+ camel.apache.org/kamelet.icon:
"
[...]
+ camel.apache.org/provider: "Apache Software Foundation"
+ camel.apache.org/kamelet.group: "AWS Comprehend"
+ camel.apache.org/kamelet.namespace: "AWS"
+ labels:
+ camel.apache.org/kamelet.type: "sink"
+spec:
+ definition:
+ title: "AWS Comprehend Sink"
+ description: Send data to AWS Comprehend for natural language processing.
+ required:
+ - region
+ type: object
+ properties:
+ operation:
+ title: Operation
+ description: The operation to perform on the input text.
+ type: string
+ default: detectDominantLanguage
+ enum: ["detectDominantLanguage", "detectEntities", "detectKeyPhrases",
"detectSentiment", "detectSyntax", "detectPiiEntities", "detectToxicContent",
"classifyDocument", "containsPiiEntities"]
+ languageCode:
+ title: Language Code
+ description: The language code of the input text. Required for all
operations except detectDominantLanguage. Use a 2-letter ISO 639-1 code (e.g.,
'en' for English, 'es' for Spanish).
+ type: string
+ endpointArn:
+ title: Endpoint ARN
+ description: The Amazon Resource Name (ARN) of the endpoint to use for
document classification. Required for classifyDocument operation.
+ 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", "a [...]
+ useDefaultCredentialsProvider:
+ title: Default Credentials Provider
+ description: If true, the Comprehend 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 Comprehend client should expect to load
credentials through a profile credentials provider.
+ type: boolean
+ default: false
+ useSessionCredentials:
+ title: Session Credentials
+ description: Set whether the Comprehend client should expect to use
Session Credentials. This is useful in a situation in which the user needs to
assume an IAM role for doing operations in Comprehend.
+ 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 an 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-comprehend"
+ - "camel:kamelet"
+ template:
+ from:
+ uri: "kamelet:source"
+ steps:
+ - to:
+ uri: "aws2-comprehend:comprehend"
+ parameters:
+ secretKey: "{{?secretKey}}"
+ accessKey: "{{?accessKey}}"
+ region: "{{region}}"
+ operation: "{{operation}}"
+ languageCode: "{{?languageCode}}"
+ endpointArn: "{{?endpointArn}}"
+ useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
+ useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}"
+ useSessionCredentials: "{{useSessionCredentials}}"
+ uriEndpointOverride: "{{?uriEndpointOverride}}"
+ profileCredentialsName: "{{?profileCredentialsName}}"
+ sessionToken: "{{?sessionToken}}"
+ overrideEndpoint: "{{overrideEndpoint}}"
diff --git
a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
index fe79189a2..c96f22c3d 100644
---
a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
+++
b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
@@ -121,7 +121,7 @@ public class KameletsCatalogTest {
void testGetKameletsByNamespace() throws Exception {
List<Kamelet> c = catalog.getKameletsByNamespace("AWS");
assertFalse(c.isEmpty());
- assertEquals(29, c.size());
+ assertEquals(30, c.size());
c = catalog.getKameletsByGroups("Not-existing-group");
assertTrue(c.isEmpty());
}
diff --git
a/library/camel-kamelets/src/main/resources/kamelets/aws-comprehend-sink.kamelet.yaml
b/library/camel-kamelets/src/main/resources/kamelets/aws-comprehend-sink.kamelet.yaml
new file mode 100644
index 000000000..798f5bc76
--- /dev/null
+++
b/library/camel-kamelets/src/main/resources/kamelets/aws-comprehend-sink.kamelet.yaml
@@ -0,0 +1,130 @@
+# ---------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+# ---------------------------------------------------------------------------
+
+apiVersion: camel.apache.org/v1
+kind: Kamelet
+metadata:
+ name: aws-comprehend-sink
+ annotations:
+ camel.apache.org/kamelet.support.level: "Preview"
+ camel.apache.org/catalog.version: "4.18.0-SNAPSHOT"
+ camel.apache.org/kamelet.icon:
"
[...]
+ camel.apache.org/provider: "Apache Software Foundation"
+ camel.apache.org/kamelet.group: "AWS Comprehend"
+ camel.apache.org/kamelet.namespace: "AWS"
+ labels:
+ camel.apache.org/kamelet.type: "sink"
+spec:
+ definition:
+ title: "AWS Comprehend Sink"
+ description: Send data to AWS Comprehend for natural language processing.
+ required:
+ - region
+ type: object
+ properties:
+ operation:
+ title: Operation
+ description: The operation to perform on the input text.
+ type: string
+ default: detectDominantLanguage
+ enum: ["detectDominantLanguage", "detectEntities", "detectKeyPhrases",
"detectSentiment", "detectSyntax", "detectPiiEntities", "detectToxicContent",
"classifyDocument", "containsPiiEntities"]
+ languageCode:
+ title: Language Code
+ description: The language code of the input text. Required for all
operations except detectDominantLanguage. Use a 2-letter ISO 639-1 code (e.g.,
'en' for English, 'es' for Spanish).
+ type: string
+ endpointArn:
+ title: Endpoint ARN
+ description: The Amazon Resource Name (ARN) of the endpoint to use for
document classification. Required for classifyDocument operation.
+ 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", "a [...]
+ useDefaultCredentialsProvider:
+ title: Default Credentials Provider
+ description: If true, the Comprehend 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 Comprehend client should expect to load
credentials through a profile credentials provider.
+ type: boolean
+ default: false
+ useSessionCredentials:
+ title: Session Credentials
+ description: Set whether the Comprehend client should expect to use
Session Credentials. This is useful in a situation in which the user needs to
assume an IAM role for doing operations in Comprehend.
+ 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 an 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-comprehend"
+ - "camel:kamelet"
+ template:
+ from:
+ uri: "kamelet:source"
+ steps:
+ - to:
+ uri: "aws2-comprehend:comprehend"
+ parameters:
+ secretKey: "{{?secretKey}}"
+ accessKey: "{{?accessKey}}"
+ region: "{{region}}"
+ operation: "{{operation}}"
+ languageCode: "{{?languageCode}}"
+ endpointArn: "{{?endpointArn}}"
+ useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
+ useProfileCredentialsProvider: "{{useProfileCredentialsProvider}}"
+ useSessionCredentials: "{{useSessionCredentials}}"
+ uriEndpointOverride: "{{?uriEndpointOverride}}"
+ profileCredentialsName: "{{?profileCredentialsName}}"
+ sessionToken: "{{?sessionToken}}"
+ overrideEndpoint: "{{overrideEndpoint}}"
diff --git a/templates/pipes/camel-k/aws-comprehend-sink-pipe.yaml
b/templates/pipes/camel-k/aws-comprehend-sink-pipe.yaml
new file mode 100644
index 000000000..8ffbfa244
--- /dev/null
+++ b/templates/pipes/camel-k/aws-comprehend-sink-pipe.yaml
@@ -0,0 +1,19 @@
+apiVersion: camel.apache.org/v1
+kind: Pipe
+metadata:
+ name: aws-comprehend-sink-pipe
+spec:
+ source:
+ ref:
+ kind: KafkaTopic
+ apiVersion: kafka.strimzi.io/v1beta1
+ name: my-topic
+ sink:
+ ref:
+ kind: Kamelet
+ apiVersion: camel.apache.org/v1
+ name: aws-comprehend-sink
+ properties:
+ accessKey: "The Access Key"
+ secretKey: "The Secret Key"
+ region: "eu-west-1"
diff --git a/templates/pipes/core/aws-comprehend-sink-pipe.yaml
b/templates/pipes/core/aws-comprehend-sink-pipe.yaml
new file mode 100644
index 000000000..0577359f3
--- /dev/null
+++ b/templates/pipes/core/aws-comprehend-sink-pipe.yaml
@@ -0,0 +1,13 @@
+- route:
+ from:
+ uri: "kamelet:timer-source"
+ parameters:
+ period: 1000
+ message: "Hello Camel JBang"
+ steps:
+ - to:
+ uri: "kamelet:aws-comprehend-sink"
+ parameters:
+ accessKey: "The Access Key"
+ secretKey: "The Secret Key"
+ region: "eu-west-1"