I created two UDT with third part OPC UA server, one is simple struct, the other is nested struct. Both of them can’t be parsed by Ignition OPCUA connection with below logging info.
Hmm. Those messages indicates some part of the datatype information is missing from the address space.
Those 2 Nodes you’ve got showing in UaExpert should each have an inverse reference of type HasDescription (so, descriptionOf) pointing to the Node representing the encoding id. The logs are complaining that this wasn’t found for some reason.
The UDT was defined in a python-opcua server with reference below python scripts.
The python-opcua may not implement the fully OPCUA protocol, but at least the UDT in python-opcua as shown in previous snapshot can be parsed by UaExpert or the UA.Net Standard C# library.
So is there any work around to parse it in ignition?
This will probably have to be fixed in either the Milo SDK or the python-opcua SDK. I’ll see if I can get that sample server running and figure out what’s going on. There’s no workaround that I can see.
This is a bug in the pyopcua server, although it’s not exactly what I expected it to be.
They do seem to have all the pieces of the address space in place, but there’s a bug in their browse service when we ask specifically for Inverse references of type HasDescription during one of the steps. It just responds saying there are no references.
If a browse is made on the same node for Inverse references of any type then it responds with multiple references, including the HasDescription reference it should have returned when asked for only references of that type.
I’ll open an issue on their GitHub repo but I don’t know how responsive they will be.