This package includes several Node-RED nodes to support sending data to the Tulip API. The included nodes are:
tulip-machine-attribute
: sends data to Tulip machine attribute endpointstulip-tables
: sends data and reads data from Tulip tablestulip-api-auth
: a configuration node that authenticates Tulip API requests using Tulip API token credentials
Note: To use the Tulip API, you must be a registered Tulip user with a factory instance. In this README, we will use the Tulip account url your-factory-instance.tulip.co
to refer to your account.
You can install this node either through npm
or the Node-RED palette.
Navigate to your Node-RED user directory, for example ~/.node-red/
, and run the following command:
npm install @tulip/node-red-tulip-api
Open the Node-RED Editor, navigate to the menu (upper right-hand corner), click Manage palette > Install, and search for node-red-tulip-api
. Click install.
If there is an issue with installation, please create an issue with details.
Before using a tulip-machine-attribute
node, make sure that you have completed the following steps:
-
Have machine monitoring enabled on your factory instance. This is required to use the Machine Attributes API.
-
Follow the steps in this support article to:
- Configure an API token with
attributes:write
permissions - Create a machine that uses the Tulip API as a datasource
- Define machine attributes for the machine
- Name: Display name for the node instance in the editor
- Tulip Api Authentication: A configuration node with authentication details for an API token on your Tulip account. The API token must have
attributes:write
permissions. See more details in the Tulip API Auth Node section. - Attribute Config: Select whether to write to a single attribute, or if unchecked, then you can instead performed batched writes by setting
msg.payload
to a list of attributes, each in the format{ attributeId, machineId, value }
. - Device Info: Defines which machine attribute endpoint this node will send data to. You can copy-paste this field from the target machine attribute on your factory instance by following these steps:
- Navigate to
your-factory-instance.tulip.co
- Click on Shop Floor > Machines
- Click on the target machine
- Copy-paste the JSON field with
attributeId
andmachineId
properties for the target machine attribute
- Navigate to
- HTTP Options:
- Enable Connection Keep-Alive: Whether to set
keepAlive=true
for the http agent. Note that this sets the keep-alive behaviour of the HTTP agent, which is different than setting the 'Connection': 'Keep-Alive' HTTP header. - Keep-Alive Initial Delay (ms): Sets the
keepAliveMsecs
of the http agent. Only relevant is keep-alive is enabled.
- Enable Connection Keep-Alive: Whether to set
- Output: Whether to retain all properties of the input message in the output message or clear them. If retaining input properties, input message properties that conflict with a property set by this node (ex:
msg.response
) then the input message property will be overwritten. - Attribute Source: What source to use for the attribute value. For example, if set to
msg.payload
, the attribute will be sent the value ofmsg.payload
; if set to a hardcoded string, the attribute will be sent the hardcoded string, etc. Supported sources are:- properties of
msg
,flows
, orglobal
- strings
- numbers
- JSONata expressions
- environment variables
- properties of
msg.payload
: The value of the attribute to send. Should match the type of the machine attribute endpoint. A different input property thanpayload
can be set as the attribute value by setting theAttribute Source
property.msg.machineId
(optional): Value to override themachineId
set in "Device Info".msg.attributeId
(optional): Value to override theattrbiuteId
set in "Device Info"msg.headers
(optional): Extra headers for the HTTP API requests. Do not setContent-Type
; it will always be overridden toContent-Type: application/json
msg.response
: The HTTP response from the API request.msg.payload
: The parsed response body.
The Tulip Tables API node supports sending data to and reading data from Tulip Tables, as well as reading Tulip Table metadata, using the Tulip Tables API.
Each tulip-tables
node is configured to send data to a single Tulip Tables API endpoint. On an input message, the node will send the configured request and output the HTTP response along with any returned data. The Query Type field determines the type of request, relevant parameters, and the response data type. See the Tulip Tables API documentation at your-factory-instance.tulip.co/apiDocs
for more information on the different types of requests.
- Name: Display name for the node instance in the editor
- Tulip Api Authentication: A configuration node with authentication details for an API token on your Tulip account. The API token must have
tables:read
andtables:write
permissions for read and write operations respectively. See more details in the Tulip API Auth Node section. - HTTP Options:
- Enable Connection Keep-Alive: Whether to set
keepAlive=true
for the http agent. Note that this sets the keep-alive behaviour of the HTTP agent, which is different than setting the 'Connection': 'Keep-Alive' HTTP header. - Keep-Alive Initial Delay (ms): Sets the
keepAliveMsecs
of the http agent. Only relevant is keep-alive is enabled.
- Enable Connection Keep-Alive: Whether to set
- Output: Whether to retain all properties of the input message in the output message or clear them. If retaining input properties, input message properties that conflict with a property set by this node (ex:
msg.response
) then the input message property will be overwritten. - Query Type: This field determines which endpoint to send the request to. All other configuration is dependent on the query type. For example, using the endpoint "Count records", the following configuration values will appear (from the API docs):
- Table ID: The id of a Tulip Table.
- Filters: An optional array of filter expressions to filter the Table records by. Each filter is an object specifying the
field
(name of a table column),functionType
(comparison function), andarg
(the value to compare to). - Filter Aggregator: How the filters in the filter parameter are combined.
all
means that every filter must match a record in order for the record to be included.any
means at least one filter must match a record in order for the record to be included.
msg.body
: If the query type is a POST or PUT request, the body of the request. Overrides any data in the "Request Body" field.msg.[parameter]
: Any parameter of a Tulip Tables API request can be set by the inputmsg.[parameter]
. The message value overrides the parameter value set by the node configuration. For example,msg.tableId
will override "Table ID". The parameter name must match the parameter name listed in the API documentation.msg.headers
(optional): Extra headers for the HTTP API requests. Do not setContent-Type
; it will always be overridden toContent-Type: application/json
msg.response
: The HTTP response from the API request.msg.payload
: The parsed response body.
Each tulip-api-auth
node configures authentication for using the Tulip API. The API credentials should be for a key on the specified factory instance that has the correct permissions to make the specified API calls.
Requests will be sent to: ${protocol}://{factory-url}:{port}/{endpoint}
Each authentication node can be shared between multiple Tulip API nodes.
- Name: Display name for the node instance in the editor.
- Protocol: Which protocol to use for API calls (
http
orhttps
). Defaults tohttps
. - Factory URL: For example,
your-factory-instance.tulip.co
- Port (optional): Custom port to use for API calls. Defaults to
80
forhttp
and443
forhttps
. - API Key: The API key for the API token. Should start with
apikey.2_
. - API Secret: The API secret for the API token.