From 69ea6a444adc8a9b5ff26201c0736c5560a01b06 Mon Sep 17 00:00:00 2001 From: Michael Jerris Date: Mon, 1 Jun 2015 15:27:45 -0400 Subject: [PATCH] FS-7587: keep sofia-sip ws lib in sync --- libs/sofia-sip/libsofia-sip-ua/tport/ws.c | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/libs/sofia-sip/libsofia-sip-ua/tport/ws.c b/libs/sofia-sip/libsofia-sip-ua/tport/ws.c index 8a46b65502..6e9a69d025 100644 --- a/libs/sofia-sip/libsofia-sip-ua/tport/ws.c +++ b/libs/sofia-sip/libsofia-sip-ua/tport/ws.c @@ -691,6 +691,7 @@ ssize_t ws_read_frame(wsh_t *wsh, ws_opcode_t *oc, uint8_t **data) ssize_t need = 2; char *maskp; int ll = 0; + int frag = 0; again: need = 2; @@ -741,8 +742,16 @@ ssize_t ws_read_frame(wsh_t *wsh, ws_opcode_t *oc, uint8_t **data) case WSOC_PING: case WSOC_PONG: { - //int fin = (wsh->buffer[0] >> 7) & 1; + int fin = (wsh->buffer[0] >> 7) & 1; int mask = (wsh->buffer[1] >> 7) & 1; + + if (fin) { + if (*oc == WSOC_CONTINUATION) { + frag = 1; + } else { + frag = 0; + } + } if (mask) { need += 4; @@ -837,6 +846,10 @@ ssize_t ws_read_frame(wsh_t *wsh, ws_opcode_t *oc, uint8_t **data) ws_write_frame(wsh, WSOC_PONG, wsh->payload, wsh->rplen); goto again; } + + if (frag) { + goto again; + } *(wsh->payload+wsh->rplen) = '\0';