提交 80cd93bd 编写于 作者: M Markus Armbruster

qmp: Make "id" optional again even in "oob" monitors

Commit cf869d53 "qmp: support out-of-band (oob) execution" made
"id" mandatory for all commands when the client accepted capability
"oob".  This is rather onerous when you play with QMP by hand, and
unnecessarily so: only out-of-band commands need an ID for reliable
matching of response to command.

Revert that part of commit cf869d53 for now, but have documentation
advise on the need to use "id" with out-of-band commands.
Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
Message-Id: <20180703085358.13941-8-armbru@redhat.com>
Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
Reviewed-by: NEric Blake <eblake@redhat.com>
上级 2970b446
...@@ -103,16 +103,13 @@ The format for command execution is: ...@@ -103,16 +103,13 @@ The format for command execution is:
required. Each command documents what contents will be considered required. Each command documents what contents will be considered
valid when handling the json-argument valid when handling the json-argument
- The "id" member is a transaction identification associated with the - The "id" member is a transaction identification associated with the
command execution. It is required for all commands if the OOB - command execution, it is optional and will be part of the response
capability was enabled at startup, and optional otherwise. The same if provided. The "id" member can be any json-value. A json-number
"id" field will be part of the response if provided. The "id" incremented for each successive command works fine.
member can be any json-value. A json-number incremented for each
successive command works fine.
- The optional "control" member further specifies how the command is - The optional "control" member further specifies how the command is
to be executed. Currently, its only member is optional "run-oob". to be executed. Currently, its only member is optional "run-oob".
See section "2.3.1 Out-of-band execution" for details. See section "2.3.1 Out-of-band execution" for details.
2.3.1 Out-of-band execution 2.3.1 Out-of-band execution
--------------------------- ---------------------------
...@@ -128,6 +125,10 @@ possibly overtaking prior in-band commands. The client may therefore ...@@ -128,6 +125,10 @@ possibly overtaking prior in-band commands. The client may therefore
receive such a command's response before responses from prior in-band receive such a command's response before responses from prior in-band
commands. commands.
To be able to match responses back to their commands, the client needs
to pass "id" with out-of-band commands. Passing it with all commands
is recommended for clients that accept capability "oob".
To execute a command out-of-band, the client puts "run-oob": true into To execute a command out-of-band, the client puts "run-oob": true into
execute's member "control". execute's member "control".
......
...@@ -4292,13 +4292,6 @@ static void handle_qmp_command(JSONMessageParser *parser, GQueue *tokens) ...@@ -4292,13 +4292,6 @@ static void handle_qmp_command(JSONMessageParser *parser, GQueue *tokens)
id = qdict_get(qdict, "id"); id = qdict_get(qdict, "id");
/* When OOB is enabled, the "id" field is mandatory. */
if (qmp_oob_enabled(mon) && !id) {
error_setg(&err, "Out-of-band capability requires that "
"every command contains an 'id' field");
goto err;
}
req_obj = g_new0(QMPRequest, 1); req_obj = g_new0(QMPRequest, 1);
req_obj->mon = mon; req_obj->mon = mon;
req_obj->id = qobject_ref(id); req_obj->id = qobject_ref(id);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册