Skip to content
This repository has been archived by the owner on Oct 31, 2024. It is now read-only.

Java application to push tags to an OSISoft PI Server

License

Notifications You must be signed in to change notification settings

hms-networks/flexy-osisoft-connector

Repository files navigation

Ewon Flexy OSIsoft Connector

About

This application connects tags from a Flexy to an OSIsoft PI dataserver.

Support

This application is supported by HMS' North American offices.

Phone Forum Email
+1 312 829 0601, Option 2 hms.how [email protected]
  1. General Information
  2. Starting Files
  3. Getting Started
    1. Basic Authentication
    2. Configuration
    3. Flexy Configuration
    4. Installation
    5. Running
  4. Certificates
    1. Generate The Certificate
    2. Install The Certificate On Server
    3. Transfer Certificate To Flexy
  5. Configuration File
    1. Example ConnectorConfig.json
    2. Server Config
      1. URL
      2. Web ID
      3. Credentials
    3. Ewon Config
      1. Certificate Path
      2. Queue Data Poll Max Behind Time
    4. App Config
      1. Communication Type
      2. HTTP Timeout Seconds
      3. OSIsoft Tag Naming Scheme
      4. LoggingLevel
      5. Auto Restart
      6. Data Poll Rate (MS)
      7. Data Post Rate (MS)
  6. Customizing The Application
  7. Tag Configuration
  8. OMF Support
  9. OSIsoft Cloud Service
  10. JVM Logger
  11. Troubleshooting Common Issues

General Information

The OSIsoft connector makes use of the Flexy's historical logging functionality to send historical data points from a Flexy to OSIsoft PIWebApi. The connector utilizes this functionality to buffer up to 900,000 data points when connection to PIWebApi is lost. More information can be found here: Ewon Historical Logging

Getting Started

Basic Authentication

This connector uses basic authentication (RFC7617) to communicate with OSIsoft and requires basic authentication to be enabled.

Starting Files

The connector release zip has a starting files directory included in it. This starting files directory contains JVMRUN file and connector configuration file, as well as an OCS specific basic script.

Configuration

User configuration of the application parameters is done through the ConnectorConfig.json file. This file must be modified to match the OSIsoft configuration.

FTP Configuration

To change configuration values, follow the below steps:

  • Transfer the ConnectorConfig.json file on the Flexy in the /usr/ directory to a local machine via FTP if one exists, otherwise skip this step.
  • Edit the ConnectorConfig.json file with updated configuration.
  • Transfer the ConnectorConfig.json file on the local machine to the Flexy in the /usr/ directory via FTP.

Flexy Configuration

Installation

Using FTP transfer the following files to the /usr/ directory of the Ewon via FTP.

  • ConnectorConfig.json, an example file is provided in the starting-files directory of the release zip.
  • flexy-osisoft-connector-x-x-x.jar, the latest version can be downloaded from the github releases.
  • jvmrun, this file is provided in the starting-files directory of the release zip.
  • You must also follow all steps in the Certificates section below and transfer the resulting certificates to the correct location on the Flexy.

Running

The application will start automatically on power on if the jvmrun file has been transferred to the /usr/ directory of the Ewon via FTP and the AutoRestart configuration setting is enabled.

Certificates

The Flexy by default only allows HTTPS connections with servers that have certificates verified by a trusted certificate authority. To enable a HTTPS connections with a server that has a self signed certificate the Flexy must have a copy of that certificate. Follow the steps outlined in this section to create and install a new certificate.

Generate the certificate

Here is an example of generating a certificate using openssl.

Generate a certificate and a private key good for 5 years.

openssl req -newkey rsa:2048 -nodes -keyout key.pem -x509 -days 1825 -out certificate.crt

Answer the prompts, making sure that the "Common Name" is set to the IP Address of the OSIsoft server.

Combine the certificate and private key into a .p12 file

openssl pkcs12 -inkey key.pem -in certificate.crt -export -out certificate.p12

You will be prompted to enter an export password, the again to verify. Remember this password.

Install the certificate on server

