cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
Showing results for 
Search instead for 
Did you mean: 

Community Tip - Learn all about the Community Ranking System, a fun gamification element of the PTC Community. X

ThingWorx Applications & External connectors

LB_9940670
5-Regular Member

ThingWorx Applications & External connectors

Introduction

ThingWorx Applications (RTPPM, AMU, CWC) standard data ingestion require an industrial connection between Kepware and ThingWorx. However, data aren't always available through Kepware tags. This documentation will outline the process on how to leverage data flowing by using external connectors such as an ERP system.

Requirements

  • ThingWorx
  • CWC, RTPPM or AMU
  • SQL
  • External Connector
  • ThingWorx Applications properly configured

Each ThingWorx application has different data requirements, make sure to respect them:

Entities Creation

When creating an external connector, some entities might need to be created. To facilitate the development and the export process it is recommended to create a custom project. This project could include all new entities created:

  • Thing/ThingShape that contains the logic
  • Application Keys
  • User
  • Other

External Connector

An external connector can either be:

  • ERP
  • MES
  • Custom views
  • External databases
  • Other data sources

Communication Protocol

The recommended communication protocol used to establish the connection between ThingWorx and the external connector is a REST API.

Data Automation

For data automation retrieval, there are 2 ways that can be used:

  1. External Source -> ThingWorx

LB_9940670_1-1735926169272.jpeg

 

The best practice is to send messages from external sources to ThingWorx. Then subscription can be used to trigger the data processing logic.

  1. ThingWorx <-> External Source

LB_9940670_2-1735926236298.jpeg

 

Another way is to trigger the external sources using ThingWorx timers to get the data. However, this is not recommended for performance and timing purpose.

Interface Data Retrieval

On another end, it is possible to customize out-of-the-box ThingWorx interfaces and use buttons as triggers for data retrieval. In those cases, ThingWorx will ask for data to the external sources via GET request through the REST API.

LB_9940670_3-1735926286069.jpeg

 

API Call

As mentioned before, REST API protocol is preferred to allow data flow between external connectors and ThingWorx. Depending on which way data retrieval is used here’s how to proceed for API call:

 

External Source -> ThingWorx

  1. Create an External Connector Thing with the ODataConnector Thing Template
    1. Configure the thing properly according to the external source
    2. Create a JSON property within the external source can write
    3. Create a subscription that is triggered on JSON property data change
    4. Create processing data services that will be called within the previous subscription
    5. Write data in application properties so the OOTB logic can go on

ThingWorx <-> External Source

  1. Create an External Connector Thing with the ODataConnector Thing Template
    1. Configure the thing properly according to the external source
    2. Create services or routes to request desired data from external sources
    3. Create processing data services that will call previous request data services/routes and then process the data
      1.      Write data in application properties so the OOTB logic can go on (data automation)
      2.      Create/Update actions (Data non application dependent)
    4. API Call directly in a ThingWorx service
      1. Use ThingWorx Snippet for GET/POST request

LB_9940670_4-1735926347843.png

 

 

For more documentation :

Data Format

JSON universal data format is recommended to communicate between the external connector and ThingWorx. The JSON structure must be consistent and must contain key data that will allow to associate external data with the proper equipment, tool, site, etc.

 

Example of JSON structure

LB_9940670_0-1735926108578.png

Processing Data

  1. Data Validation
    • Make sure that the information received from the connector are properly formatted, valid and that they can be linked to existing data in the database (equipment, product, etc.).
  2. Data Creation/Update
    • If needed create/update record in the database
  3. Write into ThingWorx properties
    • Data received from the connector need to be written in the proper application property so the out-of-the-box subscriptions can detect a data change as they would have if the property would have been connected to a Kepware tag.
  4. Out-Of-The-Box Logic should do the rest.

Note that it is highly recommended to log error message to facilitate troubleshooting. Those messages should include the error section and the JSON message received.

0 REPLIES 0
Announcements


Top Tags