From 30333b07af60abd2842edd4b3bad023c627e1454 Mon Sep 17 00:00:00 2001 From: Michael Thirion Date: Fri, 20 Jan 2023 18:38:51 +0100 Subject: [PATCH 1/4] adding kafka source and sink kamelets to support scram-sha-512 authentication --- kamelets/kafka-scram-sink.kamelet.yaml | 119 ++++++++++++++++++ kamelets/kafka-scram-source.kamelet.yaml | 154 +++++++++++++++++++++++ 2 files changed, 273 insertions(+) create mode 100644 kamelets/kafka-scram-sink.kamelet.yaml create mode 100644 kamelets/kafka-scram-source.kamelet.yaml diff --git a/kamelets/kafka-scram-sink.kamelet.yaml b/kamelets/kafka-scram-sink.kamelet.yaml new file mode 100644 index 000000000..b9fc6da4b --- /dev/null +++ b/kamelets/kafka-scram-sink.kamelet.yaml @@ -0,0 +1,119 @@ +# --------------------------------------------------------------------------- +# 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/v1alpha1 +kind: Kamelet +metadata: + name: kafka-sink + annotations: + camel.apache.org/kamelet.support.level: "Stable" + camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Kafka" + labels: + camel.apache.org/kamelet.type: "sink" +spec: + definition: + title: "Kafka Sink" + description: |- + Send data to Kafka topics. + + 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:alm:descriptor:com.tectonic.ui:password + - urn:camel:group:credentials + dependencies: + - "camel:core" + - "camel:kafka" + - "camel:kamelet" + template: + from: + uri: "kamelet:source" + steps: + - choice: + when: + - simple: "${header[key]}" + steps: + - set-header: + name: kafka.KEY + simple: "${header[key]}" + - simple: "${header[ce-key]}" + steps: + - set-header: + name: kafka.KEY + simple: "${header[ce-key]}" + - choice: + when: + - simple: "${header[partition-key]}" + steps: + - set-header: + name: kafka.PARTITION_KEY + simple: "${header[partition-key]}" + - simple: "${header[ce-partitionkey]}" + steps: + - set-header: + 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 new file mode 100644 index 000000000..78f4e7f64 --- /dev/null +++ b/kamelets/kafka-scram-source.kamelet.yaml @@ -0,0 +1,154 @@ +# --------------------------------------------------------------------------- +# 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/v1alpha1 +kind: Kamelet +metadata: + name: kafka-source + annotations: + camel.apache.org/kamelet.support.level: "Stable" + camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Kafka" + camel.apache.org/keda.type: "kafka" + camel.apache.org/keda.authentication.sasl: "plaintext" + camel.apache.org/keda.authentication.tls: "enable" + labels: + camel.apache.org/kamelet.type: "source" +spec: + definition: + title: "Kafka Source" + description: |- + Receive data from Kafka topics. + 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:alm:descriptor:com.tectonic.ui:password + - 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 + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' + allowManualCommit: + title: Allow Manual Commit + description: Whether to allow doing manual commits + type: boolean + default: false + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' + 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 + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' + default: false + dependencies: + - "github:apache.camel-kamelets:camel-kamelets-utils:3.21.0-SNAPSHOT" + - "camel:core" + - "camel:kafka" + - "camel:kamelet" + template: + beans: + - name: kafkaHeaderDeserializer + type: "#class:org.apache.camel.kamelets.utils.serialization.kafka.KafkaHeaderDeserializer" + property: + - key: enabled + value: '{{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}}" + steps: + - process: + ref: "{{kafkaHeaderDeserializer}}" + - to: "kamelet:sink" From f24e40cdb75ee70ce38988aad1296b09c8ab8eda Mon Sep 17 00:00:00 2001 From: Michael Thirion Date: Fri, 20 Jan 2023 18:42:17 +0100 Subject: [PATCH 2/4] Fix kamelet names --- kamelets/kafka-scram-sink.kamelet.yaml | 2 +- kamelets/kafka-scram-source.kamelet.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/kamelets/kafka-scram-sink.kamelet.yaml b/kamelets/kafka-scram-sink.kamelet.yaml index b9fc6da4b..bd7a4bf96 100644 --- a/kamelets/kafka-scram-sink.kamelet.yaml +++ b/kamelets/kafka-scram-sink.kamelet.yaml @@ -17,7 +17,7 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: - name: kafka-sink + name: kafka-scram-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" diff --git a/kamelets/kafka-scram-source.kamelet.yaml b/kamelets/kafka-scram-source.kamelet.yaml index 78f4e7f64..abc8043df 100644 --- a/kamelets/kafka-scram-source.kamelet.yaml +++ b/kamelets/kafka-scram-source.kamelet.yaml @@ -17,7 +17,7 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: - name: kafka-source + name: kafka-scram-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" From 76c95f2551c754c16828b39261d0cccd49bee013 Mon Sep 17 00:00:00 2001 From: Michael Thirion Date: Fri, 20 Jan 2023 19:05:36 +0100 Subject: [PATCH 3/4] Fix kamelet titles --- kamelets/kafka-scram-sink.kamelet.yaml | 2 +- kamelets/kafka-scram-source.kamelet.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/kamelets/kafka-scram-sink.kamelet.yaml b/kamelets/kafka-scram-sink.kamelet.yaml index bd7a4bf96..f735af4f3 100644 --- a/kamelets/kafka-scram-sink.kamelet.yaml +++ b/kamelets/kafka-scram-sink.kamelet.yaml @@ -28,7 +28,7 @@ metadata: camel.apache.org/kamelet.type: "sink" spec: definition: - title: "Kafka Sink" + title: "Kafka Scram Sink" description: |- Send data to Kafka topics. diff --git a/kamelets/kafka-scram-source.kamelet.yaml b/kamelets/kafka-scram-source.kamelet.yaml index abc8043df..d93e286df 100644 --- a/kamelets/kafka-scram-source.kamelet.yaml +++ b/kamelets/kafka-scram-source.kamelet.yaml @@ -31,7 +31,7 @@ metadata: camel.apache.org/kamelet.type: "source" spec: definition: - title: "Kafka Source" + title: "Kafka Scram Source" description: |- Receive data from Kafka topics. required: From ee0de4a34dde666f337ff13b6b943e20fc9f833c Mon Sep 17 00:00:00 2001 From: Michael Thirion Date: Fri, 20 Jan 2023 19:08:48 +0100 Subject: [PATCH 4/4] Switch support level to Preview --- kamelets/kafka-scram-sink.kamelet.yaml | 2 +- kamelets/kafka-scram-source.kamelet.yaml | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/kamelets/kafka-scram-sink.kamelet.yaml b/kamelets/kafka-scram-sink.kamelet.yaml index f735af4f3..a21b2731a 100644 --- a/kamelets/kafka-scram-sink.kamelet.yaml +++ b/kamelets/kafka-scram-sink.kamelet.yaml @@ -19,7 +19,7 @@ kind: Kamelet metadata: name: kafka-scram-sink annotations: - camel.apache.org/kamelet.support.level: "Stable" + camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" diff --git a/kamelets/kafka-scram-source.kamelet.yaml b/kamelets/kafka-scram-source.kamelet.yaml index d93e286df..5e91a0b0d 100644 --- a/kamelets/kafka-scram-source.kamelet.yaml +++ b/kamelets/kafka-scram-source.kamelet.yaml @@ -19,13 +19,13 @@ kind: Kamelet metadata: name: kafka-scram-source annotations: - camel.apache.org/kamelet.support.level: "Stable" + camel.apache.org/kamelet.support.level: "Preview" camel.apache.org/catalog.version: "3.21.0-SNAPSHOT" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" camel.apache.org/keda.type: "kafka" - camel.apache.org/keda.authentication.sasl: "plaintext" + camel.apache.org/keda.authentication.sasl: "scram-sha-512" camel.apache.org/keda.authentication.tls: "enable" labels: camel.apache.org/kamelet.type: "source"