From b7500fb57438cd3142dae762fb7a084a2559cc7d Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 12:15:40 +0200 Subject: [PATCH 1/8] stage lib for avro schema resolution --- avro-serialize-action.kamelet.yaml | 49 +++++++++++++++++++ library/camel-kamelets-utils/pom.xml | 5 ++ .../InflightAvroSchemaResolver.java | 21 ++++++++ pom.xml | 2 +- 4 files changed, 76 insertions(+), 1 deletion(-) create mode 100644 avro-serialize-action.kamelet.yaml create mode 100644 library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml new file mode 100644 index 000000000..4a7778757 --- /dev/null +++ b/avro-serialize-action.kamelet.yaml @@ -0,0 +1,49 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: avro-serialize-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Actions" +spec: + definition: + title: "Avro Serialize Action" + description: "Serialize payload to Avro" + type: object + properties: + schema: + title: Schema + description: The Avro schema to use during serialization (in JSON format) + type: string + validate: + title: Validate + description: Indicates if the content must be validated against the schema + type: boolean + default: true + dependencies: +# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "camel:kamelet" + - "camel:core" + - "camel:jackson-avro" + flow: + from: + uri: kamelet:source + steps: + - set-property: + name: schema + constant: "{{schema}}" + - set-property: + name: validate + constant: "{{validate}}" + - marshal: + avro: + library: Jackson + unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode + schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - set-header: + name: "Content-Type" + constant: "application/avro" diff --git a/library/camel-kamelets-utils/pom.xml b/library/camel-kamelets-utils/pom.xml index 14b7fd820..0d2041eb2 100644 --- a/library/camel-kamelets-utils/pom.xml +++ b/library/camel-kamelets-utils/pom.xml @@ -56,6 +56,11 @@ camel-jackson + + org.apache.camel + camel-jackson-avro + + org.apache.camel camel-kafka diff --git a/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java b/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java new file mode 100644 index 000000000..1faf12195 --- /dev/null +++ b/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java @@ -0,0 +1,21 @@ +package org.apache.camel.kamelets.utils.serialization; + +import com.fasterxml.jackson.core.FormatSchema; +import com.fasterxml.jackson.dataformat.avro.AvroSchema; + +import org.apache.avro.Schema; +import org.apache.camel.Exchange; +import org.apache.camel.component.jackson.SchemaResolver; + +public class InflightAvroSchemaResolver implements SchemaResolver { + + @Override + public FormatSchema resolve(Exchange exchange) { + String schemaJson = (String) exchange.getProperty("schema"); + Boolean validate = Boolean.valueOf((String) exchange.getProperty("validate")); + Schema raw = new Schema.Parser().setValidate(validate).parse(schemaJson); + AvroSchema schema = new AvroSchema(raw); + return schema; + } + +} diff --git a/pom.xml b/pom.xml index 0d0b1a9bb..ecbc4ef5e 100644 --- a/pom.xml +++ b/pom.xml @@ -49,7 +49,7 @@ 3.1.0 1.7 - 3.9.0 + 3.10.0 2.13.3 2.11.4 5.3.1 From 717128990f4e7fcfbed4b4d9dce8649022f05baa Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 15:44:50 +0200 Subject: [PATCH 2/8] Add Kamelets for JSON and Avro serialization --- avro-deserialize-action.kamelet copy.yaml | 43 +++++++++++++++++++ avro-serialize-action.kamelet.yaml | 3 +- .../avro-deserialize-action.kamelet.yaml | 31 +++++++++++++ 3 files changed, 76 insertions(+), 1 deletion(-) create mode 100644 avro-deserialize-action.kamelet copy.yaml create mode 100644 library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml diff --git a/avro-deserialize-action.kamelet copy.yaml b/avro-deserialize-action.kamelet copy.yaml new file mode 100644 index 000000000..8c3ed9e0f --- /dev/null +++ b/avro-deserialize-action.kamelet copy.yaml @@ -0,0 +1,43 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: avro-deserialize-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Actions" +spec: + definition: + title: "Avro Deserialize Action" + description: "Deserialize payload to Avro" + type: object + properties: + schema: + title: Schema + description: The Avro schema to use during serialization (as single-line, using JSON format) + type: string + example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' + validate: + title: Validate + description: Indicates if the content must be validated against the schema + type: boolean + default: true + dependencies: +# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "camel:kamelet" + - "camel:core" + - "camel:jackson-avro" + flow: + from: + uri: kamelet:source + steps: + - unmarshal: + avro: + library: Jackson + unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode + schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - remove-header: + header-name: "Content-Type" diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml index 4a7778757..0130540fd 100644 --- a/avro-serialize-action.kamelet.yaml +++ b/avro-serialize-action.kamelet.yaml @@ -16,8 +16,9 @@ spec: properties: schema: title: Schema - description: The Avro schema to use during serialization (in JSON format) + description: The Avro schema to use during serialization (as single-line, using JSON format) type: string + example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' validate: title: Validate description: Indicates if the content must be validated against the schema diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml new file mode 100644 index 000000000..ce01c669c --- /dev/null +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml @@ -0,0 +1,31 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: avro-deserialize-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Actions" +spec: + definition: + title: "Json Deserialize Action" + description: "Deserialize payload to JSON" + type: object + dependencies: +# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "camel:kamelet" + - "camel:core" + - "camel:jackson" + flow: + from: + uri: kamelet:source + steps: + - unmarshal: + json: + library: Jackson + unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode + - remove-header: + header-name: "Content-Type" From fc0a69bd2b84872951dab2ee853263d80cc1764a Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 15:46:47 +0200 Subject: [PATCH 3/8] Use fixed references in kamelets --- avro-deserialize-action.kamelet copy.yaml | 3 +-- avro-serialize-action.kamelet.yaml | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/avro-deserialize-action.kamelet copy.yaml b/avro-deserialize-action.kamelet copy.yaml index 8c3ed9e0f..ad90efc6d 100644 --- a/avro-deserialize-action.kamelet copy.yaml +++ b/avro-deserialize-action.kamelet copy.yaml @@ -25,8 +25,7 @@ spec: type: boolean default: true dependencies: -# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" - "camel:core" - "camel:jackson-avro" diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml index 0130540fd..413847560 100644 --- a/avro-serialize-action.kamelet.yaml +++ b/avro-serialize-action.kamelet.yaml @@ -25,8 +25,7 @@ spec: type: boolean default: true dependencies: -# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" - "camel:core" - "camel:jackson-avro" From fc985bb6f217f42c8f416a7120e9a531edfc2130 Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 15:48:00 +0200 Subject: [PATCH 4/8] Regen docs --- ...ml => avro-deserialize-action.kamelet.yaml | 0 .../avro-deserialize-action.kamelet.yaml | 23 ++++++--- .../avro-serialize-action.kamelet.yaml | 49 +++++++++++++++++++ 3 files changed, 66 insertions(+), 6 deletions(-) rename avro-deserialize-action.kamelet copy.yaml => avro-deserialize-action.kamelet.yaml (100%) create mode 100644 library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml diff --git a/avro-deserialize-action.kamelet copy.yaml b/avro-deserialize-action.kamelet.yaml similarity index 100% rename from avro-deserialize-action.kamelet copy.yaml rename to avro-deserialize-action.kamelet.yaml diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml index ce01c669c..ad90efc6d 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml @@ -10,22 +10,33 @@ metadata: camel.apache.org/kamelet.group: "Actions" spec: definition: - title: "Json Deserialize Action" - description: "Deserialize payload to JSON" + title: "Avro Deserialize Action" + description: "Deserialize payload to Avro" type: object + properties: + schema: + title: Schema + description: The Avro schema to use during serialization (as single-line, using JSON format) + type: string + example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' + validate: + title: Validate + description: Indicates if the content must be validated against the schema + type: boolean + default: true dependencies: -# - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - - "github:nicolaferraro.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" - "camel:core" - - "camel:jackson" + - "camel:jackson-avro" flow: from: uri: kamelet:source steps: - unmarshal: - json: + avro: library: Jackson unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode + schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" - remove-header: header-name: "Content-Type" diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml new file mode 100644 index 000000000..413847560 --- /dev/null +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml @@ -0,0 +1,49 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: avro-serialize-action + labels: + camel.apache.org/kamelet.type: "action" + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + camel.apache.org/kamelet.group: "Actions" +spec: + definition: + title: "Avro Serialize Action" + description: "Serialize payload to Avro" + type: object + properties: + schema: + title: Schema + description: The Avro schema to use during serialization (as single-line, using JSON format) + type: string + example: '{"type": "record", "namespace": "com.example", "name": "FullName", "fields": [{"name": "first", "type": "string"},{"name": "last", "type": "string"}]}' + validate: + title: Validate + description: Indicates if the content must be validated against the schema + type: boolean + default: true + dependencies: + - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" + - "camel:kamelet" + - "camel:core" + - "camel:jackson-avro" + flow: + from: + uri: kamelet:source + steps: + - set-property: + name: schema + constant: "{{schema}}" + - set-property: + name: validate + constant: "{{validate}}" + - marshal: + avro: + library: Jackson + unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode + schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - set-header: + name: "Content-Type" + constant: "application/avro" From a8dbcab3fa0adc98197126783c28b79e68d9b59c Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 15:51:16 +0200 Subject: [PATCH 5/8] Set required fields and generate docs --- avro-deserialize-action.kamelet.yaml | 2 + avro-serialize-action.kamelet.yaml | 2 + .../kamelets/avro-deserialize-action.svg | 59 ++++++++++++++++ .../images/kamelets/avro-serialize-action.svg | 59 ++++++++++++++++ docs/modules/ROOT/nav.adoc | 2 + .../ROOT/pages/avro-deserialize-action.adoc | 68 +++++++++++++++++++ .../ROOT/pages/avro-serialize-action.adoc | 68 +++++++++++++++++++ .../avro-deserialize-action.kamelet.yaml | 2 + .../avro-serialize-action.kamelet.yaml | 2 + 9 files changed, 264 insertions(+) create mode 100644 docs/modules/ROOT/assets/images/kamelets/avro-deserialize-action.svg create mode 100644 docs/modules/ROOT/assets/images/kamelets/avro-serialize-action.svg create mode 100644 docs/modules/ROOT/pages/avro-deserialize-action.adoc create mode 100644 docs/modules/ROOT/pages/avro-serialize-action.adoc diff --git a/avro-deserialize-action.kamelet.yaml b/avro-deserialize-action.kamelet.yaml index ad90efc6d..835cdcc66 100644 --- a/avro-deserialize-action.kamelet.yaml +++ b/avro-deserialize-action.kamelet.yaml @@ -13,6 +13,8 @@ spec: title: "Avro Deserialize Action" description: "Deserialize payload to Avro" type: object + required: + - schema properties: schema: title: Schema diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml index 413847560..31207b10d 100644 --- a/avro-serialize-action.kamelet.yaml +++ b/avro-serialize-action.kamelet.yaml @@ -13,6 +13,8 @@ spec: title: "Avro Serialize Action" description: "Serialize payload to Avro" type: object + required: + - schema properties: schema: title: Schema diff --git a/docs/modules/ROOT/assets/images/kamelets/avro-deserialize-action.svg b/docs/modules/ROOT/assets/images/kamelets/avro-deserialize-action.svg new file mode 100644 index 000000000..fa06352da --- /dev/null +++ b/docs/modules/ROOT/assets/images/kamelets/avro-deserialize-action.svg @@ -0,0 +1,59 @@ + + + + + + image/svg+xml + + + + + + + + + + diff --git a/docs/modules/ROOT/assets/images/kamelets/avro-serialize-action.svg b/docs/modules/ROOT/assets/images/kamelets/avro-serialize-action.svg new file mode 100644 index 000000000..fa06352da --- /dev/null +++ b/docs/modules/ROOT/assets/images/kamelets/avro-serialize-action.svg @@ -0,0 +1,59 @@ + + + + + + image/svg+xml + + + + + + + + + + diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index ee24c904f..254289002 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -1,4 +1,6 @@ // THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT +* xref:ROOT:avro-deserialize-action.adoc[image:kamelets/avro-deserialize-action.svg[] Avro Deserialize Action] +* xref:ROOT:avro-serialize-action.adoc[image:kamelets/avro-serialize-action.svg[] Avro Serialize Action] * xref:ROOT:aws-ddb-streams-source.adoc[image:kamelets/aws-ddb-streams-source.svg[] AWS DynamoDB Streams Source] * xref:ROOT:aws-kinesis-firehose-sink.adoc[image:kamelets/aws-kinesis-firehose-sink.svg[] AWS Kinesis Firehose Sink] * xref:ROOT:aws-kinesis-sink.adoc[image:kamelets/aws-kinesis-sink.svg[] AWS Kinesis Sink] diff --git a/docs/modules/ROOT/pages/avro-deserialize-action.adoc b/docs/modules/ROOT/pages/avro-deserialize-action.adoc new file mode 100644 index 000000000..da7ca4563 --- /dev/null +++ b/docs/modules/ROOT/pages/avro-deserialize-action.adoc @@ -0,0 +1,68 @@ +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT += image:kamelets/avro-deserialize-action.svg[] Avro Deserialize Action + +*Provided by: "Apache Software Foundation"* + +Deserialize payload to Avro + +== Configuration Options + +The following table summarizes the configuration options available for the `avro-deserialize-action` Kamelet: +[width="100%",cols="2,^2,3,^2,^2,^3",options="header"] +|=== +| Property| Name| Description| Type| Default| Example +| *schema {empty}* *| Schema| The Avro schema to use during serialization (as single-line, using JSON format)| string| | `"{\"type\": \"record\", \"namespace\": \"com.example\", \"name\": \"FullName\", \"fields\": [{\"name\": \"first\", \"type\": \"string\"},{\"name\": \"last\", \"type\": \"string\"}]}"` +| validate| Validate| Indicates if the content must be validated against the schema| boolean| `true`| +|=== + +NOTE: Fields marked with ({empty}*) are mandatory. + +== Usage + +This section summarizes how the `avro-deserialize-action` can be used in various contexts. + +=== Knative Action + +The `avro-deserialize-action` Kamelet can be used as intermediate step in a binding. + +.avro-deserialize-action-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: avro-deserialize-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: avro-deserialize-action + properties: + schema: "{\"type\": \"record\", \"namespace\": \"com.example\", \"name\": \"FullName\", \"fields\": [{\"name\": \"first\", \"type\": \"string\"},{\"name\": \"last\", \"type\": \"string\"}]}" + 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 `avro-deserialize-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 avro-deserialize-action-binding.yaml +---- +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/docs/modules/ROOT/pages/avro-serialize-action.adoc b/docs/modules/ROOT/pages/avro-serialize-action.adoc new file mode 100644 index 000000000..bf11d5714 --- /dev/null +++ b/docs/modules/ROOT/pages/avro-serialize-action.adoc @@ -0,0 +1,68 @@ +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT += image:kamelets/avro-serialize-action.svg[] Avro Serialize Action + +*Provided by: "Apache Software Foundation"* + +Serialize payload to Avro + +== Configuration Options + +The following table summarizes the configuration options available for the `avro-serialize-action` Kamelet: +[width="100%",cols="2,^2,3,^2,^2,^3",options="header"] +|=== +| Property| Name| Description| Type| Default| Example +| *schema {empty}* *| Schema| The Avro schema to use during serialization (as single-line, using JSON format)| string| | `"{\"type\": \"record\", \"namespace\": \"com.example\", \"name\": \"FullName\", \"fields\": [{\"name\": \"first\", \"type\": \"string\"},{\"name\": \"last\", \"type\": \"string\"}]}"` +| validate| Validate| Indicates if the content must be validated against the schema| boolean| `true`| +|=== + +NOTE: Fields marked with ({empty}*) are mandatory. + +== Usage + +This section summarizes how the `avro-serialize-action` can be used in various contexts. + +=== Knative Action + +The `avro-serialize-action` Kamelet can be used as intermediate step in a binding. + +.avro-serialize-action-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: avro-serialize-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: avro-serialize-action + properties: + schema: "{\"type\": \"record\", \"namespace\": \"com.example\", \"name\": \"FullName\", \"fields\": [{\"name\": \"first\", \"type\": \"string\"},{\"name\": \"last\", \"type\": \"string\"}]}" + 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 `avro-serialize-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 avro-serialize-action-binding.yaml +---- +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml index ad90efc6d..835cdcc66 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml @@ -13,6 +13,8 @@ spec: title: "Avro Deserialize Action" description: "Deserialize payload to Avro" type: object + required: + - schema properties: schema: title: Schema diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml index 413847560..31207b10d 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml @@ -13,6 +13,8 @@ spec: title: "Avro Serialize Action" description: "Serialize payload to Avro" type: object + required: + - schema properties: schema: title: Schema From 013fb3c47cdbedd8c8e43ae48a065913ee90817d Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Fri, 4 Jun 2021 16:11:59 +0200 Subject: [PATCH 6/8] Add missing annotations and regen --- avro-deserialize-action.kamelet.yaml | 8 ++++++-- avro-serialize-action.kamelet.yaml | 8 ++++++-- docs/modules/ROOT/pages/avro-deserialize-action.adoc | 2 ++ docs/modules/ROOT/pages/avro-serialize-action.adoc | 2 ++ .../kamelets/avro-deserialize-action.kamelet.yaml | 8 ++++++-- .../resources/kamelets/avro-serialize-action.kamelet.yaml | 8 ++++++-- 6 files changed, 28 insertions(+), 8 deletions(-) diff --git a/avro-deserialize-action.kamelet.yaml b/avro-deserialize-action.kamelet.yaml index 835cdcc66..8a7c12606 100644 --- a/avro-deserialize-action.kamelet.yaml +++ b/avro-deserialize-action.kamelet.yaml @@ -2,12 +2,14 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: name: avro-deserialize-action - labels: - camel.apache.org/kamelet.type: "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: "Actions" + labels: + camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Deserialize Action" @@ -26,6 +28,8 @@ spec: description: Indicates if the content must be validated against the schema type: boolean default: true + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' dependencies: - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml index 31207b10d..eaef74422 100644 --- a/avro-serialize-action.kamelet.yaml +++ b/avro-serialize-action.kamelet.yaml @@ -2,12 +2,14 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: name: avro-serialize-action - labels: - camel.apache.org/kamelet.type: "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: "Actions" + labels: + camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Serialize Action" @@ -26,6 +28,8 @@ spec: description: Indicates if the content must be validated against the schema type: boolean default: true + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' dependencies: - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" diff --git a/docs/modules/ROOT/pages/avro-deserialize-action.adoc b/docs/modules/ROOT/pages/avro-deserialize-action.adoc index da7ca4563..077df053b 100644 --- a/docs/modules/ROOT/pages/avro-deserialize-action.adoc +++ b/docs/modules/ROOT/pages/avro-deserialize-action.adoc @@ -3,6 +3,8 @@ *Provided by: "Apache Software Foundation"* +*Support Level for this Kamelet is: "Preview"* + Deserialize payload to Avro == Configuration Options diff --git a/docs/modules/ROOT/pages/avro-serialize-action.adoc b/docs/modules/ROOT/pages/avro-serialize-action.adoc index bf11d5714..9e0bbcc6f 100644 --- a/docs/modules/ROOT/pages/avro-serialize-action.adoc +++ b/docs/modules/ROOT/pages/avro-serialize-action.adoc @@ -3,6 +3,8 @@ *Provided by: "Apache Software Foundation"* +*Support Level for this Kamelet is: "Preview"* + Serialize payload to Avro == Configuration Options diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml index 835cdcc66..8a7c12606 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml @@ -2,12 +2,14 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: name: avro-deserialize-action - labels: - camel.apache.org/kamelet.type: "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: "Actions" + labels: + camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Deserialize Action" @@ -26,6 +28,8 @@ spec: description: Indicates if the content must be validated against the schema type: boolean default: true + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' dependencies: - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml index 31207b10d..eaef74422 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml @@ -2,12 +2,14 @@ apiVersion: camel.apache.org/v1alpha1 kind: Kamelet metadata: name: avro-serialize-action - labels: - camel.apache.org/kamelet.type: "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: "Actions" + labels: + camel.apache.org/kamelet.type: "action" spec: definition: title: "Avro Serialize Action" @@ -26,6 +28,8 @@ spec: description: Indicates if the content must be validated against the schema type: boolean default: true + x-descriptors: + - 'urn:alm:descriptor:com.tectonic.ui:checkbox' dependencies: - "github:apache.camel-kamelets:camel-kamelets-utils:main-SNAPSHOT" - "camel:kamelet" From e59722d103bf5c479ffdacd9859aea313ba5532c Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Mon, 7 Jun 2021 10:23:23 +0200 Subject: [PATCH 7/8] Remove property leak --- avro-deserialize-action.kamelet.yaml | 12 +++++++++++- avro-serialize-action.kamelet.yaml | 6 +++++- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/avro-deserialize-action.kamelet.yaml b/avro-deserialize-action.kamelet.yaml index 8a7c12606..e618ac886 100644 --- a/avro-deserialize-action.kamelet.yaml +++ b/avro-deserialize-action.kamelet.yaml @@ -39,10 +39,20 @@ spec: from: uri: kamelet:source steps: + - set-property: + name: schema + constant: "{{schema}}" + - set-property: + name: validate + constant: "{{validate}}" - unmarshal: - avro: + avro: library: Jackson unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - remove-property: + property-name: schema + - remove-property: + property-name: validate - remove-header: header-name: "Content-Type" diff --git a/avro-serialize-action.kamelet.yaml b/avro-serialize-action.kamelet.yaml index eaef74422..3e8fa60cf 100644 --- a/avro-serialize-action.kamelet.yaml +++ b/avro-serialize-action.kamelet.yaml @@ -46,10 +46,14 @@ spec: name: validate constant: "{{validate}}" - marshal: - avro: + avro: library: Jackson unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - remove-property: + property-name: schema + - remove-property: + property-name: validate - set-header: name: "Content-Type" constant: "application/avro" From abf7554c69ad4b7d508e7edb1bb9e74b82641b86 Mon Sep 17 00:00:00 2001 From: nicolaferraro Date: Mon, 7 Jun 2021 10:27:48 +0200 Subject: [PATCH 8/8] Add license header and regen --- .../avro-deserialize-action.kamelet.yaml | 12 +++++++++++- .../kamelets/avro-serialize-action.kamelet.yaml | 6 +++++- .../InflightAvroSchemaResolver.java | 16 ++++++++++++++++ 3 files changed, 32 insertions(+), 2 deletions(-) diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml index 8a7c12606..e618ac886 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-deserialize-action.kamelet.yaml @@ -39,10 +39,20 @@ spec: from: uri: kamelet:source steps: + - set-property: + name: schema + constant: "{{schema}}" + - set-property: + name: validate + constant: "{{validate}}" - unmarshal: - avro: + avro: library: Jackson unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - remove-property: + property-name: schema + - remove-property: + property-name: validate - remove-header: header-name: "Content-Type" diff --git a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml index eaef74422..3e8fa60cf 100644 --- a/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml +++ b/library/camel-kamelets-catalog/src/main/resources/kamelets/avro-serialize-action.kamelet.yaml @@ -46,10 +46,14 @@ spec: name: validate constant: "{{validate}}" - marshal: - avro: + avro: library: Jackson unmarshalTypeName: com.fasterxml.jackson.databind.JsonNode schemaResolver: "#class:org.apache.camel.kamelets.utils.serialization.InflightAvroSchemaResolver" + - remove-property: + property-name: schema + - remove-property: + property-name: validate - set-header: name: "Content-Type" constant: "application/avro" diff --git a/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java b/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java index 1faf12195..a75df4d12 100644 --- a/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java +++ b/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/serialization/InflightAvroSchemaResolver.java @@ -1,3 +1,19 @@ +/* + * 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. + */ package org.apache.camel.kamelets.utils.serialization; import com.fasterxml.jackson.core.FormatSchema;