Skip to content

Commit

Permalink
fix(#1980): Implement data type support in KameletBinding
Browse files Browse the repository at this point in the history
- Support data type reference in KameletBinding that automatically adds data type action Kamelet to the resulting integration template flow
- Allow the user to specify the data types for output/input on Kamelet references in a binding
- Camel K automatically adds respective steps (using the data-type-action Kamelet) in order to apply the data type conversion logic
  • Loading branch information
christophd committed Mar 9, 2023
1 parent 97fa74b commit f169354
Show file tree
Hide file tree
Showing 19 changed files with 583 additions and 218 deletions.
6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,10 @@ build/maven
build/m2
/api_*

# YAKS test output
.yaks-jbang/
_output/

# envrc
.envrc

Expand Down Expand Up @@ -170,4 +174,4 @@ config/**/*.gen.json
*-installer*

# Fabric8 CRDs
java/target
java/target
70 changes: 70 additions & 0 deletions e2e/yaks/common/kamelet-data-types/data-type-action.kamelet.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
# ---------------------------------------------------------------------------
# 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: data-type-action
annotations:
camel.apache.org/kamelet.support.level: "Stable"
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"
camel.apache.org/kamelet.namespace: "Transformation"
labels:
camel.apache.org/kamelet.type: "action"
spec:
definition:
title: "Data Type Action"
description: |-
Applies a given data type with respective data transformation.
required:
- format
type: object
properties:
scheme:
title: Component Scheme
description: The data type component scheme enables users to apply Camel component specific data type conversions.
type: string
default: "camel"
example: "camel"
format:
title: Data Type Format
description: Defines the data type that will be applied by this action. The Kamelet catalog supports different data types and performs automatic message conversion according to the given type.
type: string
dependencies:
- "mvn:org.apache.camel.kamelets:camel-kamelets-utils:3.20.1"
- "camel:kamelet"
- "camel:core"
template:
beans:
- name: dataTypeRegistry
type: "#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
- name: dataTypeProcessor
type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
property:
- key: scheme
value: '{{scheme}}'
- key: format
value: '{{format}}'
- key: registry
value: '#bean:{{dataTypeRegistry}}'
from:
uri: "kamelet:source"
steps:
- process:
ref: "{{dataTypeProcessor}}"
10 changes: 6 additions & 4 deletions e2e/yaks/common/kamelet-data-types/event-binding.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,9 @@ spec:
kind: Kamelet
apiVersion: camel.apache.org/v1alpha1
name: event-source
properties:
outputFormat: ${outputFormat}
dataTypes:
out:
format: binary
steps:
- ref:
kind: Kamelet
Expand All @@ -37,5 +38,6 @@ spec:
kind: Kamelet
apiVersion: camel.apache.org/v1alpha1
name: event-sink
properties:
inputFormat: ${inputFormat}
dataTypes:
in:
format: string
33 changes: 8 additions & 25 deletions e2e/yaks/common/kamelet-data-types/event-sink.kamelet.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -25,37 +25,20 @@ spec:
definition:
title: "Event Sink"
description: "Handles incoming event with data type auto conversion"
required:
- inputFormat
properties:
inputFormat:
title: Input Format
description: The data type to convert incoming events to
type: string
dataTypes:
in:
default: string
types:
string:
mediaType: plain/text
binary:
mediaType: application/octet-stream
dependencies:
- github:apache.camel-kamelets:camel-kamelets-utils:3.x-SNAPSHOT
- "camel:core"
- "camel:kamelet"
template:
beans:
- name: dataTypeRegistry
type: "#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
property:
- key: classpathScan
value: false
- name: inputTypeProcessor
type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
property:
- key: scheme
value: 'camel'
- key: format
value: '{{inputFormat}}'
- key: registry
value: '#bean:{{dataTypeRegistry}}'
from:
uri: "kamelet:source"
steps:
- process:
ref: "{{inputTypeProcessor}}"
- to:
uri: "log:info"
33 changes: 8 additions & 25 deletions e2e/yaks/common/kamelet-data-types/event-source.kamelet.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -25,38 +25,21 @@ spec:
definition:
title: "Event Source"
description: "Produces events in given data type"
required:
- outputFormat
properties:
outputFormat:
title: Output Format
description: The data type of produced events
type: string
dataTypes:
out:
default: string
types:
string:
mediaType: plain/text
binary:
mediaType: application/octet-stream
dependencies:
- github:apache.camel-kamelets:camel-kamelets-utils:3.x-SNAPSHOT
- "camel:core"
- "camel:kamelet"
template:
beans:
- name: dataTypeRegistry
type: "#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
property:
- key: classpathScan
value: false
- name: outputTypeProcessor
type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
property:
- key: scheme
value: 'camel'
- key: format
value: '{{outputFormat}}'
- key: registry
value: '#bean:{{dataTypeRegistry}}'
from:
uri: timer:tick
steps:
- set-body:
constant: "Hello from Camel K!"
- process:
ref: "{{outputTypeProcessor}}"
- to: "kamelet:sink"
9 changes: 6 additions & 3 deletions e2e/yaks/common/kamelet-data-types/kamelet-data-types.feature
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,13 @@ Feature: Kamelets with data types
| delayBetweenAttempts | 4000 |

Scenario: Kamelet event data type conversion
Given variables
| outputFormat | binary |
| inputFormat | string |
Given load KameletBinding event-binding.yaml
Given Camel K integration event-binding is running
Then Camel K integration event-binding should print BodyType: byte[], Body: Hello from Camel K!
Then Camel K integration event-binding should print BodyType: String, Body: Hello from Camel K!

Scenario: Kamelet timer-to-log conversion
Given load KameletBinding timer-to-log.yaml
Given Camel K integration timer-to-log is running
Then Camel K integration timer-to-log should print BodyType: byte[], Body: Hello from Camel K!
Then Camel K integration timer-to-log should print BodyType: String, Body: Hello from Camel K!
63 changes: 0 additions & 63 deletions e2e/yaks/common/kamelet-data-types/log-action.kamelet.yaml

This file was deleted.

44 changes: 44 additions & 0 deletions e2e/yaks/common/kamelet-data-types/timer-to-log.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
# ---------------------------------------------------------------------------
# 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: KameletBinding
metadata:
name: timer-to-log
spec:
source:
ref:
kind: Kamelet
apiVersion: camel.apache.org/v1alpha1
name: timer-source
properties:
message: "Hello from Camel K!"
steps:
- ref:
kind: Kamelet
apiVersion: camel.apache.org/v1alpha1
name: log-action
dataTypes:
in:
format: binary
out:
format: string
sink:
ref:
kind: Kamelet
apiVersion: camel.apache.org/v1alpha1
name: log-sink
3 changes: 2 additions & 1 deletion e2e/yaks/common/kamelet-data-types/yaks-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -30,12 +30,13 @@ config:
level: INFO
resources:
- event-binding.yaml
- timer-to-log.yaml
pre:
- name: installation
run: |
kubectl apply -f event-source.kamelet.yaml -n $YAKS_NAMESPACE
kubectl apply -f event-sink.kamelet.yaml -n $YAKS_NAMESPACE
kubectl apply -f log-action.kamelet.yaml -n $YAKS_NAMESPACE
kubectl apply -f data-type-action.kamelet.yaml -n $YAKS_NAMESPACE
post:
- name: print dump
if: env:CI=true && failure()
Expand Down
14 changes: 7 additions & 7 deletions pkg/client/camel/clientset/versioned/fake/register.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 7 additions & 7 deletions pkg/client/camel/clientset/versioned/scheme/register.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit f169354

Please sign in to comment.