diff --git a/docs/modules/ROOT/assets/images/kamelets/redis-source.svg b/docs/modules/ROOT/assets/images/kamelets/redis-source.svg new file mode 100644 index 000000000..313e8bc7f --- /dev/null +++ b/docs/modules/ROOT/assets/images/kamelets/redis-source.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index 50a6bf5c3..c94f9f299 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -114,6 +114,7 @@ * xref:ROOT:protobuf-deserialize-action.adoc[image:kamelets/protobuf-deserialize-action.svg[] Protobuf Deserialize Action] * xref:ROOT:protobuf-serialize-action.adoc[image:kamelets/protobuf-serialize-action.svg[] Protobuf Serialize Action] * xref:ROOT:rabbitmq-source.adoc[image:kamelets/rabbitmq-source.svg[] RabbitMQ Source] +* xref:ROOT:redis-source.adoc[image:kamelets/redis-source.svg[] Redis Source] * xref:ROOT:regex-router-action.adoc[image:kamelets/regex-router-action.svg[] Regex Router Action] * xref:ROOT:replace-field-action.adoc[image:kamelets/replace-field-action.svg[] Replace Field Action] * xref:ROOT:salesforce-source.adoc[image:kamelets/salesforce-source.svg[] Salesforce Source] diff --git a/docs/modules/ROOT/pages/redis-source.adoc b/docs/modules/ROOT/pages/redis-source.adoc new file mode 100644 index 000000000..ddb6beda8 --- /dev/null +++ b/docs/modules/ROOT/pages/redis-source.adoc @@ -0,0 +1,153 @@ +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT + += image:kamelets/redis-source.svg[] Redis Source + +*Provided by: "Apache Software Foundation"* + +*Support Level for this Kamelet is: "Preview"* + +Get Events from a Redis cache + +== Configuration Options + +The following table summarizes the configuration options available for the `redis-source` Kamelet: +[width="100%",cols="2,^2,3,^2,^2,^3",options="header"] +|=== +| Property| Name| Description| Type| Default| Example +| *channels {empty}* *| Channels| Redis Channels| string| `"one"`| +| *redisHost {empty}* *| Redis Host| The host where Redis server is running| string| | +| *redisPort {empty}* *| Redis Port| The port where Redis server is running| integer| | +| command| Command| Redis Command| string| `"SUBSCRIBE"`| +| serializer| Serializer| RedisSerializer fully qualified name implementation| string| `"org.springframework.data.redis.serializer.StringRedisSerializer"`| +|=== + +NOTE: Fields marked with an asterisk ({empty}*) are mandatory. + + +== Dependencies + +At runtime, the `redis-source` Kamelet relies upon the presence of the following dependencies: + +- camel:kamelet +- camel:core +- camel:spring-redis + +== Usage + +This section describes how you can use the `redis-source`. + +=== Knative Source + +You can use the `redis-source` Kamelet as a Knative source by binding it to a Knative object. + +.redis-source-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: redis-source-binding +spec: + source: + ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: redis-source + properties: + redisHost: "The Redis Host" + redisPort: "The Redis Port" + sink: + ref: + kind: Channel + apiVersion: messaging.knative.dev/v1 + name: mychannel + +---- + +==== *Prerequisite* + +You have xref:{camel-k-version}@camel-k::installation/installation.adoc[Camel K installed] on the cluster. + +==== *Procedure for using the cluster CLI* + +. Save the `redis-source-binding.yaml` file to your local drive, and then edit it as needed for your configuration. + +. Run the source by using the following command: ++ +[source,shell] +---- +kubectl apply -f redis-source-binding.yaml +---- + +==== *Procedure for using the Kamel CLI* + +Configure and run the source by using the following command: + +[source,shell] +---- +kamel bind redis-source -p "source.redisHost=The Redis Host" -p "source.redisPort=The Redis Port" channel:mychannel +---- + +This command creates the KameletBinding in the current namespace on the cluster. + +=== Kafka Source + +You can use the `redis-source` Kamelet as a Kafka source by binding it to a Kafka topic. + +.redis-source-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: redis-source-binding +spec: + source: + ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: redis-source + properties: + redisHost: "The Redis Host" + redisPort: "The Redis Port" + sink: + ref: + kind: KafkaTopic + apiVersion: kafka.strimzi.io/v1beta1 + name: my-topic + +---- + +==== *Prerequisites* + +* You've installed https://strimzi.io/[Strimzi]. +* You've created a topic named `my-topic` in the current namespace. +* You have xref:{camel-k-version}@camel-k::installation/installation.adoc[Camel K installed] on the cluster. + +==== *Procedure for using the cluster CLI* + +. Save the `redis-source-binding.yaml` file to your local drive, and then edit it as needed for your configuration. + +. Run the source by using the following command: ++ +[source,shell] +---- +kubectl apply -f redis-source-binding.yaml +---- + +==== *Procedure for using the Kamel CLI* + +Configure and run the source by using the following command: + +[source,shell] +---- +kamel bind redis-source -p "source.redisHost=The Redis Host" -p "source.redisPort=The Redis Port" kafka.strimzi.io/v1beta1:KafkaTopic:my-topic +---- + +This command creates the KameletBinding in the current namespace on the cluster. + +== Kamelet source file + +https://github.com/apache/camel-kamelets/blob/main/kamelets/redis-source.kamelet.yaml + +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/kamelets/redis-source.kamelet.yaml b/kamelets/redis-source.kamelet.yaml new file mode 100644 index 000000000..300babf86 --- /dev/null +++ b/kamelets/redis-source.kamelet.yaml @@ -0,0 +1,74 @@ +# --------------------------------------------------------------------------- +# 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: redis-source + labels: + camel.apache.org/kamelet.type: "source" + annotations: + camel.apache.org/kamelet.support.level: "Preview" + camel.apache.org/catalog.version: "main-SNAPSHOT" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Redis" + 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" + flow: + from: + uri: "spring-redis:{{redisHost}}:{{redisPort}}" + parameters: + command: "{{command}}" + channels: "{{channels}}" + serializer: "#class:{{serializer}}" + steps: + - to: kamelet:sink diff --git a/library/camel-kamelets/src/main/resources/kamelets/redis-source.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/redis-source.kamelet.yaml new file mode 100644 index 000000000..e7a1cf677 --- /dev/null +++ b/library/camel-kamelets/src/main/resources/kamelets/redis-source.kamelet.yaml @@ -0,0 +1,74 @@ +# --------------------------------------------------------------------------- +# 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: redis-source + labels: + camel.apache.org/kamelet.type: "source" + annotations: + camel.apache.org/kamelet.support.level: "Preview" + camel.apache.org/catalog.version: "main-SNAPSHOT" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Redis" + camel.apache.org/kamelet.icon:  +spec: + definition: + title: "Redis Source" + description: "Get Events from a Redis cache" + required: + - redisHost + - redisPort + - channels + type: object + properties: + rediHost: + 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" + flow: + from: + uri: "spring-redis:{{redisHost}}:{{redisPort}}" + parameters: + command: "{{command}}" + channels: "{{channels}}" + serializer: "#class:{{serializer}}" + steps: + - to: kamelet:sink diff --git a/templates/bindings/camel-k/redis-source-binding.yaml b/templates/bindings/camel-k/redis-source-binding.yaml new file mode 100644 index 000000000..a77f052dd --- /dev/null +++ b/templates/bindings/camel-k/redis-source-binding.yaml @@ -0,0 +1,19 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: redis-source-binding +spec: + source: + ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: redis-source + properties: + redisHost: "The Redis Host" + redisPort: "The Redis Port" + sink: + ref: + kind: KafkaTopic + apiVersion: kafka.strimzi.io/v1beta1 + name: my-topic + \ No newline at end of file diff --git a/templates/bindings/core/redis-source-binding.yaml b/templates/bindings/core/redis-source-binding.yaml new file mode 100644 index 000000000..fb7eba418 --- /dev/null +++ b/templates/bindings/core/redis-source-binding.yaml @@ -0,0 +1,10 @@ +- route: + from: + uri: "kamelet:redis-source" + parameters: + redisHost: "The Redis Host" + redisPort: "The Redis Port" + steps: + - to: + uri: "log:info" + \ No newline at end of file