This module provides an agent that runs Node-RED instances deployed from the FlowForge platform.
- NodeJS v14 or later
- A FlowForge platform instance to connect to
The Device Agent can be installed on most Linux distributions, Windows, and MacOS.
The Device Agent is published to the public npm repository as @flowforge/flowforge-device-agent.
It can be installed as a global npm module. This will ensure the agent command is on the path:
sudo npm install -g @flowforge/flowforge-device-agent
npm install -g @flowforge/flowforge-device-agent
Or you can chose to run the Docker container. When you do, you'll need to mount
the device.yml
obtained when Registering the device:
docker run --mount /path/to/device.yml:/opt/flowforge/device.yml -p 1880:1880 flowforge/device-agent:latest
The agent configuration is provided by a device.yml
file within its working
directory.
By default the agent uses /opt/flowforge-device
or c:\opt\flowforge-device
as
its working directory. This can be overridden with the -d/--dir
option.
The directory must exist and be accessible to the user that will be running the agent.
sudo mkdir /opt/flowforge-device
sudo chown -R $USER /opt/flowforge-device
mkdir c:\opt\flowforge-device
When the device is registered on the FlowForge platform, a group of configuration details are provided. These can be copied from the platform, or downloaded directly as a yml file.
This file should be copied into the working directory as device.yml
.
A different config file can be specified with the -c/--config
option.
The file must contain the following options (these are the ones provided by FlowForge)
Required options | Description |
---|---|
deviceId |
The id for the device on the FlowForge platform |
token |
Access Token to connect to the FF platform |
credentialSecret |
Key to decrypt the flow credentials |
forgeURL |
The base url of the FlowForge platform |
To enable MQTT connectivity, the following options are required. They are provided by the platform if MQTT comms are enabled.
MQTT options | Description |
---|---|
brokerURL |
The url for the platform broker |
brokerUsername |
The username to connect with - device:<teamId>:<deviceId> |
brokerPassword |
The password to connect with |
The following options can be added:
Extra options | Description |
---|---|
interval |
How often, in seconds, the agent checks in with the platform. Default: 60s |
intervalJitter |
How much, in seconds, to vary the heartbeat +/- intervalJitter . Default: 10s |
moduleCache |
If the device can not access npmjs.org then use the node modules cache in module_cache directory. Default false |
The following options are passed through to Node-RED:
Node-RED options | Description |
---|---|
port |
The port to listen on. Default: 1880 |
https |
Enable HTTPS. See below for details |
httpStatic |
Enable serving of static content from a local path |
The https
configuration option can be used to enable HTTPS within Node-RED. The values
are passed through to the Node-RED https
setting.
The ca
, key
and cert
properties can be used to provide custom certificates and keys.
The values should be set to the contents of the certificate/key.
Alternatively, the properties caPath
, keyPath
and certPath
can be used instead
to provide absolute paths to files containing the certificates/keys.
https:
keyPath: /opt/flowforge-device/certs/key.pem
certPath: /opt/flowforge-device/certs/cert.pem
caPath: /opt/flowforge-device/certs/ca.pem
This option can be used to serve content from a local directory.
If set to a path, the files in that directory will be served relative to /
.
httpStatic: /opt/flowforge-device/static-content
It is also possible to configure it with a list of directories and the corresponding path they should be served from.
httpStatic:
- path: /opt/flowforge-device/static-content/images
root: /images
- path: /opt/flowforge-device/static-content/js
root: /js
When a device should be auto registered on the FlowForge platform, a group of provisioning configuration details are required. These are generated for you in FlowForge Team Settings under the Devices tab when you create a provisioning token. These can be copied from the platform, or downloaded directly as a yml file.
This file should be copied into the working directory as device.yml
.
A different config file can be specified with the -c/--config
option.
The file must contain the following options (these are the ones provided by FlowForge)
Required options | Description |
---|---|
provisioningName |
The name of the token |
provisioningTeam |
The team this device will be registered to |
provisioningToken |
Provisioning Token to connect to the FF platform |
forgeURL |
The base url of the FlowForge platform |
The following options can be added:
Extra options | Description |
---|---|
interval |
How often, in seconds, the agent checks in with the platform. Default: 60s |
intervalJitter |
How much, in seconds, to vary the heartbeat +/- intervalJitter . Default: 10s |
If the agent was installed as a global npm module, the command
flowforge-device-agent
will be on the path.
If the default working directory and config file are being used, then the agent can be started with:
$ flowforge-device-agent
For information about the available command-line arguments, run with -h
:
Options
-c, --config file Device configuration file. Default: device.yml
-d, --dir dir Where the agent should store its state. Default: /opt/flowforge-device
-i, --interval secs
-p, --port number
-m, --moduleCache Use local npm module cache rather than install
Web UI Options
-w, --ui Start the Web UI Server (optional, does not run by default)
--ui-host string Web UI server host. Default: (0.0.0.0) (listen on all interfaces)
--ui-port number Web UI server port. Default: 1879
--ui-user string Web UI username. Required if --ui is specified
--ui-pass string Web UI password. Required if --ui is specified
--ui-runtime mins Time the Web UI server is permitted to run. Default: 10
Global Options
-h, --help print out helpful usage information
--version print out version information
-v, --verbose turn on debugging output
By default the Device Agent will try and download the correct version of Node-RED and any nodes required to run the Instance Snapshot that is assigned to run on the device.
If the device is being run on an offline network or security policies prevent the Device Agent from connecting to npmjs.org then it can be configured to use a pre-cached set of modules.
You can enable this mode by adding -m
to the command line adding moduleCache: true
to the device.yml
file. This will cause the Device Agent to load the modules from the
module_cache
directory in the Device Agents Configuration directory as described above.
By default this will be /opt/flowforge-device/module_cache
.
To create a suitable module cache, you will need to install the modules on a local device with access to npmjs.org, ensuring you use the same OS and Architecture as your target device, and then copy the modules on to your device.
- From the Instance Snapshot page, select the snapshot you want to deploy and select the option to download its
package.json
file. - Place this file in an empty directory on your local device.
- Run
npm install
to install the modules. This will create anode_modules
directory. - On your target device, create a directory called
module_cache
inside the Device Agent Configuration directory. - Copy the
node_modules
directory from your local device to the target device so that it is under themodule_cache
directory.
An example service file is provided here.
The Device Agents Web UI is provided to enable the user to download a device configuration or a provisioning configuration file. This is an optional feature and is not enabled by default.
To enable the UI, use the -w/--ui
option. This will start a web server on
the specified host and port. The default host is 0.0.0.0
and the default port is 1879
.
When enabling the UI, a username and password must be provided with the
--ui-user
and --ui-pass
options.
The UI will only be available for the duration specified by the --ui-runtime
. By
default this is 10 minutes. After this time, the web server will be disabled. The
application must be restarted to re-enable the UI. You can set this to 0
to
disable the timeout. This is not recommended.
The following scripts are available:
npm start
- Start the agentnpm run dev
- Build the agent and watch for changesnpm run lint
- Run eslintnpm run lint:fix
- Run eslint and fix any issuesnpm run test
- Run all unit testsnpm run test:lib
- Run the unit tests for the libnpm run test:frontend
- Run the unit tests for the frontend