mirror of
https://github.com/denoland/deno.git
synced 2025-09-27 04:39:10 +00:00
refactor(op_crates/websocket): refactor event loop (#9079)
This commit is contained in:
parent
9801858cb0
commit
2c1f74402c
2 changed files with 70 additions and 49 deletions
|
@ -88,7 +88,7 @@ struct CheckPermissionArgs {
|
|||
}
|
||||
|
||||
// This op is needed because creating a WS instance in JavaScript is a sync
|
||||
// operation and should throw error when permissions are not fullfiled,
|
||||
// operation and should throw error when permissions are not fulfilled,
|
||||
// but actual op that connects WS is async.
|
||||
pub fn op_ws_check_permission<WP>(
|
||||
state: &mut OpState,
|
||||
|
@ -155,7 +155,7 @@ where
|
|||
let try_socket = TcpStream::connect(addr).await;
|
||||
let tcp_socket = match try_socket.map_err(TungsteniteError::Io) {
|
||||
Ok(socket) => socket,
|
||||
Err(_) => return Ok(json!({"success": false})),
|
||||
Err(_) => return Ok(json!({ "success": false })),
|
||||
};
|
||||
|
||||
let socket: MaybeTlsStream = match uri.scheme_str() {
|
||||
|
@ -305,28 +305,30 @@ pub async fn op_ws_next_event(
|
|||
let val = rx.next().or_cancel(cancel).await?;
|
||||
let res = match val {
|
||||
Some(Ok(Message::Text(text))) => json!({
|
||||
"type": "string",
|
||||
"kind": "string",
|
||||
"data": text
|
||||
}),
|
||||
Some(Ok(Message::Binary(data))) => {
|
||||
// TODO(ry): don't use json to send binary data.
|
||||
json!({
|
||||
"type": "binary",
|
||||
"kind": "binary",
|
||||
"data": data
|
||||
})
|
||||
}
|
||||
Some(Ok(Message::Close(Some(frame)))) => json!({
|
||||
"type": "close",
|
||||
"code": u16::from(frame.code),
|
||||
"reason": frame.reason.as_ref()
|
||||
"kind": "close",
|
||||
"data": {
|
||||
"code": u16::from(frame.code),
|
||||
"reason": frame.reason.as_ref()
|
||||
}
|
||||
}),
|
||||
Some(Ok(Message::Close(None))) => json!({ "type": "close" }),
|
||||
Some(Ok(Message::Ping(_))) => json!({"type": "ping"}),
|
||||
Some(Ok(Message::Pong(_))) => json!({"type": "pong"}),
|
||||
Some(Err(_)) => json!({"type": "error"}),
|
||||
Some(Ok(Message::Close(None))) => json!({ "kind": "close" }),
|
||||
Some(Ok(Message::Ping(_))) => json!({ "kind": "ping" }),
|
||||
Some(Ok(Message::Pong(_))) => json!({ "kind": "pong" }),
|
||||
Some(Err(_)) => json!({ "kind": "error" }),
|
||||
None => {
|
||||
state.borrow_mut().resource_table.close(args.rid).unwrap();
|
||||
json!({"type": "closed"})
|
||||
json!({ "kind": "closed" })
|
||||
}
|
||||
};
|
||||
Ok(res)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue