Adding connectors to your development environment
To add a connector to your deployment of i2 Analyze, you must develop an i2 Connect connector.
Ensure that the DEPLOYMENT_PATTERN
variable in the <config_name>/utils/variables.conf
file is set to a pattern that includes the i2 Connect gateway.
For example:
DEPLOYMENT_PATTERN="i2c_istore"
For information about developing your own connectors, see i2 Connect gateway connector development.
Note: You can use Connector Designer to create simple connectors through a graphical user interface. When you use Connector Designer, you do not need to follow the instructions below.
To open Connector Designer, navigate to https://i2analyze.eia:9443/connector-designer/connectors
. For more information about using it, see Connector Designer.
Process overview:
- Create a custom connector image
- Update the configuration to reference connectors
- Build connector images and redeploy
Creating a connector image
Create a connector image from one of the image templates. You can deploy connectors using the following templates:
- Spring Boot for Java based connectors.
- For information about developing connectors in Java, see analyze-connect.
- i2 Connect server for Node v16 based connectors developed using the i2 Connect server SDK.
- For information about developing connectors using the SDK, see analyze-connect-node-sdk.
- NodeJS for Node v16 based connectors.
- User managed for connectors that are not managed by the config development environment. The connectors are managed manually outside of the environment.
The connector should be secured and run on port 3443
. For more information about securing your system, see Securing i2 Analyze.
Spring Boot based connector image
Copy the
/templates/springboot-connector-image
directory (including the sub-directories) to the/connector-images
directory.
Rename thespringboot-connector-image
folder to a custom connector name. The name of the directory is used to determine which connectors to deploy. Do not use spaces or special characters in the name.
The directory structure is:- connector-images - <connector_name> - target - connector-definition.json - connector-version.json - ...
Copy your connector code into the
target
directory of the connector directory. For example, copy your.jar
file into the/connector-images/<connector_name>/target
directory.Next, configure your connector.
i2 Connect server based connector image
Copy the
/templates/i2connect-server-connector-image
directory (including the sub-directories) to the/connector-images
directory.
Rename thei2connect-server-connector-image
folder to a custom connector name. The name of the directory is used to determine which connectors to deploy. Do not use spaces or special characters in the name.
The directory structure is:- connector-images - <connector_name> - app - connector-definition.json - connector-version.json - ...
Copy the i2 Connect server connector distributable into the connector directory. For example, copy your
.tar.gz
or.tgz
file into the/connector-images/<connector_name>
directory.Next, configure your connector.
NodeJS based connector image
Copy the
/templates/node-connector-image
directory (including the sub-directories) to the/connector-images
directory.
Rename thenode-connector-image
folder to a custom connector name. The name of the directory is used to determine which connectors to deploy. Do not use spaces or special characters in the name.
The directory structure is:- connector-images - <connector_name> - app - connector-definition.json - connector-version.json - ...
Copy your connector code into the
app
directory of the connector directory. For example, copy the files into the/connector-images/<connector_name>/app
directory. By default, the image will start node with the fileapp.js
.Next, configure your connector.
User managed connector
Copy the
/templates/user-managed-connector
directory to the/connector-images
directory.
Rename theuser-managed-connector
folder to a custom connector name. The name of the directory is used to determine which connectors to deploy. Do not use spaces or special characters in the name.
The directory structure is:- connector-images - <connector_name> - connector-definition.json
To configure SSL on the external connector, you must do the following:
Below is the example configuration for the i2 Connect server based connector running externally.
Option 1: Use certificates generated by ADT. You can run
manage-environment -t connectors
command to generate the required certificates and keys. The script will generate the required certificates and keys in the./environment-secrets/generated-secrets/certificates/<connector_name>
directory. Once the certificate and the key are generated update your external configuration with the following values:SSL_ENABLED="true" SSL_SERVER_PORT="<port>" SSL_PRIVATE_KEY_FILE="./environment-secrets/generated-secrets/certificates/<connector_name>/server.key" SSL_CERTIFICATE_FILE="./environment-secrets/generated-secrets/certificates/<connector_name>/server.cer" SSL_CA_CERTIFICATE_FILE="./environment-secrets/generated-secrets/certificates/externalCA/CA.cer" SSL_GATEWAY_CN='gateway.user'
Option 2: Generate the required certificate and key using your own Certificate Authority (CA). Once the certificate and the key are generated update your external configuration with the following values:
SSL_ENABLED="true" SSL_SERVER_PORT="<port>" SSL_PRIVATE_KEY_FILE="<path_to_your_private_key>" SSL_CERTIFICATE_FILE="<path_to_your_certificate>" SSL_CA_CERTIFICATE_FILE="<path_to_you_certificate_authority>" SSL_GATEWAY_CN='["gateway.user","<cn_of_the_client_cert_used_outside_of_ADT>"]'
Note: With this option you will need to add additional trust certificates to each configuration that uses this external connector.
Important:
Ensure
SSL_GATEWAY_CN
includes the ADT gateway username (gateway.user
).Ensure
SSL_CA_CERTIFICATE_FILE
includes the./environment-secrets/generated-secrets/certificates/externalCA/CA.cer
file contents and, if using option 2, append your own CA certificate.This is to ensure that the connector trusts the ADT gateway client certificate.
Next, configure your connector.
Configuring a connector
Populate the values in the
<connector_name>/connector-definition.json
file with information about your connector.Key Description id
An identifier that is unique for all connectors that will be deployed. name
A name for the connector that is displayed to users in the client. configurationPath
The full path to the configuration endpoint of the connector. By default, it is config
.gatewaySchema
The short name of an optional gateway schema. When no gateway schema is used, do not provide a value. Add the referenced schema and charting scheme to the gateway-schemas
directory.type
For i2 Connect server connectors, set to i2connect-server
. For any other connectors, thetype
key is not required.userManaged
Set to true
for connectors that are managed outside of the environment. For any other connectors, theuserManaged
key is not required.baseUrl
Used only for connectors with userManaged
set totrue
. ThebaseUrl
value is the URL address of the connector. For any other connectors, thebaseUrl
key is not required.sendSensitiveHeaders
This setting effectively disables connectors that employ user-specific configuration. imageName
When specified, the connector image is tagged with a custom name during the build process and uses this name, along with the tag specified in the version file, when deploying the image. Ensure to include the registry name if different than default DockerHub. For example:
{ "id": "connector1", "name": "Connector 1", "description": "First connector", "configurationPath": "/config", "gatewaySchema": "template", "sendSensitiveHeaders": "false", "type": "i2connect-server" }
or
{ "id": "connector2", "name": "Connector 2", "description": "Second connector", "configurationPath": "/config", "gatewaySchema": "template", "sendSensitiveHeaders": "false", "userManaged": true, "baseUrl": "https://example-connector:3443" }
Notes:
- If your user managed connector is hosted in a Docker container on a different network to your config development environment, connect the Liberty container to the same network as your user managed connector container. For example, run
docker network connect <connector-network-name> liberty1.<config-name>
. - If your connector is running on your host machine's operating system, use the
host.docker.internal
as the host in thebaseUrl
value. For example, "http://host.docker.internal:3000" - If your connector is running in WSL, use the IP address for WSL as the host in the
baseUrl
value. For example, "http://172.23.0.164:3000".- You can find the IP address of your current WSL distribution by running
ip addr show eth0 | grep -oP '(?<=inet\s)\d+(\.\d+){3}'
. Note that the IP address changes every time that WSL is shutdown and restarted.
- You can find the IP address of your current WSL distribution by running
- If your user managed connector is hosted in a Docker container on a different network to your config development environment, connect the Liberty container to the same network as your user managed connector container. For example, run
Provide the version of the connector in the
<connector_name>/connector-version.json
file. For user managed connectors, this file is not required. Theversion
value specifies the version of the connector.For example:
{ "version": "0.0.1", "tag": "0-0-1" }
For more information about configuring connectors, see Managing connectors.
Adding connectors to a config
In the configuration you want to deploy your connector with, update the
configs/<config_name>/configuration/connector-references.json
file and add the directory name for your connector in theconnectors
array.
For example, to add the connector in/connector-images/example-connector
theconnector-references.json
file contains the followingconnectors
array:{ "connectors": [ { "name": "example-connector" } ], ... }
Adding additional trust certificates for external connectors (if SSL is enabled with custom CA)
If you have enabled SSL on the external connector and used your own Certificate Authority (CA), you must provide this CA in the configuration.
To do that, create configs/<config_name>/configuration/secrets/additional-trust-certificates.cer
file and copy the CA certificate into it.
This file is a text file in OpenSSL PEM format, i.e. certificates should start "-----BEGIN CERTIFICATE-----
" and can hold multiple certificates.
Defining a gateway schema (Optional)
You can develop the gateway schema and associated charting schemes by following the instructions in Developing schemas in your configuration development environment. After you develop the schemes, complete the following steps to deploy them with your configuration:
- Copy the schema and charting scheme files to the
/gateway-schemas
directory.
To define the short name of the gateway schema, the prefix of the file name is used. The convention is defined as:<short>-<name>-schema.xml
and<short>-<name>-schema-charting-scheme.xml
.
For example, files with the nameslaw-enforcement-schema.xml
andlaw-enforcement-schema-charting-schemes.xml
have the short namelaw-enforcement
. Add the short name of your schema to the
configs/<config_name>/configuration/connector-references.json
file in thegatewaySchemas
array.
For example, to add a gateway schema with the short namelaw-enforcement
, the file contains the followinggatewaySchemas
array:{ ... ], "gatewaySchemas": [ { "shortName": "law-enforcement" } ] }
Note: If you are not using any gateway schemas, do not remove the
gatewaySchemas
key from the file.Set the short name of your schema in the
<connector_name>/connector-definition.json
as the value for thegatewaySchema
key of the connector that will use the gateway schema.
Building the connector images and redeploying
Run the
deploy
command to generate the secrets for your connectors, build the connector images, and deploy your environment.deploy
If you have multiple configs, specify the config name with
-c <config-name>
.
After you add connectors to your environment, you can configure the rest of the configuration.