From: Steinar H. Gunderson Date: Fri, 4 Feb 2005 15:58:59 +0000 (+0000) Subject: Basic connection to VNC added (read width and height, mostly). X-Git-Url: https://git.sesse.net/?a=commitdiff_plain;ds=sidebyside;h=8620fedb9b11c67f5eab4b07cbac9dce189f5858;p=rdpsrv Basic connection to VNC added (read width and height, mostly). --- diff --git a/rdpsrv.c b/rdpsrv.c index 7c6b1f6..43bf2a4 100644 --- a/rdpsrv.c +++ b/rdpsrv.c @@ -102,10 +102,54 @@ void handle_input_pdu(STREAM s) } } -int serve_client() +struct ServerInitialization { + unsigned short width; + unsigned short height; + unsigned char pixelformat[16]; // FIXME + unsigned int name_len; +}; + +int vnc_init() { - // connect to VNC + char buf[256]; int vnc_sock = tcp_connect("127.0.0.1", 5901); + struct ServerInitialization si; + + // get handshake + if (read(vnc_sock, buf, 12) != 12) + error("short read on handshake\n"); + write(vnc_sock, "RFB 003.003\n", 12); + + // get auth + if (read(vnc_sock, buf, 4) != 4) + error("short read on auth\n"); + + if (buf[3] != 1) + error("auth needed or connection failed\n"); + + // send shared flag + buf[0] = 1; + write(vnc_sock, buf, 1); + + // read the server initialization + if (read(vnc_sock, &si, sizeof(struct ServerInitialization)) != sizeof(struct ServerInitialization)) + error("short read on SI"); + + printf("Server is %u x %u\n", ntohs(si.width), ntohs(si.height)); + + if (read(vnc_sock, buf, si.name_len) != si.name_len) + error("short read on server name"); + + printf("Server name is '%*s'\n", si.name_len, buf); + + printf("Connected to VNC!\n"); + + return vnc_sock; +} + +int serve_client() +{ + int vnc_sock = vnc_init(); if (!mcs_recv_connect_initial()) error("MCS_CONNECT_INITIAL recv failed");