Welcome to the Seeq Connector SDK for Java!
This SDK is intended for developers that wish to write a Seeq datasource connector that can be loaded by a Seeq agent and facilitate access to data in Seeq.
Seeq connectors can be written in Java or C# but this repository is intended to be used for developing Java Connectors. Java development can occur on Windows, OSX or Ubuntu operating systems.
It is recommended that you initially test with a "test" version of your Seeq Remote Agent. This will seperate your production connections from your test connections, allowing you to restart the remote agent without impacting users. This repository contains an embedded remote agent that allows your development environment to interactively debug your connector.
Before proceeding we recommend you to install java 21 from https://docs.aws.amazon.com/corretto/latest/corretto-21-ug/downloads-list.html and change your build/build.bat scripts to set the JAVA_HOME variable to the location where your java is installed. The Java version of the SDK is built with Gradle. We recommend that you familiarize yourself with the basics of Gradle before proceeding.
Before doing anything else, we recommend that you build the connector template and ensure that it is fully working with your system.
From the root directory, execute the build
command. This command will download dependencies from the web, so make
sure you have a good internet connection. If you have any non-obvious issues building this project, please post your
issue along with any error messages on the Seeq Developer Club forum.
IntelliJ IDEA is the recommended Integrated Development Environment (IDE) to use for developing and debugging your connector. You can use the free IntelliJ IDEA Community Edition.
Import the project into IntelliJ IDEA by taking the following steps:
- At the IntelliJ launch screen, select Open or import. If you're already in an IntelliJ project, select File > * Open*.
- Browse to the extracted seeq-connector-sdk/java folder.
- Click OK.
On the left-hand side of the screen, you will see a Project tab and there will be a bolded java [seeq-connector-sdk] folder at the top level. There should be a small light-blue square in the bottom-right of the folder icon, which indicates that it was recognized as a Gradle project.
The Build tab at the bottom should eventually print BUILD SUCCESSFUL
to indicate that the Gradle project was built
correctly.
If you encounter Gradle build errors, verify that Gradle is using the correct JVM. In your IntelliJ Settings, go to
Build, Execution, Deployment > Build Tools > Gradle and select Add JDK in the dropdown menu for Gradle JVM. In the
popup for setting the JDK home directory, select the java
directory you just installed.
Take the following steps to verify your debugging setup:
- Open the
src/main/java/com/seeq/link/sdk/debugging/Main.java
file in theseeq-link-sdk-debugging-agent
project. - Modify the URL on the line
String seeqUrl = "https://yourserver.seeq.host";
to match your Seeq server - Retrieve the agent_api_key from your Seeq Server by logging in as a Seeq Administrator and navigating to the API Documentation page. Expand the System group and expand GET /system/agentKey. Click Execute
- Pre-provision this agent on your Seeq server by logging in as a Seeq Administrator and navigating to the Agents tab on the Administration page. Click the "Add Agent" button and fill the presented fields. Provide the machine name and "Java Connector SDK Debugging Agent" as the agent name. Click "Add Agent". Wait for pre-provisioning to complete. Copy the displayed one-time password.
- Replace
<your_agent_one_time_password>
in theagent.otp
file in the resources/data/keys/ directory of theseeq-link-sdk-debugging-agent
project with the one-time password you copied from the previous step. - Set a breakpoint on the first line of the
main()
function. - On the right-hand edge of IntelliJ there is a Gradle tab. Click on that tab to open the Gradle tool window, then right-click on seeq-connector-sdk > seeq-link-sdk-debugging-agent > Tasks > application > run and select Debug.
- You should hit the breakpoint you set. This verifies that your IDE built your project correctly and can connect its debugger to it.
- With execution paused at the breakpoint, open the
src/main/java/com/mycompany/seeq/link/connector/MyConnector.java
file in themycompany-seeq-link-connector-myconnector
and put a breakpoint on the first line of theinitialize()
function. - Resume execution (Run > Debugging Actions > Resume Program). You should hit the next breakpoint. This verifies that the debugging agent can load the template connector correctly.
- Resume execution.
- Bring up Seeq Workbench and click on the connections section at the top of the screen. You should
see
My Connector Type: My First Connection
in the list of connections, with 5000 items indexed. - In Seeq Workbench's Data tab, search for
simulated
. - A list of simulated signals should appear in the results. Click on any of the results.
- The signal should be added to the Details pane and a repeating waveform should be shown in the trend. This verifies that the template connector is able to index its signals and respond to data queries.
Now you're ready to start development!
You will probably want to adjust the name and group of your connector. You can do so by using rename refactorings on the
classes and folders in your IDE. You'll also have to adjust ALL the settings.gradle.kts
and build.gradle.kts
files accordingly, including the one in the seeq-link-sdk-debugging-agent
folder. After renaming, you will need to
click the Reload All Gradle Projects button within the Gradle tool window.
Connectors are discovered at runtime using Java's ServiceLoader
mechanism. You'll find your connector registered under
src/main/resources/META-INF/services/com.seeq.link.sdk.interfaces.ConnectorV2
. Make sure this file contains the
correct class name. If you use rename refactoring in your IDE, it should update this file automatically.
You can add additional dependencies in the build.gradle.kts
file in your connector's folder.
Once you are ready to start developing, just open the MyConnector.java
and MyConnection.java
files in your IDE and
start reading through the heavily-annotated source code. The template connector uses a small class called
DatasourceSimulator
. You'll know you've removed all the template-specific code when you can delete this file from
the project and still build without errors.
Any log messages you create using the log()
method on ConnectorServiceV2
and DatasourceConnectionServiceV2
will go
to the debug console and to the java/seeq-link-sdk-debugging-agent/build/log/jvm-debugging-agent.log
file.
When you are ready to deploy your connector to a test or production remote agent, execute the build
command. A zip file will be
created in the build/distributions
folder of your connector.
- Shut down the Seeq Remote Agent - execute
seeq stop
in the Seeq CLI - Copy the generated zip file to the
plugins/connectors
folder within Seeq'sdata
folder (The data folder is usuallyC:\ProgramData\Seeq\data
) - Extract the contents of the zip file.
- Start the Seeq Remote Agent - execute
seeq start
in the Seeq CLI
You should see your connector show up in Seeq when you go to add a datasource in the Seeq Administration Panel and you choose your remote agent.
Once deployed, log messages you create using the log()
method on ConnectorServiceV2
and DatasourceConnectionServiceV2
will go to log/jvm-link/jvm-link.log
file in the Seeq data folder.