Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 12 Next »

Introduction

OPC United Architechture (OPC UA) protocol is widely used industrial communications protocol. The ICD-007 OPC Server integration plugin instantiates an OPC UA Server within the Witness system, allowing 3rd party OPC UA clients to connect and obtain data from. The OPC UA Specifications come in multiple parts and can be obtained from the OPC Foundation website.

For customers and integrators intending to use OPC Server plugin, the documents assume a reasonable working knowledge of network communication. They are targeted at technical teams, typically with software development skills, who are integrating the output from Witness into external systems.

Overview

When Witness processes alarms and health statuses, it passes all this information to Witness Management Integration Manager. Witness Integration Manager then converts this information into a suitable data format to send to external systems.



The data is transmitted as the events occur, leading to near-real time reporting.

On this page:

The OPC Server Plugin

The Witness system supports integration with many different types of external systems through the use of plugins. These are stand-alone software libraries which are dynamically loaded by the Integration Manager and contain code which knows how to convert the Witness data into the required format for the external system. Navtech Radar can easily develop bespoke plugins to interface with a specific type of equipment or application. The OPC Server plugin has been developed to provide integration to the common OPC UA standard used in highway systems.

The OPC Server plugin file is entitled Tungsten.Integration.ICD007.Plugin.dll and must be present in the Witness Plugin folder which is inside the main application folder. The plugin depends on OPC Foundation's liberaries Opc.Ua.Core.dll and Opc.Ua.Server.dll which must be present in the same folder.

The plugin can be selected during setup and required files will automatically be installed in the correct location.

OPC UA Client Prequisites

The OPC UA client used to connect to the OPC server must login through a Username and Password channel. Other authentication methods are not supported.

To facilitate secure connection, the client server connection requires a security certificate. You may choose to let the plugin generate its own security certificate for the communication or provide a custom certificate. Generated certificates are by default stored under the Windows certificate store → CurrentUser -> My and must be installed as trusted by the OPC Client.

Configuring the OPC Server Plugin

When the plugin is installed and licensed, a plugin configuration with default settings is automatically generated. The settings can be viewed and edited through the Witness Client → Config workspace → Integration plugins folder and can be modified as an administrative user.




Once you have made changes to the plugin configuration and committed the changes by saving, the plugin will automatically rebuilt itself based on the new configuration.

The setting options are as follows:

  1. Enable Plugin: When not enabled, the plugin will not start up. If the plugin is already running, disabling the plugin will cause it to stop.
  2. Plugin Name: Name of the plugin within the Witness UI
  3. Health Timer: Interval, in seconds, at which the heartbeat counter on the OPC Server will count up while it is connected to the Witness system. This can be used to monitor the overall health of the OPC Server plugin.
  4. Primary MS IP:
  5. Secondary MS IP:
  6. Port:
  7. Plugin Application Name: Application Name reported through the OPC protocol. This should have the same URI as the security certificate.
  8. Plugin Application URI: Application URI reported through the OPC protocol. This should have the same URI as the security certificate.
  9. Certificate Type:
    1. Windows: Default - tries to read the certificate from in Windows Certificate Store. Certificate path must be a valid windows certificate store path e.g. "CurrentUser\My" or "LocalMachine\TrustedPublisher".

    2. Directory: This tries to read the certificate from the file storage.

  10. Certificate Path: Location to store the server certificate. This can be a file location e.g. "C:\OpcCertificate\" if using Directory certificate type or Certificate Store path e.g. "CurrentUser\My"
  11. Certificate Name: Name on the server certificate file. This name is used as both the issuer and the issued to.
  12. Autocreate Certificate: Defaults to True. This indicates that a server certificate will be generated if the specified one is not available. This is the recommended option.If a custom pregenerated certificate is used, the OPC Server must be configured to match the certified application name and application URI.
  13. (Server URI: Location where the OPC Server is hosted. This should be the actual Canary hosting machine name, localhost or the canary machine IP followed by an unused port and optionally additional path - for example if the same server hosts multiple OPC applications.)
  14. Carriageways: This section indicates the carriageways that we want to track in the OPC server. When a highway alarm is received, only an alarm matching a configured Carriageway will be processed.

