From 165d915aea67dafacce5df1a2f7c27b4e01ec026 Mon Sep 17 00:00:00 2001 From: Igor Petrov <108870003+igpetrov@users.noreply.github.com> Date: Tue, 2 Apr 2024 19:44:51 +0300 Subject: [PATCH] chore(inbound,sqs): move to generator (#2249) * chore(inbound,sqs): move to generator * fix(sqs): fixed correct template overrides Co-authored-by: Oleksii Ivanov <108869886+Oleksiivanov@users.noreply.github.com> * chore(inbound,sqs): corrected generator props --------- Co-authored-by: Oleksii Ivanov <108869886+Oleksiivanov@users.noreply.github.com> --- .../aws-sqs-boundary-connector.json | 499 ++++++++-------- ...ws-sqs-inbound-intermediate-connector.json | 500 ++++++++-------- .../aws-sqs-start-event-connector.json | 431 +++++++------- .../aws-sqs-start-message.json | 557 +++++++++--------- connectors/aws/aws-sqs/pom.xml | 21 + .../connector/inbound/MessageMapper.java | 35 +- .../connector/inbound/SqsExecutable.java | 44 +- .../connector/inbound/SqsQueueConsumer.java | 14 +- .../model/SqsInboundQueueProperties.java | 142 ++--- .../model/message/MessageAttributeValue.java | 93 +-- .../model/message/SqsInboundMessage.java | 128 +--- .../connector/inbound/MessageMapperTest.java | 31 +- .../inbound/SqsQueueConsumerTest.java | 12 +- 13 files changed, 1141 insertions(+), 1366 deletions(-) diff --git a/connectors/aws/aws-sqs/element-templates/aws-sqs-boundary-connector.json b/connectors/aws/aws-sqs/element-templates/aws-sqs-boundary-connector.json index 35b786dae7..920588e153 100644 --- a/connectors/aws/aws-sqs/element-templates/aws-sqs-boundary-connector.json +++ b/connectors/aws/aws-sqs/element-templates/aws-sqs-boundary-connector.json @@ -1,277 +1,274 @@ { - "$schema": "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", - "name": "Amazon SQS Boundary Event Connector", - "id": "io.camunda.connectors.AWSSQS.boundary.v1", - "version": 3, - "description": "Receive message from a queue", - "documentationRef": "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", - "appliesTo": [ - "bpmn:BoundaryEvent" - ], - "elementType": { - "value": "bpmn:BoundaryEvent", - "eventDefinition": "bpmn:MessageEventDefinition" + "$schema" : "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", + "name" : "Amazon SQS Boundary Event Connector", + "id" : "io.camunda.connectors.AWSSQS.boundary.v1", + "description" : "Receive message from a queue", + "documentationRef" : "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", + "version" : 9, + "category" : { + "id" : "connectors", + "name" : "Connectors" }, - "category": { - "id": "connectors", - "name": "Connectors" + "appliesTo" : [ "bpmn:BoundaryEvent" ], + "elementType" : { + "value" : "bpmn:BoundaryEvent", + "eventDefinition" : "bpmn:MessageEventDefinition" }, - "groups": [ - { - "id": "authentication", - "label": "Authentication" + "groups" : [ { + "id" : "authentication", + "label" : "Authentication" + }, { + "id" : "configuration", + "label" : "Configuration" + }, { + "id" : "queueProperties", + "label" : "Queue properties" + }, { + "id" : "messagePollingProperties", + "label" : "Message polling properties" + }, { + "id" : "input", + "label" : "Use next attribute names for activation condition" + }, { + "id" : "activation", + "label" : "Activation" + }, { + "id" : "correlation", + "label" : "Correlation" + }, { + "id" : "output", + "label" : "Output mapping" + } ], + "properties" : [ { + "value" : "io.camunda:aws-sqs-inbound:1", + "binding" : { + "name" : "inbound.type", + "type" : "zeebe:property" }, - { - "id": "queueProperties", - "label": "Queue properties" + "type" : "Hidden" + }, { + "id" : "authentication.type", + "label" : "Authentication", + "description" : "Specify AWS authentication strategy. Learn more at the documentation page", + "value" : "credentials", + "group" : "authentication", + "binding" : { + "name" : "authentication.type", + "type" : "zeebe:property" }, - { - "id": "messagePollingProperties", - "label": "Message polling properties" + "type" : "Dropdown", + "choices" : [ { + "name" : "Default Credentials Chain (Hybrid/Self-Managed only)", + "value" : "defaultCredentialsChain" + }, { + "name" : "Credentials", + "value" : "credentials" + } ] + }, { + "id" : "authentication.accessKey", + "label" : "Access key", + "description" : "Provide an IAM access key tailored to a user, equipped with the necessary permissions", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "id": "input", - "label": "Use next attribute names for activation condition" + "group" : "authentication", + "binding" : { + "name" : "authentication.accessKey", + "type" : "zeebe:property" }, - { - "id": "activation", - "label": "Activation" + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "id": "variable-mapping", - "label": "Variable mapping" - } - ], - "properties": [ - { - "type": "Hidden", - "value": "io.camunda:aws-sqs-inbound:1", - "binding": { - "type": "zeebe:property", - "name": "inbound.type" - } + "type" : "String" + }, { + "id" : "authentication.secretKey", + "label" : "Secret key", + "description" : "Provide a secret key of a user with permissions to invoke specified AWS Lambda function", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "type": "Hidden", - "generatedValue": { - "type": "uuid" - }, - "binding": { - "type": "bpmn:Message#property", - "name": "name" - } + "group" : "authentication", + "binding" : { + "name" : "authentication.secretKey", + "type" : "zeebe:property" }, - { - "id": "authenticationType", - "label": "Authentication", - "description": "Specify AWS authentication strategy. Learn more at the documentation page", - "group": "authentication", - "type": "Dropdown", - "optional": false, - "value": "credentials", - "choices": [ - { - "name": "Credentials", - "value": "credentials" - }, - { - "name": "Default Credentials Chain (Hybrid/Self-Managed only)", - "value": "defaultCredentialsChain" - } - ], - "binding": { - "type": "zeebe:property", - "name": "authentication.type" - }, - "constraints": { - "notEmpty": true - } + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "label": "Access key", - "description": "Provide AWS IAM access key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.accessKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "type" : "String" + }, { + "id" : "configuration.region", + "label" : "Region", + "description" : "Specify the AWS region", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "label": "Secret key", - "description": "Provide AWS IAM secret key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.secretKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "group" : "configuration", + "binding" : { + "name" : "configuration.region", + "type" : "zeebe:property" }, - { - "label": "Queue URL", - "description": "Specify the URL of the SQS queue where you would like to subscribe to", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "queue.url" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^(https?://.+|arn:.+|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be an queue URL or ARN" - } - } + "type" : "String" + }, { + "id" : "configuration.endpoint", + "label" : "Endpoint", + "description" : "Specify endpoint if need to use custom endpoint", + "optional" : true, + "group" : "configuration", + "binding" : { + "name" : "configuration.endpoint", + "type" : "zeebe:property" }, - { - "label": "Region", - "description": "Specify the AWS region of your queue", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "configuration.region" - }, - "constraints": { - "notEmpty": true - } + "type" : "Hidden" + }, { + "id" : "queue.queue.url", + "label" : "Queue URL", + "description" : "Specify the URL of the SQS queue where you would like to subscribe to", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "queueProperties", + "binding" : { + "name" : "queue.url", + "type" : "zeebe:property" }, - { - "label": "Polling wait time", - "description": "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", - "group": "messagePollingProperties", - "type": "String", - "optional":false, - "feel":"optional", - "value": "20", - "binding": { - "type": "zeebe:property", - "name": "queue.pollingWaitTime" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^([0-9]?|1[0-9]|20|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be >= 0 and <= 20 or a FEEL expression" - } + "type" : "String" + }, { + "id" : "queue.queue.pollingWaitTime", + "label" : "Polling wait time", + "description" : "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", + "optional" : false, + "value" : "20", + "constraints" : { + "notEmpty" : true, + "pattern" : { + "value" : "^([0-9]?|1[0-9]|20|secrets\\..+)$" } }, - { - "label": "Attribute names", - "description": "Array of queue attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.attributeNames" - }, - "feel": "required" + "group" : "messagePollingProperties", + "binding" : { + "name" : "queue.pollingWaitTime", + "type" : "zeebe:property" }, - { - "label": "Message attribute names", - "description": "Array of message attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.messageAttributeNames" - }, - "feel": "required" + "type" : "String" + }, { + "id" : "queue.queue.attributeNames", + "label" : "Attribute names", + "description" : "Array of queue attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.attributeNames", + "type" : "zeebe:property" }, - { - "label": "Correlation key (process)", - "type": "String", - "group": "activation", - "feel": "required", - "description": "Sets up the correlation key from process variables", - "binding": { - "type": "bpmn:Message#zeebe:subscription#property", - "name": "correlationKey" - }, - "constraints": { - "notEmpty": true - } + "type" : "String" + }, { + "id" : "queue.queue.messageAttributeNames", + "label" : "Message attribute names", + "description" : "Array of message attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.messageAttributeNames", + "type" : "zeebe:property" }, - { - "label": "Correlation key (payload)", - "type": "String", - "group": "activation", - "feel": "required", - "binding": { - "type": "zeebe:property", - "name": "correlationKeyExpression" - }, - "description": "Extracts the correlation key from the incoming message payload", - "constraints": { - "notEmpty": true - } + "type" : "String" + }, { + "id" : "activationCondition", + "label" : "Activation condition", + "description" : "Condition under which the Connector triggers. Leave empty to catch all events", + "optional" : true, + "feel" : "required", + "group" : "activation", + "binding" : { + "name" : "activationCondition", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "correlationKeyProcess", + "label" : "Correlation key (process)", + "description" : "Sets up the correlation key from process variables", + "constraints" : { + "notEmpty" : true + }, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKey", + "type" : "bpmn:Message#zeebe:subscription#property" + }, + "type" : "String" + }, { + "id" : "correlationKeyPayload", + "label" : "Correlation key (payload)", + "description" : "Extracts the correlation key from the incoming message payload", + "constraints" : { + "notEmpty" : true + }, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKeyExpression", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "messageIdExpression", + "label" : "Message ID expression", + "description" : "Expression to extract unique identifier of a message", + "optional" : true, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "messageIdExpression", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "messageNameUuid", + "generatedValue" : { + "type" : "uuid" }, - { - "label": "Message ID expression", - "feel": "required", - "type": "String", - "optional": true, - "group": "activation", - "binding": { - "type": "zeebe:property", - "name": "messageIdExpression" - }, - "description": "Expression to extract unique identifier of a message" + "group" : "correlation", + "binding" : { + "name" : "name", + "type" : "bpmn:Message#property" }, - { - "label": "Activation condition", - "type": "String", - "group": "activation", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "activationCondition" - }, - "description": "Condition under which the connector triggers. Leave empty to catch all events" + "type" : "Hidden" + }, { + "id" : "resultVariable", + "label" : "Result variable", + "description" : "Name of variable to store the response in", + "group" : "output", + "binding" : { + "name" : "resultVariable", + "type" : "zeebe:property" }, - { - "label": "Result variable", - "type": "String", - "group": "variable-mapping", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultVariable" - }, - "description": "Name of variable to store the result of the connector in" + "type" : "String" + }, { + "id" : "resultExpression", + "label" : "Result expression", + "description" : "Expression to map the response into process variables", + "feel" : "required", + "group" : "output", + "binding" : { + "name" : "resultExpression", + "type" : "zeebe:property" }, - { - "label": "Result expression", - "type": "String", - "group": "variable-mapping", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultExpression" - }, - "description": "Expression to map the inbound payload to process variables" - } - ], - "icon": { - "contents": "" } } \ No newline at end of file diff --git a/connectors/aws/aws-sqs/element-templates/aws-sqs-inbound-intermediate-connector.json b/connectors/aws/aws-sqs/element-templates/aws-sqs-inbound-intermediate-connector.json index 06a8300157..89d298a605 100644 --- a/connectors/aws/aws-sqs/element-templates/aws-sqs-inbound-intermediate-connector.json +++ b/connectors/aws/aws-sqs/element-templates/aws-sqs-inbound-intermediate-connector.json @@ -1,278 +1,274 @@ { - "$schema": "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", - "name": "Amazon SQS Intermediate Message Catch Event connector", - "id": "io.camunda.connectors.AWSSQS.intermediate.v1", - "version": 8, - "description": "Receive message from a queue", - "documentationRef": "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", - "appliesTo": [ - "bpmn:IntermediateCatchEvent", - "bpmn:IntermediateThrowEvent" - ], - "elementType": { - "value": "bpmn:IntermediateCatchEvent", - "eventDefinition": "bpmn:MessageEventDefinition" + "$schema" : "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", + "name" : "Amazon SQS Intermediate Message Catch Event connector", + "id" : "io.camunda.connectors.AWSSQS.intermediate.v1", + "description" : "Receive message from a queue", + "documentationRef" : "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", + "version" : 9, + "category" : { + "id" : "connectors", + "name" : "Connectors" }, - "category": { - "id": "connectors", - "name": "Connectors" + "appliesTo" : [ "bpmn:IntermediateCatchEvent", "bpmn:IntermediateThrowEvent" ], + "elementType" : { + "value" : "bpmn:IntermediateCatchEvent", + "eventDefinition" : "bpmn:MessageEventDefinition" }, - "groups": [ - { - "id": "authentication", - "label": "Authentication" + "groups" : [ { + "id" : "authentication", + "label" : "Authentication" + }, { + "id" : "configuration", + "label" : "Configuration" + }, { + "id" : "queueProperties", + "label" : "Queue properties" + }, { + "id" : "messagePollingProperties", + "label" : "Message polling properties" + }, { + "id" : "input", + "label" : "Use next attribute names for activation condition" + }, { + "id" : "activation", + "label" : "Activation" + }, { + "id" : "correlation", + "label" : "Correlation" + }, { + "id" : "output", + "label" : "Output mapping" + } ], + "properties" : [ { + "value" : "io.camunda:aws-sqs-inbound:1", + "binding" : { + "name" : "inbound.type", + "type" : "zeebe:property" }, - { - "id": "queueProperties", - "label": "Queue properties" + "type" : "Hidden" + }, { + "id" : "authentication.type", + "label" : "Authentication", + "description" : "Specify AWS authentication strategy. Learn more at the documentation page", + "value" : "credentials", + "group" : "authentication", + "binding" : { + "name" : "authentication.type", + "type" : "zeebe:property" }, - { - "id": "messagePollingProperties", - "label": "Message polling properties" + "type" : "Dropdown", + "choices" : [ { + "name" : "Default Credentials Chain (Hybrid/Self-Managed only)", + "value" : "defaultCredentialsChain" + }, { + "name" : "Credentials", + "value" : "credentials" + } ] + }, { + "id" : "authentication.accessKey", + "label" : "Access key", + "description" : "Provide an IAM access key tailored to a user, equipped with the necessary permissions", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "id": "input", - "label": "Use next attribute names for activation condition" + "group" : "authentication", + "binding" : { + "name" : "authentication.accessKey", + "type" : "zeebe:property" }, - { - "id": "activation", - "label": "Activation" + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "id": "variable-mapping", - "label": "Variable mapping" - } - ], - "properties": [ - { - "type": "Hidden", - "value": "io.camunda:aws-sqs-inbound:1", - "binding": { - "type": "zeebe:property", - "name": "inbound.type" - } + "type" : "String" + }, { + "id" : "authentication.secretKey", + "label" : "Secret key", + "description" : "Provide a secret key of a user with permissions to invoke specified AWS Lambda function", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "type": "Hidden", - "generatedValue": { - "type": "uuid" - }, - "binding": { - "type": "bpmn:Message#property", - "name": "name" - } + "group" : "authentication", + "binding" : { + "name" : "authentication.secretKey", + "type" : "zeebe:property" }, - { - "id": "authenticationType", - "label": "Authentication", - "description": "Specify AWS authentication strategy. Learn more at the documentation page", - "group": "authentication", - "type": "Dropdown", - "optional": false, - "value": "credentials", - "choices": [ - { - "name": "Credentials", - "value": "credentials" - }, - { - "name": "Default Credentials Chain (Hybrid/Self-Managed only)", - "value": "defaultCredentialsChain" - } - ], - "binding": { - "type": "zeebe:property", - "name": "authentication.type" - }, - "constraints": { - "notEmpty": true - } + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "label": "Access key", - "description": "Provide AWS IAM access key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.accessKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "type" : "String" + }, { + "id" : "configuration.region", + "label" : "Region", + "description" : "Specify the AWS region", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "label": "Secret key", - "description": "Provide AWS IAM secret key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.secretKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "group" : "configuration", + "binding" : { + "name" : "configuration.region", + "type" : "zeebe:property" }, - { - "label": "Queue URL", - "description": "Specify the URL of the SQS queue where you would like to subscribe to", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "queue.url" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^(https?://.+|arn:.+|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be an queue URL or ARN" - } - } + "type" : "String" + }, { + "id" : "configuration.endpoint", + "label" : "Endpoint", + "description" : "Specify endpoint if need to use custom endpoint", + "optional" : true, + "group" : "configuration", + "binding" : { + "name" : "configuration.endpoint", + "type" : "zeebe:property" }, - { - "label": "Region", - "description": "Specify the AWS region of your queue", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "configuration.region" - }, - "constraints": { - "notEmpty": true - } + "type" : "Hidden" + }, { + "id" : "queue.queue.url", + "label" : "Queue URL", + "description" : "Specify the URL of the SQS queue where you would like to subscribe to", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "queueProperties", + "binding" : { + "name" : "queue.url", + "type" : "zeebe:property" }, - { - "label": "Polling wait time", - "description": "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", - "group": "messagePollingProperties", - "type": "String", - "optional":false, - "feel":"optional", - "value": "20", - "binding": { - "type": "zeebe:property", - "name": "queue.pollingWaitTime" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^([0-9]?|1[0-9]|20|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be >= 0 and <= 20 or a FEEL expression" - } + "type" : "String" + }, { + "id" : "queue.queue.pollingWaitTime", + "label" : "Polling wait time", + "description" : "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", + "optional" : false, + "value" : "20", + "constraints" : { + "notEmpty" : true, + "pattern" : { + "value" : "^([0-9]?|1[0-9]|20|secrets\\..+)$" } }, - { - "label": "Attribute names", - "description": "Array of queue attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.attributeNames" - }, - "feel": "required" + "group" : "messagePollingProperties", + "binding" : { + "name" : "queue.pollingWaitTime", + "type" : "zeebe:property" }, - { - "label": "Message attribute names", - "description": "Array of message attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.messageAttributeNames" - }, - "feel": "required" + "type" : "String" + }, { + "id" : "queue.queue.attributeNames", + "label" : "Attribute names", + "description" : "Array of queue attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.attributeNames", + "type" : "zeebe:property" }, - { - "label": "Correlation key (process)", - "type": "String", - "group": "activation", - "feel": "required", - "description": "Sets up the correlation key from process variables", - "binding": { - "type": "bpmn:Message#zeebe:subscription#property", - "name": "correlationKey" - }, - "constraints": { - "notEmpty": true - } + "type" : "String" + }, { + "id" : "queue.queue.messageAttributeNames", + "label" : "Message attribute names", + "description" : "Array of message attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.messageAttributeNames", + "type" : "zeebe:property" }, - { - "label": "Correlation key (payload)", - "type": "String", - "group": "activation", - "feel": "required", - "binding": { - "type": "zeebe:property", - "name": "correlationKeyExpression" - }, - "description": "Extracts the correlation key from the incoming message payload", - "constraints": { - "notEmpty": true - } + "type" : "String" + }, { + "id" : "activationCondition", + "label" : "Activation condition", + "description" : "Condition under which the Connector triggers. Leave empty to catch all events", + "optional" : true, + "feel" : "required", + "group" : "activation", + "binding" : { + "name" : "activationCondition", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "correlationKeyProcess", + "label" : "Correlation key (process)", + "description" : "Sets up the correlation key from process variables", + "constraints" : { + "notEmpty" : true + }, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKey", + "type" : "bpmn:Message#zeebe:subscription#property" + }, + "type" : "String" + }, { + "id" : "correlationKeyPayload", + "label" : "Correlation key (payload)", + "description" : "Extracts the correlation key from the incoming message payload", + "constraints" : { + "notEmpty" : true + }, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKeyExpression", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "messageIdExpression", + "label" : "Message ID expression", + "description" : "Expression to extract unique identifier of a message", + "optional" : true, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "messageIdExpression", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "messageNameUuid", + "generatedValue" : { + "type" : "uuid" }, - { - "label": "Message ID expression", - "feel": "required", - "type": "String", - "optional": true, - "group": "activation", - "binding": { - "type": "zeebe:property", - "name": "messageIdExpression" - }, - "description": "Expression to extract unique identifier of a message" + "group" : "correlation", + "binding" : { + "name" : "name", + "type" : "bpmn:Message#property" }, - { - "label": "Activation condition", - "type": "String", - "group": "activation", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "activationCondition" - }, - "description": "Condition under which the connector triggers. Leave empty to catch all events" + "type" : "Hidden" + }, { + "id" : "resultVariable", + "label" : "Result variable", + "description" : "Name of variable to store the response in", + "group" : "output", + "binding" : { + "name" : "resultVariable", + "type" : "zeebe:property" }, - { - "label": "Result variable", - "type": "String", - "group": "variable-mapping", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultVariable" - }, - "description": "Name of variable to store the result of the connector in" + "type" : "String" + }, { + "id" : "resultExpression", + "label" : "Result expression", + "description" : "Expression to map the response into process variables", + "feel" : "required", + "group" : "output", + "binding" : { + "name" : "resultExpression", + "type" : "zeebe:property" }, - { - "label": "Result expression", - "type": "String", - "group": "variable-mapping", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultExpression" - }, - "description": "Expression to map the inbound payload to process variables" - } - ], - "icon": { - "contents": "" } } \ No newline at end of file diff --git a/connectors/aws/aws-sqs/element-templates/aws-sqs-start-event-connector.json b/connectors/aws/aws-sqs/element-templates/aws-sqs-start-event-connector.json index 99dab1a2cc..7e849e54c3 100644 --- a/connectors/aws/aws-sqs/element-templates/aws-sqs-start-event-connector.json +++ b/connectors/aws/aws-sqs/element-templates/aws-sqs-start-event-connector.json @@ -1,226 +1,219 @@ { - "$schema": "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", - "name": "Amazon SQS Start Event Connector", - "id": "io.camunda.connectors.AWSSQS.StartEvent.v1", - "version": 7, - "description": "Receive message from a queue", - "documentationRef": "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", - "appliesTo": [ - "bpmn:StartEvent" - ], - "elementType": { - "value": "bpmn:StartEvent" + "$schema" : "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", + "name" : "Amazon SQS Start Event Connector", + "id" : "io.camunda.connectors.AWSSQS.StartEvent.v1", + "description" : "Receive message from a queue", + "documentationRef" : "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", + "version" : 9, + "category" : { + "id" : "connectors", + "name" : "Connectors" }, - "category": { - "id": "connectors", - "name": "Connectors" + "appliesTo" : [ "bpmn:StartEvent" ], + "elementType" : { + "value" : "bpmn:StartEvent" }, - "groups": [ - { - "id": "authentication", - "label": "Authentication" - }, - { - "id": "queueProperties", - "label": "Queue properties" - }, - { - "id": "messagePollingProperties", - "label": "Message polling properties" - }, - { - "id": "input", - "label": "Use next attribute names for activation condition" - }, - { - "id": "activation", - "label": "Activation" - }, - { - "id": "variable-mapping", - "label": "Variable mapping" - } - ], - "properties": [ - { - "type": "Hidden", - "value": "io.camunda:aws-sqs-inbound:1", - "binding": { - "type": "zeebe:property", - "name": "inbound.type" + "groups" : [ { + "id" : "authentication", + "label" : "Authentication" + }, { + "id" : "configuration", + "label" : "Configuration" + }, { + "id" : "queueProperties", + "label" : "Queue properties" + }, { + "id" : "messagePollingProperties", + "label" : "Message polling properties" + }, { + "id" : "input", + "label" : "Use next attribute names for activation condition" + }, { + "id" : "activation", + "label" : "Activation" + }, { + "id" : "output", + "label" : "Output mapping" + } ], + "properties" : [ { + "value" : "io.camunda:aws-sqs-inbound:1", + "binding" : { + "name" : "inbound.type", + "type" : "zeebe:property" + }, + "type" : "Hidden" + }, { + "id" : "authentication.type", + "label" : "Authentication", + "description" : "Specify AWS authentication strategy. Learn more at the documentation page", + "value" : "credentials", + "group" : "authentication", + "binding" : { + "name" : "authentication.type", + "type" : "zeebe:property" + }, + "type" : "Dropdown", + "choices" : [ { + "name" : "Default Credentials Chain (Hybrid/Self-Managed only)", + "value" : "defaultCredentialsChain" + }, { + "name" : "Credentials", + "value" : "credentials" + } ] + }, { + "id" : "authentication.accessKey", + "label" : "Access key", + "description" : "Provide an IAM access key tailored to a user, equipped with the necessary permissions", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "authentication", + "binding" : { + "name" : "authentication.accessKey", + "type" : "zeebe:property" + }, + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" + }, + "type" : "String" + }, { + "id" : "authentication.secretKey", + "label" : "Secret key", + "description" : "Provide a secret key of a user with permissions to invoke specified AWS Lambda function", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "authentication", + "binding" : { + "name" : "authentication.secretKey", + "type" : "zeebe:property" + }, + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" + }, + "type" : "String" + }, { + "id" : "configuration.region", + "label" : "Region", + "description" : "Specify the AWS region", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "configuration", + "binding" : { + "name" : "configuration.region", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "configuration.endpoint", + "label" : "Endpoint", + "description" : "Specify endpoint if need to use custom endpoint", + "optional" : true, + "group" : "configuration", + "binding" : { + "name" : "configuration.endpoint", + "type" : "zeebe:property" + }, + "type" : "Hidden" + }, { + "id" : "queue.queue.url", + "label" : "Queue URL", + "description" : "Specify the URL of the SQS queue where you would like to subscribe to", + "optional" : false, + "constraints" : { + "notEmpty" : true + }, + "group" : "queueProperties", + "binding" : { + "name" : "queue.url", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "queue.queue.pollingWaitTime", + "label" : "Polling wait time", + "description" : "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", + "optional" : false, + "value" : "20", + "constraints" : { + "notEmpty" : true, + "pattern" : { + "value" : "^([0-9]?|1[0-9]|20|secrets\\..+)$" } }, - { - "id": "authenticationType", - "label": "Authentication", - "description": "Specify AWS authentication strategy. Learn more at the documentation page", - "group": "authentication", - "type": "Dropdown", - "optional": false, - "value": "credentials", - "choices": [ - { - "name": "Credentials", - "value": "credentials" - }, - { - "name": "Default Credentials Chain (Hybrid/Self-Managed only)", - "value": "defaultCredentialsChain" - } - ], - "binding": { - "type": "zeebe:property", - "name": "authentication.type" - }, - "constraints": { - "notEmpty": true - } - }, - { - "label": "Access key", - "description": "Provide AWS IAM access key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.accessKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } - }, - { - "label": "Secret key", - "description": "Provide AWS IAM secret key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.secretKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } - }, - { - "label": "Queue URL", - "description": "Specify the URL of the SQS queue where you would like to subscribe to", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "queue.url" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^(https?://.+|arn:.+|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be an queue URL or ARN" - } - } - }, - { - "label": "Region", - "description": "Specify the AWS region of your queue", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "configuration.region" - }, - "constraints": { - "notEmpty": true - } - }, - { - "label": "Polling wait time", - "description": "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", - "group": "messagePollingProperties", - "type": "String", - "optional":false, - "feel":"optional", - "value": "20", - "binding": { - "type": "zeebe:property", - "name": "queue.pollingWaitTime" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^([0-9]?|1[0-9]|20|\\{\\{secrets\\..+\\}\\})$", - "message": "Must be >= 0 and <= 20 or a FEEL expression" - } - } - }, - { - "label": "Attribute names", - "description": "Array of queue attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.attributeNames" - }, - "feel": "required" - }, - { - "label": "Message attribute names", - "description": "Array of message attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.messageAttributeNames" - }, - "feel": "required" - }, - { - "label": "Activation condition", - "type": "String", - "group": "activation", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "activationCondition" - }, - "description": "Condition under which the connector triggers. Leave empty to catch all events" - }, - { - "label": "Result variable", - "type": "String", - "group": "variable-mapping", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultVariable" - }, - "description": "Name of variable to store the result of the connector in" - }, - { - "label": "Result expression", - "type": "String", - "group": "variable-mapping", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultExpression" - }, - "description": "Expression to map the inbound payload to process variables" - } - ], - "icon": { - "contents": "" } } \ No newline at end of file diff --git a/connectors/aws/aws-sqs/element-templates/aws-sqs-start-message.json b/connectors/aws/aws-sqs/element-templates/aws-sqs-start-message.json index 389946c544..33d557dc5c 100644 --- a/connectors/aws/aws-sqs/element-templates/aws-sqs-start-message.json +++ b/connectors/aws/aws-sqs/element-templates/aws-sqs-start-message.json @@ -1,311 +1,302 @@ { - "$schema": "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", - "name": "Amazon SQS Message Start Event Connector", - "id": "io.camunda.connectors.AWSSQS.startmessage.v1", - "version": 2, - "description": "Receive message from a queue", - "documentationRef": "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", - "appliesTo": [ - "bpmn:StartEvent" - ], - "elementType": { - "value": "bpmn:StartEvent", - "eventDefinition": "bpmn:MessageEventDefinition" + "$schema" : "https://unpkg.com/@camunda/zeebe-element-templates-json-schema/resources/schema.json", + "name" : "Amazon SQS Message Start Event Connector", + "id" : "io.camunda.connectors.AWSSQS.startmessage.v1", + "description" : "Receive message from a queue", + "documentationRef" : "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", + "version" : 9, + "category" : { + "id" : "connectors", + "name" : "Connectors" }, - "category": { - "id": "connectors", - "name": "Connectors" + "appliesTo" : [ "bpmn:StartEvent" ], + "elementType" : { + "value" : "bpmn:StartEvent", + "eventDefinition" : "bpmn:MessageEventDefinition" }, - "groups": [ - { - "id": "authentication", - "label": "Authentication" + "groups" : [ { + "id" : "authentication", + "label" : "Authentication" + }, { + "id" : "configuration", + "label" : "Configuration" + }, { + "id" : "queueProperties", + "label" : "Queue properties" + }, { + "id" : "messagePollingProperties", + "label" : "Message polling properties" + }, { + "id" : "input", + "label" : "Use next attribute names for activation condition" + }, { + "id" : "activation", + "label" : "Activation" + }, { + "id" : "correlation", + "label" : "Correlation" + }, { + "id" : "output", + "label" : "Output mapping" + } ], + "properties" : [ { + "value" : "io.camunda:aws-sqs-inbound:1", + "binding" : { + "name" : "inbound.type", + "type" : "zeebe:property" }, - { - "id": "queueProperties", - "label": "Queue properties" + "type" : "Hidden" + }, { + "id" : "authentication.type", + "label" : "Authentication", + "description" : "Specify AWS authentication strategy. Learn more at the documentation page", + "value" : "credentials", + "group" : "authentication", + "binding" : { + "name" : "authentication.type", + "type" : "zeebe:property" }, - { - "id": "messagePollingProperties", - "label": "Message polling properties" + "type" : "Dropdown", + "choices" : [ { + "name" : "Default Credentials Chain (Hybrid/Self-Managed only)", + "value" : "defaultCredentialsChain" + }, { + "name" : "Credentials", + "value" : "credentials" + } ] + }, { + "id" : "authentication.accessKey", + "label" : "Access key", + "description" : "Provide an IAM access key tailored to a user, equipped with the necessary permissions", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "id": "input", - "label": "Use next attribute names for activation condition" + "group" : "authentication", + "binding" : { + "name" : "authentication.accessKey", + "type" : "zeebe:property" }, - { - "id": "activation", - "label": "Activation" + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "id": "correlation", - "label": "Subprocess correlation" + "type" : "String" + }, { + "id" : "authentication.secretKey", + "label" : "Secret key", + "description" : "Provide a secret key of a user with permissions to invoke specified AWS Lambda function", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "id": "variable-mapping", - "label": "Variable mapping" - } - ], - "properties": [ - { - "type": "Hidden", - "value": "io.camunda:aws-sqs-inbound:1", - "binding": { - "type": "zeebe:property", - "name": "inbound.type" - } + "group" : "authentication", + "binding" : { + "name" : "authentication.secretKey", + "type" : "zeebe:property" }, - { - "type": "Hidden", - "generatedValue": { - "type": "uuid" - }, - "binding": { - "type": "bpmn:Message#property", - "name": "name" - } + "condition" : { + "property" : "authentication.type", + "equals" : "credentials", + "type" : "simple" }, - { - "id": "authenticationType", - "label": "Authentication", - "description": "Specify AWS authentication strategy. Learn more at the documentation page", - "group": "authentication", - "type": "Dropdown", - "optional": false, - "value": "credentials", - "choices": [ - { - "name": "Credentials", - "value": "credentials" - }, - { - "name": "Default Credentials Chain (Hybrid/Self-Managed only)", - "value": "defaultCredentialsChain" - } - ], - "binding": { - "type": "zeebe:property", - "name": "authentication.type" - }, - "constraints": { - "notEmpty": true - } + "type" : "String" + }, { + "id" : "configuration.region", + "label" : "Region", + "description" : "Specify the AWS region", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "label": "Access key", - "description": "Provide AWS IAM access key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.accessKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "group" : "configuration", + "binding" : { + "name" : "configuration.region", + "type" : "zeebe:property" }, - { - "label": "Secret key", - "description": "Provide AWS IAM secret key that has permission to read from desired SQS", - "group": "authentication", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "authentication.secretKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "authenticationType", - "equals": "credentials" - } + "type" : "String" + }, { + "id" : "configuration.endpoint", + "label" : "Endpoint", + "description" : "Specify endpoint if need to use custom endpoint", + "optional" : true, + "group" : "configuration", + "binding" : { + "name" : "configuration.endpoint", + "type" : "zeebe:property" }, - { - "label": "Queue URL", - "description": "Specify the URL of the SQS queue where you would like to subscribe to", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "queue.url" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^(https?://.+|arn:.+|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be an queue URL or ARN" - } - } + "type" : "Hidden" + }, { + "id" : "queue.queue.url", + "label" : "Queue URL", + "description" : "Specify the URL of the SQS queue where you would like to subscribe to", + "optional" : false, + "constraints" : { + "notEmpty" : true }, - { - "label": "Region", - "description": "Specify the AWS region of your queue", - "group": "queueProperties", - "type": "String", - "binding": { - "type": "zeebe:property", - "name": "configuration.region" - }, - "constraints": { - "notEmpty": true - } + "group" : "queueProperties", + "binding" : { + "name" : "queue.url", + "type" : "zeebe:property" }, - { - "label": "Polling wait time", - "description": "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", - "group": "messagePollingProperties", - "type": "String", - "optional":false, - "feel":"optional", - "value": "20", - "binding": { - "type": "zeebe:property", - "name": "queue.pollingWaitTime" - }, - "constraints": { - "notEmpty": true, - "pattern": { - "value": "^([0-9]?|1[0-9]|20|\\{\\{secrets\\..+\\}\\}.*)$", - "message": "Must be >= 0 and <= 20 or a FEEL expression" - } + "type" : "String" + }, { + "id" : "queue.queue.pollingWaitTime", + "label" : "Polling wait time", + "description" : "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", + "optional" : false, + "value" : "20", + "constraints" : { + "notEmpty" : true, + "pattern" : { + "value" : "^([0-9]?|1[0-9]|20|secrets\\..+)$" } }, - { - "label": "Attribute names", - "description": "Array of queue attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.attributeNames" - }, - "feel": "required" + "group" : "messagePollingProperties", + "binding" : { + "name" : "queue.pollingWaitTime", + "type" : "zeebe:property" }, - { - "label": "Message attribute names", - "description": "Array of message attribute names. See documentation for details", - "group": "input", - "type": "String", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "queue.messageAttributeNames" - }, - "feel": "required" + "type" : "String" + }, { + "id" : "queue.queue.attributeNames", + "label" : "Attribute names", + "description" : "Array of queue attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.attributeNames", + "type" : "zeebe:property" }, - { - "label": "Message ID expression", - "feel": "required", - "type": "String", - "optional": true, - "group": "activation", - "binding": { - "type": "zeebe:property", - "name": "messageIdExpression" - }, - "description": "Expression to extract unique identifier of a message" + "type" : "String" + }, { + "id" : "queue.queue.messageAttributeNames", + "label" : "Message attribute names", + "description" : "Array of message attribute names. See documentation for details", + "optional" : false, + "feel" : "optional", + "group" : "input", + "binding" : { + "name" : "queue.messageAttributeNames", + "type" : "zeebe:property" }, - { - "label": "Activation condition", - "type": "String", - "group": "activation", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "activationCondition" - }, - "description": "Condition under which the connector triggers. Leave empty to catch all events" + "type" : "String" + }, { + "id" : "activationCondition", + "label" : "Activation condition", + "description" : "Condition under which the Connector triggers. Leave empty to catch all events", + "optional" : true, + "feel" : "required", + "group" : "activation", + "binding" : { + "name" : "activationCondition", + "type" : "zeebe:property" }, - { - "label": "Correlation required", - "description": "Indicates whether correlation is required. This is needed for event-based subprocess message start events", - "id": "correlationRequired", - "group": "correlation", - "type": "Dropdown", - "value": "notRequired", - "choices": [ - { - "name": "Correlation not required", - "value": "notRequired" - }, - { - "name": "Correlation required", - "value": "required" - } - ], - "binding": { - "type": "zeebe:property", - "name": "correlationRequired" - } + "type" : "String" + }, { + "id" : "correlationRequired", + "label" : "Subprocess correlation required", + "description" : "Indicates whether correlation is required. This is needed for event-based subprocess message start events", + "value" : "notRequired", + "group" : "correlation", + "binding" : { + "name" : "correlationRequired", + "type" : "zeebe:property" }, - { - "label": "Correlation key (process)", - "type": "String", - "group": "correlation", - "feel": "required", - "description": "Sets up the correlation key from process variables", - "binding": { - "type": "bpmn:Message#zeebe:subscription#property", - "name": "correlationKey" - }, - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "correlationRequired", - "equals": "required" - } + "type" : "Dropdown", + "choices" : [ { + "name" : "Correlation not required", + "value" : "notRequired" + }, { + "name" : "Correlation required", + "value" : "required" + } ] + }, { + "id" : "correlationKeyProcess", + "label" : "Correlation key (process)", + "description" : "Sets up the correlation key from process variables", + "constraints" : { + "notEmpty" : true }, - { - "label": "Correlation key (payload)", - "type": "String", - "group": "correlation", - "feel": "required", - "binding": { - "type": "zeebe:property", - "name": "correlationKeyExpression" - }, - "description": "Extracts the correlation key from the incoming message payload", - "constraints": { - "notEmpty": true - }, - "condition": { - "property": "correlationRequired", - "equals": "required" - } + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKey", + "type" : "bpmn:Message#zeebe:subscription#property" + }, + "condition" : { + "property" : "correlationRequired", + "equals" : "required", + "type" : "simple" + }, + "type" : "String" + }, { + "id" : "correlationKeyPayload", + "label" : "Correlation key (payload)", + "description" : "Extracts the correlation key from the incoming message payload", + "constraints" : { + "notEmpty" : true + }, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "correlationKeyExpression", + "type" : "zeebe:property" + }, + "condition" : { + "property" : "correlationRequired", + "equals" : "required", + "type" : "simple" + }, + "type" : "String" + }, { + "id" : "messageIdExpression", + "label" : "Message ID expression", + "description" : "Expression to extract unique identifier of a message", + "optional" : true, + "feel" : "required", + "group" : "correlation", + "binding" : { + "name" : "messageIdExpression", + "type" : "zeebe:property" + }, + "type" : "String" + }, { + "id" : "messageNameUuid", + "generatedValue" : { + "type" : "uuid" + }, + "group" : "correlation", + "binding" : { + "name" : "name", + "type" : "bpmn:Message#property" + }, + "type" : "Hidden" + }, { + "id" : "resultVariable", + "label" : "Result variable", + "description" : "Name of variable to store the response in", + "group" : "output", + "binding" : { + "name" : "resultVariable", + "type" : "zeebe:property" }, - { - "label": "Result variable", - "type": "String", - "group": "variable-mapping", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultVariable" - }, - "description": "Name of variable to store the result of the connector in" + "type" : "String" + }, { + "id" : "resultExpression", + "label" : "Result expression", + "description" : "Expression to map the response into process variables", + "feel" : "required", + "group" : "output", + "binding" : { + "name" : "resultExpression", + "type" : "zeebe:property" }, - { - "label": "Result expression", - "type": "String", - "group": "variable-mapping", - "feel": "required", - "optional": true, - "binding": { - "type": "zeebe:property", - "name": "resultExpression" - }, - "description": "Expression to map the inbound payload to process variables" - } - ], - "icon": { - "contents": "" } } \ No newline at end of file diff --git a/connectors/aws/aws-sqs/pom.xml b/connectors/aws/aws-sqs/pom.xml index 12001d4fdf..bb9c636b8c 100644 --- a/connectors/aws/aws-sqs/pom.xml +++ b/connectors/aws/aws-sqs/pom.xml @@ -55,6 +55,27 @@ + + io.camunda.connector.inbound.SqsExecutable + + + io.camunda.connectors.AWSSQS.StartEvent.v1 + aws-sqs-start-event-connector.json + + + io.camunda.connectors.AWSSQS.startmessage.v1 + aws-sqs-start-message.json + + + io.camunda.connectors.AWSSQS.intermediate.v1 + aws-sqs-inbound-intermediate-connector.json + + + io.camunda.connectors.AWSSQS.boundary.v1 + aws-sqs-boundary-connector.json + + + io.camunda.connector:connector-aws-base diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/MessageMapper.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/MessageMapper.java index f56f5a9d16..4c648a8f41 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/MessageMapper.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/MessageMapper.java @@ -20,12 +20,6 @@ public class MessageMapper { private static final Logger LOGGER = LoggerFactory.getLogger(MessageMapper.class); public static SqsInboundMessage toSqsInboundMessage(final Message message) { - SqsInboundMessage sqsInboundMessage = new SqsInboundMessage(); - sqsInboundMessage.setMessageId(message.getMessageId()); - sqsInboundMessage.setReceiptHandle(message.getReceiptHandle()); - sqsInboundMessage.setMD5OfMessageAttributes(message.getMD5OfMessageAttributes()); - sqsInboundMessage.setAttributes(message.getAttributes()); - Map sqsInboundMessageAttributes = new HashMap<>(); for (Map.Entry entry : @@ -35,12 +29,15 @@ public static SqsInboundMessage toSqsInboundMessage(final Message message) { sqsInboundMessageAttributes.put(entry.getKey(), sqsInboundMessageAttribute); } - sqsInboundMessage.setMessageAttributes(sqsInboundMessageAttributes); - - sqsInboundMessage.setBody(toObjectIfPossible(message.getBody())); - sqsInboundMessage.setmD5OfBody(message.getMD5OfBody()); - return sqsInboundMessage; + return new SqsInboundMessage( + message.getMessageId(), + message.getReceiptHandle(), + message.getMD5OfBody(), + toObjectIfPossible(message.getBody()), + message.getAttributes(), + message.getMD5OfMessageAttributes(), + sqsInboundMessageAttributes); } private static Object toObjectIfPossible(final String body) { @@ -54,15 +51,11 @@ private static Object toObjectIfPossible(final String body) { private static io.camunda.connector.inbound.model.message.MessageAttributeValue toSqsInboundMessageAttribute(final MessageAttributeValue attributeValue) { - io.camunda.connector.inbound.model.message.MessageAttributeValue sqsInboundMessageAttribute = - new io.camunda.connector.inbound.model.message.MessageAttributeValue(); - - sqsInboundMessageAttribute.setBinaryValue(attributeValue.getBinaryValue()); - sqsInboundMessageAttribute.setDataType(attributeValue.getDataType()); - sqsInboundMessageAttribute.setStringValue(attributeValue.getStringValue()); - sqsInboundMessageAttribute.setBinaryListValues(attributeValue.getBinaryListValues()); - sqsInboundMessageAttribute.setStringListValues(attributeValue.getStringListValues()); - - return sqsInboundMessageAttribute; + return new io.camunda.connector.inbound.model.message.MessageAttributeValue( + attributeValue.getStringValue(), + attributeValue.getBinaryValue(), + attributeValue.getStringListValues(), + attributeValue.getBinaryListValues(), + attributeValue.getDataType()); } } diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsExecutable.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsExecutable.java index 2fdca85721..b94e0b35df 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsExecutable.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsExecutable.java @@ -14,6 +14,10 @@ import io.camunda.connector.aws.CredentialsProviderSupport; import io.camunda.connector.common.suppliers.AmazonSQSClientSupplier; import io.camunda.connector.common.suppliers.DefaultAmazonSQSClientSupplier; +import io.camunda.connector.generator.dsl.BpmnType; +import io.camunda.connector.generator.java.annotation.ElementTemplate; +import io.camunda.connector.generator.java.annotation.ElementTemplate.ConnectorElementType; +import io.camunda.connector.generator.java.annotation.ElementTemplate.PropertyGroup; import io.camunda.connector.inbound.model.SqsInboundProperties; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; @@ -22,6 +26,44 @@ import org.slf4j.LoggerFactory; @InboundConnector(name = "AWS SQS Inbound", type = "io.camunda:aws-sqs-inbound:1") +@ElementTemplate( + id = "io.camunda.connectors.AWSSQS.inbound.v1", + name = "Amazon SQS Connector", + icon = "icon.svg", + version = 9, + inputDataClass = SqsInboundProperties.class, + description = "Receive message from a queue", + documentationRef = + "https://docs.camunda.io/docs/components/connectors/out-of-the-box-connectors/amazon-sqs/?amazonsqs=inbound", + propertyGroups = { + @PropertyGroup(id = "authentication", label = "Authentication"), + @PropertyGroup(id = "configuration", label = "Configuration"), + @PropertyGroup(id = "queueProperties", label = "Queue properties"), + @PropertyGroup(id = "messagePollingProperties", label = "Message polling properties"), + @PropertyGroup(id = "input", label = "Use next attribute names for activation condition") + }, + elementTypes = { + @ConnectorElementType( + appliesTo = BpmnType.START_EVENT, + elementType = BpmnType.START_EVENT, + templateIdOverride = "io.camunda.connectors.AWSSQS.StartEvent.v1", + templateNameOverride = "Amazon SQS Start Event Connector"), + @ConnectorElementType( + appliesTo = BpmnType.START_EVENT, + elementType = BpmnType.MESSAGE_START_EVENT, + templateIdOverride = "io.camunda.connectors.AWSSQS.startmessage.v1", + templateNameOverride = "Amazon SQS Message Start Event Connector"), + @ConnectorElementType( + appliesTo = {BpmnType.INTERMEDIATE_THROW_EVENT, BpmnType.INTERMEDIATE_CATCH_EVENT}, + elementType = BpmnType.INTERMEDIATE_CATCH_EVENT, + templateIdOverride = "io.camunda.connectors.AWSSQS.intermediate.v1", + templateNameOverride = "Amazon SQS Intermediate Message Catch Event connector"), + @ConnectorElementType( + appliesTo = BpmnType.BOUNDARY_EVENT, + elementType = BpmnType.BOUNDARY_EVENT, + templateIdOverride = "io.camunda.connectors.AWSSQS.boundary.v1", + templateNameOverride = "Amazon SQS Boundary Event Connector") + }) public class SqsExecutable implements InboundConnectorExecutable { private static final Logger LOGGER = LoggerFactory.getLogger(SqsExecutable.class); private final AmazonSQSClientSupplier sqsClientSupplier; @@ -50,7 +92,7 @@ public void activate(final InboundConnectorContext context) { var region = AwsUtils.extractRegionOrDefault( - properties.getConfiguration(), properties.getQueue().getRegion()); + properties.getConfiguration(), properties.getQueue().region()); amazonSQS = sqsClientSupplier.sqsClient( CredentialsProviderSupport.credentialsProvider(properties), region); diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsQueueConsumer.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsQueueConsumer.java index 20b0157976..8a88451d0c 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsQueueConsumer.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/SqsQueueConsumer.java @@ -40,7 +40,7 @@ public SqsQueueConsumer( @Override public void run() { - LOGGER.info("Started SQS consumer for queue {}", properties.getQueue().getUrl()); + LOGGER.info("Started SQS consumer for queue {}", properties.getQueue().url()); final ReceiveMessageRequest receiveMessageRequest = createReceiveMessageRequest(); ReceiveMessageResult receiveMessageResult; @@ -51,7 +51,7 @@ public void run() { for (Message message : messages) { try { context.correlate(MessageMapper.toSqsInboundMessage(message)); - sqsClient.deleteMessage(properties.getQueue().getUrl(), message.getReceiptHandle()); + sqsClient.deleteMessage(properties.getQueue().url(), message.getReceiptHandle()); } catch (ConnectorInputException e) { LOGGER.warn("NACK - failed to parse SQS message body: {}", e.getMessage()); } @@ -60,19 +60,19 @@ public void run() { LOGGER.debug("NACK - failed to correlate event", e); } } while (queueConsumerActive.get()); - LOGGER.info("Stopping SQS consumer for queue {}", properties.getQueue().getUrl()); + LOGGER.info("Stopping SQS consumer for queue {}", properties.getQueue().url()); } private ReceiveMessageRequest createReceiveMessageRequest() { return new ReceiveMessageRequest() - .withWaitTimeSeconds(Integer.valueOf(properties.getQueue().getPollingWaitTime())) - .withQueueUrl(properties.getQueue().getUrl()) + .withWaitTimeSeconds(Integer.valueOf(properties.getQueue().pollingWaitTime())) + .withQueueUrl(properties.getQueue().url()) .withMessageAttributeNames( - Optional.ofNullable(properties.getQueue().getMessageAttributeNames()) + Optional.ofNullable(properties.getQueue().messageAttributeNames()) .filter(list -> !list.isEmpty()) .orElse(ALL_ATTRIBUTES_KEY)) .withAttributeNames( - Optional.ofNullable(properties.getQueue().getAttributeNames()) + Optional.ofNullable(properties.getQueue().attributeNames()) .filter(list -> !list.isEmpty()) .orElse(ALL_ATTRIBUTES_KEY)); } diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/SqsInboundQueueProperties.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/SqsInboundQueueProperties.java index 038ce037b5..5d0104e788 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/SqsInboundQueueProperties.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/SqsInboundQueueProperties.java @@ -6,108 +6,46 @@ */ package io.camunda.connector.inbound.model; -import jakarta.validation.constraints.NotEmpty; +import io.camunda.connector.generator.dsl.Property.FeelMode; +import io.camunda.connector.generator.java.annotation.TemplateProperty; +import jakarta.validation.constraints.NotBlank; import jakarta.validation.constraints.Pattern; import java.util.List; -import java.util.Objects; -public class SqsInboundQueueProperties { - @Deprecated private String region; - @NotEmpty private String url; - private List attributeNames; - private List messageAttributeNames; - - // TODO: when migrating to template generator, default to 20 (max possible value) - @Pattern(regexp = "^([0-9]?|1[0-9]|20|secrets\\..+)$") - private String pollingWaitTime; - - @Deprecated - public String getRegion() { - return region; - } - - @Deprecated - public void setRegion(final String region) { - this.region = region; - } - - public String getUrl() { - return url; - } - - public void setUrl(final String url) { - this.url = url; - } - - public boolean isContainAttributeNames() { - return attributeNames != null && !attributeNames.isEmpty(); - } - - public boolean isContainMessageAttributeNames() { - return messageAttributeNames != null && !messageAttributeNames.isEmpty(); - } - - public List getAttributeNames() { - return attributeNames; - } - - public void setAttributeNames(final List attributeNames) { - this.attributeNames = attributeNames; - } - - public List getMessageAttributeNames() { - return messageAttributeNames; - } - - public void setMessageAttributeNames(final List messageAttributeNames) { - this.messageAttributeNames = messageAttributeNames; - } - - public String getPollingWaitTime() { - return pollingWaitTime; - } - - public void setPollingWaitTime(final String pollingWaitTime) { - this.pollingWaitTime = pollingWaitTime; - } - - @Override - public boolean equals(final Object o) { - if (this == o) { - return true; - } - if (o == null || getClass() != o.getClass()) { - return false; - } - final SqsInboundQueueProperties that = (SqsInboundQueueProperties) o; - return Objects.equals(region, that.region) - && Objects.equals(url, that.url) - && Objects.equals(attributeNames, that.attributeNames) - && Objects.equals(messageAttributeNames, that.messageAttributeNames) - && Objects.equals(pollingWaitTime, that.pollingWaitTime); - } - - @Override - public int hashCode() { - return Objects.hash(region, url, attributeNames, messageAttributeNames, pollingWaitTime); - } - - @Override - public String toString() { - return "SqsInboundQueueProperties{" - + "region='" - + region - + "'" - + ", url='" - + url - + "'" - + ", attributeNames=" - + attributeNames - + ", messageAttributeNames=" - + messageAttributeNames - + ", pollingWaitTime='" - + pollingWaitTime - + "'" - + "}"; - } -} +public record SqsInboundQueueProperties( + @Deprecated @TemplateProperty(ignore = true) String region, + @TemplateProperty( + id = "queue.url", + label = "Queue URL", + group = "queueProperties", + description = "Specify the URL of the SQS queue where you would like to subscribe to", + feel = FeelMode.disabled) + @NotBlank + String url, + @TemplateProperty( + id = "queue.attributeNames", + label = "Attribute names", + group = "input", + description = + "Array of queue attribute names. See documentation for details", + feel = FeelMode.optional) + List attributeNames, + @TemplateProperty( + id = "queue.messageAttributeNames", + label = "Message attribute names", + group = "input", + description = + "Array of message attribute names. See documentation for details", + feel = FeelMode.optional) + List messageAttributeNames, + @TemplateProperty( + id = "queue.pollingWaitTime", + label = "Polling wait time", + group = "messagePollingProperties", + defaultValue = "20", + description = + "The duration (in seconds) for which the call waits for a message to arrive in the queue before returning. See documentation for details", + feel = FeelMode.disabled) + @Pattern(regexp = "^([0-9]?|1[0-9]|20|secrets\\..+)$") + @NotBlank + String pollingWaitTime) {} diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/MessageAttributeValue.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/MessageAttributeValue.java index 0a656d8703..5ffd6ea8db 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/MessageAttributeValue.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/MessageAttributeValue.java @@ -8,91 +8,10 @@ import java.nio.ByteBuffer; import java.util.List; -import java.util.Objects; -public class MessageAttributeValue { - private String stringValue; - private ByteBuffer binaryValue; - private List stringListValues; - private List binaryListValues; - private String dataType; - - public String getStringValue() { - return stringValue; - } - - public void setStringValue(final String stringValue) { - this.stringValue = stringValue; - } - - public ByteBuffer getBinaryValue() { - return binaryValue; - } - - public void setBinaryValue(final ByteBuffer binaryValue) { - this.binaryValue = binaryValue; - } - - public List getStringListValues() { - return stringListValues; - } - - public void setStringListValues(final List stringListValues) { - this.stringListValues = stringListValues; - } - - public List getBinaryListValues() { - return binaryListValues; - } - - public void setBinaryListValues(final List binaryListValues) { - this.binaryListValues = binaryListValues; - } - - public String getDataType() { - return dataType; - } - - public void setDataType(final String dataType) { - this.dataType = dataType; - } - - @Override - public boolean equals(final Object o) { - if (this == o) { - return true; - } - if (o == null || getClass() != o.getClass()) { - return false; - } - final MessageAttributeValue that = (MessageAttributeValue) o; - return Objects.equals(stringValue, that.stringValue) - && Objects.equals(binaryValue, that.binaryValue) - && Objects.equals(stringListValues, that.stringListValues) - && Objects.equals(binaryListValues, that.binaryListValues) - && Objects.equals(dataType, that.dataType); - } - - @Override - public int hashCode() { - return Objects.hash(stringValue, binaryValue, stringListValues, binaryListValues, dataType); - } - - @Override - public String toString() { - return "MessageAttributeValue{" - + "stringValue='" - + stringValue - + "'" - + ", binaryValue=" - + binaryValue - + ", stringListValues=" - + stringListValues - + ", binaryListValues=" - + binaryListValues - + ", dataType='" - + dataType - + "'" - + "}"; - } -} +public record MessageAttributeValue( + String stringValue, + ByteBuffer binaryValue, + List stringListValues, + List binaryListValues, + String dataType) {} diff --git a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/SqsInboundMessage.java b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/SqsInboundMessage.java index 82527bf593..e049e03075 100644 --- a/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/SqsInboundMessage.java +++ b/connectors/aws/aws-sqs/src/main/java/io/camunda/connector/inbound/model/message/SqsInboundMessage.java @@ -7,124 +7,12 @@ package io.camunda.connector.inbound.model.message; import java.util.Map; -import java.util.Objects; -public class SqsInboundMessage { - private String messageId; - private String receiptHandle; - private String mD5OfBody; - private Object body; - private Map attributes; - private String mD5OfMessageAttributes; - private Map messageAttributes; - - public String getMessageId() { - return messageId; - } - - public void setMessageId(final String messageId) { - this.messageId = messageId; - } - - public String getReceiptHandle() { - return receiptHandle; - } - - public void setReceiptHandle(final String receiptHandle) { - this.receiptHandle = receiptHandle; - } - - public String getmD5OfBody() { - return mD5OfBody; - } - - public void setmD5OfBody(final String mD5OfBody) { - this.mD5OfBody = mD5OfBody; - } - - public Object getBody() { - return body; - } - - public void setBody(final Object body) { - this.body = body; - } - - public Map getAttributes() { - return attributes; - } - - public void setAttributes(final Map attributes) { - this.attributes = attributes; - } - - public String getMD5OfMessageAttributes() { - return mD5OfMessageAttributes; - } - - public void setMD5OfMessageAttributes(final String mD5OfMessageAttributes) { - this.mD5OfMessageAttributes = mD5OfMessageAttributes; - } - - public Map getMessageAttributes() { - return messageAttributes; - } - - public void setMessageAttributes(final Map messageAttributes) { - this.messageAttributes = messageAttributes; - } - - @Override - public boolean equals(final Object o) { - if (this == o) { - return true; - } - if (o == null || getClass() != o.getClass()) { - return false; - } - final SqsInboundMessage that = (SqsInboundMessage) o; - return Objects.equals(messageId, that.messageId) - && Objects.equals(receiptHandle, that.receiptHandle) - && Objects.equals(mD5OfBody, that.mD5OfBody) - && Objects.equals(body, that.body) - && Objects.equals(attributes, that.attributes) - && Objects.equals(mD5OfMessageAttributes, that.mD5OfMessageAttributes) - && Objects.equals(messageAttributes, that.messageAttributes); - } - - @Override - public int hashCode() { - return Objects.hash( - messageId, - receiptHandle, - mD5OfBody, - body, - attributes, - mD5OfMessageAttributes, - messageAttributes); - } - - @Override - public String toString() { - return "SqsInboundMessage{" - + "messageId='" - + messageId - + "'" - + ", receiptHandle='" - + receiptHandle - + "'" - + ", mD5OfBody='" - + mD5OfBody - + "'" - + ", body=" - + body - + ", attributes=" - + attributes - + ", mD5OfMessageAttributes='" - + mD5OfMessageAttributes - + "'" - + ", messageAttributes=" - + messageAttributes - + "}"; - } -} +public record SqsInboundMessage( + String messageId, + String receiptHandle, + String mD5OfBody, + Object body, + Map attributes, + String mD5OfMessageAttributes, + Map messageAttributes) {} diff --git a/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/MessageMapperTest.java b/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/MessageMapperTest.java index 2fc4e6ae6a..7037892c80 100644 --- a/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/MessageMapperTest.java +++ b/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/MessageMapperTest.java @@ -65,22 +65,21 @@ public void toSqsInboundMessage_shouldMapAllProperties() { // When SqsInboundMessage sqsInboundMessage = MessageMapper.toSqsInboundMessage(awsMessage); // then - assertThat(sqsInboundMessage.getMessageId()).isEqualTo(MESSAGE_ID); - assertThat(sqsInboundMessage.getReceiptHandle()).isEqualTo(RECEIPT_HANDLE); - assertThat(sqsInboundMessage.getMD5OfMessageAttributes()).isEqualTo(MD5_OF_MESSAGE_ATTRIBUTES); - assertThat(sqsInboundMessage.getAttributes()).isEqualTo(ATTRIBUTES); - assertThat(sqsInboundMessage.getmD5OfBody()).isEqualTo(JSON_BODY); - assertThat(sqsInboundMessage.getBody()).isEqualTo(STRING_BODY); + assertThat(sqsInboundMessage.messageId()).isEqualTo(MESSAGE_ID); + assertThat(sqsInboundMessage.receiptHandle()).isEqualTo(RECEIPT_HANDLE); + assertThat(sqsInboundMessage.mD5OfMessageAttributes()).isEqualTo(MD5_OF_MESSAGE_ATTRIBUTES); + assertThat(sqsInboundMessage.attributes()).isEqualTo(ATTRIBUTES); + assertThat(sqsInboundMessage.mD5OfBody()).isEqualTo(JSON_BODY); + assertThat(sqsInboundMessage.body()).isEqualTo(STRING_BODY); io.camunda.connector.inbound.model.message.MessageAttributeValue - sqsInboundMessageAttributeValue = - sqsInboundMessage.getMessageAttributes().get("attributeKey"); - assertThat(sqsInboundMessageAttributeValue.getStringValue()).isEqualTo(ATTRIBUTE_STRING_VALUE); - assertThat(sqsInboundMessageAttributeValue.getDataType()).isEqualTo(ATTRIBUTE_DATA_TYPE); - assertThat(sqsInboundMessageAttributeValue.getBinaryValue()).isEqualTo(ATTRIBUTE_BINARY_TYPE); - assertThat(sqsInboundMessageAttributeValue.getStringListValues()) + sqsInboundMessageAttributeValue = sqsInboundMessage.messageAttributes().get("attributeKey"); + assertThat(sqsInboundMessageAttributeValue.stringValue()).isEqualTo(ATTRIBUTE_STRING_VALUE); + assertThat(sqsInboundMessageAttributeValue.dataType()).isEqualTo(ATTRIBUTE_DATA_TYPE); + assertThat(sqsInboundMessageAttributeValue.binaryValue()).isEqualTo(ATTRIBUTE_BINARY_TYPE); + assertThat(sqsInboundMessageAttributeValue.stringListValues()) .isEqualTo(List.of(ATTRIBUTE_STRING_VALUE)); - assertThat(sqsInboundMessageAttributeValue.getBinaryListValues()) + assertThat(sqsInboundMessageAttributeValue.binaryListValues()) .isEqualTo(List.of(ATTRIBUTE_BINARY_TYPE)); } @@ -91,7 +90,7 @@ public void toSqsInboundMessage_shouldMapStringJsonBodyToObject() { // When SqsInboundMessage sqsInboundMessage = MessageMapper.toSqsInboundMessage(awsMessage); // then - JsonNode jsonNode = objectMapper.convertValue(sqsInboundMessage.getBody(), JsonNode.class); + JsonNode jsonNode = objectMapper.convertValue(sqsInboundMessage.body(), JsonNode.class); String actualValue = jsonNode.get("key").get("innerKey").asText(); assertThat(actualValue).isEqualTo("value"); } @@ -104,7 +103,7 @@ public void toSqsInboundMessage_shouldWorkWithEmptyAttributes() { // When SqsInboundMessage sqsInboundMessage = MessageMapper.toSqsInboundMessage(awsMessage); // then - assertThat(sqsInboundMessage.getAttributes()).isEqualTo(new HashMap<>()); - assertThat(sqsInboundMessage.getMessageAttributes()).isEqualTo(new HashMap<>()); + assertThat(sqsInboundMessage.attributes()).isEqualTo(new HashMap<>()); + assertThat(sqsInboundMessage.messageAttributes()).isEqualTo(new HashMap<>()); } } diff --git a/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/SqsQueueConsumerTest.java b/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/SqsQueueConsumerTest.java index 569fb6921e..d745285d02 100644 --- a/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/SqsQueueConsumerTest.java +++ b/connectors/aws/aws-sqs/src/test/java/io/camunda/connector/inbound/SqsQueueConsumerTest.java @@ -52,11 +52,7 @@ void setUp() { message = new Message().withMessageId("message id").withBody("body msg"); - queue = new SqsInboundQueueProperties(); - queue.setUrl("my-queue"); - queue.setAttributeNames(null); - queue.setMessageAttributeNames(null); - queue.setPollingWaitTime("1"); + queue = new SqsInboundQueueProperties("us-east-1", "my-queue", null, null, "1"); properties.setQueue(queue); @@ -96,8 +92,10 @@ void run_shouldActivateWithAttributes() throws InterruptedException { // given List attributeNames = Collections.singletonList("attribute"); List messageAttributeNames = Collections.singletonList("attribute"); - queue.setAttributeNames(attributeNames); - queue.setMessageAttributeNames(messageAttributeNames); + queue = + new SqsInboundQueueProperties( + "us-east-1", "my-queue", attributeNames, messageAttributeNames, "1"); + properties.setQueue(queue); when(sqsClient.receiveMessage(requestArgumentCaptor.capture())) .thenReturn(receiveMessageResult); when(receiveMessageResult.getMessages()).thenReturn(messages);