The "Connect" component is responsible for the communication with a target system. This component implements the logic of the interaction protocol, receiving and sending messages from and to the system, respectively.
This project includes only an adapter for using the Sailfish service in the th2 packed into a Docker Image. This image should be used as a base to implement extensions with the real logic for specific protocols using services in the Sailfish format.
As an example, the th2-conn-generic project implements the extension for connecting via FIX protocol using standard Sailfish's FIX service.
This configuration should be specified in the custom configuration block in schema editor.
session-alias: "connectivity-alias"
workspace: "/home/sailfish/workspace"
type: "th2_service:Your_Service_Type"
name: "your_service"
settings:
param1: "value1"
Parameters:
- session-alias - that session alias will be set for all messages received or sent by this component. It should be unique for each "Connect" component;
- workspace - the folder inside the container that will contain a plugin adapted to use in the TH2;
- type - the service type from services.xml file. If service name from services.xml file contains
-
symbols they must be replaced with_
symbol; - name - the service name that will be displayed in the events in the report;
- settings - the parameters that will be transformed to the actual service's settings specified in the services.xml file.
You can add the ability to connect to a target system by implementing your own service in the Sailfish format and putting it and its configuration to the correct places in the base image.
You need to take the following steps:
-
Create the implementation of the com.exactpro.sf.services.IService. The examples of implementing this interface can be found here. If the protocol is already implemented in the Sailfish services you can simply use the dependencies on the service's artifact for that protocol.
-
Create the services.xml configuration file that contains the description for services you can use from that "Connect" component. You can find the example here. This file must contain:
- service name - the alias to use it from the "Connect" component;
- the full class name of the com.exactpro.sf.services.IService interface implementation for the protocol;
- the full settings' class name for that protocol;
- the full validator's class name - the optional parameter. Can be omitted.
-
Create a file with VERSION in the following format (parameters plugin_alias and name can be customized, but you will need to use a different folder on step 4):
lightweight: true plugin_alias: th2_service name: th2_service build_number: 0 revision: 0 git_hash: 0 branch: fake version: 3.2.0.0 core_version: 3.2.0
-
Create you own image based on the current one and put all files to the correct places in the base image:
- Create the following directory - ${workspace}/plugins/th2_service. ${workspace} - it is a folder from the "Connect" configuration. If you use the plugin_alias and name different from th2_service in the VERSION file correct the th2_service folder name according to value you use. Let's name that directory as PLUGIN_DIRECTORY for simplicity. This name will be used in future steps.
- Artifact with the service(s) implementation(s) and all its dependencies should be put to the following directory - ${PLUGIN_DIRECTORY}/libs.
- The configuration file created on the step 2 should be put to the following directory - ${PLUGIN_DIRECTORY}/cfg.
- The VERSION file created on step 3 should be put to the following directory - ${PLUGIN_DIRECTORY}/.
Connect has 4 types of pins for interacting with th2 components. Messages that were received from / sent to the target system will be sent to the following queues:
- incoming parsed messages // it will be removed in future
- outgoing parsed messages // it will be removed in future
- incoming raw messages
- outgoing raw messages
The "Connect" component uses a separate queue to send messages. The component subscribes to that pin at the start and waits for the messages. The messages received from that pin will be sent to the target system. Also, this component is responsible for maintaining connections and sessions in the cases where this is provided by the communication protocol. Here you can automatically send heartbeat messages, send a logon/logout, requests to retransmit messages in the event of a gap, etc.
apiVersion: th2.exactpro.com/v1
kind: Th2GenericBox
spec:
image-name: your.image.repo:42/your_image_name
image-version: 1.0.0
type: th2-conn
custom-config:
session-alias: "connectivity-alias"
workspace: "/home/sailfish/workspace"
type: "th2_service:Your_Service_Type"
name: "your_service"
settings:
param1: "value1"
pins:
- name: in_parsed
connection-type: mq
attributes: ["first", "parsed", "publish"]
- name: in_raw
connection-type: mq
attributes: ["first", "raw", "publish", "store"]
- name: out_parsed
connection-type: mq
attributes: ["second", "parsed", "publish"]
- name: out_raw
connection-type: mq
attributes: ["second", "raw", "publish", "store"]
- name: fix_to_send
connection-type: mq
attributes: ["send", "parsed", "subscribe"]