SelectCarriageway Name
Select this to

If Certificate Type is "Directory", auto create certificate can only create new certificates if Opc Foundation Redistributable is installed.

If the specified certificate does not exist and new certificate cannot be created (e.g. due to the above or if Auto create Certificate is not selected), the plugin will not be able to start up.

Generating the OPC Node Structure

To assist development or configuration of the OPC UA Client, the OPC node structure will be output to the local program data folder in csv format each time the plugin is started. As you add or remove radars or change plugin configuration, OPC Node structure will change.

You should be able to find the output at: ProgramData → Navtech\OPCServer\OPCNodes.csv. The location of your ProgramData folder will depend on your Windows setup.

Example output in table format:

Each node is listed first with Display Name, DataType and namespace : relative browse name. Child nodes are indented relative to their parent.

WitnessFolder1:Witness





HeartbeatInt321:Heartbeat



ManagementServerHealthInt321:ManagementServerHealth



TrackEngineHealthInt321:TrackEngineHealth



DatabaseHealthInt321:DatabaseHealth



CarriagewayCountInt321:CarriagewayCount



RadarCountInt321:RadarCount



CarriageWaysFolder1:CarriageWays




Carriageway 1Folder1:Carriageway1




SectionCountInt321:SectionCount



Section 1Folder1:Section1




SectionIdInt321:SectionId




ModeInt321:Mode




RadarIdInt321:RadarId




TrafficDataBoolean1:TrafficData




AverageSpeedDouble1:AverageSpeed




AverageCountInt321:AverageCount




Reversing RuleFolder1:Rule1





DescriptionString1:Description





ActiveBoolean1:Active





RaisedDateTime1:Raised





LocationXDouble1:LocationX





LocationYDouble1:LocationY





LaneInt321:Lane




Speed RuleFolder1:Rule2





DescriptionString1:Description





ActiveBoolean1:Active





RaisedDateTime1:Raised





LocationXDouble1:LocationX





LocationYDouble1:LocationY





LaneInt321:Lane



Section 2Folder1:Section2




SectionIdInt321:SectionId




ModeInt321:Mode




RadarIdInt321:RadarId




TrafficDataBoolean1:TrafficData




AverageSpeedDouble1:AverageSpeed




AverageCountInt321:AverageCount




Reversing RuleFolder1:Rule1





DescriptionString1:Description





ActiveBoolean1:Active





RaisedDateTime1:Raised





LocationXDouble1:LocationX





LocationYDouble1:LocationY





LaneInt321:Lane




Speed RuleFolder1:Rule2





DescriptionString1:Description





ActiveBoolean1:Active





RaisedDateTime1:Raised





LocationXDouble1:LocationX





LocationYDouble1:LocationY





LaneInt321:Lane




Person RuleFolder1:Rule3





DescriptionString1:Description





ActiveBoolean1:Active





RaisedDateTime1:Raised





LocationXDouble1:LocationX





LocationYDouble1:LocationY





LaneInt321:Lane

SensorsFolder1:Sensors





Radar 1Folder1:Sensor7083798e-329d-4eb6-a4bc-4dee3553faea



LastHealthInt321:LastHealth



LastTimeDateTime1:LastTime



RadarIdInt321:RadarId



Radar 2Folder1:Sensord8aec3b1-4f71-41c1-8d90-0bb0387340b0



LastHealthInt321:LastHealth



LastTimeDateTime1:LastTime



RadarIdInt321:RadarId


READMEString1:README


OPC Login Credentials


To log in to the OPC server with an OPC client, you can use the credential of any System user. If none exist, an admin level user may create a new one.


  • No labels