diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index 4e9ff5e17..4bdeb40b0 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -37,6 +37,7 @@ * xref:chunk-template-action.adoc[] * xref:couchbase-sink.adoc[] * xref:cron-source.adoc[] +* xref:delay-action.adoc[] * xref:dns-dig-action.adoc[] * xref:dns-ip-action.adoc[] * xref:dns-lookup-action.adoc[] diff --git a/docs/modules/ROOT/pages/index.adoc b/docs/pages/index.adoc similarity index 100% rename from docs/modules/ROOT/pages/index.adoc rename to docs/pages/index.adoc diff --git a/kamelets/aws-sqs-source.kamelet.yaml b/kamelets/aws-sqs-source.kamelet.yaml index 4122bb152..1f8c55336 100644 --- a/kamelets/aws-sqs-source.kamelet.yaml +++ b/kamelets/aws-sqs-source.kamelet.yaml @@ -25,6 +25,7 @@ metadata: camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" + camel.apache.org/keda.type: "aws-sqs-queue" labels: camel.apache.org/kamelet.type: "source" spec: @@ -58,6 +59,8 @@ spec: x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials + - urn:keda:authentication:awsAccessKeyID + - urn:keda:required secretKey: title: Secret Key description: The secret key obtained from AWS @@ -66,11 +69,16 @@ spec: x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials + - urn:keda:authentication:awsSecretAccessKey + - urn:keda:required region: title: AWS Region description: The AWS region to connect to type: string example: eu-west-1 + x-descriptors: + - urn:keda:metadata:awsRegion + - urn:keda:required autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. @@ -88,6 +96,13 @@ spec: 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 dependencies: - "camel:aws2-sqs" - "camel:kamelet" diff --git a/kamelets/delay-action.kamelet.yaml b/kamelets/delay-action.kamelet.yaml new file mode 100644 index 000000000..88c265c6e --- /dev/null +++ b/kamelets/delay-action.kamelet.yaml @@ -0,0 +1,51 @@ +# --------------------------------------------------------------------------- +# 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: delay-action + annotations: + camel.apache.org/kamelet.support.level: "Preview" + camel.apache.org/catalog.version: "main-SNAPSHOT" + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Delay" + 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" + flow: + from: + uri: "kamelet:source" + steps: + - delay: + constant: "{{milliseconds}}" diff --git a/kamelets/kafka-not-secured-source.kamelet.yaml b/kamelets/kafka-not-secured-source.kamelet.yaml index adc52f8e6..b7c4f50e7 100644 --- a/kamelets/kafka-not-secured-source.kamelet.yaml +++ b/kamelets/kafka-not-secured-source.kamelet.yaml @@ -24,6 +24,7 @@ metadata: camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" + camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: @@ -40,10 +41,16 @@ spec: 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 @@ -68,11 +75,16 @@ spec: 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 dependencies: - "camel:kafka" - "camel:kamelet" diff --git a/kamelets/kafka-source.kamelet.yaml b/kamelets/kafka-source.kamelet.yaml index 8167e8ac4..9d9cc9f48 100644 --- a/kamelets/kafka-source.kamelet.yaml +++ b/kamelets/kafka-source.kamelet.yaml @@ -24,6 +24,9 @@ metadata: 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: @@ -42,10 +45,16 @@ spec: 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 @@ -62,6 +71,8 @@ spec: type: string x-descriptors: - urn:camel:group:credentials + - urn:keda:authentication:username + - urn:keda:required password: title: Password description: Password to authenticate to kafka @@ -70,6 +81,8 @@ spec: 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 @@ -94,11 +107,16 @@ spec: 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 dependencies: - "camel:kafka" - "camel:kamelet" diff --git a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java index 3cde5be2d..6e3cb9f66 100644 --- a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java +++ b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java @@ -56,7 +56,7 @@ void testGetKamelets() throws Exception { @Test void testGetKameletsDefinition() throws Exception { JSONSchemaProps props = catalog.getKameletDefinition("aws-sqs-source"); - assertEquals(8, props.getProperties().keySet().size()); + assertEquals(9, props.getProperties().keySet().size()); assertTrue(props.getProperties().keySet().contains("queueNameOrArn")); } diff --git a/library/camel-kamelets/src/main/resources/kamelets/aws-sqs-source.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/aws-sqs-source.kamelet.yaml index 4122bb152..1f8c55336 100644 --- a/library/camel-kamelets/src/main/resources/kamelets/aws-sqs-source.kamelet.yaml +++ b/library/camel-kamelets/src/main/resources/kamelets/aws-sqs-source.kamelet.yaml @@ -25,6 +25,7 @@ metadata: camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "AWS SQS" + camel.apache.org/keda.type: "aws-sqs-queue" labels: camel.apache.org/kamelet.type: "source" spec: @@ -58,6 +59,8 @@ spec: x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials + - urn:keda:authentication:awsAccessKeyID + - urn:keda:required secretKey: title: Secret Key description: The secret key obtained from AWS @@ -66,11 +69,16 @@ spec: x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials + - urn:keda:authentication:awsSecretAccessKey + - urn:keda:required region: title: AWS Region description: The AWS region to connect to type: string example: eu-west-1 + x-descriptors: + - urn:keda:metadata:awsRegion + - urn:keda:required autoCreateQueue: title: Autocreate Queue description: Setting the autocreation of the SQS queue. @@ -88,6 +96,13 @@ spec: 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 dependencies: - "camel:aws2-sqs" - "camel:kamelet" diff --git a/library/camel-kamelets/src/main/resources/kamelets/delay-action.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/delay-action.kamelet.yaml new file mode 100644 index 000000000..88c265c6e --- /dev/null +++ b/library/camel-kamelets/src/main/resources/kamelets/delay-action.kamelet.yaml @@ -0,0 +1,51 @@ +# --------------------------------------------------------------------------- +# 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: delay-action + annotations: + camel.apache.org/kamelet.support.level: "Preview" + camel.apache.org/catalog.version: "main-SNAPSHOT" + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Delay" + 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" + flow: + from: + uri: "kamelet:source" + steps: + - delay: + constant: "{{milliseconds}}" diff --git a/library/camel-kamelets/src/main/resources/kamelets/kafka-not-secured-source.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/kafka-not-secured-source.kamelet.yaml index adc52f8e6..b7c4f50e7 100644 --- a/library/camel-kamelets/src/main/resources/kamelets/kafka-not-secured-source.kamelet.yaml +++ b/library/camel-kamelets/src/main/resources/kamelets/kafka-not-secured-source.kamelet.yaml @@ -24,6 +24,7 @@ metadata: camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Kafka" + camel.apache.org/keda.type: "kafka" labels: camel.apache.org/kamelet.type: "source" spec: @@ -40,10 +41,16 @@ spec: 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 @@ -68,11 +75,16 @@ spec: 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 dependencies: - "camel:kafka" - "camel:kamelet" diff --git a/library/camel-kamelets/src/main/resources/kamelets/kafka-source.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/kafka-source.kamelet.yaml index 8167e8ac4..9d9cc9f48 100644 --- a/library/camel-kamelets/src/main/resources/kamelets/kafka-source.kamelet.yaml +++ b/library/camel-kamelets/src/main/resources/kamelets/kafka-source.kamelet.yaml @@ -24,6 +24,9 @@ metadata: 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: @@ -42,10 +45,16 @@ spec: 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 @@ -62,6 +71,8 @@ spec: type: string x-descriptors: - urn:camel:group:credentials + - urn:keda:authentication:username + - urn:keda:required password: title: Password description: Password to authenticate to kafka @@ -70,6 +81,8 @@ spec: 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 @@ -94,11 +107,16 @@ spec: 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 dependencies: - "camel:kafka" - "camel:kamelet" diff --git a/script/validator/validator.go b/script/validator/validator.go index b7eb20b98..90ec701f7 100644 --- a/script/validator/validator.go +++ b/script/validator/validator.go @@ -163,6 +163,15 @@ func hasXDescriptor(p camelapi.JSONSchemaProp, desc string) bool { return false } +func hasXDescriptorPrefix(p camelapi.JSONSchemaProp, prefix string) bool { + for _, d := range p.XDescriptors { + if strings.HasPrefix(d, prefix) { + return true + } + } + return false +} + func verifyInvalidContent(kamelets []KameletInfo) (errors []error) { for _, kamelet := range kamelets { ser, err := json.Marshal(&kamelet.Kamelet) @@ -430,6 +439,12 @@ func getUsedParams(k camelapi.Kamelet) map[string]bool { } params := make(map[string]bool) inspectFlowParams(flowData, params) + for propName, propVal := range k.Spec.Definition.Properties { + if hasXDescriptorPrefix(propVal, "urn:keda:") { + // Assume KEDA parameters may be used by KEDA + params[propName] = true + } + } return params } return nil diff --git a/templates/bindings/camel-k/delay-action-binding.yaml b/templates/bindings/camel-k/delay-action-binding.yaml new file mode 100644 index 000000000..b6b3b7531 --- /dev/null +++ b/templates/bindings/camel-k/delay-action-binding.yaml @@ -0,0 +1,24 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: delay-action-binding +spec: + source: + ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: timer-source + properties: + message: "Hello" + steps: + - ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: delay-action + properties: + milliseconds: 1000 + sink: + ref: + kind: KafkaTopic + apiVersion: kafka.strimzi.io/v1beta1 + name: my-topic diff --git a/templates/bindings/core/delay-action-binding.yaml b/templates/bindings/core/delay-action-binding.yaml new file mode 100644 index 000000000..b9f4d73e1 --- /dev/null +++ b/templates/bindings/core/delay-action-binding.yaml @@ -0,0 +1,13 @@ +- route: + from: + uri: "kamelet:timer-source" + parameters: + period: 1000 + message: "{ \"foo\": \"John\"}" + steps: + - to: + uri: "kamelet:delay-action" + parameters: + milliseconds: 1000 + - to: + uri: "log:info"