These installation instructions are specific to Windows 7. If the OSIsoft server is running on a different OS the process may differ.

  • In Windows, right click on the certificate.crt file and click "Install Certificate" to the current user.
  • Follow the prompts and place the certificate in the "Trusted Root Certification Authorities" store.
  • When you click finish a security prompt will warn you that it cannot validate the certificate's origin and ask if you want to install this certificate, click yes.
  • Hold down Windows key and press R on your keyboard to open the 'run' command.
  • Type "certmgr.msc" into the run command and click "OK".
  • Expand "Certificates (Current User)", then expand "Personal", then expand and select "Certificates".
  • Click "Action"->"All Tasks"->"Import".
  • Click "Next" then "Browse".
  • In the file open window select the file extension to be "Personal Information Exchange (.pfx;.p12)".
  • Find and select the "certificate.p12" file, then click open then next.
  • There will be a prompt to enter the export password from when the certificate.p12 file was created, after doing so click next.
  • Place the certificate in the "Personal" certificate store, then click "Next" then "Finish".
  • You should be prompted that the import was successful, click "OK".

The next steps take place in the PI Web API Admin Utility tool.

  • Run "PI Web API Admin Utility".
  • Configure the server normally.
  • When you get to the "Certificate" setup page click "Change".
  • You may be prompted that a certificate binding is already configured, click "Yes" to "Do you still want to change the certificate?".
  • Select the certificate you created from the list and click "OK".
  • Continue with the rest of the configuration normally.

Transfer certificate to Flexy

The file certificate.crt must be placed somewhere in the /usr directory of the Flexy. The certificate can be transferred to the Flexy using FTP. The "CertificatePath" in ConnectorConfig.json must be updated with the path to where you store the certificate file.

// Path to the directory containing the OSIsoft server's certificate
static String eWONCertificatePath = "/usr/Certificates";

Configuration File

Example ConnectorConfig.json

{
   "ServerConfig":{
      "URL":"https://<USER-DOMAIN>/piwebapi/omf",
      "WebID":"<USER-WEB-ID>",
      "Credentials":"<USER-CREDENTIALS>"
   },
   "eWONConfig":{
      "CertificatePath":"/usr/Certificates",
      "QueueDataPollMaxBehindTimeMins": -1,
      "QueueDiagnosticTagsEnabled": false
   },
   "AppConfig":{
      "CommunicationType":"omf",
      "OSIsoftTagNamingScheme":"default",
      "LoggingLevel": 4,
      "httpTimeoutSeconds": 2,
      "AutoRestart": true,
      "DataPollRateMs": 5000,
      "DataPostRateMs": 5000
   }
}

ServerConfig

The OSIsoft PI Database Web API must be installed for this connector to work. The connector requires three items to connect to the OSIsoft PI Web API they are the URL of the server running the PI Web API, WebID of the PI Web API and a valid user name and password for the system running the PI Web API software.

URL

IP address or domain name of the system running the Web API (in this example replace with the correct domain or IP).

Below is a partial config file with the OMF protocol in use.

    {
        "ServerConfig":{
            "URL":"https://<USER-DOMAIN>/piwebapi/omf"
        }
    }

Below is a partial config file with the PIWEBAPI protocol in use.

    {
        "ServerConfig":{
            "URL":"https://<USER-DOMAIN>/piwebapi"
        }
    }

Specifying a port in the URL is possible. The following shows a partial config file with port 8080 in use.

    {
        "ServerConfig":{
            "URL":"https://<USER-DOMAIN>:8080/piwebapi/omf"
        }
    }

WebID

