From e140e1782dec536351d97b57096bdca3985ba59b Mon Sep 17 00:00:00 2001 From: Andrea Cosentino Date: Thu, 26 Sep 2024 11:18:29 +0200 Subject: [PATCH] Removed not supported/planned Kamelets and Jenkins specific files Signed-off-by: Andrea Cosentino --- Jenkinsfile | 50 ---- Jenkinsfile.deploy | 90 ------- Jenkinsfile.ppc64le | 89 ------- jitpack.yml | 2 - ...ws-bedrock-agent-runtime-sink.kamelet.yaml | 132 ---------- kamelets/aws-bedrock-text-sink.kamelet.yaml | 132 ---------- kamelets/aws-cloudtrail-source.kamelet.yaml | 179 ------------- kamelets/aws-ec2-sink.kamelet.yaml | 135 ---------- kamelets/aws-eventbridge-sink.kamelet.yaml | 168 ------------ .../aws-s3-event-based-source.kamelet.yaml | 225 ---------------- .../aws-secrets-manager-sink.kamelet.yaml | 131 ---------- kamelets/aws-sns-fifo-sink.kamelet.yaml | 194 -------------- kamelets/aws-sqs-batch-sink.kamelet.yaml | 149 ----------- .../aws-sts-assume-role-action.kamelet.yaml | 136 ---------- .../aws-timestream-query-sink.kamelet.yaml | 135 ---------- kamelets/aws-translate-action.kamelet.yaml | 123 --------- kamelets/azure-cosmosdb-sink.kamelet.yaml | 119 --------- kamelets/azure-cosmosdb-source.kamelet.yaml | 146 ----------- kamelets/azure-servicebus-sink.kamelet.yaml | 81 ------ kamelets/azure-servicebus-source.kamelet.yaml | 96 ------- ...zure-storage-blob-append-sink.kamelet.yaml | 97 ------- ...orage-blob-event-based-source.kamelet.yaml | 145 ----------- .../azure-storage-datalake-sink.kamelet.yaml | 117 --------- ...azure-storage-datalake-source.kamelet.yaml | 245 ------------------ .../azure-storage-files-sink.kamelet.yaml | 100 ------- .../azure-storage-files-source.kamelet.yaml | 189 -------------- kamelets/beer-source.kamelet.yaml | 58 ----- kamelets/bitcoin-source.kamelet.yaml | 86 ------ kamelets/caffeine-action.kamelet.yaml | 97 ------- kamelets/chuck-norris-source.kamelet.yaml | 61 ----- kamelets/chunk-template-action.kamelet.yaml | 55 ---- kamelets/coffee-source.kamelet.yaml | 58 ----- kamelets/couchbase-sink.kamelet.yaml | 95 ------- kamelets/counter-source.kamelet.yaml | 75 ------ kamelets/cron-source.kamelet.yaml | 66 ----- kamelets/data-type-action.kamelet.yaml | 71 ----- kamelets/delay-action.kamelet.yaml | 52 ---- .../djl-image-to-text-action.kamelet.yaml | 75 ------ kamelets/dns-dig-action.kamelet.yaml | 91 ------- kamelets/dns-ip-action.kamelet.yaml | 70 ----- kamelets/dns-lookup-action.kamelet.yaml | 74 ------ kamelets/drop-field-action.kamelet.yaml | 84 ------ kamelets/dropbox-sink.kamelet.yaml | 97 ------- kamelets/dropbox-source.kamelet.yaml | 97 ------- kamelets/earthquake-source.kamelet.yaml | 110 -------- .../elasticsearch-search-source.kamelet.yaml | 123 --------- kamelets/exec-sink.kamelet.yaml | 72 ----- kamelets/fhir-sink.kamelet.yaml | 160 ------------ kamelets/fhir-source.kamelet.yaml | 102 -------- kamelets/file-watch-source.kamelet.yaml | 58 ----- .../freemarker-template-action.kamelet.yaml | 55 ---- kamelets/github-commit-source.kamelet.yaml | 85 ------ kamelets/github-event-source.kamelet.yaml | 73 ------ ...ub-pullrequest-comment-source.kamelet.yaml | 73 ------ .../github-pullrequest-source.kamelet.yaml | 73 ------ kamelets/github-tag-source.kamelet.yaml | 73 ------ kamelets/google-calendar-source.kamelet.yaml | 161 ------------ kamelets/google-functions-sink.kamelet.yaml | 73 ------ kamelets/google-mail-source.kamelet.yaml | 182 ------------- kamelets/google-sheets-sink.kamelet.yaml | 184 ------------- kamelets/google-sheets-source.kamelet.yaml | 216 --------------- ...le-storage-event-based-source.kamelet.yaml | 123 --------- kamelets/google-storage-sink.kamelet.yaml | 88 ------- kamelets/google-storage-source.kamelet.yaml | 128 --------- kamelets/graphql-sink.kamelet.yaml | 62 ----- .../header-matches-filter-action.kamelet.yaml | 57 ---- kamelets/infinispan-sink.kamelet.yaml | 129 --------- kamelets/infinispan-source.kamelet.yaml | 134 ---------- kamelets/jira-oauth-source.kamelet.yaml | 105 -------- ...ms-pooled-apache-artemis-sink.kamelet.yaml | 112 -------- ...-pooled-apache-artemis-source.kamelet.yaml | 111 -------- .../jolt-transformation-action.kamelet.yaml | 62 ----- kamelets/json-patch-action.kamelet.yaml | 55 ---- .../json-schema-validator-action.kamelet.yaml | 55 ---- kamelets/jsonata-action.kamelet.yaml | 55 ---- ...rio-registry-not-secured-sink.kamelet.yaml | 113 -------- ...o-registry-not-secured-source.kamelet.yaml | 135 ---------- ...ka-azure-schema-registry-sink.kamelet.yaml | 143 ---------- ...-azure-schema-registry-source.kamelet.yaml | 172 ------------ ...atch-apicurio-registry-source.kamelet.yaml | 209 --------------- ...-azure-schema-registry-source.kamelet.yaml | 193 -------------- .../kafka-manual-commit-action.kamelet.yaml | 42 --- ...apicurio-registry-json-source.kamelet.yaml | 182 ------------- ...ecured-apicurio-registry-sink.kamelet.yaml | 160 ------------ ...ured-apicurio-registry-source.kamelet.yaml | 188 -------------- kamelets/kafka-not-secured-sink.kamelet.yaml | 92 ------- .../kafka-not-secured-source.kamelet.yaml | 119 --------- kamelets/kafka-scram-sink.kamelet.yaml | 119 --------- kamelets/kafka-scram-source.kamelet.yaml | 153 ----------- .../kubernetes-namespaces-source.kamelet.yaml | 67 ----- kamelets/kubernetes-nodes-source.kamelet.yaml | 72 ----- kamelets/kubernetes-pods-source.kamelet.yaml | 72 ----- kamelets/mail-imap-source.kamelet.yaml | 113 -------- kamelets/mail-sink.kamelet.yaml | 121 --------- ...mongodb-changes-stream-source.kamelet.yaml | 109 -------- kamelets/mqtt-sink.kamelet.yaml | 75 ------ kamelets/mqtt-source.kamelet.yaml | 80 ------ kamelets/mqtt5-sink.kamelet.yaml | 75 ------ kamelets/mqtt5-source.kamelet.yaml | 80 ------ ...ange-online-imap-oauth-source.kamelet.yaml | 105 -------- .../mustache-template-action.kamelet.yaml | 55 ---- kamelets/mvel-template-action.kamelet.yaml | 55 ---- kamelets/nats-sink.kamelet.yaml | 61 ----- kamelets/nats-source.kamelet.yaml | 66 ----- .../nominatim-geocode-action.kamelet.yaml | 112 -------- kamelets/ogcapi-features-action.kamelet.yaml | 123 --------- kamelets/opensearch-index-sink.kamelet.yaml | 144 ---------- .../opensearch-search-source.kamelet.yaml | 123 --------- kamelets/oracle-database-sink.kamelet.yaml | 113 -------- kamelets/oracle-database-source.kamelet.yaml | 110 -------- kamelets/pdf-action.kamelet.yaml | 68 ----- kamelets/pulsar-sink.kamelet.yaml | 157 ----------- kamelets/pulsar-source.kamelet.yaml | 168 ------------ kamelets/redis-sink.kamelet.yaml | 130 ---------- kamelets/redis-source.kamelet.yaml | 75 ------ .../resolve-pojo-schema-action.kamelet.yaml | 76 ------ kamelets/rest-openapi-sink.kamelet.yaml | 58 ----- ...esforce-composite-upsert-sink.kamelet.yaml | 121 --------- kamelets/scp-sink.kamelet.yaml | 94 ------- kamelets/set-kafka-key-action.kamelet.yaml | 66 ----- kamelets/snowflake-sink.kamelet.yaml | 104 -------- kamelets/snowflake-source.kamelet.yaml | 107 -------- kamelets/splunk-hec-sink.kamelet.yaml | 115 -------- kamelets/spring-rabbitmq-sink.kamelet.yaml | 109 -------- kamelets/spring-rabbitmq-source.kamelet.yaml | 108 -------- kamelets/ssh-sink.kamelet.yaml | 81 ------ kamelets/ssh-source.kamelet.yaml | 89 ------- kamelets/string-template-action.kamelet.yaml | 55 ---- .../twitter-directmessage-source.kamelet.yaml | 97 ------- kamelets/twitter-search-source.kamelet.yaml | 97 ------- kamelets/twitter-timeline-source.kamelet.yaml | 98 ------- .../velocity-template-action.kamelet.yaml | 55 ---- kamelets/webhook-source.kamelet.yaml | 55 ---- kamelets/wttrin-source.kamelet.yaml | 89 ------- kamelets/xj-identity-action.kamelet.yaml | 54 ---- kamelets/xj-template-action.kamelet.yaml | 62 ----- 136 files changed, 14255 deletions(-) delete mode 100644 Jenkinsfile delete mode 100644 Jenkinsfile.deploy delete mode 100644 Jenkinsfile.ppc64le delete mode 100644 jitpack.yml delete mode 100644 kamelets/aws-bedrock-agent-runtime-sink.kamelet.yaml delete mode 100644 kamelets/aws-bedrock-text-sink.kamelet.yaml delete mode 100644 kamelets/aws-cloudtrail-source.kamelet.yaml delete mode 100644 kamelets/aws-ec2-sink.kamelet.yaml delete mode 100644 kamelets/aws-eventbridge-sink.kamelet.yaml delete mode 100644 kamelets/aws-s3-event-based-source.kamelet.yaml delete mode 100644 kamelets/aws-secrets-manager-sink.kamelet.yaml delete mode 100644 kamelets/aws-sns-fifo-sink.kamelet.yaml delete mode 100644 kamelets/aws-sqs-batch-sink.kamelet.yaml delete mode 100644 kamelets/aws-sts-assume-role-action.kamelet.yaml delete mode 100644 kamelets/aws-timestream-query-sink.kamelet.yaml delete mode 100644 kamelets/aws-translate-action.kamelet.yaml delete mode 100644 kamelets/azure-cosmosdb-sink.kamelet.yaml delete mode 100644 kamelets/azure-cosmosdb-source.kamelet.yaml delete mode 100644 kamelets/azure-servicebus-sink.kamelet.yaml delete mode 100644 kamelets/azure-servicebus-source.kamelet.yaml delete mode 100644 kamelets/azure-storage-blob-append-sink.kamelet.yaml delete mode 100644 kamelets/azure-storage-blob-event-based-source.kamelet.yaml delete mode 100644 kamelets/azure-storage-datalake-sink.kamelet.yaml delete mode 100644 kamelets/azure-storage-datalake-source.kamelet.yaml delete mode 100644 kamelets/azure-storage-files-sink.kamelet.yaml delete mode 100644 kamelets/azure-storage-files-source.kamelet.yaml delete mode 100644 kamelets/beer-source.kamelet.yaml delete mode 100644 kamelets/bitcoin-source.kamelet.yaml delete mode 100644 kamelets/caffeine-action.kamelet.yaml delete mode 100644 kamelets/chuck-norris-source.kamelet.yaml delete mode 100644 kamelets/chunk-template-action.kamelet.yaml delete mode 100644 kamelets/coffee-source.kamelet.yaml delete mode 100644 kamelets/couchbase-sink.kamelet.yaml delete mode 100644 kamelets/counter-source.kamelet.yaml delete mode 100644 kamelets/cron-source.kamelet.yaml delete mode 100644 kamelets/data-type-action.kamelet.yaml delete mode 100644 kamelets/delay-action.kamelet.yaml delete mode 100644 kamelets/djl-image-to-text-action.kamelet.yaml delete mode 100644 kamelets/dns-dig-action.kamelet.yaml delete mode 100644 kamelets/dns-ip-action.kamelet.yaml delete mode 100644 kamelets/dns-lookup-action.kamelet.yaml delete mode 100644 kamelets/drop-field-action.kamelet.yaml delete mode 100644 kamelets/dropbox-sink.kamelet.yaml delete mode 100644 kamelets/dropbox-source.kamelet.yaml delete mode 100644 kamelets/earthquake-source.kamelet.yaml delete mode 100644 kamelets/elasticsearch-search-source.kamelet.yaml delete mode 100644 kamelets/exec-sink.kamelet.yaml delete mode 100644 kamelets/fhir-sink.kamelet.yaml delete mode 100644 kamelets/fhir-source.kamelet.yaml delete mode 100644 kamelets/file-watch-source.kamelet.yaml delete mode 100644 kamelets/freemarker-template-action.kamelet.yaml delete mode 100644 kamelets/github-commit-source.kamelet.yaml delete mode 100644 kamelets/github-event-source.kamelet.yaml delete mode 100644 kamelets/github-pullrequest-comment-source.kamelet.yaml delete mode 100644 kamelets/github-pullrequest-source.kamelet.yaml delete mode 100644 kamelets/github-tag-source.kamelet.yaml delete mode 100644 kamelets/google-calendar-source.kamelet.yaml delete mode 100644 kamelets/google-functions-sink.kamelet.yaml delete mode 100644 kamelets/google-mail-source.kamelet.yaml delete mode 100644 kamelets/google-sheets-sink.kamelet.yaml delete mode 100644 kamelets/google-sheets-source.kamelet.yaml delete mode 100644 kamelets/google-storage-event-based-source.kamelet.yaml delete mode 100644 kamelets/google-storage-sink.kamelet.yaml delete mode 100644 kamelets/google-storage-source.kamelet.yaml delete mode 100644 kamelets/graphql-sink.kamelet.yaml delete mode 100644 kamelets/header-matches-filter-action.kamelet.yaml delete mode 100644 kamelets/infinispan-sink.kamelet.yaml delete mode 100644 kamelets/infinispan-source.kamelet.yaml delete mode 100644 kamelets/jira-oauth-source.kamelet.yaml delete mode 100644 kamelets/jms-pooled-apache-artemis-sink.kamelet.yaml delete mode 100644 kamelets/jms-pooled-apache-artemis-source.kamelet.yaml delete mode 100644 kamelets/jolt-transformation-action.kamelet.yaml delete mode 100644 kamelets/json-patch-action.kamelet.yaml delete mode 100644 kamelets/json-schema-validator-action.kamelet.yaml delete mode 100644 kamelets/jsonata-action.kamelet.yaml delete mode 100644 kamelets/kafka-apicurio-registry-not-secured-sink.kamelet.yaml delete mode 100644 kamelets/kafka-apicurio-registry-not-secured-source.kamelet.yaml delete mode 100644 kamelets/kafka-azure-schema-registry-sink.kamelet.yaml delete mode 100644 kamelets/kafka-azure-schema-registry-source.kamelet.yaml delete mode 100644 kamelets/kafka-batch-apicurio-registry-source.kamelet.yaml delete mode 100644 kamelets/kafka-batch-azure-schema-registry-source.kamelet.yaml delete mode 100644 kamelets/kafka-manual-commit-action.kamelet.yaml delete mode 100644 kamelets/kafka-not-secured-apicurio-registry-json-source.kamelet.yaml delete mode 100644 kamelets/kafka-not-secured-apicurio-registry-sink.kamelet.yaml delete mode 100644 kamelets/kafka-not-secured-apicurio-registry-source.kamelet.yaml delete mode 100644 kamelets/kafka-not-secured-sink.kamelet.yaml delete mode 100644 kamelets/kafka-not-secured-source.kamelet.yaml delete mode 100644 kamelets/kafka-scram-sink.kamelet.yaml delete mode 100644 kamelets/kafka-scram-source.kamelet.yaml delete mode 100644 kamelets/kubernetes-namespaces-source.kamelet.yaml delete mode 100644 kamelets/kubernetes-nodes-source.kamelet.yaml delete mode 100644 kamelets/kubernetes-pods-source.kamelet.yaml delete mode 100644 kamelets/mail-imap-source.kamelet.yaml delete mode 100644 kamelets/mail-sink.kamelet.yaml delete mode 100644 kamelets/mongodb-changes-stream-source.kamelet.yaml delete mode 100644 kamelets/mqtt-sink.kamelet.yaml delete mode 100644 kamelets/mqtt-source.kamelet.yaml delete mode 100644 kamelets/mqtt5-sink.kamelet.yaml delete mode 100644 kamelets/mqtt5-source.kamelet.yaml delete mode 100644 kamelets/ms-exchange-online-imap-oauth-source.kamelet.yaml delete mode 100644 kamelets/mustache-template-action.kamelet.yaml delete mode 100644 kamelets/mvel-template-action.kamelet.yaml delete mode 100644 kamelets/nats-sink.kamelet.yaml delete mode 100644 kamelets/nats-source.kamelet.yaml delete mode 100644 kamelets/nominatim-geocode-action.kamelet.yaml delete mode 100644 kamelets/ogcapi-features-action.kamelet.yaml delete mode 100644 kamelets/opensearch-index-sink.kamelet.yaml delete mode 100644 kamelets/opensearch-search-source.kamelet.yaml delete mode 100644 kamelets/oracle-database-sink.kamelet.yaml delete mode 100644 kamelets/oracle-database-source.kamelet.yaml delete mode 100644 kamelets/pdf-action.kamelet.yaml delete mode 100644 kamelets/pulsar-sink.kamelet.yaml delete mode 100644 kamelets/pulsar-source.kamelet.yaml delete mode 100644 kamelets/redis-sink.kamelet.yaml delete mode 100644 kamelets/redis-source.kamelet.yaml delete mode 100644 kamelets/resolve-pojo-schema-action.kamelet.yaml delete mode 100644 kamelets/rest-openapi-sink.kamelet.yaml delete mode 100644 kamelets/salesforce-composite-upsert-sink.kamelet.yaml delete mode 100644 kamelets/scp-sink.kamelet.yaml delete mode 100644 kamelets/set-kafka-key-action.kamelet.yaml delete mode 100644 kamelets/snowflake-sink.kamelet.yaml delete mode 100644 kamelets/snowflake-source.kamelet.yaml delete mode 100644 kamelets/splunk-hec-sink.kamelet.yaml delete mode 100644 kamelets/spring-rabbitmq-sink.kamelet.yaml delete mode 100644 kamelets/spring-rabbitmq-source.kamelet.yaml delete mode 100644 kamelets/ssh-sink.kamelet.yaml delete mode 100644 kamelets/ssh-source.kamelet.yaml delete mode 100644 kamelets/string-template-action.kamelet.yaml delete mode 100644 kamelets/twitter-directmessage-source.kamelet.yaml delete mode 100644 kamelets/twitter-search-source.kamelet.yaml delete mode 100644 kamelets/twitter-timeline-source.kamelet.yaml delete mode 100644 kamelets/velocity-template-action.kamelet.yaml delete mode 100644 kamelets/webhook-source.kamelet.yaml delete mode 100644 kamelets/wttrin-source.kamelet.yaml delete mode 100644 kamelets/xj-identity-action.kamelet.yaml delete mode 100644 kamelets/xj-template-action.kamelet.yaml diff --git a/Jenkinsfile b/Jenkinsfile deleted file mode 100644 index 062244228..000000000 --- a/Jenkinsfile +++ /dev/null @@ -1,50 +0,0 @@ -/* - * 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. - */ - -def AGENT_LABEL = env.AGENT_LABEL ?: 'ubuntu' - -pipeline { - - agent { - label AGENT_LABEL - } - - options { - buildDiscarder( - logRotator(artifactNumToKeepStr: '5', numToKeepStr: '10') - ) - disableConcurrentBuilds() - } - - stages { - - stage('Website update') { - when { - branch 'main' - changeset 'docs/**/*' - } - - steps { - build job: 'Camel/Camel.website/main', wait: false - } - } - - } -} - diff --git a/Jenkinsfile.deploy b/Jenkinsfile.deploy deleted file mode 100644 index 76714d120..000000000 --- a/Jenkinsfile.deploy +++ /dev/null @@ -1,90 +0,0 @@ -/* - * 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. - */ - -def LOCAL_REPOSITORY = env.LOCAL_REPOSITORY ?: '/home/jenkins/jenkins-slave/maven-repositories/0' -def AGENT_LABEL = env.AGENT_LABEL ?: 'ubuntu' -def JDK_NAME = env.JDK_NAME ?: 'jdk_17_latest' - -def MAVEN_PARAMS = '-U -B -e -fae -V -Dmaven.repo.local=/home/jenkins/.m2/repository -Dmaven.compiler.fork=true' - -def kamelets_result - -pipeline { - - agent { - label AGENT_LABEL - } - - triggers { - cron('@daily') - } - - tools { - jdk JDK_NAME - } - - environment { - MAVEN_SKIP_RC = true - } - - options { - buildDiscarder( - logRotator(artifactNumToKeepStr: '5', numToKeepStr: '10') - ) - disableConcurrentBuilds() - } - - parameters { - booleanParam(name: 'CLEAN', defaultValue: true, description: 'Perform the build in clean workspace') - } - - stages { - - stage('Clean workspace') { - when { - expression { params.CLEAN } - } - steps { - sh 'git clean -fdx' - } - } - - stage('Build') { - steps { - script { - kamelets_result = sh script: "./mvnw $MAVEN_PARAMS -Dmaven.test.failure.ignore=true clean deploy install", returnStatus: true - } - } - post { - always { - junit allowEmptyResults: true, testResults: '**/target/surefire-reports/*.xml' - } - } - } - } - - post { - always { - script { - currentBuild.result = kamelets_result == 0 ? 'SUCCESS' : 'FAILURE' - } - } - } -} - diff --git a/Jenkinsfile.ppc64le b/Jenkinsfile.ppc64le deleted file mode 100644 index 9bc4c280c..000000000 --- a/Jenkinsfile.ppc64le +++ /dev/null @@ -1,89 +0,0 @@ -/* - * 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. - */ - -def LOCAL_REPOSITORY = env.LOCAL_REPOSITORY ?: '/home/jenkins/jenkins-slave/maven-repositories/0' -def AGENT_LABEL = env.AGENT_LABEL ?: 'power9' -def JDK_NAME = env.JDK_NAME ?: 'jdk_17_latest' - -def MAVEN_PARAMS = '-U -B -e -fae -V -Dmaven.repo.local=/home/jenkins/.m2/repository -Dmaven.compiler.fork=true' - -def kamelets_result - -pipeline { - - agent { - label AGENT_LABEL - } - - triggers { - cron('@daily') - } - - tools { - jdk JDK_NAME - } - - environment { - MAVEN_SKIP_RC = true - } - - options { - buildDiscarder( - logRotator(artifactNumToKeepStr: '5', numToKeepStr: '10') - ) - disableConcurrentBuilds() - } - - parameters { - booleanParam(name: 'CLEAN', defaultValue: true, description: 'Perform the build in clean workspace') - } - - stages { - - stage('Clean workspace') { - when { - expression { params.CLEAN } - } - steps { - sh 'git clean -fdx' - } - } - - stage('Build') { - steps { - script { - kamelets_result = sh script: "./mvnw $MAVEN_PARAMS -Dmaven.test.failure.ignore=true clean install", returnStatus: true - } - } - post { - always { - junit allowEmptyResults: true, testResults: '**/target/surefire-reports/*.xml' - } - } - } - } - - post { - always { - script { - currentBuild.result = kamelets_result == 0 ? 'SUCCESS' : 'FAILURE' - } - } - } -} diff --git a/jitpack.yml b/jitpack.yml deleted file mode 100644 index efde7bf25..000000000 --- a/jitpack.yml +++ /dev/null @@ -1,2 +0,0 @@ -jdk: - - openjdk17 diff --git a/kamelets/aws-bedrock-agent-runtime-sink.kamelet.yaml b/kamelets/aws-bedrock-agent-runtime-sink.kamelet.yaml deleted file mode 100644 index 8c2148458..000000000 --- a/kamelets/aws-bedrock-agent-runtime-sink.kamelet.yaml +++ /dev/null @@ -1,132 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-bedrock-agent-runtime-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The basic authentication method for the Bedrock service is to specify an access key and a secret key. These parameters are optional because the Kamelet provides a default credentials provider. - - If you use the default credentials provider, the Bedrock client loads the credentials through this provider and doesn't use the basic authentication method. - 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 will set 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}}" diff --git a/kamelets/aws-bedrock-text-sink.kamelet.yaml b/kamelets/aws-bedrock-text-sink.kamelet.yaml deleted file mode 100644 index bd5e20e29..000000000 --- a/kamelets/aws-bedrock-text-sink.kamelet.yaml +++ /dev/null @@ -1,132 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-bedrock-text-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The basic authentication method for the Bedrock service is to specify an access key and a secret key. These parameters are optional because the Kamelet provides a default credentials provider. - - If you use the default credentials provider, the Bedrock client loads the credentials through this provider and doesn't use the basic authentication method. - 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 will set 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}}" diff --git a/kamelets/aws-cloudtrail-source.kamelet.yaml b/kamelets/aws-cloudtrail-source.kamelet.yaml deleted file mode 100644 index 64a191bc4..000000000 --- a/kamelets/aws-cloudtrail-source.kamelet.yaml +++ /dev/null @@ -1,179 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-cloudtrail-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The basic authentication method for the Cloudtrail service is to specify an access key and a secret key. These parameters are optional because the Kamelet provides a default credentials provider. - 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 will set 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 will be 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" diff --git a/kamelets/aws-ec2-sink.kamelet.yaml b/kamelets/aws-ec2-sink.kamelet.yaml deleted file mode 100644 index 7850afc2e..000000000 --- a/kamelets/aws-ec2-sink.kamelet.yaml +++ /dev/null @@ -1,135 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-ec2-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - Access Key/Secret Key are the basic method for authenticating to the AWS EC2 Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the EC2 client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - - The Kamelet expects the following headers to be set: - - - `instanceIds` / `ce-instanceids`: as a comma separated list of EC2 instance ids. - 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 will set 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}}" diff --git a/kamelets/aws-eventbridge-sink.kamelet.yaml b/kamelets/aws-eventbridge-sink.kamelet.yaml deleted file mode 100644 index 72c2dfe6b..000000000 --- a/kamelets/aws-eventbridge-sink.kamelet.yaml +++ /dev/null @@ -1,168 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-eventbridge-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The basic authentication method for the Eventbridge service is to specify an access key and a secret key. These parameters are optional because the Kamelet provides a default credentials provider. - - If you use the default credentials provider, the Eventbridge client loads the credentials through this provider and doesn't use the basic authentication method. - - In the headers, you need to set the `resources-arn` / `ce-resources-arn` property to specify the ARN of resources related to the event. - - In the headers, you need to set the `detail-type` / `ce-detail-type` property to specify the detail type related to the event. - - In the headers, you need to 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 exchange ID for the file name. - required: - - eventbusNameOrArn - - region - type: object - properties: - eventbusNameOrArn: - title: Eventbus Name - description: The Eventbridge Eventbus 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"] - 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 will set 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]}" - - 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]}" - - choice: - when: - - simple: "${header[event-source]}" - steps: - - setHeader: - name: CamelAwsEventbridgeSource - simple: "${header[event-source]}" - - simple: "${header[ce-event-source]}" - steps: - - setHeader: - name: CamelAwsEventbridgeSource - simple: "${header[ce-event-source]}" - - 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" diff --git a/kamelets/aws-s3-event-based-source.kamelet.yaml b/kamelets/aws-s3-event-based-source.kamelet.yaml deleted file mode 100644 index 31eacc5d5..000000000 --- a/kamelets/aws-s3-event-based-source.kamelet.yaml +++ /dev/null @@ -1,225 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-s3-event-based-source - annotations: - camel.apache.org/kamelet.support.level: Preview - camel.apache.org/catalog.version: "4.8.0" - 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. - - Access Key/Secret Key are the basic method for authenticating to the AWS - SQS Service. - - To use this Kamelet you'll need to set up Eventbridge on your bucket and subscribe Eventbridge bus to an SQS Queue. - - For doing this you'll need to enable Evenbridge notification on your bucket and creating a rule on Eventbridge console related to all the events on S3 bucket and pointing to the SQS Queue specified as parameter in this Kamelet. - 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 will be - get 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' - diff --git a/kamelets/aws-secrets-manager-sink.kamelet.yaml b/kamelets/aws-secrets-manager-sink.kamelet.yaml deleted file mode 100644 index 23e8ada88..000000000 --- a/kamelets/aws-secrets-manager-sink.kamelet.yaml +++ /dev/null @@ -1,131 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-secrets-manager-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Access Key/Secret Key are the basic method for authenticating to the AWS Secrets Manager Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the Secrets Manager client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - - The Kamelet expects the following headers to be set: - - - `secret-name` / `ce-secret-name`: as the secret name to create. - - If the header won't be set the exchange ID will be used as secret name. - 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 will set 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}}" diff --git a/kamelets/aws-sns-fifo-sink.kamelet.yaml b/kamelets/aws-sns-fifo-sink.kamelet.yaml deleted file mode 100644 index 3bf31795f..000000000 --- a/kamelets/aws-sns-fifo-sink.kamelet.yaml +++ /dev/null @@ -1,194 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-sns-fifo-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Access Key/Secret Key are the basic method for authenticating to the AWS SNS Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the SNS client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - - The Kamelet expects the following headers to be set: - - - `subject` / `ce-subject`: the subject of the message - 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 will set 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}}" diff --git a/kamelets/aws-sqs-batch-sink.kamelet.yaml b/kamelets/aws-sqs-batch-sink.kamelet.yaml deleted file mode 100644 index 650eaf67e..000000000 --- a/kamelets/aws-sqs-batch-sink.kamelet.yaml +++ /dev/null @@ -1,149 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-sqs-batch-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Access Key/Secret Key are the basic method for authenticating to the AWS SQS Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the SQS client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - 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 will set 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}}" diff --git a/kamelets/aws-sts-assume-role-action.kamelet.yaml b/kamelets/aws-sts-assume-role-action.kamelet.yaml deleted file mode 100644 index 9dacb91f5..000000000 --- a/kamelets/aws-sts-assume-role-action.kamelet.yaml +++ /dev/null @@ -1,136 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-sts-assume-role-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - Access Key/Secret Key are the basic method for authenticating to the AWS STS Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the Translate client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - - In the headers, you have to specify the `role-arn` / `ce-role-arn` property to specify the role ARN you want to assume. - - In the headers, you have to specify the `role-session-name` / `ce-role-session-name` property to specify the role Session name you want to use. - 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 will set 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}}" diff --git a/kamelets/aws-timestream-query-sink.kamelet.yaml b/kamelets/aws-timestream-query-sink.kamelet.yaml deleted file mode 100644 index b1b827658..000000000 --- a/kamelets/aws-timestream-query-sink.kamelet.yaml +++ /dev/null @@ -1,135 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-timestream-query-sink - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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 - - Access Key/Secret Key are the basic method for authenticating to the AWS Timestream Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the Timestream client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - - The Kamelet expects the following headers to be set: - - - `query` / `ce-query`: as a Timestream Query - 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 will set 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}}" diff --git a/kamelets/aws-translate-action.kamelet.yaml b/kamelets/aws-translate-action.kamelet.yaml deleted file mode 100644 index b77ef5223..000000000 --- a/kamelets/aws-translate-action.kamelet.yaml +++ /dev/null @@ -1,123 +0,0 @@ -# --------------------------------------------------------------------------- -# 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-translate-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Access Key/Secret Key are the basic method for authenticating to the AWS Translate Service. These parameters are optional because the Kamelet provides the 'useDefaultCredentialsProvider'. - - When using a default Credentials Provider the Translate client will load the credentials through this provider and won't use the static credential. This is reason for not having the access key and secret key as mandatory parameter for this Kamelet. - 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 will set 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}}" diff --git a/kamelets/azure-cosmosdb-sink.kamelet.yaml b/kamelets/azure-cosmosdb-sink.kamelet.yaml deleted file mode 100644 index 94d5fecea..000000000 --- a/kamelets/azure-cosmosdb-sink.kamelet.yaml +++ /dev/null @@ -1,119 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-cosmosdb-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - In the headers, you can optionally set the `itemPartitionKey` / `ce-itemPartitionKey` property to specify the partition key for a specific item. - - If you do not set the property in the header, you'll need to use the static property itemPartitonKey. - - There are two different mechanism of authentication `SHARED_ACCOUNT_KEY` and `AZURE_IDENTITY`, you could specify with credentialType property. If you're using `SHARED_ACCOUNT_KEY` accountKey property will be needed. - - In case of `AZURE_IDENTITY` selection, the DefaultAzureCredential will attempt to authenticate via the following mechanisms in the following order enviroment, Workload Identity, Managed Identity, Azure Developer CLI, IntelliJ, Azure CLI and Azure Powershell. - 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}}" - diff --git a/kamelets/azure-cosmosdb-source.kamelet.yaml b/kamelets/azure-cosmosdb-source.kamelet.yaml deleted file mode 100644 index 4b3232cf4..000000000 --- a/kamelets/azure-cosmosdb-source.kamelet.yaml +++ /dev/null @@ -1,146 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-cosmosdb-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - There are two different mechanism of authentication `SHARED_ACCOUNT_KEY` and `AZURE_IDENTITY`, you could specify with credentialType property. If you're using `SHARED_ACCOUNT_KEY` accountKey property will be needed. - - In case of `AZURE_IDENTITY` selection, the DefaultAzureCredential will attempt to authenticate via the following mechanisms in the following order enviroment, Workload Identity, Managed Identity, Azure Developer CLI, IntelliJ, Azure CLI and Azure Powershell. - 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 will be 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" - diff --git a/kamelets/azure-servicebus-sink.kamelet.yaml b/kamelets/azure-servicebus-sink.kamelet.yaml deleted file mode 100644 index 00dcd62b0..000000000 --- a/kamelets/azure-servicebus-sink.kamelet.yaml +++ /dev/null @@ -1,81 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-servicebus-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/azure-servicebus-source.kamelet.yaml b/kamelets/azure-servicebus-source.kamelet.yaml deleted file mode 100644 index a88524426..000000000 --- a/kamelets/azure-servicebus-source.kamelet.yaml +++ /dev/null @@ -1,96 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-servicebus-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The subscribtion name parameter needs to be populated in case of consuming from a Topic. - 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" - diff --git a/kamelets/azure-storage-blob-append-sink.kamelet.yaml b/kamelets/azure-storage-blob-append-sink.kamelet.yaml deleted file mode 100644 index fd6e40b45..000000000 --- a/kamelets/azure-storage-blob-append-sink.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-blob-append-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - In the header, you can set the `file` / `ce-file` property to specify the filename to upload. If you do set property in the header, the Kamelet uses the exchange ID as filename. - 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}}" diff --git a/kamelets/azure-storage-blob-event-based-source.kamelet.yaml b/kamelets/azure-storage-blob-event-based-source.kamelet.yaml deleted file mode 100644 index 38ad71f4b..000000000 --- a/kamelets/azure-storage-blob-event-based-source.kamelet.yaml +++ /dev/null @@ -1,145 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-blob-event-based-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Connection string is the basic method for authenticating to the Azure Servicebus Queue. - - To use this Kamelet you'll need to set up Events on your Azure Storage Blob account and select as an endpoint an Azure Servicebus Queue. - 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 will be - get and returned as body, if not only the event will be 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' - diff --git a/kamelets/azure-storage-datalake-sink.kamelet.yaml b/kamelets/azure-storage-datalake-sink.kamelet.yaml deleted file mode 100644 index 525be7eb8..000000000 --- a/kamelets/azure-storage-datalake-sink.kamelet.yaml +++ /dev/null @@ -1,117 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-datalake-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - 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}}" diff --git a/kamelets/azure-storage-datalake-source.kamelet.yaml b/kamelets/azure-storage-datalake-source.kamelet.yaml deleted file mode 100644 index cb5c1f603..000000000 --- a/kamelets/azure-storage-datalake-source.kamelet.yaml +++ /dev/null @@ -1,245 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-datalake-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - template: - from: - uri: "azure-storage-datalake:{{accountName}}/{{fileSystemName}}" - parameters: - clientId: "{{clientId}}" - clientSecret: "{{clientSecret}}" - tenantId: "{{tenantId}}" - delay: "{{delay}}" - credentialType: "{{credentialType}}" - steps: - - to: "kamelet:sink" diff --git a/kamelets/azure-storage-files-sink.kamelet.yaml b/kamelets/azure-storage-files-sink.kamelet.yaml deleted file mode 100644 index a1720e8f0..000000000 --- a/kamelets/azure-storage-files-sink.kamelet.yaml +++ /dev/null @@ -1,100 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-files-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - In the header, you can set the `file` / `ce-file` property to specify the filename to upload. If you do set property in the header, the Kamelet uses the exchange ID as filename. - 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}}" diff --git a/kamelets/azure-storage-files-source.kamelet.yaml b/kamelets/azure-storage-files-source.kamelet.yaml deleted file mode 100644 index d4c318dbd..000000000 --- a/kamelets/azure-storage-files-source.kamelet.yaml +++ /dev/null @@ -1,189 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: azure-storage-files-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - Should normally be false for relative paths. Absolute paths should normally not be used but we added to the move option to allow moving files to absolute paths. - But can be used elsewhere as well. - 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" - diff --git a/kamelets/beer-source.kamelet.yaml b/kamelets/beer-source.kamelet.yaml deleted file mode 100644 index c6ebba910..000000000 --- a/kamelets/beer-source.kamelet.yaml +++ /dev/null @@ -1,58 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: beer-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - camel.apache.org/kamelet.icon: "" - camel.apache.org/provider: "Apache Software Foundation" - camel.apache.org/kamelet.group: "Beers" - camel.apache.org/kamelet.namespace: "Dataset" - labels: - camel.apache.org/kamelet.type: "source" -spec: - definition: - title: "Beer Source" - description: "Produces periodic events about beers!" - type: object - properties: - period: - title: Period - description: The time interval between two events - type: integer - default: 5000 - types: - out: - mediaType: application/json - dependencies: - - "camel:timer" - - "camel:http" - - "camel:kamelet" - template: - from: - uri: "timer:beer" - parameters: - period: "{{period}}" - steps: - - to: https://random-data-api.com/api/beer/random_beer - - removeHeaders: - pattern: '*' - - to: "kamelet:sink" diff --git a/kamelets/bitcoin-source.kamelet.yaml b/kamelets/bitcoin-source.kamelet.yaml deleted file mode 100644 index 0f0f1b83e..000000000 --- a/kamelets/bitcoin-source.kamelet.yaml +++ /dev/null @@ -1,86 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: bitcoin-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/caffeine-action.kamelet.yaml b/kamelets/caffeine-action.kamelet.yaml deleted file mode 100644 index b3a90bf87..000000000 --- a/kamelets/caffeine-action.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: caffeine-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The Kamelet expects the following headers to be set: - - - `caffeine-key` / `ce-caffeinekey`: as the cache key used in the operation - - - `caffeine-operation` / `ce-caffeineoperation`: as the operation to perform. It can be PUT, GET, INVALIDATE and CLEANUP. - - If the caffeine-key header won't be set the exchange ID will be used as key. - - If the caffeine-operation header won't be set, the GET operation will be performed. - 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}}" diff --git a/kamelets/chuck-norris-source.kamelet.yaml b/kamelets/chuck-norris-source.kamelet.yaml deleted file mode 100644 index 46dc79934..000000000 --- a/kamelets/chuck-norris-source.kamelet.yaml +++ /dev/null @@ -1,61 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: chuck-norris-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/chunk-template-action.kamelet.yaml b/kamelets/chunk-template-action.kamelet.yaml deleted file mode 100644 index ef37a0bef..000000000 --- a/kamelets/chunk-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: chunk-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The template property needs to be encoded in base64, so when you pass it as parameter, don't forget to encode it. - 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}}" diff --git a/kamelets/coffee-source.kamelet.yaml b/kamelets/coffee-source.kamelet.yaml deleted file mode 100644 index ad256ef47..000000000 --- a/kamelets/coffee-source.kamelet.yaml +++ /dev/null @@ -1,58 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: coffee-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - camel.apache.org/kamelet.icon: "" - camel.apache.org/provider: "Apache Software Foundation" - camel.apache.org/kamelet.group: "Coffees" - camel.apache.org/kamelet.namespace: "Dataset" - labels: - camel.apache.org/kamelet.type: "source" -spec: - definition: - title: "Coffee Source" - description: "Produces periodic events about coffees!" - type: object - properties: - period: - title: Period - description: The time interval between two events - type: integer - default: 5000 - types: - out: - mediaType: application/json - dependencies: - - "camel:timer" - - "camel:http" - - "camel:kamelet" - template: - from: - uri: "timer:coffee" - parameters: - period: "{{period}}" - steps: - - to: https://random-data-api.com/api/coffee/random_coffee - - removeHeaders: - pattern: '*' - - to: "kamelet:sink" diff --git a/kamelets/couchbase-sink.kamelet.yaml b/kamelets/couchbase-sink.kamelet.yaml deleted file mode 100644 index ce9ccf8e9..000000000 --- a/kamelets/couchbase-sink.kamelet.yaml +++ /dev/null @@ -1,95 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: couchbase-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/counter-source.kamelet.yaml b/kamelets/counter-source.kamelet.yaml deleted file mode 100644 index d6a68788b..000000000 --- a/kamelets/counter-source.kamelet.yaml +++ /dev/null @@ -1,75 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: counter-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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: Counts upwards such as 1,2,3,... - 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 diff --git a/kamelets/cron-source.kamelet.yaml b/kamelets/cron-source.kamelet.yaml deleted file mode 100644 index aef845d46..000000000 --- a/kamelets/cron-source.kamelet.yaml +++ /dev/null @@ -1,66 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: cron-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 will be 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" diff --git a/kamelets/data-type-action.kamelet.yaml b/kamelets/data-type-action.kamelet.yaml deleted file mode 100644 index 2f90155e6..000000000 --- a/kamelets/data-type-action.kamelet.yaml +++ /dev/null @@ -1,71 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: data-type-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 will be 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 diff --git a/kamelets/delay-action.kamelet.yaml b/kamelets/delay-action.kamelet.yaml deleted file mode 100644 index 6f1064c37..000000000 --- a/kamelets/delay-action.kamelet.yaml +++ /dev/null @@ -1,52 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: delay-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/djl-image-to-text-action.kamelet.yaml b/kamelets/djl-image-to-text-action.kamelet.yaml deleted file mode 100644 index 17072cd42..000000000 --- a/kamelets/djl-image-to-text-action.kamelet.yaml +++ /dev/null @@ -1,75 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: djl-image-to-text-action - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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" - - "mvn:net.sf.extjwnl:extjwnl:2.0.5" - - "mvn:net.sf.extjwnl:extjwnl-data-wn31:1.2" - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:core" - - "camel:kamelet" - - "camel:jackson" - - "camel:djl" - template: - beans: - - name: imageNetUtil - type: "#class:org.apache.camel.kamelets.utils.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: {} diff --git a/kamelets/dns-dig-action.kamelet.yaml b/kamelets/dns-dig-action.kamelet.yaml deleted file mode 100644 index 52a9cc967..000000000 --- a/kamelets/dns-dig-action.kamelet.yaml +++ /dev/null @@ -1,91 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: dns-dig-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The Kamelet expects the following headers to be set: - - - `domain-name` / `ce-domainname`: as the domain for which we are querying the DNS - - - `dns-type` / `ce-dnstype`: as the DNS type - - If the domain-name header won't be set the body will be used as domain name. - - If the dns-type header won't be set, the DNS Type A will be used. - 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" diff --git a/kamelets/dns-ip-action.kamelet.yaml b/kamelets/dns-ip-action.kamelet.yaml deleted file mode 100644 index 83ffab19a..000000000 --- a/kamelets/dns-ip-action.kamelet.yaml +++ /dev/null @@ -1,70 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: dns-ip-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The Kamelet expects the following headers to be set: - - - `domain` / `ce-domain`: as the domain for which we are looking for the IP - - If the header won't be set the body will be used as domain to look for. - 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" diff --git a/kamelets/dns-lookup-action.kamelet.yaml b/kamelets/dns-lookup-action.kamelet.yaml deleted file mode 100644 index bb05b023f..000000000 --- a/kamelets/dns-lookup-action.kamelet.yaml +++ /dev/null @@ -1,74 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: dns-lookup-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The Kamelet expects the following headers to be set: - - - `domain-name` / `ce-domainname`: as the domain for which we are looking up - - If the domain-name header won't be set the body will be used as domain name. - 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: {} diff --git a/kamelets/drop-field-action.kamelet.yaml b/kamelets/drop-field-action.kamelet.yaml deleted file mode 100644 index 4c6e1dadc..000000000 --- a/kamelets/drop-field-action.kamelet.yaml +++ /dev/null @@ -1,84 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: drop-field-action - labels: - camel.apache.org/kamelet.type: "action" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The drop field action expects an application/json content type. - - If for example you have an object like '{ "foo":"John", "bar":30, "element":"hello" }' and your action has been configured with field as 'element', you'll get '{ "foo":"John", "bar":30 }' as a result because the field 'element' has been removed. - required: - - field - properties: - field: - title: Field - description: The name of the field to be removed - type: string - type: object - dependencies: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:core" - - "camel:jackson" - - "camel:kamelet" - template: - beans: - - name: dropField - type: "#class:org.apache.camel.kamelets.utils.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" diff --git a/kamelets/dropbox-sink.kamelet.yaml b/kamelets/dropbox-sink.kamelet.yaml deleted file mode 100644 index fe035463c..000000000 --- a/kamelets/dropbox-sink.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: dropbox-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet expects the following headers to be set: - - - `file` / `ce-file`: as the file name to upload - - If the header won't be set the exchange ID will be used as file name. - 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: Which mode to upload. in case of add the new file will be renamed if a file with the same name already exists on dropbox. in case of force if a file with the same name already exists on dropbox, this will be overwritten. The value can be one of add, force. - 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}}' - diff --git a/kamelets/dropbox-source.kamelet.yaml b/kamelets/dropbox-source.kamelet.yaml deleted file mode 100644 index f89c3ba38..000000000 --- a/kamelets/dropbox-source.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: dropbox-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 will be 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}" - diff --git a/kamelets/earthquake-source.kamelet.yaml b/kamelets/earthquake-source.kamelet.yaml deleted file mode 100644 index ab2d2ad64..000000000 --- a/kamelets/earthquake-source.kamelet.yaml +++ /dev/null @@ -1,110 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: earthquake-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/elasticsearch-search-source.kamelet.yaml b/kamelets/elasticsearch-search-source.kamelet.yaml deleted file mode 100644 index 8d539387c..000000000 --- a/kamelets/elasticsearch-search-source.kamelet.yaml +++ /dev/null @@ -1,123 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: elasticsearch-search-source - labels: - camel.apache.org/kamelet.type: "source" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The `query` parameter must be formatted in JSON. - - If you specify the `certificate` property, you must base64 encode it before you pass it as a parameter. - 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 diff --git a/kamelets/exec-sink.kamelet.yaml b/kamelets/exec-sink.kamelet.yaml deleted file mode 100644 index 335a70a4b..000000000 --- a/kamelets/exec-sink.kamelet.yaml +++ /dev/null @@ -1,72 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: exec-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The Kamelet expects the following headers to be set: - - - `args` / `ce-args`: as the args to be set on the executable. - - If the header won't be set the executable will be run without arguments. - 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}" diff --git a/kamelets/fhir-sink.kamelet.yaml b/kamelets/fhir-sink.kamelet.yaml deleted file mode 100644 index 8298ec813..000000000 --- a/kamelets/fhir-sink.kamelet.yaml +++ /dev/null @@ -1,160 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: fhir-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/fhir-source.kamelet.yaml b/kamelets/fhir-source.kamelet.yaml deleted file mode 100644 index 68728c38d..000000000 --- a/kamelets/fhir-source.kamelet.yaml +++ /dev/null @@ -1,102 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: fhir-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/file-watch-source.kamelet.yaml b/kamelets/file-watch-source.kamelet.yaml deleted file mode 100644 index 9adb44494..000000000 --- a/kamelets/file-watch-source.kamelet.yaml +++ /dev/null @@ -1,58 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: file-watch-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/freemarker-template-action.kamelet.yaml b/kamelets/freemarker-template-action.kamelet.yaml deleted file mode 100644 index 88e11a267..000000000 --- a/kamelets/freemarker-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: freemarker-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:freemarker" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "freemarker:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/github-commit-source.kamelet.yaml b/kamelets/github-commit-source.kamelet.yaml deleted file mode 100644 index 617b3d7be..000000000 --- a/kamelets/github-commit-source.kamelet.yaml +++ /dev/null @@ -1,85 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: github-commit-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/github-event-source.kamelet.yaml b/kamelets/github-event-source.kamelet.yaml deleted file mode 100644 index f888b5db9..000000000 --- a/kamelets/github-event-source.kamelet.yaml +++ /dev/null @@ -1,73 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: github-event-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/github-pullrequest-comment-source.kamelet.yaml b/kamelets/github-pullrequest-comment-source.kamelet.yaml deleted file mode 100644 index f0ee8470b..000000000 --- a/kamelets/github-pullrequest-comment-source.kamelet.yaml +++ /dev/null @@ -1,73 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: github-pullrequest-comment-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/github-pullrequest-source.kamelet.yaml b/kamelets/github-pullrequest-source.kamelet.yaml deleted file mode 100644 index 9bad4b1a8..000000000 --- a/kamelets/github-pullrequest-source.kamelet.yaml +++ /dev/null @@ -1,73 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: github-pullrequest-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/github-tag-source.kamelet.yaml b/kamelets/github-tag-source.kamelet.yaml deleted file mode 100644 index e5f6be288..000000000 --- a/kamelets/github-tag-source.kamelet.yaml +++ /dev/null @@ -1,73 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: github-tag-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/google-calendar-source.kamelet.yaml b/kamelets/google-calendar-source.kamelet.yaml deleted file mode 100644 index e56afa1ca..000000000 --- a/kamelets/google-calendar-source.kamelet.yaml +++ /dev/null @@ -1,161 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-calendar-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/google-functions-sink.kamelet.yaml b/kamelets/google-functions-sink.kamelet.yaml deleted file mode 100644 index 901d4f9ce..000000000 --- a/kamelets/google-functions-sink.kamelet.yaml +++ /dev/null @@ -1,73 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-functions-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/google-mail-source.kamelet.yaml b/kamelets/google-mail-source.kamelet.yaml deleted file mode 100644 index cc3404a15..000000000 --- a/kamelets/google-mail-source.kamelet.yaml +++ /dev/null @@ -1,182 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-mail-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/google-sheets-sink.kamelet.yaml b/kamelets/google-sheets-sink.kamelet.yaml deleted file mode 100644 index c8e9fa9b0..000000000 --- a/kamelets/google-sheets-sink.kamelet.yaml +++ /dev/null @@ -1,184 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-sheets-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - Each cell value is represented by a Json property named after the respective row (A-Z) or column (1-n) depending on the given majorDimension. - Custom column names are supported in order to use custom property names instead of generic row (A-Z) or column (1-n) coordinates. - The given Json struct is ready to be transformed into a proper Google Sheets ValueRange object that can be used in the update/append values operation. - The data type uses a set of header entries to determine properties such as spreadsheetId, the target cell range, the majorDimension and so on. - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "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}}" diff --git a/kamelets/google-sheets-source.kamelet.yaml b/kamelets/google-sheets-source.kamelet.yaml deleted file mode 100644 index a49ad4b69..000000000 --- a/kamelets/google-sheets-source.kamelet.yaml +++ /dev/null @@ -1,216 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-sheets-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - Or Json array of values for a single row/column in the range when 'splitResults' mode is enabled. - 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. - Each cell value is represented by a Json property named after the respective row (A-Z) or column (1-n) depending on the given majorDimension. - Custom column names are supported in order to use custom property names instead of generic row (A-Z) or column (1-n) coordinates. - The produced Json struct is ready to be transformed back into a proper Google Sheets ValueRange object that can be used in an update/append values operation. - 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 Spreasheet 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" diff --git a/kamelets/google-storage-event-based-source.kamelet.yaml b/kamelets/google-storage-event-based-source.kamelet.yaml deleted file mode 100644 index b63174927..000000000 --- a/kamelets/google-storage-event-based-source.kamelet.yaml +++ /dev/null @@ -1,123 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-storage-event-based-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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. - - Service account key is the basic method for authenticating to the Google Pubsub and Google Storage. - - To use this Kamelet you'll need to set up Events notification for your Google Storage Bucket. - - You must encode the `serviceAccountKey` property before you pass it as a parameter. - 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 will be - get and returned as body, if not only the event will be 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' diff --git a/kamelets/google-storage-sink.kamelet.yaml b/kamelets/google-storage-sink.kamelet.yaml deleted file mode 100644 index 534d0d0fd..000000000 --- a/kamelets/google-storage-sink.kamelet.yaml +++ /dev/null @@ -1,88 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-storage-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - If you specify the `serviceAccountKey` property, you must base64 encode it before you pass it as a parameter. - - In the header, you can set the `file` / `ce-file` property to specify the filename to upload. If you do set property in the header, the Kamelet uses the exchange ID as filename. - 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}}" diff --git a/kamelets/google-storage-source.kamelet.yaml b/kamelets/google-storage-source.kamelet.yaml deleted file mode 100644 index 231e5cbbd..000000000 --- a/kamelets/google-storage-source.kamelet.yaml +++ /dev/null @@ -1,128 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: google-storage-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - If you specify the `serviceAccountKey` property, you must base64 encode it before you pass it as a parameter. - 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 - 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. - Is the generation number of the object for which you are retrieving information. - 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 to 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.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}}" - steps: - - to: kamelet:sink diff --git a/kamelets/graphql-sink.kamelet.yaml b/kamelets/graphql-sink.kamelet.yaml deleted file mode 100644 index ca3c6883c..000000000 --- a/kamelets/graphql-sink.kamelet.yaml +++ /dev/null @@ -1,62 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: graphql-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/header-matches-filter-action.kamelet.yaml b/kamelets/header-matches-filter-action.kamelet.yaml deleted file mode 100644 index bad31ef37..000000000 --- a/kamelets/header-matches-filter-action.kamelet.yaml +++ /dev/null @@ -1,57 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: 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.8.0" - 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: {} diff --git a/kamelets/infinispan-sink.kamelet.yaml b/kamelets/infinispan-sink.kamelet.yaml deleted file mode 100644 index 2916d51ed..000000000 --- a/kamelets/infinispan-sink.kamelet.yaml +++ /dev/null @@ -1,129 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: infinispan-sink - labels: - camel.apache.org/kamelet.type: "sink" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet expects the following headers to be set: - - - `key` / `ce-key`: as the key to use when put an object in the Infinispan cache. - - If the header won't be set the exchange ID will be used as key. - 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}}" diff --git a/kamelets/infinispan-source.kamelet.yaml b/kamelets/infinispan-source.kamelet.yaml deleted file mode 100644 index 531ba78f0..000000000 --- a/kamelets/infinispan-source.kamelet.yaml +++ /dev/null @@ -1,134 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: infinispan-source - labels: - camel.apache.org/kamelet.type: "source" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 diff --git a/kamelets/jira-oauth-source.kamelet.yaml b/kamelets/jira-oauth-source.kamelet.yaml deleted file mode 100644 index b9bbc6914..000000000 --- a/kamelets/jira-oauth-source.kamelet.yaml +++ /dev/null @@ -1,105 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: jira-oauth-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/jms-pooled-apache-artemis-sink.kamelet.yaml b/kamelets/jms-pooled-apache-artemis-sink.kamelet.yaml deleted file mode 100644 index 83560bd98..000000000 --- a/kamelets/jms-pooled-apache-artemis-sink.kamelet.yaml +++ /dev/null @@ -1,112 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: 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.8.0" - 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: int - default: 500 - maxIdleSessionsPerConnection: - title: "Max Idle Sessions Per Connection" - description: "The number of idle sessions allowed per connection before they are closed." - type: int - 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: int - default: 30000 - dependencies: - - "camel:jms" - - "camel:kamelet" - - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.37.0" - - "mvn:org.messaginghub:pooled-jms:3.1.6" - 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}}" diff --git a/kamelets/jms-pooled-apache-artemis-source.kamelet.yaml b/kamelets/jms-pooled-apache-artemis-source.kamelet.yaml deleted file mode 100644 index 295a51ac6..000000000 --- a/kamelets/jms-pooled-apache-artemis-source.kamelet.yaml +++ /dev/null @@ -1,111 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: 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.8.0" - 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: int - default: 500 - maxIdleSessionsPerConnection: - title: "Max Idle Sessions Per Connection" - description: "The number of idle sessions allowed per connection before they are closed." - type: int - 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: int - default: 30000 - dependencies: - - "camel:jms" - - "camel:kamelet" - - "mvn:org.apache.activemq:artemis-jakarta-client-all:2.37.0" - - "mvn:org.messaginghub:pooled-jms:3.1.6" - 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" diff --git a/kamelets/jolt-transformation-action.kamelet.yaml b/kamelets/jolt-transformation-action.kamelet.yaml deleted file mode 100644 index 37e9d8221..000000000 --- a/kamelets/jolt-transformation-action.kamelet.yaml +++ /dev/null @@ -1,62 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: jolt-transformation-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - transform: - title: Transform DSL - description: Specifies the Transform DSL of the endpoint resource. If none is specified Chainr will be 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}}" diff --git a/kamelets/json-patch-action.kamelet.yaml b/kamelets/json-patch-action.kamelet.yaml deleted file mode 100644 index 67c45c78d..000000000 --- a/kamelets/json-patch-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: json-patch-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:json-patch" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "json-patch:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/json-schema-validator-action.kamelet.yaml b/kamelets/json-schema-validator-action.kamelet.yaml deleted file mode 100644 index 84154c3e8..000000000 --- a/kamelets/json-schema-validator-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: json-schema-validator-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:json-validator" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "json-validator:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/jsonata-action.kamelet.yaml b/kamelets/jsonata-action.kamelet.yaml deleted file mode 100644 index 29c7d18c8..000000000 --- a/kamelets/jsonata-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: jsonata-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:jsonata" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "jsonata:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/kafka-apicurio-registry-not-secured-sink.kamelet.yaml b/kamelets/kafka-apicurio-registry-not-secured-sink.kamelet.yaml deleted file mode 100644 index 600a10deb..000000000 --- a/kamelets/kafka-apicurio-registry-not-secured-sink.kamelet.yaml +++ /dev/null @@ -1,113 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-apicurio-registry-not-secured-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet is able to understand the following headers to be set: - - - `key` / `ce-key`: as message key - - - `partition-key` / `ce-partitionkey`: as message partition key - - Both the headers are optional. - 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}}" diff --git a/kamelets/kafka-apicurio-registry-not-secured-source.kamelet.yaml b/kamelets/kafka-apicurio-registry-not-secured-source.kamelet.yaml deleted file mode 100644 index 33ca96f1f..000000000 --- a/kamelets/kafka-apicurio-registry-not-secured-source.kamelet.yaml +++ /dev/null @@ -1,135 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-apicurio-registry-not-secured-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - - "mvn:io.quarkus:io.quarkus:quarkus-apicurio-registry-json-schema:3.6.3" - template: - beans: - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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" diff --git a/kamelets/kafka-azure-schema-registry-sink.kamelet.yaml b/kamelets/kafka-azure-schema-registry-sink.kamelet.yaml deleted file mode 100644 index 2c0a3d692..000000000 --- a/kamelets/kafka-azure-schema-registry-sink.kamelet.yaml +++ /dev/null @@ -1,143 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-azure-schema-registry-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet is able to understand the following headers to be set: - - - `key` / `ce-key`: as message key - - - `partition-key` / `ce-partitionkey`: as message partition key - - Both the headers are optional. - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:core" - - "camel:kafka" - - "camel:kamelet" - - "camel:azure-schema-registry" - - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.1" - - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.20" - - "mvn:com.azure:azure-identity:1.13.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}}' diff --git a/kamelets/kafka-azure-schema-registry-source.kamelet.yaml b/kamelets/kafka-azure-schema-registry-source.kamelet.yaml deleted file mode 100644 index 4774fc058..000000000 --- a/kamelets/kafka-azure-schema-registry-source.kamelet.yaml +++ /dev/null @@ -1,172 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-azure-schema-registry-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - - "camel:azure-schema-registry" - - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.1" - - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.20" - - "mvn:com.azure:azure-identity:1.13.2" - template: - beans: - - name: defaultAzureCredential - type: "#class:org.apache.camel.component.azure.schema.registry.DefaultAzureCredentialWrapper" - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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" diff --git a/kamelets/kafka-batch-apicurio-registry-source.kamelet.yaml b/kamelets/kafka-batch-apicurio-registry-source.kamelet.yaml deleted file mode 100644 index 475e1d20e..000000000 --- a/kamelets/kafka-batch-apicurio-registry-source.kamelet.yaml +++ /dev/null @@ -1,209 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-batch-apicurio-registry-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: int - default: 500 - pollTimeout: - title: Poll Timeout Interval - description: The timeout used when polling the KafkaConsumer - type: int - default: 5000 - maxPollIntervalMs: - title: Max Poll Interval - description: The maximum delay between invocations of poll() when using consumer group management - type: int - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - - "mvn:io.quarkus:quarkus-apicurio-registry-avro:3.6.3" - template: - beans: - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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}}" - batching: true - kafkaManualCommitFactory: "#bean:{{manualCommitFactory}}" - topicIsPattern: "{{topicIsPattern}}" - steps: - - process: - ref: "{{kafkaHeaderDeserializer}}" - - to: "kamelet:sink" diff --git a/kamelets/kafka-batch-azure-schema-registry-source.kamelet.yaml b/kamelets/kafka-batch-azure-schema-registry-source.kamelet.yaml deleted file mode 100644 index e4e04f63e..000000000 --- a/kamelets/kafka-batch-azure-schema-registry-source.kamelet.yaml +++ /dev/null @@ -1,193 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-batch-azure-schema-registry-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: int - default: 500 - pollTimeout: - title: Poll Timeout Interval - description: The timeout used when polling the KafkaConsumer - type: int - default: 5000 - maxPollIntervalMs: - title: Max Poll Interval - description: The maximum delay between invocations of poll() when using consumer group management - type: int - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - - "camel:azure-schema-registry" - - "mvn:com.microsoft.azure:azure-schemaregistry-kafka-avro:1.1.1" - - "mvn:com.azure:azure-data-schemaregistry-apacheavro:1.1.20" - - "mvn:com.azure:azure-identity:1.13.2" - template: - beans: - - name: defaultAzureCredential - type: "#class:org.apache.camel.component.azure.schema.registry.DefaultAzureCredentialWrapper" - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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}}" - 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" diff --git a/kamelets/kafka-manual-commit-action.kamelet.yaml b/kamelets/kafka-manual-commit-action.kamelet.yaml deleted file mode 100644 index e25326239..000000000 --- a/kamelets/kafka-manual-commit-action.kamelet.yaml +++ /dev/null @@ -1,42 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: 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.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kamelet" - template: - from: - uri: kamelet:source - steps: - - bean: "org.apache.camel.kamelets.utils.transform.kafka.ManualCommit" diff --git a/kamelets/kafka-not-secured-apicurio-registry-json-source.kamelet.yaml b/kamelets/kafka-not-secured-apicurio-registry-json-source.kamelet.yaml deleted file mode 100644 index a01e7a086..000000000 --- a/kamelets/kafka-not-secured-apicurio-registry-json-source.kamelet.yaml +++ /dev/null @@ -1,182 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-not-secured-apicurio-registry-json-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "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.kamelets.utils.serialization.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" diff --git a/kamelets/kafka-not-secured-apicurio-registry-sink.kamelet.yaml b/kamelets/kafka-not-secured-apicurio-registry-sink.kamelet.yaml deleted file mode 100644 index 4727ad02c..000000000 --- a/kamelets/kafka-not-secured-apicurio-registry-sink.kamelet.yaml +++ /dev/null @@ -1,160 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-not-secured-apicurio-registry-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet is able to understand the following headers to be set: - - - `key` / `ce-key`: as message key - - - `partition-key` / `ce-partitionkey`: as message partition key - - Both the headers are optional. - 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}}" diff --git a/kamelets/kafka-not-secured-apicurio-registry-source.kamelet.yaml b/kamelets/kafka-not-secured-apicurio-registry-source.kamelet.yaml deleted file mode 100644 index 5c85151a1..000000000 --- a/kamelets/kafka-not-secured-apicurio-registry-source.kamelet.yaml +++ /dev/null @@ -1,188 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-not-secured-apicurio-registry-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - - "mvn:io.quarkus:quarkus-apicurio-registry-avro:3.6.3" - template: - beans: - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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" diff --git a/kamelets/kafka-not-secured-sink.kamelet.yaml b/kamelets/kafka-not-secured-sink.kamelet.yaml deleted file mode 100644 index 0a4c8da3b..000000000 --- a/kamelets/kafka-not-secured-sink.kamelet.yaml +++ /dev/null @@ -1,92 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-not-secured-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet is able to understand the following headers to be set: - - - `key` / `ce-key`: as message key - - - `partition-key` / `ce-partitionkey`: as message partition key - - Both the headers are optional. - 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" - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "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}}" diff --git a/kamelets/kafka-not-secured-source.kamelet.yaml b/kamelets/kafka-not-secured-source.kamelet.yaml deleted file mode 100644 index cf6668df1..000000000 --- a/kamelets/kafka-not-secured-source.kamelet.yaml +++ /dev/null @@ -1,119 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-not-secured-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kafka" - - "camel:core" - - "camel:kamelet" - template: - beans: - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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" diff --git a/kamelets/kafka-scram-sink.kamelet.yaml b/kamelets/kafka-scram-sink.kamelet.yaml deleted file mode 100644 index ee2026442..000000000 --- a/kamelets/kafka-scram-sink.kamelet.yaml +++ /dev/null @@ -1,119 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-scram-sink - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet is able to understand the following headers to be set: - - - `key` / `ce-key`: as message key - - - `partition-key` / `ce-partitionkey`: as message partition key - - Both the headers are optional. - 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}}";' diff --git a/kamelets/kafka-scram-source.kamelet.yaml b/kamelets/kafka-scram-source.kamelet.yaml deleted file mode 100644 index 00665fdeb..000000000 --- a/kamelets/kafka-scram-source.kamelet.yaml +++ /dev/null @@ -1,153 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kafka-scram-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:core" - - "camel:kafka" - - "camel:kamelet" - template: - beans: - - name: kafkaHeaderDeserializer - type: "#class:org.apache.camel.kamelets.utils.serialization.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" diff --git a/kamelets/kubernetes-namespaces-source.kamelet.yaml b/kamelets/kubernetes-namespaces-source.kamelet.yaml deleted file mode 100644 index 6b9b82d43..000000000 --- a/kamelets/kubernetes-namespaces-source.kamelet.yaml +++ /dev/null @@ -1,67 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kubernetes-namespaces-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - diff --git a/kamelets/kubernetes-nodes-source.kamelet.yaml b/kamelets/kubernetes-nodes-source.kamelet.yaml deleted file mode 100644 index f2a5e5d37..000000000 --- a/kamelets/kubernetes-nodes-source.kamelet.yaml +++ /dev/null @@ -1,72 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kubernetes-nodes-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - diff --git a/kamelets/kubernetes-pods-source.kamelet.yaml b/kamelets/kubernetes-pods-source.kamelet.yaml deleted file mode 100644 index 0c3b84d7f..000000000 --- a/kamelets/kubernetes-pods-source.kamelet.yaml +++ /dev/null @@ -1,72 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: kubernetes-pods-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - diff --git a/kamelets/mail-imap-source.kamelet.yaml b/kamelets/mail-imap-source.kamelet.yaml deleted file mode 100644 index cdb97bae3..000000000 --- a/kamelets/mail-imap-source.kamelet.yaml +++ /dev/null @@ -1,113 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mail-imap-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The Kamelet generates the following headers: - - - `subject` / `ce-subject`: the subject of the incoming mail - - - `from` / `ce-from`: the `from` field of the incoming mail - - - `to` / `ce-to`: the `to` field of the incoming mail - - - `cc` / `ce-cc`: the `cc` field of the incoming mail - - 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" diff --git a/kamelets/mail-sink.kamelet.yaml b/kamelets/mail-sink.kamelet.yaml deleted file mode 100644 index aac54a0bd..000000000 --- a/kamelets/mail-sink.kamelet.yaml +++ /dev/null @@ -1,121 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mail-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" - diff --git a/kamelets/mongodb-changes-stream-source.kamelet.yaml b/kamelets/mongodb-changes-stream-source.kamelet.yaml deleted file mode 100644 index db72b5421..000000000 --- a/kamelets/mongodb-changes-stream-source.kamelet.yaml +++ /dev/null @@ -1,109 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mongodb-changes-stream-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - template: - beans: - - name: local-mongodb - type: "#class:org.apache.camel.component.mongodb.MongoDbComponent" - - name: mongo-client - type: "#class:org.apache.camel.kamelets.utils.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 diff --git a/kamelets/mqtt-sink.kamelet.yaml b/kamelets/mqtt-sink.kamelet.yaml deleted file mode 100644 index b9d69f824..000000000 --- a/kamelets/mqtt-sink.kamelet.yaml +++ /dev/null @@ -1,75 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mqtt-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/mqtt-source.kamelet.yaml b/kamelets/mqtt-source.kamelet.yaml deleted file mode 100644 index 1230290af..000000000 --- a/kamelets/mqtt-source.kamelet.yaml +++ /dev/null @@ -1,80 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mqtt-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 diff --git a/kamelets/mqtt5-sink.kamelet.yaml b/kamelets/mqtt5-sink.kamelet.yaml deleted file mode 100644 index 81c6e642d..000000000 --- a/kamelets/mqtt5-sink.kamelet.yaml +++ /dev/null @@ -1,75 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mqtt5-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/mqtt5-source.kamelet.yaml b/kamelets/mqtt5-source.kamelet.yaml deleted file mode 100644 index 37f7c048f..000000000 --- a/kamelets/mqtt5-source.kamelet.yaml +++ /dev/null @@ -1,80 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mqtt5-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 diff --git a/kamelets/ms-exchange-online-imap-oauth-source.kamelet.yaml b/kamelets/ms-exchange-online-imap-oauth-source.kamelet.yaml deleted file mode 100644 index a7874666e..000000000 --- a/kamelets/ms-exchange-online-imap-oauth-source.kamelet.yaml +++ /dev/null @@ -1,105 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: ms-exchange-online-imap-oauth-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - It uses OAuth2 to authenticate IMAP session. - 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" diff --git a/kamelets/mustache-template-action.kamelet.yaml b/kamelets/mustache-template-action.kamelet.yaml deleted file mode 100644 index 7372f97db..000000000 --- a/kamelets/mustache-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mustache-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:mustache" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "mustache:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/mvel-template-action.kamelet.yaml b/kamelets/mvel-template-action.kamelet.yaml deleted file mode 100644 index 0369c9d4b..000000000 --- a/kamelets/mvel-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: mvel-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:mvel" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "mvel:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/nats-sink.kamelet.yaml b/kamelets/nats-sink.kamelet.yaml deleted file mode 100644 index 51e3e70a4..000000000 --- a/kamelets/nats-sink.kamelet.yaml +++ /dev/null @@ -1,61 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: nats-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - dependencies: - - "camel:nats" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "nats:{{topic}}" - parameters: - servers: "{{servers}}" diff --git a/kamelets/nats-source.kamelet.yaml b/kamelets/nats-source.kamelet.yaml deleted file mode 100644 index 818ca4b52..000000000 --- a/kamelets/nats-source.kamelet.yaml +++ /dev/null @@ -1,66 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: nats-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - types: - out: - mediaType: application/json - dependencies: - - "camel:jackson" - - "camel:nats" - - "camel:kamelet" - template: - from: - uri: "nats:{{topic}}" - parameters: - servers: "{{servers}}" - steps: - - marshal: - json: {} - - to: "kamelet:sink" diff --git a/kamelets/nominatim-geocode-action.kamelet.yaml b/kamelets/nominatim-geocode-action.kamelet.yaml deleted file mode 100644 index a36086f9a..000000000 --- a/kamelets/nominatim-geocode-action.kamelet.yaml +++ /dev/null @@ -1,112 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: nominatim-geocode-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - This Kamelet expects in the body the `address` to find. - The return message will also contain the following headers with the geolocation info: - - - `CamelGeoCoderAddress` - - `CamelGeoCoderCity` - - `CamelGeoCoderCountryLong` - - `CamelGeoCoderCountryShort` - - `CamelGeoCoderLat` - - `CamelGeoCoderLng` - - `CamelGeoCoderLatlng` - - `CamelGeoCoderPostalCode` - - `CamelGeoCoderRegionCode` - - `CamelGeoCoderRegionName` - - `CamelGeoCoderStatus` - - The body will be returned in JSON format. - 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: {} - - - diff --git a/kamelets/ogcapi-features-action.kamelet.yaml b/kamelets/ogcapi-features-action.kamelet.yaml deleted file mode 100644 index 8f5634b9f..000000000 --- a/kamelets/ogcapi-features-action.kamelet.yaml +++ /dev/null @@ -1,123 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: ogcapi-features-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - The collection must be a valid collection name on the server. - - Query can be defined in the body too. - - See https://www.ogc.org/standards/ogcapi-features - 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" - - - diff --git a/kamelets/opensearch-index-sink.kamelet.yaml b/kamelets/opensearch-index-sink.kamelet.yaml deleted file mode 100644 index 5487c35fa..000000000 --- a/kamelets/opensearch-index-sink.kamelet.yaml +++ /dev/null @@ -1,144 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: opensearch-index-sink - labels: - camel.apache.org/kamelet.type: "sink" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The input data must be formatted in JSON according to the requirements of the index. - - If you specify the `certificate` property, you must base64 encode it before you pass it as a parameter. - - In the header, you can set the following properties: - - - `indexId` / `ce-indexid`: The index ID for OpenSearch. - - - `indexName` / `ce-indexname`: The index name for OpenSearch. - - If you do not set a property in the header, the Kamelet uses the exchange ID for the index setting. - 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}}" diff --git a/kamelets/opensearch-search-source.kamelet.yaml b/kamelets/opensearch-search-source.kamelet.yaml deleted file mode 100644 index 426c0cd21..000000000 --- a/kamelets/opensearch-search-source.kamelet.yaml +++ /dev/null @@ -1,123 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: opensearch-search-source - labels: - camel.apache.org/kamelet.type: "source" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 - - The `query` parameter must be formatted in JSON. - - If you specify the `certificate` property, you must base64 encode it before you pass it as a parameter. - 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 diff --git a/kamelets/oracle-database-sink.kamelet.yaml b/kamelets/oracle-database-sink.kamelet.yaml deleted file mode 100644 index 707e2c69b..000000000 --- a/kamelets/oracle-database-sink.kamelet.yaml +++ /dev/null @@ -1,113 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: oracle-database-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - In your Pipe file, you must explicitly declare the Oracle Database driver dependency in spec->integration->dependencies. - - - "mvn:com.oracle.database.jdbc:ojdbc11:" - - This Kamelet expects a JSON-formatted body. Use key:value pairs to map the JSON fields and parameters. For example, here is a query: - - 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' - - Here is example input for the example query: - - '{ "username":"oscerd", "city":"Rome"}' - 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.12.0" - template: - beans: - - 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: "sql:{{query}}" - parameters: - dataSource: "#bean:{{dsBean}}" diff --git a/kamelets/oracle-database-source.kamelet.yaml b/kamelets/oracle-database-source.kamelet.yaml deleted file mode 100644 index 5d0316b35..000000000 --- a/kamelets/oracle-database-source.kamelet.yaml +++ /dev/null @@ -1,110 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: oracle-database-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - In your Pipe file, you must explicitly declare the Oracle Database driver dependency in spec->integration->dependencies. - - - "mvn:com.oracle.database.jdbc:ojdbc11:" - 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.12.0" - template: - beans: - - 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: "sql:{{query}}" - parameters: - dataSource: "#bean:{{dsBean}}" - onConsume: "{{?consumedQuery}}" - steps: - - marshal: - json: - library: Jackson - - to: "kamelet:sink" diff --git a/kamelets/pdf-action.kamelet.yaml b/kamelets/pdf-action.kamelet.yaml deleted file mode 100644 index 8f885ed40..000000000 --- a/kamelets/pdf-action.kamelet.yaml +++ /dev/null @@ -1,68 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: pdf-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/pulsar-sink.kamelet.yaml b/kamelets/pulsar-sink.kamelet.yaml deleted file mode 100644 index 670272376..000000000 --- a/kamelets/pulsar-sink.kamelet.yaml +++ /dev/null @@ -1,157 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: pulsar-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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: "The maximum time period within which the messages sent will be batched if batchingEnabled is true." - 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 will be 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}}" diff --git a/kamelets/pulsar-source.kamelet.yaml b/kamelets/pulsar-source.kamelet.yaml deleted file mode 100644 index 9d146a28c..000000000 --- a/kamelets/pulsar-source.kamelet.yaml +++ /dev/null @@ -1,168 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: pulsar-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 will be sent. Note: if not set, default topic name will be topicName-subscriptionName-DLQ." - type: integer - maxRedeliverCount: - title: Maximum Redelivery Count - description: "Maximum number of times that a message will be redelivered before being sent to the dead letter queue. If this value is not set, no Dead Letter Policy will be 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" diff --git a/kamelets/redis-sink.kamelet.yaml b/kamelets/redis-sink.kamelet.yaml deleted file mode 100644 index 39493d81b..000000000 --- a/kamelets/redis-sink.kamelet.yaml +++ /dev/null @@ -1,130 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: redis-sink - labels: - camel.apache.org/kamelet.type: "sink" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/redis-source.kamelet.yaml b/kamelets/redis-source.kamelet.yaml deleted file mode 100644 index e21ed1232..000000000 --- a/kamelets/redis-source.kamelet.yaml +++ /dev/null @@ -1,75 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: redis-source - labels: - camel.apache.org/kamelet.type: "source" - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 diff --git a/kamelets/resolve-pojo-schema-action.kamelet.yaml b/kamelets/resolve-pojo-schema-action.kamelet.yaml deleted file mode 100644 index 7a6d731b6..000000000 --- a/kamelets/resolve-pojo-schema-action.kamelet.yaml +++ /dev/null @@ -1,76 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: resolve-pojo-schema-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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: - - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.8.0" - - "camel:kamelet" - - "camel:core" - - "camel:jackson-avro" - - "camel:jackson-protobuf" - template: - beans: - - name: schemaResolver - type: "#class:org.apache.camel.kamelets.utils.format.schema.DelegatingSchemaResolver" - properties: - mimeType: '{{mimeType}}' - schema: '{{schema:}}' - contentClass: '{{contentClass:}}' - targetMimeType: '{{targetMimeType:}}' - from: - uri: "kamelet:source" - steps: - - process: - ref: "{{schemaResolver}}" diff --git a/kamelets/rest-openapi-sink.kamelet.yaml b/kamelets/rest-openapi-sink.kamelet.yaml deleted file mode 100644 index 9c37eacde..000000000 --- a/kamelets/rest-openapi-sink.kamelet.yaml +++ /dev/null @@ -1,58 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: rest-openapi-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - 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}}" diff --git a/kamelets/salesforce-composite-upsert-sink.kamelet.yaml b/kamelets/salesforce-composite-upsert-sink.kamelet.yaml deleted file mode 100644 index 114d78b33..000000000 --- a/kamelets/salesforce-composite-upsert-sink.kamelet.yaml +++ /dev/null @@ -1,121 +0,0 @@ -#--------------------------------------------------------------------------- -# 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: salesforce-composite-upsert-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The body received must contain List of JSON SObjects to insert/update inside the records attribute, for example: - - `{"records" : ["attributes" : {"type" : "KameletSinkSObject__c"},"ExtId__c" : "1","Name__c": "Ziauddin", "City__c": "Bhopal"], ["attributes" : {"type" : "KameletSinkSObject__c"},"ExtId__c" : "2","Name__c": "Shaikh", "City__c": "Bhopal"] }` - - 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" diff --git a/kamelets/scp-sink.kamelet.yaml b/kamelets/scp-sink.kamelet.yaml deleted file mode 100644 index 469db7eee..000000000 --- a/kamelets/scp-sink.kamelet.yaml +++ /dev/null @@ -1,94 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: scp-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/set-kafka-key-action.kamelet.yaml b/kamelets/set-kafka-key-action.kamelet.yaml deleted file mode 100644 index f9e378fca..000000000 --- a/kamelets/set-kafka-key-action.kamelet.yaml +++ /dev/null @@ -1,66 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: 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.8.0" - 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. - - The headerName parameter allows you to specify which header value to set as Kafka Key. - 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}}" diff --git a/kamelets/snowflake-sink.kamelet.yaml b/kamelets/snowflake-sink.kamelet.yaml deleted file mode 100644 index 690a6890f..000000000 --- a/kamelets/snowflake-sink.kamelet.yaml +++ /dev/null @@ -1,104 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: snowflake-sink - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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. For example, here is a query: - - 'INSERT INTO accounts (username,city) VALUES (:#username,:#city)' - - Here is example input for the example query: - - '{ "username":"oscerd", "city":"Rome"}' - 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.19.0" - - "mvn:org.apache.commons:commons-dbcp2:2.12.0" - template: - beans: - - 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: "sql:{{query}}" - parameters: - dataSource: "#bean:{{dsBean}}" diff --git a/kamelets/snowflake-source.kamelet.yaml b/kamelets/snowflake-source.kamelet.yaml deleted file mode 100644 index 755772020..000000000 --- a/kamelets/snowflake-source.kamelet.yaml +++ /dev/null @@ -1,107 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: snowflake-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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.19.0" - - "mvn:org.apache.commons:commons-dbcp2:2.12.0" - template: - beans: - - name: dsBean - type: "#class:net.snowflake.client.jdbc.SnowflakeBasicDataSource" - properties: - user: '{{username}}' - password: '{{password}}' - url: 'jdbc:snowflake://{{instanceUrl}}' - databaseName: '{{?databaseName}}' - from: - uri: "sql:{{query}}" - parameters: - dataSource: "#bean:{{dsBean}}" - onConsume: "{{?consumedQuery}}" - delay: "{{delay}}" - steps: - - marshal: - json: - library: Jackson - - to: "kamelet:sink" diff --git a/kamelets/splunk-hec-sink.kamelet.yaml b/kamelets/splunk-hec-sink.kamelet.yaml deleted file mode 100644 index 40b845f3a..000000000 --- a/kamelets/splunk-hec-sink.kamelet.yaml +++ /dev/null @@ -1,115 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: splunk-hec-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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 even occurred. By default, the time will be 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}}/{{token}}" - parameters: - host: "{{?hostPayload}}" - bodyOnly: "{{?bodyOnly}}" - headersOnly: "{{?headersOnly}}" - index: "{{?index}}" - source: "{{?source}}" - sourceType: "{{?sourceType}}" - skipTlsVerify: "{{?skipTlsVerify}}" - https: "{{?https}}" - time: "{{?time}}" diff --git a/kamelets/spring-rabbitmq-sink.kamelet.yaml b/kamelets/spring-rabbitmq-sink.kamelet.yaml deleted file mode 100644 index e9c0c5e47..000000000 --- a/kamelets/spring-rabbitmq-sink.kamelet.yaml +++ /dev/null @@ -1,109 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: spring-rabbitmq-sink - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: int - 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 will be 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: "/" - dependencies: - - "camel:spring-rabbitmq" - - "camel:kamelet" - template: - beans: - - name: connectionFactory - type: "#class:org.springframework.amqp.rabbit.connection.CachingConnectionFactory" - properties: - username: '{{?username}}' - password: '{{?password}}' - host: '{{host}}' - port: '{{port}}' - virtualHost: "{{vhost}}" - from: - uri: "kamelet:source" - steps: - - to: - uri: "spring-rabbitmq://{{exchangeName}}" - parameters: - connectionFactory: "#bean:{{connectionFactory}}" - routingKey: "{{?routingKey}}" - queues: "{{?queues}}" - autoDeclareProducer: "{{autoDeclareProducer}}" diff --git a/kamelets/spring-rabbitmq-source.kamelet.yaml b/kamelets/spring-rabbitmq-source.kamelet.yaml deleted file mode 100644 index 9ea567cb5..000000000 --- a/kamelets/spring-rabbitmq-source.kamelet.yaml +++ /dev/null @@ -1,108 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: spring-rabbitmq-source - annotations: - camel.apache.org/kamelet.support.level: "Preview" - camel.apache.org/catalog.version: "4.8.0" - 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: int - 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 will be 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: "/" - dependencies: - - "camel:spring-rabbitmq" - - "camel:kamelet" - template: - beans: - - name: connectionFactory - type: "#class:org.springframework.amqp.rabbit.connection.CachingConnectionFactory" - properties: - username: '{{?username}}' - password: '{{?password}}' - host: '{{host}}' - port: '{{port}}' - virtualHost: "{{vhost}}" - from: - uri: "spring-rabbitmq://{{exchangeName}}" - parameters: - connectionFactory: "#bean:{{connectionFactory}}" - routingKey: "{{?routingKey}}" - queues: "{{?queues}}" - autoDeclare: "{{autoDeclare}}" - steps: - - to: "kamelet:sink" diff --git a/kamelets/ssh-sink.kamelet.yaml b/kamelets/ssh-sink.kamelet.yaml deleted file mode 100644 index 665e1f261..000000000 --- a/kamelets/ssh-sink.kamelet.yaml +++ /dev/null @@ -1,81 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: ssh-sink - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/ssh-source.kamelet.yaml b/kamelets/ssh-source.kamelet.yaml deleted file mode 100644 index db660f44e..000000000 --- a/kamelets/ssh-source.kamelet.yaml +++ /dev/null @@ -1,89 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: ssh-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/string-template-action.kamelet.yaml b/kamelets/string-template-action.kamelet.yaml deleted file mode 100644 index 9615e85f5..000000000 --- a/kamelets/string-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: string-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:stringtemplate" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "string-template:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/twitter-directmessage-source.kamelet.yaml b/kamelets/twitter-directmessage-source.kamelet.yaml deleted file mode 100644 index 1600be14d..000000000 --- a/kamelets/twitter-directmessage-source.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: twitter-directmessage-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - It requires tokens that can be obtained by creating an application - in the Twitter developer portal: https://developer.twitter.com/. - 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" diff --git a/kamelets/twitter-search-source.kamelet.yaml b/kamelets/twitter-search-source.kamelet.yaml deleted file mode 100644 index 06a4de657..000000000 --- a/kamelets/twitter-search-source.kamelet.yaml +++ /dev/null @@ -1,97 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: twitter-search-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - It requires tokens that can be obtained by creating an application - in the Twitter developer portal: https://developer.twitter.com/. - 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" diff --git a/kamelets/twitter-timeline-source.kamelet.yaml b/kamelets/twitter-timeline-source.kamelet.yaml deleted file mode 100644 index 1caa6cbac..000000000 --- a/kamelets/twitter-timeline-source.kamelet.yaml +++ /dev/null @@ -1,98 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: twitter-timeline-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - It requires tokens that can be obtained by creating an application - in the Twitter developer portal: https://developer.twitter.com/. - 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" diff --git a/kamelets/velocity-template-action.kamelet.yaml b/kamelets/velocity-template-action.kamelet.yaml deleted file mode 100644 index 810f8a370..000000000 --- a/kamelets/velocity-template-action.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: velocity-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:velocity" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "velocity:" - parameters: - resourceUri: "{{template}}" diff --git a/kamelets/webhook-source.kamelet.yaml b/kamelets/webhook-source.kamelet.yaml deleted file mode 100644 index d30004749..000000000 --- a/kamelets/webhook-source.kamelet.yaml +++ /dev/null @@ -1,55 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: webhook-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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. - - The "subpath" parameter of the Webhook source allows to customize the subpath where the integration will respond to HTTP requests. - It's common to use a non-guessable ID for that parameter. - - When the "subpath" parameter is set to "webhook" (default), the integration will accept requests at the "https://integration-external-url/webhook" endpoint. - 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" diff --git a/kamelets/wttrin-source.kamelet.yaml b/kamelets/wttrin-source.kamelet.yaml deleted file mode 100644 index 668ea19a2..000000000 --- a/kamelets/wttrin-source.kamelet.yaml +++ /dev/null @@ -1,89 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: wttrin-source - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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" diff --git a/kamelets/xj-identity-action.kamelet.yaml b/kamelets/xj-identity-action.kamelet.yaml deleted file mode 100644 index e9e1f8248..000000000 --- a/kamelets/xj-identity-action.kamelet.yaml +++ /dev/null @@ -1,54 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: xj-identity-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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}}" diff --git a/kamelets/xj-template-action.kamelet.yaml b/kamelets/xj-template-action.kamelet.yaml deleted file mode 100644 index 4a7c83944..000000000 --- a/kamelets/xj-template-action.kamelet.yaml +++ /dev/null @@ -1,62 +0,0 @@ -# --------------------------------------------------------------------------- -# 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: xj-template-action - annotations: - camel.apache.org/kamelet.support.level: "Stable" - camel.apache.org/catalog.version: "4.8.0" - 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)://.*" - dependencies: - - "camel:xj" - - "camel:kamelet" - template: - from: - uri: "kamelet:source" - steps: - - to: - uri: "xj:" - parameters: - resourceUri: "{{template}}" - transformDirection: "{{direction}}"