Avatar

Please consider registering
guest

sp_LogInOut Log In sp_Registration Register

Register | Lost password?
Advanced Search

— Forum Scope —




— Match —





— Forum Options —





Minimum search word length is 3 characters - maximum search word length is 84 characters

sp_Feed Topic RSS sp_TopicIcon
Call own Methods from Server Node Manager
September 3, 2024
11:45, EEST
Avatar
chk
Member
Members
Forum Posts: 3
Member Since:
September 3, 2024
sp_UserOfflineSmall Offline

Hello,
for a special server, I would like to add nodes and methods without creating an extra custom namespace and NodeManager for it. Therefore, I added them to ns=1, which is the server’s own namespace with the NodeManagerUaServer. The methods thematically belong to this namespace as well, because the methods are supposed to control the server.

I cannot call these methods using the client. It shows “Executable=True”, but “UserExecutable=false”. Even if I set “methodNode.setUserExecutable(true);” while creating the method, it remains “false” in the client, and the method is not executable. In a new namespace with its own NodeManagerUaNode, everything works fine. The UserExecutable must have been automatically overwritten in the background.

Is there a way to bypass this and somehow execute custom methods in ns=1?

Thanks and Best Regards
Christian

September 3, 2024
14:13, EEST
Avatar
Bjarne Boström
Moderator
Moderators
Forum Posts: 1032
Member Since:
April 3, 2012
sp_UserOfflineSmall Offline

Hi,

Any UserXXX Attribute on the server side must be handled via IoManagerListener by implemnting the onGetUserXXX methods within that and be attached to the respective namespace’s NodeManager.getIoManager(). It is sort of a flaw that on the server side the API allows you to try to set it to the node directly (the value should depend based on the user/session/context and not the same for all).

Thus, if you implement IoManagerListener.onGetUserExecutable(ServiceContext, NodeId, UaMethod) and add that to NodeManagerUaServer.getIoManager().addListeners(your_listener_here), it should work.

IMPORTANT! The namespaceindexes 0 and 1 are special. You can think them like hard-coded by the spec (2 is first “user-intended one”); 0 holds “static nodes” (NodeId known and hardcoded by the spec) and 1 holds “dynamic nodes” (NodeId unknown and depends on dynamic factors such as SessionId). Mostly the dynamic nodes are diagnostic nodes (if turned on), but in some sense you could say the whole ‘1’ is a reserved namespace. Though I think in the past the idea was also that it could hold “any node” that is not modelled by some well known namespaceuri, but nowadays I would say there is a risk of them being conflicting anything possibly being added later to the specification. Thus at least currently I would avoid adding any nodes to ‘1’. The only exception might be if you try to simulate 1:1 a server and thus are unable to add any extra namespaces depending on the client side assuming things.

SDK has special logic for these 2 in NodeManagerRoot and NodeManagerUaServer. NodeManagerUaServer has an internal “security IoManagerListener” that forbids some access related to parts of diagnostics since it is assumed it contains only those (NodeManagerRoot has some as well, since the entry-point to diagnostic is a static node, individual nodes related to a session are dynamic). That one also returns false for all UserExecutable. Added IoManagerListeners works in last-added-called-first order, thus yours should be called first.
IMPORTANT! Do return ‘null’ from all onGetUserXXX if the node is not a node that you yourself has added, you could accidentally override some of the security logic related to diagnostics otherwise. SDK skips to the next listener if you return null (for the onGetUserExecutable the return type is Boolean, thus it is possible to return null, which should intentionally be done in this case to indicate skipping).

P.S.
Diagnostics-related logic for access can be controlled by implementing UaServerListener.onAllowReadSecurityDiagnostics(ServiceContext) and determining is the given context/session “an admin” (and our internal IoManagerListener calls that one). Since there are no Methods for diagnostics that is outside of that (but it still returns false for those).

Forum Timezone: Europe/Helsinki

Most Users Ever Online: 1919

Currently Online:
228 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: 749

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, Georgecotag

Moderators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0

Administrators: admin: 1