-
Notifications
You must be signed in to change notification settings - Fork 91
Proposal for clarifications when calling gNMI Set on a list node or element. #140
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -453,6 +453,34 @@ update: < | |
| > | ||
| ``` | ||
|
|
||
| For `/a/b[name=b1]`: | ||
|
|
||
| ``` | ||
| update: < | ||
| path: < | ||
| elem: < | ||
| name: "a" | ||
| > | ||
| elem: < | ||
| name: "b" | ||
| key: < | ||
| key: "name" | ||
| value: "b1" | ||
| > | ||
| > | ||
| > | ||
| val: < | ||
| json_ietf_val: `{ | ||
| "name": "b1", | ||
| "c": { | ||
| "d": "AStringValue", | ||
| "e": 10042 | ||
| } | ||
| }` | ||
| > | ||
| > | ||
| ``` | ||
|
|
||
| For `/a` : | ||
|
|
||
| ``` | ||
|
|
@@ -467,10 +495,10 @@ update: < | |
| { | ||
| "name": "b1", | ||
| "c": { | ||
| "d": "AStringValue", | ||
| "d": "AStringValue", | ||
| "e": 10042 | ||
| } | ||
| } | ||
| } | ||
| ] | ||
| }` | ||
| > | ||
|
|
@@ -1109,11 +1137,11 @@ array), the following considerations apply: | |
|
|
||
| * In the case that multiple attribute values are required to uniquely address | ||
| an element - e.g., `/a/f[k1=10][k2=20] `- and a replace or update | ||
| operation's path specifies a subset of the attributes (e.g., `/a/f[k1=10]`) | ||
| then this MUST be considered an error by the target system - and an status | ||
| code of` InvalidArgument (3)` specified. | ||
| operation's path specifies a proper subset of the attributes (e.g., | ||
| `/a/f[k1=10]`, `/a/f`), then this MUST be considered an error by the target | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This change means that one cannot send
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I didn't change anything here -- a strict/proper subset is likely what the original sentence meant to say. I think there is no clear reason to disallow this, since the keys for each element in the array should be provided in the update message as well. However, that would now mean this spec needs to be changed, right?
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think there's an ambiguity here, I think that this was intended to say a non-null subset - i.e., keys were partially specified. I think there are a few cases here:
I think it'd be worth checking implementations to see whether the no-keys variant is supported. This was the original motivation for having surrounding containers in OpenConfig such that a get + set could be done on the surrounding container to get all entries. |
||
| system - and an status code of` InvalidArgument (3)` specified. | ||
| * Where the path specified refers to a node which itself represents the | ||
| collection of objects (list, map, or array) a replace operation MUST remove | ||
| collection of objects (list, map, or array), a replace operation MUST remove | ||
| all collection entries that are not supplied in the value provided in the | ||
| `SetRequest`. An update operation MUST be considered to add new entries to | ||
| the collection if they do not exist. | ||
|
|
||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it worth explicitly stating here that the contents of the update is the JSON object that would be expected at that list entry?