qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Stefan Reiter <s.reiter@proxmox.com>
To: "Marc-André Lureau" <marcandre.lureau@gmail.com>
Cc: Wolfgang Bumiller <w.bumiller@proxmox.com>,
	QEMU <qemu-devel@nongnu.org>,
	"Dr. David Alan Gilbert" <dgilbert@redhat.com>,
	Markus Armbruster <armbru@redhat.com>,
	Gerd Hoffmann <kraxel@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>,
	Eric Blake <eblake@redhat.com>,
	Thomas Lamprecht <t.lamprecht@proxmox.com>
Subject: Re: [PATCH 2/2] monitor: allow VNC related QMP and HMP commands to take a display ID
Date: Wed, 25 Aug 2021 13:26:09 +0200	[thread overview]
Message-ID: <4400f41b-4ecc-9340-a20d-8acdaae033be@proxmox.com> (raw)
In-Reply-To: <CAJ+F1CKf5icfpA4X_kHQQJGfiHj+dvct9OqEvtOQ2UD4WPCbtw@mail.gmail.com>

On 8/25/21 12:59 PM, Marc-André Lureau wrote:
> Hi
> 
> On Wed, Aug 25, 2021 at 1:39 PM Stefan Reiter <s.reiter@proxmox.com> wrote:
> 
>> It is possible to specify more than one VNC server on the command line,
>> either with an explicit ID or the auto-generated ones à la "default",
>> "vnc2", "vnc3", ...
>>
>> It is not possible to change the password on one of these extra VNC
>> displays though. Fix this by adding a "display" parameter to the
>> 'set_password' and 'expire_password' QMP and HMP commands.
>>
>> For HMP, this is a bit trickier, since at least 'set_password' already
>> has the 'connected' parameter following the mandatory 'password' one, so
>> we need to prefix the display ID with "id=" to allow correct parsing.
>>
> 
> It's not something done with other commands afaik, feels a bit awkward (the
> "connected = display"...).
>

Indeed, if there is a better way I'd love to use it.

One idea I had was making the parameter 'connected' OR 'display', since
the former only supports 'keep' for VNC anyway - but that introduces a
weird double-meaning again.
  
> Is it really necessary to add support for HMP?
> 

For us it would be, as we provide an easy HMP interface to our users, but
not a QMP one, so it ended up being a bit of a regression with 6.0.

