From a2cfbf49751b18adfcbc0682ba38044b3179435c Mon Sep 17 00:00:00 2001 From: Anton Bachin Date: Fri, 10 Nov 2023 20:54:40 +0300 Subject: [PATCH] WebSocket: allow non-FIN frames Since https://github.com/anmonteiro/websocketaf/issues/33, websocket/af supports sending frames without the FIN bit. Begin using this in Dream. See also https://github.com/aantron/dream/issues/181. --- src/http/shared/websocket.ml | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/src/http/shared/websocket.ml b/src/http/shared/websocket.ml index a6e5e288..c5737422 100644 --- a/src/http/shared/websocket.ml +++ b/src/http/shared/websocket.ml @@ -187,16 +187,13 @@ let websocket_handler stream socket = let rec outgoing_loop () = Stream.read stream - ~data:(fun buffer offset length binary _fin -> - (* Until https://github.com/anmonteiro/websocketaf/issues/33. *) - (* if not fin then - websocket_log.error (fun log -> - log "Non-FIN frames not yet supported"); *) + ~data:(fun buffer offset length binary fin -> let kind = if binary then `Binary else `Text in if !closed then close !close_code else begin - Websocketaf.Wsd.schedule socket ~kind buffer ~off:offset ~len:length; + Websocketaf.Wsd.schedule + socket ~is_fin:fin ~kind buffer ~off:offset ~len:length; bytes_since_flush := !bytes_since_flush + length; if !bytes_since_flush >= 4096 then flush ~close outgoing_loop