diff options
Diffstat (limited to 'ext/websocket')
-rw-r--r-- | ext/websocket/01_websocket.js | 12 | ||||
-rw-r--r-- | ext/websocket/lib.rs | 8 |
2 files changed, 18 insertions, 2 deletions
diff --git a/ext/websocket/01_websocket.js b/ext/websocket/01_websocket.js index afe543da5..60580a56c 100644 --- a/ext/websocket/01_websocket.js +++ b/ext/websocket/01_websocket.js @@ -424,6 +424,18 @@ class WebSocket extends EventTarget { const rid = this[_rid]; while (this[_readyState] !== CLOSED) { const kind = await op_ws_next_event(rid); + /* close the connection if read was cancelled, and we didn't get a close frame */ + if ( + (this[_readyState] == CLOSING) && + kind <= 3 && this[_role] !== CLIENT + ) { + this[_readyState] = CLOSED; + + const event = new CloseEvent("close"); + this.dispatchEvent(event); + core.tryClose(rid); + break; + } switch (kind) { case 0: { diff --git a/ext/websocket/lib.rs b/ext/websocket/lib.rs index 87503120b..5c3e8d7b1 100644 --- a/ext/websocket/lib.rs +++ b/ext/websocket/lib.rs @@ -699,10 +699,14 @@ pub async fn op_ws_close( #[smi] code: Option<u16>, #[string] reason: Option<String>, ) -> Result<(), AnyError> { - let resource = state + let Ok(resource) = state .borrow_mut() .resource_table - .get::<ServerWebSocket>(rid)?; + .get::<ServerWebSocket>(rid) + else { + return Ok(()); + }; + let frame = reason .map(|reason| Frame::close(code.unwrap_or(1005), reason.as_bytes())) .unwrap_or_else(|| Frame::close_raw(vec![].into())); |