diff --git a/docs/modules/ROOT/assets/images/kamelets/value-to-key-action.svg b/docs/modules/ROOT/assets/images/kamelets/value-to-key-action.svg new file mode 100644 index 000000000..fa06352da --- /dev/null +++ b/docs/modules/ROOT/assets/images/kamelets/value-to-key-action.svg @@ -0,0 +1,59 @@ + + + + + + image/svg+xml + + + + + + + + + + diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index 780c3851f..a2a1ee4bb 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -68,5 +68,6 @@ * xref:ROOT:twitter-directmessage-source.adoc[image:kamelets/twitter-directmessage-source.svg[] Twitter Direct Message Source] * xref:ROOT:twitter-search-source.adoc[image:kamelets/twitter-search-source.svg[] Twitter Search Source] * xref:ROOT:twitter-timeline-source.adoc[image:kamelets/twitter-timeline-source.svg[] Twitter Timeline Source] +* xref:ROOT:value-to-key-action.adoc[image:kamelets/value-to-key-action.svg[] Value to Key action] * xref:ROOT:webhook-source.adoc[image:kamelets/webhook-source.svg[] Webhook Source] // THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/docs/modules/ROOT/pages/value-to-key-action.adoc b/docs/modules/ROOT/pages/value-to-key-action.adoc new file mode 100644 index 000000000..1265bb699 --- /dev/null +++ b/docs/modules/ROOT/pages/value-to-key-action.adoc @@ -0,0 +1,67 @@ +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT += image:kamelets/value-to-key-action.svg[] Value to Key action + +*Provided by: "Apache Software Foundation"* + +Replace the Kafka record key with a new key formed from a subset of fields in the body + +== Configuration Options + +The following table summarizes the configuration options available for the `value-to-key-action` Kamelet: +[width="100%",cols="2,^2,3,^2,^2,^3",options="header"] +|=== +| Property| Name| Description| Type| Default| Example +| *fields {empty}* *| Fields| Comma separated list of fields to be used to form the new key| string| | +|=== + +NOTE: Fields marked with ({empty}*) are mandatory. + +== Usage + +This section summarizes how the `value-to-key-action` can be used in various contexts. + +=== Knative Action + +The `value-to-key-action` Kamelet can be used as intermediate step in a binding. + +.value-to-key-action-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: value-to-key-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: value-to-key-action + properties: + fields: "The Fields" + sink: + ref: + kind: InMemoryChannel + apiVersion: messaging.knative.dev/v1 + name: mychannel + +---- + +Make sure you have xref:latest@camel-k::installation/installation.adoc[Camel K installed] into the Kubernetes cluster you're connected to. + +Save the `value-to-key-action-binding.yaml` file into your hard drive, then configure it according to your needs. + +You can run the action using the following command: + +[source,shell] +---- +kubectl apply -f value-to-key-action-binding.yaml +---- +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/value-to-key-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/value-to-key-action.kamelet.yaml new file mode 100644 index 000000000..bf3cf83c3 --- /dev/null +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/value-to-key-action.kamelet.yaml @@ -0,0 +1,42 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: value-to-key-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" +spec: + definition: + title: "Value to Key action" + description: "Replace the Kafka record key with a new key formed from a subset of fields in the body" + required: + - fields + properties: + fields: + title: Fields + description: Comma separated list of fields to be used to form the new key + type: string + type: object + dependencies: + - github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT + flow: + from: + uri: kamelet:source + steps: + - choice: + when: + - simple: "${header[Content-Type]} == 'application/json'" + steps: + - unmarshal: + json: {} + - set-property: + name: "fields" + constant: "{{fields}}" + - bean: "org.apache.camel.kamelets.utils.transform.kafka.ValueToKey" + - marshal: + json: {} + - set-header: + name: "Content-Type" + constant: "application/json" diff --git a/value-to-key-action.kamelet.yaml b/value-to-key-action.kamelet.yaml new file mode 100644 index 000000000..bf3cf83c3 --- /dev/null +++ b/value-to-key-action.kamelet.yaml @@ -0,0 +1,42 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: value-to-key-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" +spec: + definition: + title: "Value to Key action" + description: "Replace the Kafka record key with a new key formed from a subset of fields in the body" + required: + - fields + properties: + fields: + title: Fields + description: Comma separated list of fields to be used to form the new key + type: string + type: object + dependencies: + - github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT + flow: + from: + uri: kamelet:source + steps: + - choice: + when: + - simple: "${header[Content-Type]} == 'application/json'" + steps: + - unmarshal: + json: {} + - set-property: + name: "fields" + constant: "{{fields}}" + - bean: "org.apache.camel.kamelets.utils.transform.kafka.ValueToKey" + - marshal: + json: {} + - set-header: + name: "Content-Type" + constant: "application/json"