Ignore spaces before "binary" value. HTTP allows space before and after the value although usually browsers implementation start the value with a single ASCII space. Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> --- server/websocket.c | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/server/websocket.c b/server/websocket.c index 69f993a..ff0f550 100644 --- a/server/websocket.c +++ b/server/websocket.c @@ -472,15 +472,23 @@ static void websocket_ack_close(void *stream, websocket_write_cb_t write_cb) static bool websocket_is_start(gchar *buf) { - if (strncmp(buf, "GET ", 4) == 0 && - // TODO strip, do not assume a single space - find_str(buf, "\nSec-WebSocket-Protocol: binary") && - find_str(buf, "\nSec-WebSocket-Key:") && - g_str_has_suffix(buf, "\r\n\r\n")) { - return TRUE; + const char *protocol = find_str(buf, "\nSec-WebSocket-Protocol:"); + const char *key = find_str(buf, "\nSec-WebSocket-Key:"); + + if (strncmp(buf, "GET ", 4) != 0 || + protocol == NULL || key == NULL || + !g_str_has_suffix(buf, "\r\n\r\n")) { + return FALSE; + } + + /* check protocol value ignoring spaces before and after */ + int binary_pos = -1; + sscanf(protocol, " binary %n", &binary_pos); + if (binary_pos <= 0) { + return FALSE; } - return FALSE; + return TRUE; } static void websocket_create_reply(gchar *buf, gchar *outbuf) -- 2.7.4 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel