mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-05 04:25:19 +00:00
cmdQemuMonitorCommandQMPWrap: Reset ignored errors from JSON parsing
'cmdQemuMonitorCommandQMPWrap' is checking whether the user provided string is not valid JSON to avoid wrapping it. In cases where it's not JSON we ignore the error and add the wrapper. If the caller then reports a different non-libvirt error the error from the JSON parsing would be printed as well. Reset errors we ignore: # virsh qemu-monitor-command cd --pass-fds a asdf error: Unable to parse FD number 'a' error: internal error: cannot parse json asdf: lexical error: invalid char in json text. asdf (right here) ------^ In the above case 'asdf' is not valid JSON, but the code did wrap it into '{"execute":"asdf"}', the only problem is the argument for --pass-fds. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
This commit is contained in:
parent
619d825a18
commit
8e2a043c32
@ -9870,7 +9870,7 @@ cmdQemuMonitorCommandQMPWrap(vshControl *ctl,
|
|||||||
const vshCmd *cmd)
|
const vshCmd *cmd)
|
||||||
{
|
{
|
||||||
g_autofree char *fullcmd = cmdQemuMonitorCommandConcatCmd(ctl, cmd, NULL);
|
g_autofree char *fullcmd = cmdQemuMonitorCommandConcatCmd(ctl, cmd, NULL);
|
||||||
g_autoptr(virJSONValue) fullcmdjson = virJSONValueFromString(fullcmd);
|
g_autoptr(virJSONValue) fullcmdjson = NULL;
|
||||||
g_autofree char *fullargs = NULL;
|
g_autofree char *fullargs = NULL;
|
||||||
g_autoptr(virJSONValue) fullargsjson = NULL;
|
g_autoptr(virJSONValue) fullargsjson = NULL;
|
||||||
const vshCmdOpt *opt = NULL;
|
const vshCmdOpt *opt = NULL;
|
||||||
@ -9878,6 +9878,11 @@ cmdQemuMonitorCommandQMPWrap(vshControl *ctl,
|
|||||||
g_autoptr(virJSONValue) command = NULL;
|
g_autoptr(virJSONValue) command = NULL;
|
||||||
g_autoptr(virJSONValue) arguments = NULL;
|
g_autoptr(virJSONValue) arguments = NULL;
|
||||||
|
|
||||||
|
if (!(fullcmdjson = virJSONValueFromString(fullcmd))) {
|
||||||
|
/* Reset the error before adding wrapping. */
|
||||||
|
vshResetLibvirtError();
|
||||||
|
}
|
||||||
|
|
||||||
/* if we've got a JSON object, pass it through */
|
/* if we've got a JSON object, pass it through */
|
||||||
if (virJSONValueIsObject(fullcmdjson))
|
if (virJSONValueIsObject(fullcmdjson))
|
||||||
return g_steal_pointer(&fullcmd);
|
return g_steal_pointer(&fullcmd);
|
||||||
@ -9889,8 +9894,11 @@ cmdQemuMonitorCommandQMPWrap(vshControl *ctl,
|
|||||||
commandname = opt->data;
|
commandname = opt->data;
|
||||||
|
|
||||||
/* now we process arguments similarly to how we've dealt with the full command */
|
/* now we process arguments similarly to how we've dealt with the full command */
|
||||||
if ((fullargs = cmdQemuMonitorCommandConcatCmd(ctl, cmd, opt)))
|
if ((fullargs = cmdQemuMonitorCommandConcatCmd(ctl, cmd, opt)) &&
|
||||||
fullargsjson = virJSONValueFromString(fullargs);
|
!(fullargsjson = virJSONValueFromString(fullargs))) {
|
||||||
|
/* Reset the error before adding wrapping. */
|
||||||
|
vshResetLibvirtError();
|
||||||
|
}
|
||||||
|
|
||||||
/* for empty args or a valid JSON object we just use that */
|
/* for empty args or a valid JSON object we just use that */
|
||||||
if (!fullargs || virJSONValueIsObject(fullargsjson)) {
|
if (!fullargs || virJSONValueIsObject(fullargsjson)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user