void vnc_display_init(const char *id, Error **errp);
void vnc_display_open(const char *id, Error **errp);
void vnc_display_add_client(const char *id, int csock, bool skipauth);
-int vnc_display_password(const char *id, const char *password);
+int vnc_display_password(const char *id, const char *password, Error **errp);
int vnc_display_pw_expire(const char *id, time_t expires);
void vnc_parse(const char *str);
int vnc_init_func(void *opaque, QemuOpts *opts, Error **errp);
void (*display_init)(void);
int (*migrate_info)(const char *h, int p, int t, const char *s);
int (*set_passwd)(const char *passwd,
- bool fail_if_connected, bool disconnect_if_connected);
+ bool fail_if_connected, bool disconnect_if_connected,
+ Error **errp);
int (*set_pw_expire)(time_t expires);
int (*display_add_client)(int csock, int skipauth, int tls);
#ifdef CONFIG_SPICE
self.assertEqual(set_password_response['error']['class'],
'GenericError')
self.assertEqual(set_password_response['error']['desc'],
- 'Could not set password')
+ 'No VNC display is present');
def launch_guarded(self):
try:
self.assertEqual(set_password_response['error']['class'],
'GenericError')
self.assertEqual(set_password_response['error']['desc'],
- 'Could not set password')
+ 'VNC password authentication is disabled')
def test_change_password(self):
self.set_machine('none')
tls_ciphers);
}
if (password) {
- qemu_spice.set_passwd(password, false, false);
+ qemu_spice.set_passwd(password, false, false, NULL);
}
if (qemu_opt_get_bool(opts, "sasl", 0)) {
if (spice_server_set_sasl(spice_server, 1) == -1) {
return qemu_spice_add_interface(&qxlin->base);
}
-static int qemu_spice_set_ticket(bool fail_if_conn, bool disconnect_if_conn)
+static int qemu_spice_set_ticket(bool fail_if_conn, bool disconnect_if_conn,
+ Error **errp)
{
+ int ret;
time_t lifetime, now = time(NULL);
char *passwd;
passwd = NULL;
lifetime = 1;
}
- return spice_server_set_ticket(spice_server, passwd, lifetime,
- fail_if_conn, disconnect_if_conn);
+ ret = spice_server_set_ticket(spice_server, passwd, lifetime,
+ fail_if_conn, disconnect_if_conn);
+ if (ret < 0) {
+ error_setg(errp, "Unable to set SPICE server ticket");
+ return -1;
+ }
+ return 0;
}
static int qemu_spice_set_passwd(const char *passwd,
- bool fail_if_conn, bool disconnect_if_conn)
+ bool fail_if_conn, bool disconnect_if_conn,
+ Error **errp)
{
if (strcmp(auth, "spice") != 0) {
+ error_setg(errp, "SPICE authentication is disabled");
+ error_append_hint(errp,
+ "To enable it use '-spice ...,password-secret=ID'");
return -1;
}
g_free(auth_passwd);
auth_passwd = g_strdup(passwd);
- return qemu_spice_set_ticket(fail_if_conn, disconnect_if_conn);
+ return qemu_spice_set_ticket(fail_if_conn, disconnect_if_conn, errp);
}
static int qemu_spice_set_pw_expire(time_t expires)
{
auth_expires = expires;
- return qemu_spice_set_ticket(false, false);
+ return qemu_spice_set_ticket(false, false, NULL);
}
static int qemu_spice_display_add_client(int csock, int skipauth, int tls)
static int qemu_spice_set_passwd_stub(const char *passwd,
bool fail_if_connected,
- bool disconnect_if_connected)
+ bool disconnect_if_connected,
+ Error **errp)
{
- return -1;
+ g_assert_not_reached();
}
static int qemu_spice_set_pw_expire_stub(time_t expires)
{
- return -1;
+ g_assert_not_reached();
}
static int qemu_spice_display_add_client_stub(int csock, int skipauth,
void qmp_set_password(SetPasswordOptions *opts, Error **errp)
{
- int rc;
-
if (opts->protocol == DISPLAY_PROTOCOL_SPICE) {
if (!qemu_using_spice(errp)) {
return;
}
- rc = qemu_spice.set_passwd(opts->password,
- opts->connected == SET_PASSWORD_ACTION_FAIL,
- opts->connected == SET_PASSWORD_ACTION_DISCONNECT);
+ qemu_spice.set_passwd(opts->password,
+ opts->connected == SET_PASSWORD_ACTION_FAIL,
+ opts->connected == SET_PASSWORD_ACTION_DISCONNECT,
+ errp);
} else {
assert(opts->protocol == DISPLAY_PROTOCOL_VNC);
if (opts->connected != SET_PASSWORD_ACTION_KEEP) {
* Note that setting an empty password will not disable login
* through this interface.
*/
- rc = vnc_display_password(opts->u.vnc.display, opts->password);
- }
-
- if (rc != 0) {
- error_setg(errp, "Could not set password");
+ vnc_display_password(opts->u.vnc.display, opts->password, errp);
}
}
#ifdef CONFIG_VNC
void qmp_change_vnc_password(const char *password, Error **errp)
{
- if (vnc_display_password(NULL, password) < 0) {
- error_setg(errp, "Could not set password");
- }
+ vnc_display_password(NULL, password, errp);
}
#endif
#include "ui/console.h"
#include "qapi/error.h"
-int vnc_display_password(const char *id, const char *password)
+int vnc_display_password(const char *id, const char *password, Error **errp)
{
- return -ENODEV;
+ g_assert_not_reached();
}
int vnc_display_pw_expire(const char *id, time_t expires)
{
- return -ENODEV;
+ g_assert_not_reached();
};
#endif
}
-int vnc_display_password(const char *id, const char *password)
+int vnc_display_password(const char *id, const char *password, Error **errp)
{
VncDisplay *vd = vnc_display_find(id);
if (!vd) {
+ error_setg(errp, "No VNC display is present");
+ error_append_hint(errp,
+ "To enable it, use '-vnc ...'");
return -EINVAL;
}
if (vd->auth == VNC_AUTH_NONE) {
- error_printf_unless_qmp("If you want use passwords please enable "
- "password auth using '-vnc ${dpy},password'.\n");
+ error_setg(errp, "VNC password authentication is disabled");
+ error_append_hint(errp,
+ "To enable it, use '-vnc ...,password-secret=ID'");
return -EINVAL;
}