This field is only needed when the CommunicationType is set to "piwebapi". WebID is the web ID of the OSIsoft PI Web API instance. This value can be attained by pointing a browser to the OSIsoft PIWEBAPI URL (https:///piwebapi/dataservers). The WebID is one of several parameters returned. A username and password will be required to access the page. If a username is not required it may be cached. Try clearing the cache to verify the username and password. The same username and password will be used to create the credentials in the next step. (If the PIWEBAPI certificates are self-signed a security warning may occur when trying to access this page. This warning should be ignored.)

Credentials

Base64 encoded user credentials for basic authentication

To generate the Base64 encoded user credentials visit https://www.base64encode.org/ and encode "username:password"

Example: If the username is 'username' and the password is 'password' you would encode "username:password" and should get "dXNlcm5hbWU6cGFzc3dvcmQ="

eWONConfig

CertificatePath

Path to the directory containing the OSIsoft server's certificate. For more information see the Certificates section

Queue Data Poll Max Behind Time (QueueDataPollMaxBehindTimeMins)

Parameter to configure the data poll maximum behind time (in minutes). Changing this will modify the maximum number of minutes which the historical queue data polling may be running behind by. For example, a setting of 30 will ensure the Flexy never tries to sync data that is older than 30 minutes from current time. A value of -1 disables this functionality.

AppConfig

CommunicationType

This refers to if you are using OMF (OSIsoft Message Format) or PIWEBAPI. OMF is the recommended setting. The valid values are as follows:

  • "omf"
  • "piwebapi"

For more information on OMF read the section here: OMF

httpTimeoutSeconds

Optional field to override the default value used for HTTPS_TIMEOUT_S. If omitted the default value of 2 will be used. This field is only needed if https requests consistently take large amounts of time to complete.

OSIsoftTagNamingScheme

This field is to configure how OSIsoft tags will be named. The options are listed below:

  • default, which stands for TN-SN-TT
  • SN, which stands for serial number
  • TN, which stands for tag name
  • TT, which stands for tag type.

If the value of "default" is given, tag naming scheme will be set to TN-SN-TT. tags would be named as (tag name)-(serial number)-(tag type). The following are rules to make a valid tag name scheme:

  • Tag name scheme must include the tag name
  • Tag name options must be separated by the "-" delimiter
  • There cannot be more than 3 tag name scheme options present
  • There cannot be less than 1 tag name scheme option present
  • There cannot be any options used other than the 4 listed values of "default", "SN", "TN", or "TT"

LoggingLevel

The OSIsoft connector uses the HMS Solution Center logging library for application logging to the Ewon Flexy's realtime logs.

To change the logging level in the configuration file, specify the logging level under the AppConfig object. LoggingLevel is an optional field in the configuration file and is not required by the application to properly run.

Below is a partial example of the configuration file set to log general application state information. See Log Level for more information.

    {
        "AppConfig": {
            "LoggingLevel": 4
        }
    }

AutoRestart

Enable or disable to auto restart functionality. Setting the AutoRestart value to "true" configures the Flexy to launch the application again in the event the application crashes or ends. This requires a jvmrun file to exist on the Flexy usr directory.

Setting the AutoRestart value to 'false' prevents the application from restarting on reboots and crashes.

DataPollRateMs

This field is used to set the rate (in milliseconds) at which the connector will poll the Flexy historical data queue for data points. The default value is 5000ms (5 seconds).

DataPostRateMs

This field is used to set the rate at which the connector will post data points to the OSIsoft server. The default value is 5000ms (5 seconds).

Customizing the application

If you wish to modify, debug, or rebuild the application the toolkit and documentation is available here https://developer.ewon.biz/content/java-0. The instructions for setting up the development environment are here https://developer.ewon.biz/system/files_force/AUG-072-0-EN-%28JAVA%20J2SE%20Toolkit%20for%20eWON%20Flexy%29.pdf?download=1

Tag Configuration

To have a tag's historical data sent to OSIsoft, the tag needs to have historical logging enabled and needs to be assigned to a group. Follow the steps below for each tag.

Navigate to the tag values page. If the "mode" slider on the top left of the screen is set to "view", click on it to set it to "setup".

osisoft tag configuration step 1

Double click on a tag to open the tag configuration page. Enable historical logging for each tag you want recorded in OSIsoft by clicking the "Historical Logging Enabled" checkbox.

osisoft tag configuration step 2

Ensure the tag is added to a group. If it is not, no the tag data will not be sent to OSIsoft.

osisoft tag configuration step 3

OMF Support

The OSIsoft connector now has the ability to support OMF. To enable OMF follow the following steps:

  1. Download the latest version of PIWEBAPI - PIWEBAPI 2019 or later is required.
    1. Install the new software.
  2. Enable CSRFDefence.
    1. Open Pi System Explorer.
    2. Expand elements -> osisoft -> PI Web API -> 'computer name' -> System Configuration
    3. Click on attributes and find the field for EnableCSRFDefence.
    4. Change the value to true and click the 'check in' button at the top.
  3. Run the PI Web API Admin Utility.
    1. In the OMF services section of the configuration tool, click edit.
    2. Make sure there is a green checkmark next to every field.
    3. IMPORTANT: The PI Data Archive Server can disconnect for various reasons. Make sure this is connected if you have a connection issue.
    4. Click confirm and finish running the utility.

OSIsoft Cloud Service

OCS Account Setup

The OSIsoft connector supports an OCS connection. To make use of this feature, follow the below steps.

  1. First create an OCS account.
  2. Under the namespace tab, create an OCS namespace.
    1. Save the namespace for later use. It will be needed in another step.
  3. Under the client tab, create a client.
    1. Select "Client-Credentials" as the client type.
    2. Click the "Add Client button.
    3. Give the client a name. NOTE: the client will be the Flexy device.
    4. Select the "Account Administrator" role which will check all the role selection boxes.
    5. Make sure the token lifetime is set to 3600 seconds.
    6. Add a secret decription.
    7. Check the box that says "Never Expires".
    8. Click "Add".
    9. Copy both the client ID and client secret to use later.
  4. Under the connections tab, create a new client connection.
    1. Select OMF as the connection type.
    2. Click the "Add Connection" button.
    3. Enter the connection name, and hit next.
    4. Select the client you just created and hit next.
    5. Select the namespace you created and hit next.
    6. Click the "Save" button.
    7. Expand the dropdown menu that now shows up under the list of clients.
    8. Click on the new client, more details will be available on the right hand panel.
  5. Obtain the Client ID.
    1. Navigate to the namespace tab.
    2. Select the namespace.
    3. Click the "Display Details" button.
    4. Copy the Account id for later use. This is the tenant ID.

The namespace and tenantId will need to be added to the ConnectorConfig file and uploaded to the Flexy. The Client ID and the Client Secret will be needed for the basic script you will have running on the Flexy.

Flexy OCS Configuration File Changes

  1. Add OCS information to the ConnectorConfig.json file.
    1. Replace the {tenantId} below with the tenant ID of the OCS account.
    2. Replace the {namespace} below with the namespace of the OCS account.
    3. Make sure that the JSON formatting is valid. Below is an example of a properly formatted configuration file.
    {
        "ServerConfig":{
            "URL": "https://dat-b.osisoft.com/api/v1/Tenants/{tenantId}/Namespaces/{namespace}/omf",
            "WebID":"<USER-WEB-ID>",
            "Credentials":"<USER-CREDENTIALS>"
        },
        "eWONConfig":{
            "CertificatePath":"/usr"
        },
        "AppConfig": {
            "LoggingLevel": 4,
            "CommunicationType": "omfOcs"
        }
    }
  1. Upload the updated ConnectorConfig.json file to the /usr directory of the Flexy.

Flexy OCS BASIC Script

  1. Create a tag in the Flexy for the Basic script to store information.

    1. On the Flexy's web page, click to expand the "Tags" section.
    2. Click the "Values" tab.
    3. Click the "MODE" slider to say "setup".
    4. Click the "Add" button.
    5. Enter the tag name "tokenReq".
    6. Under the "I/O Server Setup" section, change the type to "Integer".
    7. Leave everything else as the default values and click "Add Tag" at the bottom right of the window.
  2. Obtain URL encoded client Id and client secret.

    1. In a web browser such as Internet Explorer or Chrome, navigate to the website https://www.urlencoder.org/
    2. Copy the client ID into the encoder section of that website.
    3. Leave the destination character set as UTF-8.
    4. Leave the destination newline seperator as LF (Unix).
    5. Hit Encode.
    6. Copy out the encoded client id and save for later use.
    7. Copy the client secret into the encoder section of that website.
    8. Leave the destination character set as UTF-8.
    9. Leave the destination newline seperator as LF (Unix).
    10. Hit Encode.
    11. Copy out the encoded client secret for later use.
  3. Import the below basic script to the Flexy Basic IDE.

    1. On the Flexy's web page, click to expand the "Setup" section.
    2. Click on the "BASIC IDE" tab.
    3. Click "File".
    4. Click "Import".
    5. Click "Select".
    6. Navigate to the unzipped directory of the OSIsoft Connector and select the file "OcsBasicScript.txt"
    7. Click "Import".
    8. Change the xxxxxx for client ID to be the URL encoded client id that you saved previously.
    9. Change the yyyyyy for client secret the URL encoded client secret you saved previously.
    10. Click on "File".
    11. Click on "Save".
    12. Click on the script execution slider that says "Stopped" to switch it to say "Running".

You can now restart the Flexy to restart the Java application. Messages will be sent to the OCS endpoint.

Troubleshooting common issues

Commonly encountered issues:

  • Certificates
    • You will not be able to connect to the server if the certificate is incorrect.
    • The first thing to check is the 'common name' of the certificate. This needs to match the ip address or domain name of the OSIsoft server's machine.
  • Not connecting when OMF support is enabled.
    • We have found that you may need to rerun the PI Web API Admin Utility to ensure that PI data archive is connected. This is especially true if the connector was working properly and then stopped working after restarting the OSIsoft server machine.

OMF response logs

OMF request responses will be logged in the /usr directory of the Flexy, and contained messages (such as warnings or errors) will be relayed to the Ewon's Realtime logs. Type initialization response logs are stored with the filename format {data type} + "Response.json" Container initialization response logs are stored with the filename format {container} + {container batch number} + "Response.json" Data message response logs are stored with the file name "dataMessage.json". Only the latest response is retained.

About

Java application to push tags to an OSISoft PI Server

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •