mod_websocket: Continue to process data already in the buffer after an error occurs

Previously any error, or even a normal websocket close frame, would return early,
leaving potentially entire frames in the buffer unprocessed and then discarded.

This change stops processing new data, but returns an existing processed data up
to the point of the error/close.
This commit is contained in:
Matthew Wild 2020-09-28 16:36:12 +01:00
parent e7f545bae6
commit 15aaf9446b

View file

@ -291,7 +291,7 @@ function handle_request(event)
end end
frameBuffer:discard(length); frameBuffer:discard(length);
local result = handle_frame(frame); local result = handle_frame(frame);
if not result then return; end if not result then break; end
cache[#cache+1] = filter_open_close(result); cache[#cache+1] = filter_open_close(result);
frame, length = parse_frame(frameBuffer); frame, length = parse_frame(frameBuffer);
end end