Jitterbit Connector SDK
Overview
Connectors allow end users in Jitterbit to connect to and interact with endpoints, and a custom connector built with the Connector SDK extends the capabilities of the endpoints an integration project can connect to and interact with. Connectors built with the Connector SDK are not limited to HTTP/REST APIs (as is Connector Builder) but can use any API provided by an endpoint.
Creating a connector with the Connector SDK requires a developer to be familiar with standard Java development practices and tools, such as Maven, Docker, Postman, and Git.
This documentation is the starting point in the development of a connector, and assumes that you are already familiar with Jitterbit, Harmony, Integration Studio, Jitterbit agents, and Java development. Please see the related parts of our documentation at the Jitterbit documentation site if you are not familiar with Jitterbit.
The current version of the Connector SDK is version 1.0.0.
Connector SDK concepts
Connectors built with the Connector SDK show up in Integration Studio just as any other connector. Once a connection is configured, they provide specific activities—as determined by the connector developer—that can be used as sources or targets in an operation. They run on private agents and work with Integration Studio.
The Dropbox connector is a custom connector developed using the Connector SDK, shown in Integration Studio with its activities: Process File, Fetch File, Get File, and Put File:
This Jitterbit connector interacts with Dropbox, providing both reading and writing of files from and to Dropbox. The example is available as source code through the GitHub repository jitterbit/dropbox-connector
and is used as the basis for the Dropbox Connector Tutorial.
Warning
The example Dropbox connector is not for production use. It is intended as a starting point for developing Jitterbit connectors built with the Connector SDK.
From a development perspective, these are the main elements of a Jitterbit connector:
- Connector: A collection of activities that interacts with a system. A connector needs to implement the
JitterbitConnector
interface. - Activity: Represents the smallest unit of execution within a Jitterbit operation. It matches to a node within a Integration Studio operation. Every activity needs to implement a
JitterbitActivity
interface with these two parts:Configuration
: Performed by an end user using the Integration Studio UI.Execution
: Executes an activity according to the user configuration.
- Endpoint: Represents a connection to a system, with endpoint information provided by an end user configuring a connection using the Integration Studio UI.
- Payload: Represents a request/response (input/output) of an activity during execution; maps to a
Payload
interface. - Request/Response: The request and response of an activity developed with the Connector SDK will always be in XML format.
adapter.json
: A JSON file containing the declarative UI associated with an endpoint connection and the activities that make up a connector. As the developer, you set the parameters that need to be configured and the types associated with each parameter. For more complex interfaces, there are components available as part of the Integration Studio UI.- XML Schema: An XML XSD file containing the declaration of the data structures used for the request or response of each activity. These XSD files are the contract between Harmony and the connector, and determine how data is mapped between Harmony and the connector.
Note
These terms are specific to custom connectors developed using the Connector SDK and differ slightly from those used in the Integration Studio UI.
Connector implementation
The Connector SDK allows developers to create custom connectors for end users to configure endpoints, whose activities can be used as sources or targets within the Integration Studio UI. There are a number of interfaces that the developer must complete when writing a connector; they are described with related code samples in Connector implementation.
Connector registration
All connectors to be used in an integration project are required to be registered, and developers need to register their connectors before building and packaging them. Detailed instructions for registering your connector and setting appropriate values in the manifest file are described in Connector registration.
Connector UI in Integration Studio
The UI of the connector as displayed in Integration Studio is defined by a JSON file (by default called adapter.json
) included in the JAR file that packages the connector.
Available UI elements—including icons and components, with code samples to create them—are described in Connector SDK UI components.
Connector synchronization
Public connectors are connectors built and maintained by Jitterbit. They are available to all users, on all agents. The JAR files for these public connectors are automatically installed and updated as required on agents, for both the public cloud agent groups and for private agents (as of Harmony version 10.1).
The public connector JAR file will be downloaded to an agent as needed once a connector has been configured and either the configuration's Test
button clicked or an activity added and configured.
Private connectors are connectors built by third-party developers (such as yourself) and are installed on private agents directly by copying the JAR file to the private agent's connectors
directory.
APIs are available for login, registering, listing, and deleting connectors. See REST APIs for details of the APIs and registration for examples of using the APIs with Postman.