Commit 1ff7df1a848044f58d0f3540f1447db4bb1d2d20

Authored by aliguori
1 parent adc5ec85

Enhance 'info vnc' monitor output ("Daniel P. Berrange")

The current 'info vnc' monitor output just displays the VNC server address
as provided by the -vnc command line flag. This isn't particularly useful
since it doesn't tell you what VNC is actually listening on. eg, if you
use '-vnc :1' it is useful to know whether this translated to '0.0.0.0:5901'
or chose IPv6 ':::5901'.  It is also useful to know the address of the
client that is currently connected. It is also useful to know the active
authentication (if any).

This patch tweaks the monitor output to look like:

   (qemu) info vnc
    Server:
         address: 0.0.0.0:5902
            auth: vencrypt+x509
    Client: none

And when 2 clients are connected

   (qemu) info vnc
    Server:
         address: 0.0.0.0:5902
            auth: vencrypt+x509
    Client:
         address: 10.33.6.67:38621
    Client:
         address: 10.33.6.63:38620

More data will be added to this later in the patch series...

The 'addr_to_string' helper method in this patch is overly generic
for the needs of this patch alone. This is because it will be re-used
by the later SASL patches in this series, where the flexibility is
important.


 vnc.c |  137 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 127 insertions(+), 10 deletions(-)

   Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6720 c046a42c-6fe2-441c-8c8c-71466251a162
Showing 1 changed file with 128 additions and 11 deletions
... ... @@ -167,19 +167,136 @@ struct VncState
167 167 static VncDisplay *vnc_display; /* needed for info vnc */
168 168 static DisplayChangeListener *dcl;
169 169  
  170 +static char *addr_to_string(const char *format,
  171 + struct sockaddr_storage *sa,
  172 + socklen_t salen) {
  173 + char *addr;
  174 + char host[NI_MAXHOST];
  175 + char serv[NI_MAXSERV];
  176 + int err;
  177 +
  178 + if ((err = getnameinfo((struct sockaddr *)sa, salen,
  179 + host, sizeof(host),
  180 + serv, sizeof(serv),
  181 + NI_NUMERICHOST | NI_NUMERICSERV)) != 0) {
  182 + VNC_DEBUG("Cannot resolve address %d: %s\n",
  183 + err, gai_strerror(err));
  184 + return NULL;
  185 + }
  186 +
  187 + if (asprintf(&addr, format, host, serv) < 0)
  188 + return NULL;
  189 +
  190 + return addr;
  191 +}
  192 +
  193 +static char *vnc_socket_local_addr(const char *format, int fd) {
  194 + struct sockaddr_storage sa;
  195 + socklen_t salen;
  196 +
  197 + salen = sizeof(sa);
  198 + if (getsockname(fd, (struct sockaddr*)&sa, &salen) < 0)
  199 + return NULL;
  200 +
  201 + return addr_to_string(format, &sa, salen);
  202 +}
  203 +
  204 +static char *vnc_socket_remote_addr(const char *format, int fd) {
  205 + struct sockaddr_storage sa;
  206 + socklen_t salen;
  207 +
  208 + salen = sizeof(sa);
  209 + if (getpeername(fd, (struct sockaddr*)&sa, &salen) < 0)
  210 + return NULL;
  211 +
  212 + return addr_to_string(format, &sa, salen);
  213 +}
  214 +
  215 +static const char *vnc_auth_name(VncDisplay *vd) {
  216 + switch (vd->auth) {
  217 + case VNC_AUTH_INVALID:
  218 + return "invalid";
  219 + case VNC_AUTH_NONE:
  220 + return "none";
  221 + case VNC_AUTH_VNC:
  222 + return "vnc";
  223 + case VNC_AUTH_RA2:
  224 + return "ra2";
  225 + case VNC_AUTH_RA2NE:
  226 + return "ra2ne";
  227 + case VNC_AUTH_TIGHT:
  228 + return "tight";
  229 + case VNC_AUTH_ULTRA:
  230 + return "ultra";
  231 + case VNC_AUTH_TLS:
  232 + return "tls";
  233 + case VNC_AUTH_VENCRYPT:
  234 +#ifdef CONFIG_VNC_TLS
  235 + switch (vd->subauth) {
  236 + case VNC_AUTH_VENCRYPT_PLAIN:
  237 + return "vencrypt+plain";
  238 + case VNC_AUTH_VENCRYPT_TLSNONE:
  239 + return "vencrypt+tls+none";
  240 + case VNC_AUTH_VENCRYPT_TLSVNC:
  241 + return "vencrypt+tls+vnc";
  242 + case VNC_AUTH_VENCRYPT_TLSPLAIN:
  243 + return "vencrypt+tls+plain";
  244 + case VNC_AUTH_VENCRYPT_X509NONE:
  245 + return "vencrypt+x509+none";
  246 + case VNC_AUTH_VENCRYPT_X509VNC:
  247 + return "vencrypt+x509+vnc";
  248 + case VNC_AUTH_VENCRYPT_X509PLAIN:
  249 + return "vencrypt+x509+plain";
  250 + default:
  251 + return "vencrypt";
  252 + }
  253 +#else
  254 + return "vencrypt";
  255 +#endif
  256 + }
  257 + return "unknown";
  258 +}
  259 +
  260 +#define VNC_SOCKET_FORMAT_PRETTY "local %s:%s"
  261 +
  262 +static void do_info_vnc_client(Monitor *mon, VncState *client)
  263 +{
  264 + char *clientAddr =
  265 + vnc_socket_remote_addr(" address: %s:%s\n",
  266 + client->csock);
  267 + if (!clientAddr)
  268 + return;
  269 +
  270 + monitor_printf(mon, "Client:\n");
  271 + monitor_printf(mon, "%s", clientAddr);
  272 + free(clientAddr);
  273 +}
  274 +
170 275 void do_info_vnc(Monitor *mon)
171 276 {
172   - if (vnc_display == NULL || vnc_display->display == NULL)
173   - monitor_printf(mon, "VNC server disabled\n");
174   - else {
175   - monitor_printf(mon, "VNC server active on: ");
176   - monitor_print_filename(mon, vnc_display->display);
177   - monitor_printf(mon, "\n");
178   -
179   - if (vnc_display->clients == NULL)
180   - monitor_printf(mon, "No client connected\n");
181   - else
182   - monitor_printf(mon, "Client connected\n");
  277 + if (vnc_display == NULL || vnc_display->display == NULL) {
  278 + monitor_printf(mon, "Server: disabled\n");
  279 + } else {
  280 + char *serverAddr = vnc_socket_local_addr(" address: %s:%s\n",
  281 + vnc_display->lsock);
  282 +
  283 + if (!serverAddr)
  284 + return;
  285 +
  286 + monitor_printf(mon, "Server:\n");
  287 + monitor_printf(mon, "%s", serverAddr);
  288 + free(serverAddr);
  289 + monitor_printf(mon, " auth: %s\n", vnc_auth_name(vnc_display));
  290 +
  291 + if (vnc_display->clients) {
  292 + VncState *client = vnc_display->clients;
  293 + while (client) {
  294 + do_info_vnc_client(mon, client);
  295 + client = client->next;
  296 + }
  297 + } else {
  298 + monitor_printf(mon, "Client: none\n");
  299 + }
183 300 }
184 301 }
185 302  
... ...