Skip to content

Latest commit

 

History

History
 
 

connector-runtime-core

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Connector Runtime Core utilities

A collection of runtime utilities to wrap Connector functions as job workers and handle Connector discovery. This artifact can be used to build custom Connector runtimes. If you are looking for a ready-to-use Connector runtime, refer to the Spring Connector Runtime or a corresponding Spring Boot starter.

Wrapping a Connector function

Include the job worker runtime utilities as maven dependency:

<dependency>
  <groupId>io.camunda.connector</groupId>
  <artifactId>connector-runtime-core</artifactId>
  <version>${version.connectors}</version>
</dependency>

You can create a job worker by wrapping a Connector function like this:

import io.camunda.connector.slack.outbound.SlackFunction;
import io.camunda.connector.runtime.jobworker.api.outbound.ConnectorJobHandler;
import io.camunda.zeebe.client.ZeebeClient;

public class Main {

  public static void main(String[] args) {

    var zeebeClient = ZeebeClient.newClientBuilder().build();

    zeebeClient.newWorker()
        .jobType("slack")
        .handler(new ConnectorJobHandler(new SlackFunction()))
        .name("SLACK")
        .fetchVariables("foo", "bar")
        .open();
  }
}

Connector discovery

Implementations of the ConnectorFactory interface are responsible for Connector configuration discovery and creation of Connector instances.

You can use out-of-the-box OutboundConnectorFactory andInboundConnectorFactory implementations, and you can also extend to support custom discovery mechanisms. Default discovery mechanism supports configuring Connectors via environment variables and with SPI. Only one configuration approach must be used per application.

Discovery via environment variables

Outbound Connector configuration example:

CONNECTOR_SLACK_FUNCTION=io.camunda.connector.runtime.util.outbound.SlackFunction
CONNECTOR_SLACK_TYPE=io.camunda.connector:SLACK
CONNECTOR_SLACK_INPUT_VARIABLES=foo,bar
CONNECTOR_SLACK_TIMEOUT=10000 # optional

Inbound Connector configuration example:

CONNECTOR_KAFKA_SUBSCRIPTION_EXECUTABLE=io.camunda.connector.runtime.util.outbound.KafkaSubscription
CONNECTOR_KAFKA_SUBSCRIPTION_TYPE=io.camunda.connector:KAFKA_SUBSCRIPTION

When using discovery via environment variables, you can omit the @InboundConnector/@OutboundConnector annotation if you provide all the environment variables. Alternatively, if you decide to keep the annotation, you don't have to provide all the variables. CONNECTOR_${NAME}_FUNCTION for outbound or CONNECTOR_${NAME}_EXECUTABLE for inbound will be enough for discovery to work, and the remaining properties will be populated from annotation.

Connector names must be globally unique, i.e. outbound and inbound Connectors cannot have the same name. If you have both inbound and outbound Connectors for the same system, e.g. RabbitMQ, we recommend adding a _SUBSCRIPTION suffix to the Connector name.

SPI discovery

SPI discovery utilizes Java ServiceProvider Interface to automatically discover Connectors present in classpath. Connector Service Provider interfaces are OutboundConnectorFunction and InboundConnectorExecutable.

When using SPI discovery, annotating your connector with @InboundConnector or @OutboundConnector is mandatory.

Build

mvn clean package