This driver implements a server for the OPC-UA protocol (binary transport only, opc.tcp://hostname:port/resourcePath).
Implemented using the Node OPC-UA library.
https://github.com/node-opcua/node-opcua
The driver can serve multiple connections to OPC-UA clients on multiple computers, if needed.
To configure the driver it is necessary to create one or more driver instances and one protocol connection per instance.
To create a new OPC-UA client instance, insert a new document in the protocolDriverInstances collection using a command like this:
use json_scada_db_name
db.protocolDriverInstances.insert({
protocolDriver: "OPC-UA_SERVER",
protocolDriverInstanceNumber: 1,
enabled: true,
logLevel: 1,
nodeNames: [],
});
- protocolDriver [String] - Name of the protocol driver, must be "OPC-UA". Mandatory parameter.
- protocolDriverInstanceNumber [Double] - Number of the instance. Use 1 to N to number instances. For the same driver instance numbers should be unique. The instance number makes possible to run use multiple processes of the driver, each one with a distinct configuration. Mandatory parameter.
- enabled [Boolean] - Controls the enabling of the instance. Use false here to disable the instance. Mandatory parameter.
- logLevel [Double] - Number code for log level (0=minimum,1=basic,2=detailed,3=debug). Too much logging (levels 2 and 3) can affect performance. Mandatory parameter.
- nodeNames [Array of Strings]- Array of node names that can run the instance. Leave empty to allow any node to run this driver. Mandatory parameter.
Changes in the protocolDriverInstances config requires that the driver instances processes be restarted to be effective.
Each instance for this driver can have many client connection defined that must be described in the protocolConnections collection.
This driver will make all points available to the clients, unless filtered. There is no need to configure tags for protocol destinations (protocolDestinations property).
use json_scada_db_name
db.protocolConnections.insert({
protocolDriver: "OPC-UA_SERVER",
protocolDriverInstanceNumber: 1.0,
protocolConnectionNumber: 81.0,
name: "OPCUAServer",
description: "OPC-UA Server",
enabled: true,
commandsEnabled: true,
groupId: "UA/JsonScada",
ipAddressLocalBind: "0.0.0.0:4840",
ipAddresses: ["192.168.1.1"],
topics: ["KAW2", "KOR1"],
timeoutMs: 15000,
useSecurity: false,
localCertFilePath: "",
privateKeyFilePath: "",
stats: {}
});
Parameters for communication with OPC-UA servers.
- protocolDriver [String] - Name of the protocol driver, must be "OPC-UA_SERVER". Mandatory parameter.
- protocolDriverInstanceNumber [Double] - Number of the instance. Use 1 to N to number instances. For the same driver instance numbers should be unique. The instance number makes possible to run use multiple processes of the driver, each one with a distinct configuration. Mandatory parameter.
- protocolConnectionNumber [Double] - Number code for the protocol connection. This must be unique for all connections over all drivers on a system. This number is be used to define the connection that can update a tag. Mandatory parameter.
- name [String] - Name for a connection. Will be used for logging. Mandatory parameter.
- description [String] - Description for the purpose of a connection. Just documental. Optional parameter.
- enabled [Boolean] - Controls the enabling of the connection. Use false here to disable the connection. Mandatory parameter.
- commandsEnabled [Boolean] - Allows to disable/enable commands (messages in control direction) for a connection. Use false to disable all commands. If true the driver will create writable command tags for the enabled topics (group1 list). Mandatory parameter.
- groupId [String] - OPC-UA resource path. This path will be added to the endpoint resource name. Default value is "UA/JsonScada". Optional parameter.
- ipAddresses [Array of Strings] - List of client's IP addresses allowed. Leave empty to allow any IP address to connect to the server. Optional parameter.
- ipAddressLocalBind [String] - Interface bind IP address and port. Currently supports only IP "0.0.0.0". Default "0.0.0.0:4840". Optional parameter.
- topics [Array of Strings] - List of group1 filter for the available tags on the OPC-UA server. Leave empty to include all tags. Optional parameter.
- timeoutMs [Double] - Timeout. The HEL/ACK transaction timeout in ms. Use a large value (i.e. 15000 ms) for slow connections or embedded devices. Mandatory parameter.
- useSecurity [Boolean] - Use (true) or not (false) secure encrypted connection. Mandatory parameter.
- localCertFilePath [String] - File that contains the certificate (*.PEM) that will be presented to the remote side of the connection (equiv. to NodeJS TLS option 'cert'). Optional parameter.
- privateKeyFilePath [String] - File (*.PEM) that contains the private key corresponding to the local certificate (equiv. to NodeJS TLS option 'key'). Optional parameter.
- stats [Object] - Protocol statistics updated by the driver. Mandatory parameter.
Commands received on this driver (OPC tag writes) can be routed to protocol clients. A command tag that is associated to a client via protocolSource* parameters can be used to route commands to the client by configuring a protocolDestination for the command tag.
Use the AdminUI to add a new destination for a command tag. Configure the following parameters:
- Protocol Connection - Select the protocol OPC-UA_SERVER connection to use for the destination.
- Object Address - Use the command tag name as the object address.
- ASDU TI Type - Use "boolean" for digital commands or "double" for analog commands.
- Leave the rest of the parameters as default.
This driver has the following command line arguments.
- 1st arg. - Instance Number [Integer] - Instance number to be executed. Optional argument, default=1.
- 2nd arg. - Log. Level [Integer] - Log level (0=minimum,1=basic,2=detailed,3=debug). Optional argument, default=1.
- 3rd arg. - Config File Path/Name [String] - Complete path/name of the JSON-SCADA config file. Optional argument, default="../conf/json-scada.json".