12:17, EEST
April 3, 2012
Hi, thanks for the notification.
Seems this did break in 4.0.0 as the stack layer was integrated as part of the SDK (https://downloads.prosysopc.com/opcua/Prosys_OPC_UA_SDK_for_Java_4_Release_Notes.html#version-4-0-0).
Do you have a use-case in which that method would be useful or cases which cannot be workarounded?
Note that it could ever only give NodeIds of the standard namespace, so I’m not that sure about it’s usefullness. Internally it only would be used from deprecated methods used to load the (really) old ModelDesign.xsd based files, which SDK doesn’t anymore support (as all information models use the NodeSet2 format). Therefore I’m not exactly sure should the method be even kept. However I do see some potential use-cases, but I would personally store the NodeIds (or well it would be always even better to store the namespace as uri and not the index) instead of the “name” as String. Additionally I have seen at least one server that used the same BrowseName for a DataType and a VariableType.
We’ll try to fix this to the next version. Note however that 4.0.2 did some changes on how the Identifiers are generated (https://downloads.prosysopc.com/opcua/Prosys_OPC_UA_SDK_for_Java_4_Release_Notes.html#version-4-0-2). Basically we are hitting java limits on how big the classfile can be so that it still compiles. Those changes will allow us to split the interfaces into sub-interfaces to contain more standard identifiers (as the standard model keeps on growing…). Exactly for 4.0.2 if you just want to get the standard data type NodeIds, the following workaround should work (does not include exception handling etc., also this might break in the future):
for (Field f : clazz.getFields()) {
if (!f.getType().equals(NodeId.class)) {
continue;
}
f.setAccessible(true);
NodeId nodeId = (NodeId) f.get(null);
String name = f.getName();
// Store to a map and look up from there
}
12:51, EEST
April 3, 2012
Hmm actually,
there would seem to still work even with the split, so the fix is a lot easier than I thought first. Still I would prefer a solution that utilizes the codegen and not reflection on field names as reflection can break if obfuscation is used.
14:06, EEST
August 9, 2016
we use a configuration database where all tags we want to read from OPC (UA/DA) with in string form we want to see the data returned.
Internally for OPC UA this string must be translate to a nodeId so easy way was NodeId nodeid = IdentifierDescriptions.toNodeId(“Float”)
now I added a translate method to solve the problem, but of course I will need to update it if new datatype are introduced in future.
so it would be nice to have a default string to nodeid converter build in
14:47, EEST
April 3, 2012
I see. I have fixed this now in the latest beta build we have, send mail to uajava-support@prosysopc.com if you want to try, otherwise it will be part of the next release (no exact dates on that, as it is summer vacation season here in Finland). It still uses reflection though.
Just note that DataTypes in UA are not limited to the standard model, any model could add their own ones, in which case that storage logic might not be enough or work. I wont go here in great details as otherwise this would be very long post.
There are Built-in (e.g. String), Simple (e.g. DurationString) and Structured (anything below ‘Structure’ type) DataTypes. Simple types are subtypes of Built-in types. Structures are collections of fields that can have any type. Encoded binary format of Simple types is the same as their super Built-in type. Structures have their own rules. Basically as long as you’ll need to only write values to nodes having their DataType as a Built-in type or a Simple type you should be fine (encoding-wise at least, if a subtype defines additional rules e.g. valid values are only a part of the Built-in type you might get errors from the server).
I hope that didn’t confuse too much..
Most Users Ever Online: 1919
Currently Online:
39 Guest(s)
Currently Browsing this Page:
1 Guest(s)
Top Posters:
Heikki Tahvanainen: 402
hbrackel: 144
rocket science: 88
pramanj: 86
Francesco Zambon: 83
Ibrahim: 78
Sabari: 62
kapsl: 57
gjevremovic: 49
Xavier: 43
Member Stats:
Guest Posters: 0
Members: 746
Moderators: 7
Admins: 1
Forum Stats:
Groups: 3
Forums: 15
Topics: 1529
Posts: 6471
Newest Members:
scvchad954, misty3446453365, KelsonzFu, Kelsonz, lienbelisario, erick34s63346, Kaitlyntvsl, lonaerskine7, KTP21ideft, GeorgecotagModerators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0
Administrators: admin: 1