If the ConnectionConfigurationSet contains PortableRelativePaths, then the Client should perform the following steps (Figure 70 provides an overview of the configuration and actions):

  1. Resolve the location of the Server and connect to it. This process is required for several of the node configuration options and is described in its own clause (see 13.2).
  2. Convert PortableRelativePaths to BrowsePaths. This is accomplished by connecting to the Server, reading the NamespaceArray from the Server, and matching all NamespaceUri from the NamespaceArray to the URI’s store in the PortableRelativePaths. PortableRelativePathElements and storing the Index of the URI in the table in the temporary BrowsePath. This will convert the PortableRelativePath to a BrowsePath.
  3. Call the TranslateBrowsePathsToNodeIds Service with all of the BrowsePaths that are to be converted to NodeIds. Cache the resulting list of NodeIds.
  4. The cache shall also include the NamespaceArray of the target Server. This array can be checked before establishing a Connection to ensure it has not changed. Additionally, the NamespaceMetadata (NamespacePublicationDate) shall be cached. This data can be used to check if the namespace has been updated. If the Namespace has been updated, the process for resolving BrowsePaths shall be repeated.
  5. Repeat for all Servers.

When resolving NamespaceUri, if a Null or empty NamespaceUri is encountered, the Server shall assume that it is a reference to NamespaceArray index 1. NamespaceArray index 1 is the local Server namespace, and the URI corresponding to the Server might not be known at configuration time. For additional details on Namespaces, see OPC 10000-3.

image073.png

Figure 70 – PortableRelativePath Client resolution

The process is illustrated in the sequence diagram shown in Figure 71.

The resolution of BrowsePaths to NodeIds can result in multiple NodesIds for a single BrowsePath. Configurations should try to produce unique BrowsePaths (see 6.4.4, 6.4.5 and 6.4.6 for recommendations). Clients shall be able to handle this condition by reporting an error.

image074.png

Figure 71 – PortableRelativePath resolution sequence