YumaPro SIL Sub-Agent message definitions. Copyright (c) 2014 - 2024 YumaWorks, Inc. All rights reserved. Redistribution and u...
Version: 2024-07-28
module yumaworks-sil-sa { yang-version 1.1; namespace "http://yumaworks.com/ns/yumaworks-sil-sa"; prefix ysil; import ietf-yang-structure-ext { prefix sx; } import yuma-types { prefix yt; } import yumaworks-types { prefix ywt; } import yumaworks-ycontrol { prefix yctl; } import yumaworks-agt-profile { prefix yprof; } import yumaworks-schema-mount { prefix ysm; } organization "YumaWorks, Inc."; contact "Support <support at yumaworks.com>"; description "YumaPro SIL Sub-Agent message definitions. Copyright (c) 2014 - 2024 YumaWorks, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, is permitted pursuant to, and subject to the license terms contained in, the BSD 3-Clause License http://opensource.org/licenses/BSD-3-Clause"; revision "2024-07-28" { description "23.10T-10: Add SIL-SA Global callbacks support: - Add grouping for all the callbacks"; } revision "2024-02-23" { description "Add SIL-SA EDIT3 callbacks support: - Add leaf-list edit3-path to register-request message - Add update value to edit list in <start-transaction> message"; } revision "2023-08-04" { description "22.10T-11: Change CLI container to sx:structure"; } revision "2023-06-16" { description "Add edit-phase-complete boolean leaf"; } revision "2023-02-19" { description "Add revision leaf to register container in <register-request> message."; } revision "2022-08-23" { description "Add MPID support for schema mount. Change all anyxml to anydata to match usage."; } revision "2022-04-05" { description "YPW-1916: - Add modpath, datapath, and runpath leafs to config-response message"; } revision "2022-03-29" { description "Add event-path and event-key fields to the notification message to support nested YANG 1.1 event types."; } revision "2021-11-28" { description "Fix pyang compiler errors for this module. 'list needs at lest one key' messages"; } revision "2021-10-28" { description "YPW-1857: SIL-SA EDIT2 callback on leaf-list node malfunction. Add remove to the enum list of operation; YPW-1864: Commit Completeness callbacks support for SIL-SA: - Add validate-complete boolean leaf - Add apply-complete boolean leaf - Add commit-complete boolean leaf - Add rollback-complete boolean leaf - Add commit-completeness-hook message YPW-1870: SIL-SA editvars support - Add editvars container to edit list - Add editvars container to child-edit list"; } revision "2020-08-27" { description "Add SIL-SA EDIT2 callbacks support: - Add leaf-list edit2-path to register-request message - Add child-edit list to edit list in <start-transaction> message"; } revision "2020-06-05" { description "Add SIL-SA Hook callbacks support: - Add leaf-list sethook-path to register-request message - Add leaf-list post-sethook-path to register-request message - Add leaf-list transaction-path to register-request message - Add hook-request message - Add hook-response message - Add hook-get-request message - Add hook-get-response message"; } revision "2019-10-11" { description "Add with-origin flag for NMDA support"; } revision "2019-08-18" { description "Add stream-name to notification message. Add client-addr to transaction messages to support sil_sa_get_client_addr function"; } revision "2019-07-02" { description "Added HOOKS support: * Add following leafs to register-request message: - Add transaction-start boolean leaf - Add transaction-complete boolean leaf * Add trans-start-hook message * Add trans-complete-hook message"; } revision "2019-04-20" { description "Added ACTION support: * Add action-path to register-request message * Add action-request message * Add action-response message"; } revision "2019-01-31" { description "Added user-id-obj grouping used by start-transaction, get-request and rpc-request messages"; } revision "2019-01-20" { description "Add deviation parm to config-response message."; } revision "2018-12-05" { description "Add load-config parameter to start-transaction message"; } revision "2018-10-03" { description "Add bundle parameter to register-request message"; } revision "2018-06-03" { description "Add rpc-request and rpc-response messages"; } revision "2017-09-19" { description "Fix broken augment statement for payload"; } revision "2015-11-01" { description "Added support for GETBULK to get-response message."; } revision "2015-08-17" { description "Added 'select' node support to get2 SIL-SA get-request message"; } revision "2015-04-17" { description "Updated notification container for release"; } revision "2015-01-15" { description "Add get and notification support"; } revision "2014-11-18" { description "Fix module type, supposed to be NcModuleNameSpec to allow foo@2000-01-01, not just foo. Add bundle-module leaf-list to register msg Add bundle-load-event to inform server of any modules loaded from a SIL-SA bundle; Remove shutdown-event."; } revision "2014-09-06" { description "Add agt-profile container to config-parms grouping used in the <config-response> from server to subsystem."; } revision "2014-08-01" { description "Initial version."; } sx:augment-structure "/yctl:ycontrol/yctl:message-payload/yctl:payload/yctl:payload"; grouping bundle-module-parm { leaf-list bundle-module { type yt:NcModuleSpec; description "Module parameters that were loaded as a result of any bundle parameters. They will be returned in the form modname@revision-date."; } } // grouping bundle-module-parm grouping bundle-parm { leaf-list bundle { type yt:NcxName; description "Bundle names that were loaded as a result of any bundle parameters."; } } // grouping bundle-parm grouping path-parm { leaf path { type string; mandatory true; description "Object identifier string: * matches 'path' in the register-request message for an EDIT callback * matches 'get-path' in the register-request message for a GET2 callback * matches 'action-path' in the register-request message for an ACTION callback The path string is generated with YANG prefixes using the obj_gen_object_id_prefix function in ncx/obj.h "; } } // grouping path-parm grouping system-callbacks-parm { description "Specifies what system callbacks are enabled."; leaf transaction-start { type empty; description "The leaf specifies if there is a Transaction Start Callback to register"; } leaf transaction-complete { type empty; description "The leaf specifies if there is a Transaction Complete Callback to register"; } leaf validate-complete { type empty; description "The leaf specifies if there is a Validate Complete Callback to register"; } leaf apply-complete { type empty; description "The leaf specifies if there is an Apply Complete Callback to register"; } leaf commit-complete { type empty; description "The leaf specifies if there is a Commit Complete Callback to register"; } leaf rollback-complete { type empty; description "The leaf specifies if there is a Rollback Complete Callback to register"; } leaf edit-phase-complete { type empty; description "The leaf specifies if there is an Edit Phase Complete Callback to register"; } } // grouping system-callbacks-parm grouping glob-callbacks-parm { description "Specifies what global callbacks are enabled."; leaf glob-action { type empty; description "The leaf specifies if there is a Global ACTION Callback to register"; } leaf glob-edit2 { type empty; description "The leaf specifies if there is a Global EDIT2 Callback to register"; } leaf glob-edit3 { type empty; description "The leaf specifies if there is a Global EDIT3 Callback to register"; } leaf glob-get { type empty; description "The leaf specifies if there is a Global GET2 Callback to register"; } leaf glob-rpc { type empty; description "The leaf specifies if there is a Global RPC Callback to register"; } } // grouping glob-callbacks-parm grouping operation-parms { leaf operation { type enumeration { enum "merge" { value 0; } enum "replace" { value 1; } enum "create" { value 2; } enum "delete" { value 3; } enum "load" { value 4; } enum "commit" { value 5; } enum "remove" { value 6; } } mandatory true; description "Operation matching op_editop_t enumeration list."; } } // grouping operation-parms grouping hook-edit-parms { leaf operation { type string; description "Operation matching yang_patch_op_t enumeration list. Specific for Set Hook add_edit() API"; } leaf where { type string; description "Specifies how a node should be inserted within a user-ordered list"; } leaf point { type string; description "Specifies an insertion point for a data resource that is being created or moved within a user ordered list or leaf-list."; } leaf skip-callback { type boolean; default "false"; description "Specifies whether the server should invoke callbacks for an added edit"; } } // grouping hook-edit-parms grouping hooks-param { leaf hook-path { type string; description "Path string for object for Hook callbacks"; } leaf hook-format { type enumeration { enum "node" { value 0; } enum "subtree" { value 1; } } default "node"; description "Hook format; dictates specific hook functionality"; } leaf hook-type { type enumeration { enum "none" { value 0; } enum "set-hook" { value 1; } enum "post-set-hook" { value 2; } enum "transaction-hook" { value 3; } } description "Specifies Hook callback type"; } leaf added-edit { type boolean; description "Specifies whether the edit was added by Set Hook of Post Set Hook callbacks. Flag to prevent Set Hook looping; will not allow to call Set Hook family callbacks"; } } // grouping hooks-param grouping transaction-id-obj { leaf transaction-id { type string; mandatory true; description "Server specific transaction identifier."; } } // grouping transaction-id-obj grouping user-id-obj { leaf user-id { type string; description "Identifies the user that initiated this transaction."; } } // grouping user-id-obj grouping client-addr-obj { leaf client-addr { type string; description "Identifies the address of the client that initiated this transaction."; } } // grouping client-addr-obj grouping config-parms { uses yprof:agt-profile; leaf-list bundle { type yt:NcxName; description "Bundle SIL SA libraries to load"; } leaf-list module { type yt:NcModuleSpec; description "Module SIL SA libraries to load"; } leaf-list deviation { type yt:NcModuleSpec; description "Deviations and annotations to load"; } leaf modpath { type string; description "Server module search path setting"; } leaf datapath { type string; description "Server data search path setting"; } leaf runpath { type string; description "Server library search path setting"; } } // grouping config-parms grouping event-stream-parm { leaf event-stream { type ywt:NcxNumName; description "Event stream name to use for the operation."; } } // grouping event-stream-parm grouping stream-subevent-parm { leaf stream-subevent { type enumeration { enum "active" { value 0; description "Event stream is active"; } enum "inactive" { value 1; description "Event stream is inactive"; } } description "Event stream callback subevent types."; } } // grouping stream-subevent-parm grouping commit-phase-parm { leaf commit-phase { type enumeration { enum "validate" { value 0; description "Invoke Validate Complete callback"; } enum "apply" { value 1; description "Invoke Apply Complete callback"; } enum "commit" { value 2; description "Invoke Commit Complete callback"; } enum "rollback" { value 3; description "Invoke Rollback Complete callback"; } } description "Specifies the Commit Completeness callback phase."; } } // grouping commit-phase-parm grouping commit-type-parm { leaf commit-type { type enumeration { enum "normal" { value 0; description "Commit operation was completed"; } enum "reply" { value 1; description "Replay-commit operation was completed"; } enum "none" { value 2; description "Type is not set"; } } description "Specifies the type of commit that was just completed. Used only for Commit Complete Callback."; } } // grouping commit-type-parm grouping return-val { anydata return-keys { description "List of all ancestor or self key values for the object being retrieved, identified by the 'path' value. There will be one child leaf for each key in each list."; } anydata values { description "Represents the retrieved values, if any. There will be one child node for each returned value."; } } // grouping return-val grouping editvars-parm { container editvars { leaf insert-op { type enumeration { enum "none" { value 0; } enum "first" { value 1; } enum "last" { value 2; } enum "before" { value 3; } enum "after" { value 4; } } description "Specifies the YANG insert operation."; } leaf insert-str { type string; description "Identifies the saved string for value or key attr."; } leaf insert-mode { type enumeration { enum "none" { value 0; } enum "key" { value 1; } enum "value" { value 2; } enum "point" { value 3; } } description "Specifies the insert mode requested."; } anydata insert-val { description "Represents the insert value, if any. Should be present if the insert operation is 'before' or 'after'."; } leaf sil-priority { type uint8; description "Identifies the 2nd SIL priority for server."; } leaf operset { type empty; description "Specifies whether operation is set or not."; } leaf move { type empty; description "Specifies whether the insert is for MOVE operation or not."; } leaf skip-sil-partial { type empty; description "Specifies whether skip_sil_partial is needed or not."; } } // container editvars } // grouping editvars-parm grouping schema-mount-parm { leaf mounted { type empty; description "Specifies whether this callback is for a mounted node or a top level node."; } } // grouping schema-mount-parm grouping sm-mpid-parm { description "Specifies the Mount Point Instance for the request"; container mpid { uses ysm:sm-config-keys; leaf objpath { type string; description "Mount point root object path."; } anydata keys { description "List of all ancestor key values for the Mount Point Instance, identified in the 'objpath' object. There will be one child leaf for each key in each list, starting from the mount point root object."; } } // container mpid } // grouping sm-mpid-parm augment /yctl:ycontrol/yctl:message-payload/yctl:payload/yctl:payload { container sil-sa { description "Server Instrumentation Library Sub-Agent API Messages SIL-SA Protocol Initialization: 1) subsys sends a <config-request> subsys-request msg 2) server replies with <config-response> server-response msg with the agt_profile data 3) subsys sends a <register-request> subsys-request msg with modules and object path-expressions to register. Any bundle and bundle-module info is also sent 4) server sends <ok> server-response 5) subsys sends a <trigger-replay> subsys-event; if any config for this subsystem, server will send a <start-transaction> server-request with a config-replay transaction SIL-SA Protocol Edit Operation: 1) the server sends a <start-transaction> server-request msg with the edit list 2) the subsys validates the request and sends an <ok> subsys-response (or error) 3) the server sends a <continue-transaction> for the apply phase 4) the subsys applies the request and sends an <ok> subsys-response (or error) 5) the server sends a <continue-transaction> for the commit phase 6) the subsys commits the request and sends an <ok> subsys-response (or error). If the server does not get to step (5) because of an error, a <continue-transaction> server-request msg will be sent for the rollback phase. If the server does not get to step (3) because of an error, it will send a <cancel-transaction> server-event msg so the subsystem can release any saved state. RPC Operation: 1) the server sends an <rpc-request> with the input parameters 2) the subsystem performs VALIDATE and INVOKE phases 3) the subsystem returns <rpc-ok> or <rpc-data>. YControl error is used for any errors ACTION Operation: 1) the server sends an <action-request> with the input parameters 2) the subsystem performs VALIDATE and INVOKE phases 3) the subsystem returns <action-ok> or <action-data>. YControl error is used for any errors HOOKS Support: Transaction Start Hooks: 1) the server send trans-start-hook request 2) the subsys validates the request, invoke callbacks, and sends an <ok> subsys-response (or error) Transaction Complete Hooks: 1) the server send trans-complete-hook event msg so subsystem can invoke Transaction Complete Callbacks "; choice message-type { mandatory true; leaf config-request { type empty; description "Message type: subsys-request; Purpose: register the service with the server and request the service configuration from server. Expected Response Message: config-response"; } container config-response { description "Message type: server-reply; Purpose: server will send this element containing the requested sub-system configuration. Expected Response Message: none"; uses config-parms; container schema-mount { uses ysm:sm-config-contents; } // container schema-mount } // container config-response container register-request { description "Message type: subsys-request; Purpose: register the SIL-SA callback functions for this sub-system. Expected Response Message: ok"; uses bundle-parm; uses bundle-module-parm; list register { key "module"; description "Specifies the path strings of all the objects in each module that is supported by the subsystem."; leaf module { type yt:NcxName; description "Module name for the target object."; } leaf revision { type string; description "Module revision identifier. Currently just a revision date."; } leaf-list path { type string; description "Path string for object for an EDIT callback"; } leaf-list edit2-path { type string; description "Path string for object for an EDIT2 callback"; } leaf-list edit3-path { type string; description "Path string for object for an EDIT3 callback"; } leaf-list get-path { type string; description "Path string for object for a GET callback"; } leaf-list rpc-name { type yt:NcxName; description "Name of the RPC operation callback"; } leaf-list action-path { type string; description "Path string for object for an ACTION callback"; } leaf-list post-sethook-path { type string; description "Path string for object for a Post Set Hook callback"; } list sethook-list { key "hook-path"; description "List for a Set Hook callbacks"; uses hooks-param; } // list sethook-list list transaction-hook-list { key "hook-path"; description "List for a Transaction Hook callbacks"; uses hooks-param; } // list transaction-hook-list container stream-callback { presence "Indicates a stream-callback is registered for the 'module' in the 'register' list entry with the 'register-request' message. If no child nodes then the registration is for the module name. Otherwise it is for one stream or all streams."; choice callback-type { case event-stream { uses event-stream-parm; } // case event-stream leaf all-streams { type empty; description "Flag to register for all event-stream events"; } } // choice callback-type } // container stream-callback } // list register uses system-callbacks-parm; uses glob-callbacks-parm; } // container register-request container start-transaction { description "Message type: server-request; Purpose: Start an edit transaction which may require the SIL-SA callback functions on the subsystem to be invoked. This message requests that a new edit transaction be started on the subsystem. Only 1 transaction can be in progress at a time. If this transaction is for a validate operation then there will not be any followup messages. Otherwise, the subsystem will retain this message until a cancel-transaction message has been received with the same transaction-id value, or a continue-transaction message has been received with the same transaction-id value for the 'rollback' or 'commit' phase. Expected Response Message: transaction-response or error"; uses transaction-id-obj; uses user-id-obj { refine user-id { mandatory true; } } uses client-addr-obj; leaf target { type string; mandatory true; description "Identifies the target datastore being edited. The values 'candidate' and 'running' are supported."; } leaf validate { type boolean; default 'false'; description "If 'true' then this start-transaction is for a validate operation or edit that is not on the running configuration datastore, so there will not be any followup messages at all for this message. The subsystem will release this info instead of caching it, and not expect any more messages for the same value of 'transaction-id'. If 'false' then this is a normal edit operation and the apply and commit/rollback followup messages will be sent. The subsystem will cache this data until the transaction is cancelled or completed."; } leaf reverse-edit { type boolean; default 'false'; description "If 'true' then this start-transaction is for a reverse-edit operation. All the phases should be invoked in sequence for the provided edit-list. The transaction can be discarded after sending a response, like the 'validate=true' flag. If 'false' then this is a normal edit operation."; } leaf load-config { type boolean; default 'false'; description "If 'true' then this start-transaction is for a <trigger-replay> operation. If 'false' then this is a normal edit operation, probably caused by a client <edit-config> operation."; } leaf is-hook-load { type boolean; description "Specifies whether this is a LOAD operation or not"; } leaf is-hook-validate { type boolean; description "Specifies whether this is a Validate operation or not"; } list edit { key "id"; leaf id { type uint32; description "Arbitrary edit identifier."; } uses operation-parms; uses path-parm; uses hooks-param; uses editvars-parm; anydata newval { description "Represents the new value, if any. Should be present if operation is 'merge' 'replace', 'create', or 'load'."; } anydata curval { description "Represents the current value, if any. Should be present if operation is 'replace', 'delete', or 'commit'"; } anydata update { description "Represents the combination of a new value and a current value, if any. Used in EDIT3 callbacks. Should be present if operation is 'merge' 'replace', 'create', or 'load'."; } anydata keys { description "List of all ancestor or self key values for the object being edited, identified by the 'path' value. There will be one child leaf for each key in each list."; } uses sm-mpid-parm; list child-edit { description "List of EDIT2 children edits, only when the operation is MERGE"; uses operation-parms; uses editvars-parm; anydata newval { description "Represents the new child value, if any. Should be present if operation is 'merge' 'replace', 'create', or 'load'."; } anydata curval { description "Represents the current child value, if any. Should be present if operation is 'replace', 'delete', or 'commit'"; } } // list child-edit } // list edit } // container start-transaction container continue-transaction { description "Message type: server-request; Purpose: Invoke a callback phase for an edit transaction in progress. Expected Response Message: transaction-response or error"; uses transaction-id-obj; leaf phase { type enumeration { enum "apply" { value 0; description "Apply the curent transaction. Resources can be reserved that will be used in the commit phase."; } enum "commit" { value 1; description "Commit the current transaction."; } enum "rollback" { value 2; description "Rollback the current transaction."; } } mandatory true; description "The SIL-SA callback phase in progress."; } } // container continue-transaction container transaction-response { description "Message type: subsys-response Purpose: - Set Hook: return added edits data or status - Post Set Hook: return added edits data or status - Transaction Hook: Expected Response Message: ok or error - If no Hook invoked: Expected Response Message: ok or error"; uses transaction-id-obj; list added-edit { uses path-parm; uses hook-edit-parms; anydata edit { description "Represents the added edits values, if any. There will be one child node for each added edit value."; } } // list added-edit } // container transaction-response container cancel-transaction { description "Message type: server-event; Purpose: Cancel an edit transaction in progress. Expected Response Message: none"; uses transaction-id-obj; } // container cancel-transaction leaf trigger-replay { type empty; description "Message type: subsys-event; Purpose: Trigger a configueration replay to load the running config data into the SIL-SA instrumentation. Expected Response Message: none; server will send a <start-transaction> if there is any config for the SIL-SA functions registered by the subsystem."; } container load-event { description "Message type: server-event; Purpose: A module or bundle has been loaded or unloaded at run-time. Subsys wil load SIL-SA code. and trigger a register event for any SIL calls registered. Expected Response Message: none"; leaf load { type boolean; default 'true'; description "Set to 'true' if this is a load event. Set to 'false' if this is an unload event."; } uses config-parms; } // container load-event container bundle-load-event { description "Message type: subsys-event; Purpose: A SIL-SA bundle has been loaded with a load-event sent from the server. This has caused some modules to be loaded on the subsystem, that need to be reported back to the main server so the datastore validation, agt_state, and other system book-keeping can be done. Expected Response Message: none"; uses bundle-parm; uses bundle-module-parm; } // container bundle-load-event container get-request { description "Composite retrieval request to support NETCONF and RESTCONF get operations. Type: server-request Expected Response Message: subsys-response (get-response or error)"; uses transaction-id-obj; uses user-id-obj; uses client-addr-obj; leaf flags { type bits { bit keys { position 0; description "Return only the key values"; } bit config { position 1; description "Return config=true data nodes"; } bit oper { position 2; description "Return config=false data nodes"; } bit getnext { position 3; description "This is a get-next request instead of a get request"; } bit withdef { position 4; description "Return default values for missing nodes"; } bit select { position 5; description "Return only the select nodes and any key leafs. Ignore the config, oper, withdef flags if this bit is set."; } bit with-origin { position 6; description "This is a <get-data> operation and the with-origin parameter is selected."; } } default ""; description "Set of get request modifier flags"; } leaf max-entries { type uint32; description "Max number of entries requested. The default is '0' == all for leaf-list and '1' for all other node types."; } uses path-parm; anydata keys { description "List of all ancestor or self key values for the object being retrieved, identified by the 'path' value. There will be one child leaf for each key in each list."; } anydata matches { description "Represents any content-match child leafs for the request. All leafs in this container must match the corresponding child nodes in an instance of the requested list or container, for that instance to be returned. Any content-match nodes must match in addition to any key leafs specified in the 'keys' container."; } container select-nodes { list select-node { key "objname"; description "Only requesting these nodes be returned. If no entries and the 'select' bit is set in the flags leaf, then no objects except list keys are returned."; leaf objname { type string; description "Object name of the select node"; } leaf modname { type string; description "Module name of the select node; If missing then use the module-name of the path target object."; } } // list select-node } // container select-nodes uses sm-mpid-parm; } // container get-request container get-response { description "Composite retrieval response to support NETCONF and RESTCONF get operations. Type: subsys-response Expected Response Message: none"; uses transaction-id-obj; leaf more-data { type boolean; default 'false'; description "Indicates if the GET callback has more data to send"; } leaf match-test-done { type boolean; default 'false'; description "Indicates if the requested content-match tests have be performed. Ignored if the 'matches' parameter is missing or empty."; } leaf active-case-modname { type string; description "Module name of the active case if there is one. Only applies if the GET2 object callback is for a YANG choice-stmt."; } leaf active-case { type string; description "Name of the active case if there is one. Only applies if the GET2 object callback is for a YANG choice-stmt."; } leaf origin { type string; description "The NMDA origin value for this object. Only applies for config=true list and presence containers."; } choice return-choice { case return-one { description "For all objects except YANG list, one entry will be returned. This can also be used for YANG list, except in GETBULK mode."; uses return-val; } // case return-one case return-getbulk { description "For YANG list GETBULK mode. There will be one entry for each list instance that met the search criteria. If the max_entries parameter was greater than zero, there the number of instances of 'entry' should not exceed this value."; list entry { uses return-val; } // list entry } // case return-getbulk } // choice return-choice } // container get-response container notification { description "Subsystem generated YANG notification event for NETCONF and RESTCONF streams. Type: subsys-event Expected Response Message: none"; leaf module-name { type string; mandatory true; description "Module name containing the notification definition"; } leaf event-name { type string; mandatory true; description "Notification statement name"; } leaf event-path { type string; description "Path string for a nested notification object. Not present for top-level event types."; } leaf-list event-key { type string; ordered-by user; description "Value of an ancestor key for a nested notification. The keys must be in the proper order. Top-to-bottom and left to right. Not present for top-level event types, or if a nested event type has no ancestor keys."; } leaf event-time { type string; mandatory true; description "Notification creation timestamp"; } leaf stream-name { type yt:NcxName; default "NETCONF"; description "Stream name for this notification"; } uses sm-mpid-parm; anydata parms { description "List of all parameters that this notification is sending in the payload."; } } // container notification container rpc-request { description "Message type: server-request; Purpose: Start an RPC transaction which may require the SIL-SA callback functions on the subsystem to be invoked. This message requests that a new remote procedure call be validated and invoked on the subsystem. If there are input parameters the subsystem must validate them. If not valid or if the operation cannot be performed, the subsystem must return an error. Expected Response Message: rpc-response"; uses transaction-id-obj; uses user-id-obj; uses client-addr-obj; leaf rpc-module { type yt:NcxName; mandatory true; description "Identifies the module name of the RPC definition."; } leaf rpc-name { type yt:NcxName; mandatory true; description "Identifies the name of the RPC definition."; } uses sm-mpid-parm; anydata rpc-input { description "Contains the RPC input data (if any)."; } } // container rpc-request container rpc-response { description "Message type: subsys-response Purpose: Return RPC data or status Expected Response Message: none"; uses transaction-id-obj; choice response-type { leaf rpc-ok { type empty; description "RPC successfully invoked"; } anydata rpc-output { description "Contains the RPC output data (if any)."; } } // choice response-type } // container rpc-response container action-request { description "Message type: server-request; Purpose: Start an ACTION transaction which may require the SIL-SA callback functions on the subsystem to be invoked. This message requests that a new action call be validated and invoked on the subsystem. If there are input parameters the subsystem must validate them. If not valid or if the operation cannot be performed, the subsystem must return an error. Expected Response Message: action-response"; uses transaction-id-obj; uses user-id-obj; uses client-addr-obj; uses path-parm; anydata keys { description "List of all ancestor key values for the action being invoked, identified by the 'path' value. There will be one child leaf for each key in each list."; } uses sm-mpid-parm; anydata action-input { description "Contains the ACTION input data (if any)."; } } // container action-request container action-response { description "Message type: subsys-response Purpose: Return ACTION data or status Expected Response Message: none"; uses transaction-id-obj; choice response-type { leaf action-ok { type empty; description "ACTION successfully invoked"; } anydata action-output { description "Contains the ACTION output data (if any)."; } } // choice response-type } // container action-response container trans-start-hook { description "Message type: server-request; Purpose: Send a request which may require the SIL-SA callback functions on the subsystem to be invoked; Expected Response Message: <ok> or <error>. This message requests that Transaction Start Hook callbacks should be invoked on the subsystem."; uses transaction-id-obj; uses user-id-obj; uses client-addr-obj; leaf isvalidate { type boolean; description "Specifies whether this is a <validate> operation or not. TRUE if this is a validate operation transaction"; } leaf isrollback { type boolean; description "Specifies whether this is a confirmed commit timeout or a cancel-confirmed-commit operation. FALSE if this is some other type of transaction"; } leaf isrunning { type boolean; description "Specifies whether this is transaction for running datastore. TRUE if this is a running datastore transaction"; } } // container trans-start-hook container trans-complete-hook { description "Message type: server-event; Purpose: Send an event which may require the SIL-SA callback functions on the subsystem to be invoked; Expected Response Message: none"; uses transaction-id-obj; } // container trans-complete-hook container hook-get-request { description "Message type: subsys-request; Purpose: Start a transaction which may require the server to run agt_val_get_data() API and return result. Get the val_value based on XPath of object instance This function will return value only if there is existing node in the datastore or there is defaults for the node. Expected Response Message: hook-get-response"; uses path-parm; leaf isrunning { type boolean; description "Specifies whether to retrieve a value from the running datastore or candidate"; } } // container hook-get-request container hook-get-response { description "Message type: server-reply; Purpose: server will send this element containing the requested val_value based on XPath of object instance. Expected Response Message: none"; anydata value { description "Represents the the val_value based on XPath of object instance"; } } // container hook-get-response container stream-callback-event { description "Message type: server-event; Purpose: An event-stream callback on a SIL-SA platform needs to be invoked. One event will be generated for each remote subsystem entry found that needs to be invoked. E.g., if 3 modules register but all are mapped to the same stream, then 3 events would be sent to the subsystem. Expected Response Message: none"; uses event-stream-parm; uses stream-subevent-parm; leaf module-name { type yt:NcxName; description "Module name to use to identify callback."; } leaf all-streams { type empty; description "All streams flag to identify callback."; } } // container stream-callback-event container commit-completeness-hook { description "Message type: server-request; Purpose: Send a request which may require the SIL-SA callback functions on the subsystem to be invoked; This message requests that Commit Completeness callbacks should be invoked on the subsystem. Expected Response Message: <ok> or <error>."; uses transaction-id-obj; uses user-id-obj; uses client-addr-obj; uses commit-phase-parm; uses commit-type-parm; } // container commit-completeness-hook } // choice message-type } // container sil-sa } } // module yumaworks-sil-sa
© 2023 YumaWorks, Inc. All rights reserved.