OPC UA™
OPC UA™, which stands for OPC Unified Architecture, is a protocol designed for accessing data in both read and write modes. The data is organized within a tree-like address space and is referenced using unique identifiers known as node IDs. OPC UA is a modern standard that is based on TCP/IP and has replaced older OPC Classic™ (HDA/DA) technologies (refer to the OPC Classic™ connector). It is often natively embedded in industrial controllers.
OPC UA incorporates two variants of the protocol: HA (Historical Access) and DA (Data Access). In HA mode, you can access a history of values over a specified time interval for the requested data points, whereas in DA mode, you can access the values at each request or listen to changes in the values.
OIBus integrates both OPC UA modes (HA and DA) in read-only mode, using the node-opcua library.
Specific settings
To establish a connection to an OPC UA server, OIBus requires several settings:
- URL: This is the string used to connect to the server, and it follows the format
opc.tcp://<host>:<port>/<server-name>
. - Retry interval : The time to wait between reconnection attempts in the event of a connection failure.
- Security Mode : Communication can be secured using the security mode and security policy fields. Available security modes include: None, Sign, SignAndEncrypt.
- Security Policy (Applicable when Security mode is not None): Security policies define the level of security for communication. Available security policies include: None, Basic128, Basic192, Basic256, Basic128Rsa15, Basic192Rsa15, Basic256Rsa15, Basic256Sha256, Aes128_Sha256_RsaOaep, PubSub_Aes128_CTR, PubSub_Aes256_CTR.
- Authentication: Authentication options include None, Basic, and Certificate. Refer to the security settings for more details.
It's essential to choose a security mode and security policy that are supported by the OPC UA server you are connecting to. Ensuring compatibility is crucial for a successful connection.
Throttling settings
For South connectors capable of historical data retrieval, you have the flexibility to request data in intervals. These intervals can vary in size, depending on factors such as the chosen scan mode or the presence of prolonged network failures.
To handle such scenarios, the throttling settings enable you to divide large intervals into smaller sub-intervals, each no longer than the specified Max read interval (in seconds). These sub-intervals are requested with a delay defined by the Read delay setting (in milliseconds).
In certain situations, adding an overlap to the query can be beneficial. You can achieve this by configuring
the overlap field (in milliseconds): it will subtract this specified number of milliseconds from the @StartTime
variable of the subsequent query.
Item settings
When configuring each item to retrieve data in JSON payload, you'll need to specify the following specific settings:
- Node ID: The Node ID corresponds to the path of the data within the appropriate namespace on the OPC UA server.
It's essential to consider the supported node format of the server, which may use either numbers or strings. For
example, on Prosys,
ns=3;i=1001
matchesns=3;s=Counter
. - Mode: You can select either HA (Historical Access) or DA (Data Access) mode, depending on your requirements.
- Aggregate (HA mode only): In HA mode, there is an option to aggregate the retrieved values over the requested interval.
- Resampling (HA mode only): Similarly, in HA mode, you can choose to resample the retrieved values at the requested interval.
It's important to note that not all aggregation and resampling options are supported by OPC UA servers. To avoid
compatibility issues, it's recommended to use Raw
aggregation and None
resampling whenever possible. Additionally,
ensure that the selected mode (HA or DA) is supported by the server you are connecting to.
The name of the item will serve as a reference in JSON payloads, specifically in the pointID
field for the North
application.
Security settings
Communication
When using a security mode other than None, a certificate is required to sign and potentially encrypt the
communications.
OIBus generates a self-signed certificate for securing communication with the OPC UA server during startup. You can
locate the certificate used by OPC UA in the opcua
folder of the South cache. This certificate must be trusted by the
OPC UA server to enable secure communication.
If the certificate is not trusted by the OPC UA server, you may encounter an error with the message: Error: The connection may have been rejected by the server
.
Authentication
The certificate used for client authentication must be added to the trusted user certificates list on the OPC UA server. It is managed separately from the self-signed certificate mentioned earlier, which is used for securing communication.
For Prosys OPC UA servers, the certificate used to authenticate OIBus must be placed in the
.prosysopc\prosys-opc-ua-simulation-server\USERS_PKI\CA\certs
folder. Failure to do so may result in an error with the
message: Error: serviceResult = BadIdentityTokenRejected (0x80210000)
.
If a connection has previously been attempted and rejected, you should remove the certificate from the rejected
certificates
folder (.prosysopc\prosys-opc-ua-simulation-server\USERS_PKI\CA\rejected
) and move it to the trusted folder
(.prosysopc\prosys-opc-ua-simulation-server\USERS_PKI\CA\certs
).
Use the same certificate for user authentication and secure communications
The same certificate can be used for both sign and encrypt operations and for authentication. To do that, the cert.pem
and private.pem
file paths must be specified. They are located in the south cache data stream folder (inside the opcua
directory).
On the OPC UA server side, the self-signed certificate (cert.pem
) must be copied in the user certificates' folder.
For example, with Prosys OPC UA Simulation Server: .prosysopc\prosys-opc-ua-simulation-server\USERS_PKI\CA\certs
.
Using certificates with ProSys OPC UA Simulation Server
You can create your self-signed certificate to authenticate OIBus with the Cert method.
- Create a cert.conf file:
[ req ]
default_bits = 2048
default_md = sha256
distinguished_name = subject
req_extensions = req_ext
x509_extensions = req_ext
string_mask = utf8only
prompt = no
[ req_ext ]
basicConstraints = CA:FALSE
nsCertType = client, server
keyUsage = nonRepudiation, digitalSignature, keyEncipherment, dataEncipherment, keyCertSign
extendedKeyUsage= serverAuth, clientAuth
nsComment = "OIBus User Cert"
subjectKeyIdentifier=hash
authorityKeyIdentifier=keyid,issuer
subjectAltName = URI:urn:opcua:user:oibus,IP: 127.0.0.1
[ subject ]
countryName = FR
stateOrProvinceName = FR
localityName = Chambéry
organizationName = OI
commonName = oibus
- Create a private key and certificate using the
cert.conf
:
openssl req -new -x509 -keyout oibus.key -out oibus.pem -config cert.conf
- Remove private key passphrase:
openssl rsa -in oibus.key -out oibus.key
- Create DER cert for ProSys:
openssl x509 -inform PEM -outform DER -in oibus.pem -out oibus.der
- Copy the DER cert in ProSys USERS_PKI certificate folder:
prosys-opc-ua-simulation-server\USERS_PKI\CA\certs