Skip to content

Well known methods

Fanda Vacek edited this page Dec 7, 2019 · 61 revisions

Well known methods

hello

client starts handshake with server when TCP connection is established

client ChainPack connection: <id:1, method:"hello">i{} or JSON connection: {"id":1, "method":"hello"}

server ChainPack connection: <id:1>i{result:{"nonce":"2101306386"}} or JSON connection: {"id":1, "result":{"nonce":"2101306386"}}

Server response result might contain parameter pubKey to check server identity. RSA-OAEP login password encription can be used then.

login

client authorization to server when hello response is received

login types:

  • PLAIN
  • SHA1 - password == HEX(SHA1(nonce + HEX(SHA1(password))))
  • RSA-OAEP

client: <1:1, 8:2, 10:"login">i{1:{"login":{"password":"3d613ce0c3b59a36811e4acbad533ee771afa9f3", "user":"iot", "type":"SHA1"}, "options":{"device":{"deviceId":"bfsview_test", "mountPoint":""}, "idleWatchDogTimeOut":180}}}

server: <8:2>i{2:{"clientId":68384}}

ping

client calls method ping on node .broker/app as its heart-beat. Is server does not receive client's ping for time longer than idleWatchDogTimeOut then server aborts TCP connection

ls

list node children

ls() or ls(node_id_pattern) or ls("", attributes) or ls(node_id_pattern, attributes)

  • node_id_pattern: currently supported are empty string to list all children or node_id to call methods on particular node or discover if node exists

  • attributes: bitfield of method attribute values to return. Currently supported attributes:

    1. HasChildren = 1 << 0
  • return: [[node_id_1 [, ret_1, ..., ret_n], ..., [node_id_n [, ret_1, ..., ret_n]]

dir

list node methods

dir() or dir(method_name_pattern) or dir([method_pattern, attributes])

Calling dir() is the same as calling dir(["", 0])

  • method_name_pattern: currently supported are empty string to list all methods or method_name to get attributes of particular method or discover if method with method_name exists
  • attributes: bitfield of method attribute values to return. Currently supported attributes:
    1. Signature = 1 << 0
    2. Flags = 1 << 1
    3. AccessLevel = 1 << 2
    4. Help = 1 << 3
  • return: [[method_1 [, attr_val_1, ..., attr_val_n], ..., [node_id_n [, attr_val_1, ..., attr_val_n]]

Flags:

  1. IsSignal = 1 << 0

get

get node value

set

set node value

subscribe

subscribe notifications for subdir and method, must be called on shv path .broker/app

example: <T:RpcMessage, id:4u, shvPath:".broker/app", method:"subscribe">i{params:{"method":"chng", "path":"test"}}

subscribes all notifications with method chng on all subdirs of test broker directory

example: <T:RpcMessage, id:4u, shvPath:".broker/app", method:"subscribe">i{params:{"method":"foo", "path":""}}

subscribes all foo notifications

method cannot be empty, to enable rejectNotSubscribed implementation. With wild-card in method the most specific subscription cannot be always determined.

Privileged user can still create subscription with empty method to grab all the notification for debug purposes. rejectNotSubscribed might not work as expected in such a case.

unsubscribe

unsubscribe notifications for subdir and method, must be called on shv path .broker/app

example: <T:RpcMessage, id:4u, shvPath:".broker/app", method:"unsubscribe">i{params:{"method":"chng", "path":"test"}}

unsubscribes all notifications with method chng on all subdirs of test broker directory

shv_path and method must exactly match parameters of one of previous subscribe call.

Returns:

  • True if subscribe record is found and deleted
  • False otherwise

rejectNotSubscribed

rejectNotSubscribed({"method":"received-notify-method", "path":"received-notify-path"})

un-subscribe unexpected notification. When client receive unexpected notification, it can call this method to get rid of it. Broker returns true or false if some subscription matching path and method of unwanted notification was found and deleted or not.

If more subscriptions are found, the one with wild-carded method will be removed first. This way the "debug subscriptions" will be removed first, what is correct, because they are not needed for proper system function.

chng

node value changed notification, cannot be called explicitly

Clone this wiki locally