>> With this prefix, no existing command or workflow should be affected.
>>
>> While rewriting the descriptions, also remove the line "Use zero to make
>> the password stay valid forever." from 'set_password', I believe this was
>> intended for 'expire_password', but would even be wrong there.
>>
>> Signed-off-by: Stefan Reiter <s.reiter@proxmox.com>
>> ---
>>   hmp-commands.hx    | 28 +++++++++++++++-------------
>>   monitor/hmp-cmds.c | 20 ++++++++++++++++++--
>>   monitor/qmp-cmds.c |  9 +++++----
>>   qapi/ui.json       | 12 ++++++++++--
>>   4 files changed, 48 insertions(+), 21 deletions(-)
>>
>> diff --git a/hmp-commands.hx b/hmp-commands.hx
>> index e01ca13ca8..0b5abcfb8a 100644
>> --- a/hmp-commands.hx
>> +++ b/hmp-commands.hx
>> @@ -1541,34 +1541,36 @@ ERST
>>
>>       {
>>           .name       = "set_password",
>> -        .args_type  = "protocol:s,password:s,connected:s?",
>> -        .params     = "protocol password action-if-connected",
>> +        .args_type  = "protocol:s,password:s,display:s?,connected:s?",
>> +        .params     = "protocol password [id=display]
>> [action-if-connected]",
>>           .help       = "set spice/vnc password",
>>           .cmd        = hmp_set_password,
>>       },
>>
>>   SRST
>> -``set_password [ vnc | spice ] password [ action-if-connected ]``
>> -  Change spice/vnc password.  Use zero to make the password stay valid
>> -  forever.  *action-if-connected* specifies what should happen in
>> +``set_password [ vnc | spice ] password [ id=display ] [
>> action-if-connected ]``
>> +  Change spice/vnc password.  *display* (must be prefixed with
>> +  'id=') can be used with 'vnc' to specify which display to set the
>> +  password on.  *action-if-connected* specifies what should happen in
>>     case a connection is established: *fail* makes the password change
>> -  fail.  *disconnect* changes the password and disconnects the
>> -  client.  *keep* changes the password and keeps the connection up.
>> -  *keep* is the default.
>> +  fail.  *disconnect* changes the password and disconnects the client.
>> +  *keep* changes the password and keeps the connection up.  *keep* is
>> +  the default.
>>   ERST
>>
>>       {
>>           .name       = "expire_password",
>> -        .args_type  = "protocol:s,time:s",
>> -        .params     = "protocol time",
>> +        .args_type  = "protocol:s,time:s,display:s?",
>> +        .params     = "protocol time [id=display]",
>>           .help       = "set spice/vnc password expire-time",
>>           .cmd        = hmp_expire_password,
>>       },
>>
>>   SRST
>> -``expire_password [ vnc | spice ]`` *expire-time*
>> -  Specify when a password for spice/vnc becomes
>> -  invalid. *expire-time* accepts:
>> +``expire_password [ vnc | spice ] expire-time [ id=display ]``
>> +  Specify when a password for spice/vnc becomes invalid.
>> +  *display* behaves the same as in ``set_password``.
>> +  *expire-time* accepts:
>>
>>     ``now``
>>       Invalidate password instantly.
>> diff --git a/monitor/hmp-cmds.c b/monitor/hmp-cmds.c
>> index 31366e6331..30f5b2c3e3 100644
>> --- a/monitor/hmp-cmds.c
>> +++ b/monitor/hmp-cmds.c
>> @@ -1546,10 +1546,20 @@ void hmp_set_password(Monitor *mon, const QDict
>> *qdict)
>>   {
>>       const char *protocol  = qdict_get_str(qdict, "protocol");
>>       const char *password  = qdict_get_str(qdict, "password");
>> +    const char *display = qdict_get_try_str(qdict, "display");
>>       const char *connected = qdict_get_try_str(qdict, "connected");
>>       Error *err = NULL;
>>
>> -    qmp_set_password(protocol, password, !!connected, connected, &err);
>> +    if (display && strncmp(display, "id=", 3)) {
>> +        connected = display;
>> +        display = NULL;
>> +    } else if (display) {
>> +        /* skip "id=" */
>> +        display = display + 3;
>> +    }
>> +
>> +    qmp_set_password(protocol, password, !!connected, connected,
>> !!display,
>> +                     display, &err);
>>       hmp_handle_error(mon, err);
>>   }
>>
>> @@ -1557,9 +1567,15 @@ void hmp_expire_password(Monitor *mon, const QDict
>> *qdict)
>>   {
>>       const char *protocol  = qdict_get_str(qdict, "protocol");
>>       const char *whenstr = qdict_get_str(qdict, "time");
>> +    const char *display = qdict_get_try_str(qdict, "display");
>>       Error *err = NULL;
>>
>> -    qmp_expire_password(protocol, whenstr, &err);
>> +    if (display && !strncmp(display, "id=", 3)) {
>> +        /* skip "id=" */
>> +        display = display + 3;
>> +    }
>> +
>> +    qmp_expire_password(protocol, whenstr, !!display, display, &err);
>>       hmp_handle_error(mon, err);
>>   }
>>
>> diff --git a/monitor/qmp-cmds.c b/monitor/qmp-cmds.c
>> index f7d64a6457..a9ded90a41 100644
>> --- a/monitor/qmp-cmds.c
>> +++ b/monitor/qmp-cmds.c
>> @@ -165,7 +165,8 @@ void qmp_system_wakeup(Error **errp)
>>   }
>>
>>   void qmp_set_password(const char *protocol, const char *password,
>> -                      bool has_connected, const char *connected, Error
>> **errp)
>> +                      bool has_connected, const char *connected,
>> +                      bool has_display, const char *display, Error **errp)
>>   {
>>       int disconnect_if_connected = 0;
>>       int fail_if_connected = 0;
>> @@ -198,7 +199,7 @@ void qmp_set_password(const char *protocol, const char
>> *password,
>>           }
>>           /* Note that setting an empty password will not disable login
>> through
>>            * this interface. */
>> -        rc = vnc_display_password(NULL, password);
>> +        rc = vnc_display_password(has_display ? display : NULL, password);
>>       } else {
>>           error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "protocol",
>>                      "'vnc' or 'spice'");
>> @@ -211,7 +212,7 @@ void qmp_set_password(const char *protocol, const char
>> *password,
>>   }
>>
>>   void qmp_expire_password(const char *protocol, const char *whenstr,
>> -                         Error **errp)
>> +                         bool has_display, const char *display, Error
>> **errp)
>>   {
>>       time_t when;
>>       int rc;
>> @@ -232,7 +233,7 @@ void qmp_expire_password(const char *protocol, const
>> char *whenstr,
>>           }
>>           rc = qemu_spice.set_pw_expire(when);
>>       } else if (strcmp(protocol, "vnc") == 0) {
>> -        rc = vnc_display_pw_expire(NULL, when);
>> +        rc = vnc_display_pw_expire(has_display ? display : NULL, when);
>>       } else {
>>           error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "protocol",
>>                      "'vnc' or 'spice'");
>> diff --git a/qapi/ui.json b/qapi/ui.json
>> index 16bf03224f..24dca811f8 100644
>> --- a/qapi/ui.json
>> +++ b/qapi/ui.json
>> @@ -25,6 +25,9 @@
>>   #             'disconnect' to disconnect existing clients
>>   #             'keep' to maintain existing clients
>>   #
>> +# @display: In case of VNC, the id of the display where the password
>> +#           should be changed. Defaults to the first.
>> +#
>>   # Returns: - Nothing on success
>>   #          - If Spice is not enabled, DeviceNotFound
>>   #
>> @@ -38,7 +41,8 @@
>>   #
>>   ##
>>   { 'command': 'set_password',
>> -  'data': {'protocol': 'str', 'password': 'str', '*connected': 'str'} }
>> +  'data': {'protocol': 'str', 'password': 'str', '*connected': 'str',
>> +           '*display': 'str'} }
>>
>>   ##
>>   # @expire_password:
>> @@ -54,6 +58,9 @@
>>   #        - '+INT' where INT is the number of seconds from now (integer)
>>   #        - 'INT' where INT is the absolute time in seconds
>>   #
>> +# @display: In case of VNC, the id of the display where the password
>> +#           should be set to expire. Defaults to the first.
>> +#
>>   # Returns: - Nothing on success
>>   #          - If @protocol is 'spice' and Spice is not active,
>> DeviceNotFound
>>   #
>> @@ -71,7 +78,8 @@
>>   # <- { "return": {} }
>>   #
>>   ##
>> -{ 'command': 'expire_password', 'data': {'protocol': 'str', 'time':
>> 'str'} }
>> +{ 'command': 'expire_password',
>> +  'data': {'protocol': 'str', 'time': 'str', '*display': 'str'} }
>>
>>   ##
>>   # @screendump:
>> --
>> 2.30.2
>>
>>
>>
>>
> 



  reply	other threads:[~2021-08-25 11:36 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-08-25  9:36 [PATCH 0/2] VNC-related HMP/QMP fixes Stefan Reiter
2021-08-25  9:37 ` [PATCH 1/2] monitor/hmp: correctly invert password argument detection again Stefan Reiter
2021-08-25 10:42   ` Marc-André Lureau
2021-08-25  9:37 ` [PATCH 2/2] monitor: allow VNC related QMP and HMP commands to take a display ID Stefan Reiter
2021-08-25 10:59   ` Marc-André Lureau
2021-08-25 11:26     ` Stefan Reiter [this message]
2021-08-25 19:20       ` Eric Blake
2021-08-25 19:16     ` Eric Blake
2021-08-31 12:20       ` Gerd Hoffmann

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4400f41b-4ecc-9340-a20d-8acdaae033be@proxmox.com \
    --to=s.reiter@proxmox.com \
    --cc=armbru@redhat.com \
    --cc=dgilbert@redhat.com \
    --cc=eblake@redhat.com \
    --cc=kraxel@redhat.com \
    --cc=marcandre.lureau@gmail.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=t.lamprecht@proxmox.com \
    --cc=w.bumiller@proxmox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).