You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Andrea Cosentino (Jira)" <ji...@apache.org> on 2021/06/11 07:50:00 UTC

[jira] [Created] (CAMEL-16712) Kamelet Local Beans: Referencing them as part of the endpoint as parameters doesn't work seem to not work.

Andrea Cosentino created CAMEL-16712:
----------------------------------------

             Summary: Kamelet Local Beans: Referencing them as part of the endpoint as parameters doesn't work seem to not work.
                 Key: CAMEL-16712
                 URL: https://issues.apache.org/jira/browse/CAMEL-16712
             Project: Camel
          Issue Type: Bug
    Affects Versions: 3.10.0
            Reporter: Andrea Cosentino


Suppose you have a Kamelet like this one:
{code:yaml}
apiVersion: camel.apache.org/v1alpha1
kind: Kamelet
metadata:   name: sql-sink
  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: "SQL"
  labels:     camel.apache.org/kamelet.type: "sink"
spec:   definition:     title: "SQL Sink"
    description: |-
      Send data to a Database.
    required:       - serverName
      - port
      - username
      - password
      - query
    type: object
    properties:       serverName:         title: Server Name
        description: Server Name for the data source
        type: string
        example: localhost
      port:         title: Port
        description: Server Port for the data source
        type: string
        example: 9042
      username:         title: Username
        description: The username to use for accessing a secured Cassandra Cluster
        type: string
      password:         title: Password
        description: The password to use for accessing a secured Cassandra Cluster
        type: string
        format: password
        x-descriptors:         - urn:alm:descriptor:com.tectonic.ui:password
      query:         title: Prepared Statement
        description: The Prepared statement to execute against the Cassandra cluster table
        type: string
  dependencies:   - "camel:jackson"
  - "camel:kamelet"
  - "camel:sql"
  flow:     beans:       - name: dsBean
        type: org.postgresql.ds.PGSimpleDataSource
        property:           - key: username
            value: '{{username}}'
          - key: password
            value: '{{password}}'
          - key: serverName
            value: '{{serverName}}'
    from:       uri: "kamelet:source"
      steps:       - unmarshal:           json: 
            library: Jackson
      - to: 
          uri: "kamelet-reify:sql:{{query}}?dataSource=#dsBean"{code}
 

You'll get an error like:
{code:java}
[1] 2021-06-11 07:44:18,800 ERROR [io.qua.run.Application] (main) Failed to start application (with profile prod): java.lang.IllegalArgumentException: Could not find a suitable setter for property: dataSource as there isn't a setter method with same type: java.lang.String nor type conversion possible: No type converter available to convert from type: java.lang.String to the required type: javax.sql.DataSource with value #dsBean{code}
 

If you switch to
{code:yaml}
      - to: 
          uri: "kamelet-reify:sql:{{query}}"
          parameters:             dataSource: "#{{dsBean}}"{code}
 

The error will be

 
{code:java}
[1] 2021-06-11 07:47:24,195 ERROR [io.qua.run.Application] (main) Failed to start application (with profile prod): java.lang.IllegalArgumentException: Property with key [dsBean] not found in properties from text: kamelet-reify:sql:INSERT INTO accounts (username,city) VALUES (:#username,:#city)?dataSource=#{{dsBean}}{code}
If you switch to
{code:yaml}
      - to: 
          uri: "kamelet-reify:sql:{{query}}"
          parameters:             dataSource: "{{dsBean}}"{code}
The error will be

 
{code:java}
[2] 2021-06-11 07:48:32,313 ERROR [io.qua.run.Application] (main) Failed to start application (with profile prod): java.lang.IllegalArgumentException: Property with key [dsBean] not found in properties from text: kamelet-reify:sql:INSERT INTO accounts (username,city) VALUES (:#username,:#city)?dataSource={{dsBean}}{code}

This happens even without the kamelet-reify component



--
This message was sent by Atlassian Jira
(v8.3.4#803005)