diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index e60bc8a1b..c8f6e4707 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -216,6 +216,8 @@ * xref:splunk-hec-sink.adoc[] * xref:splunk-sink.adoc[] * xref:splunk-source.adoc[] +* xref:spring-rabbitmq-sink.adoc[] +* xref:spring-rabbitmq-source.adoc[] * xref:sqlserver-sink.adoc[] * xref:sqlserver-source.adoc[] * xref:ssh-sink.adoc[] diff --git a/kamelets/spring-rabbitmq-sink.kamelet.yaml b/kamelets/spring-rabbitmq-sink.kamelet.yaml new file mode 100644 index 000000000..77d1f8c38 --- /dev/null +++ b/kamelets/spring-rabbitmq-sink.kamelet.yaml @@ -0,0 +1,97 @@ +# --------------------------------------------------------------------------- +# 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.4.0-SNAPSHOT" + 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 + 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}}' + from: + uri: "kamelet:source" + steps: + - to: + uri: "spring-rabbitmq://{{exchangeName}}" + parameters: + connectionFactory: "#bean:{{connectionFactory}}" + routingKey: "{{?routingKey}}" + queues: "{{?queues}}" diff --git a/kamelets/spring-rabbitmq-source.kamelet.yaml b/kamelets/spring-rabbitmq-source.kamelet.yaml new file mode 100644 index 000000000..d96e2b37b --- /dev/null +++ b/kamelets/spring-rabbitmq-source.kamelet.yaml @@ -0,0 +1,102 @@ +# --------------------------------------------------------------------------- +# 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.4.0-SNAPSHOT" + 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 + 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}}' + from: + uri: "spring-rabbitmq://{{exchangeName}}" + parameters: + connectionFactory: "#bean:{{connectionFactory}}" + routingKey: "{{?routingKey}}" + queues: "{{?queues}}" + autoDeclare: "{{autoDeclare}}" + steps: + - to: "kamelet:sink" diff --git a/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-sink.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-sink.kamelet.yaml new file mode 100644 index 000000000..77d1f8c38 --- /dev/null +++ b/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-sink.kamelet.yaml @@ -0,0 +1,97 @@ +# --------------------------------------------------------------------------- +# 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.4.0-SNAPSHOT" + 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 + 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}}' + from: + uri: "kamelet:source" + steps: + - to: + uri: "spring-rabbitmq://{{exchangeName}}" + parameters: + connectionFactory: "#bean:{{connectionFactory}}" + routingKey: "{{?routingKey}}" + queues: "{{?queues}}" diff --git a/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-source.kamelet.yaml b/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-source.kamelet.yaml new file mode 100644 index 000000000..d96e2b37b --- /dev/null +++ b/library/camel-kamelets/src/main/resources/kamelets/spring-rabbitmq-source.kamelet.yaml @@ -0,0 +1,102 @@ +# --------------------------------------------------------------------------- +# 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.4.0-SNAPSHOT" + 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 + 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}}' + from: + uri: "spring-rabbitmq://{{exchangeName}}" + parameters: + connectionFactory: "#bean:{{connectionFactory}}" + routingKey: "{{?routingKey}}" + queues: "{{?queues}}" + autoDeclare: "{{autoDeclare}}" + steps: + - to: "kamelet:sink"