Skip to content

Commit

Permalink
Add simple-filter-action kamelet (#338)
Browse files Browse the repository at this point in the history
  • Loading branch information
claudio4j authored Jun 3, 2024
1 parent 08b0839 commit 06d6447
Show file tree
Hide file tree
Showing 7 changed files with 327 additions and 0 deletions.
59 changes: 59 additions & 0 deletions docs/modules/ROOT/assets/images/kamelets/simple-filter-action.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions docs/modules/ROOT/nav.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@
* xref:ROOT:set-body-action.adoc[image:kamelets/set-body-action.svg[] Set Body Action]
* xref:ROOT:sftp-sink.adoc[image:kamelets/sftp-sink.svg[] SFTP Sink]
* xref:ROOT:sftp-source.adoc[image:kamelets/sftp-source.svg[] SFTP Source]
* xref:ROOT:simple-filter-action.adoc[image:kamelets/simple-filter-action.svg[] Simple Filter Action]
* xref:ROOT:slack-sink.adoc[image:kamelets/slack-sink.svg[] Slack Sink]
* xref:ROOT:slack-source.adoc[image:kamelets/slack-source.svg[] Slack Source]
* xref:ROOT:splunk-sink.adoc[image:kamelets/splunk-sink.svg[] Splunk Sink]
Expand Down
157 changes: 157 additions & 0 deletions docs/modules/ROOT/pages/simple-filter-action.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT

= image:kamelets/simple-filter-action.svg[] Simple Filter Action

*Provided by: "Red Hat"*

Filter based on simple expression

== Configuration Options

The following table summarizes the configuration options available for the `simple-filter-action` Kamelet:
[width="100%",cols="2,^2,3,^2,^2,^3",options="header"]
|===
| Property| Name| Description| Type| Default| Example
| *expression {empty}* *| Simple Expression| A simple expression to apply on the exchange to filter out some exchange| string| |
|===

NOTE: Fields marked with an asterisk ({empty}*) are mandatory.


== Dependencies

At runtime, the `simple-filter-action` Kamelet relies upon the presence of the following dependencies:

- camel:core
- camel:kamelet

== Usage

This section describes how you can use the `simple-filter-action`.

=== Knative Action

You can use the `simple-filter-action` Kamelet as an intermediate step in a Knative binding.

.simple-filter-action-binding.yaml
[source,yaml]
----
apiVersion: camel.apache.org/v1
kind: Pipe
metadata:
name: simple-filter-action-pipe
spec:
source:
ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: timer-source
properties:
message: "Hello"
steps:
- ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: simple-filter-action
properties:
expression: "The Simple Expression"
sink:
ref:
kind: Channel
apiVersion: messaging.knative.dev/v1
name: mychannel
----

==== *Prerequisite*

Make sure you have *"Red Hat Integration - Camel K"* installed into the OpenShift cluster you're connected to.

==== *Procedure for using the cluster CLI*

. Save the `simple-filter-action-binding.yaml` file to your local drive, and then edit it as needed for your configuration.

. Run the action by using the following command:
+
[source,shell]
----
oc apply -f simple-filter-action-binding.yaml
----

==== *Procedure for using the Kamel CLI*

Configure and run the action by using the following command:

[source,shell]
----
kamel bind timer-source?message=Hello --step simple-filter-action -p "step-0.expression=The Simple Expression" channel:mychannel
----

This command creates the Pipe in the current namespace on the cluster.

=== Kafka Action

You can use the `simple-filter-action` Kamelet as an intermediate step in a Kafka binding.

.simple-filter-action-binding.yaml
[source,yaml]
----
apiVersion: camel.apache.org/v1
kind: Pipe
metadata:
name: simple-filter-action-pipe
spec:
source:
ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: timer-source
properties:
message: "Hello"
steps:
- ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: simple-filter-action
properties:
expression: "The Simple Expression"
sink:
ref:
kind: KafkaTopic
apiVersion: kafka.strimzi.io/v1beta1
name: my-topic
----

==== *Prerequisites*

Ensure that you've installed the *AMQ Streams* operator in your OpenShift cluster and created a topic named `my-topic` in the current namespace.
Make also sure you have *"Red Hat Integration - Camel K"* installed into the OpenShift cluster you're connected to.

==== *Procedure for using the cluster CLI*

. Save the `simple-filter-action-binding.yaml` file to your local drive, and then edit it as needed for your configuration.

. Run the action by using the following command:
+
[source,shell]
----
oc apply -f simple-filter-action-binding.yaml
----

==== *Procedure for using the Kamel CLI*

Configure and run the action by using the following command:

[source,shell]
----
kamel bind timer-source?message=Hello --step simple-filter-action -p "step-0.expression=The Simple Expression" kafka.strimzi.io/v1beta1:KafkaTopic:my-topic
----

This command creates the Pipe in the current namespace on the cluster.

== Kamelet source file

https://github.com/openshift-integration/kamelet-catalog/blob/main/simple-filter-action.kamelet.yaml

// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
apiVersion: camel.apache.org/v1
kind: Kamelet
metadata:
name: simple-filter-action
labels:
camel.apache.org/kamelet.type: "action"
annotations:
camel.apache.org/kamelet.support.level: "Stable"
camel.apache.org/catalog.version: "2.3.0"
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Red Hat"
camel.apache.org/kamelet.group: "Actions"
camel.apache.org/kamelet.namespace: "EIP"
spec:
definition:
title: "Simple Filter Action"
description: "Filter based on simple expression"
required:
- expression
properties:
expression:
title: Simple Expression
description: A simple expression to apply on the exchange to filter out some exchange
type: string
type: object
dependencies:
- "camel:core"
- "camel:kamelet"
template:
from:
uri: kamelet:source
steps:
- filter:
simple: "{{expression}}"
steps:
- stop: {}
36 changes: 36 additions & 0 deletions simple-filter-action.kamelet.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
apiVersion: camel.apache.org/v1
kind: Kamelet
metadata:
name: simple-filter-action
labels:
camel.apache.org/kamelet.type: "action"
annotations:
camel.apache.org/kamelet.support.level: "Stable"
camel.apache.org/catalog.version: "2.3.0"
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Red Hat"
camel.apache.org/kamelet.group: "Actions"
camel.apache.org/kamelet.namespace: "EIP"
spec:
definition:
title: "Simple Filter Action"
description: "Filter based on simple expression"
required:
- expression
properties:
expression:
title: Simple Expression
description: A simple expression to apply on the exchange to filter out some exchange
type: string
type: object
dependencies:
- "camel:core"
- "camel:kamelet"
template:
from:
uri: kamelet:source
steps:
- filter:
simple: "{{expression}}"
steps:
- stop: {}
25 changes: 25 additions & 0 deletions templates/bindings/camel-k/simple-filter-action-binding.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
apiVersion: camel.apache.org/v1
kind: Pipe
metadata:
name: simple-filter-action-pipe
spec:
source:
ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: timer-source
properties:
message: "Hello"
steps:
- ref:
kind: Kamelet
apiVersion: camel.apache.org/v1
name: simple-filter-action
properties:
expression: "The Simple Expression"
sink:
ref:
kind: KafkaTopic
apiVersion: kafka.strimzi.io/v1beta1
name: my-topic

13 changes: 13 additions & 0 deletions templates/bindings/core/simple-filter-action-binding.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
- route:
from:
uri: "kamelet:timer-source"
parameters:
period: 1000
message: "{ \"foo\": \"John\"}"
steps:
- to:
uri: "kamelet:simple-filter-action"
parameters:
expression: "The Simple Expression"
- to:
uri: "log:info"

0 comments on commit 06d6447

Please sign in to comment.