mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 00:54:02 -05:00
chore(ext/websocket): custom arity (#14202)
This commit is contained in:
parent
cc49b5e0d8
commit
995d1666ff
4 changed files with 35 additions and 61 deletions
|
@ -328,7 +328,7 @@
|
||||||
httpConn.close();
|
httpConn.close();
|
||||||
|
|
||||||
if (ws[_readyState] === WebSocket.CLOSING) {
|
if (ws[_readyState] === WebSocket.CLOSING) {
|
||||||
await core.opAsync("op_ws_close", { rid: wsRid });
|
await core.opAsync("op_ws_close", wsRid);
|
||||||
|
|
||||||
ws[_readyState] = WebSocket.CLOSED;
|
ws[_readyState] = WebSocket.CLOSED;
|
||||||
|
|
||||||
|
|
|
@ -223,10 +223,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
core.opAsync("op_ws_create", {
|
core.opAsync(
|
||||||
url: wsURL.href,
|
"op_ws_create",
|
||||||
protocols: ArrayPrototypeJoin(protocols, ", "),
|
wsURL.href,
|
||||||
}),
|
ArrayPrototypeJoin(protocols, ", "),
|
||||||
|
),
|
||||||
(create) => {
|
(create) => {
|
||||||
this[_rid] = create.rid;
|
this[_rid] = create.rid;
|
||||||
this[_extensions] = create.extensions;
|
this[_extensions] = create.extensions;
|
||||||
|
@ -234,9 +235,7 @@
|
||||||
|
|
||||||
if (this[_readyState] === CLOSING) {
|
if (this[_readyState] === CLOSING) {
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
core.opAsync("op_ws_close", {
|
core.opAsync("op_ws_close", this[_rid]),
|
||||||
rid: this[_rid],
|
|
||||||
}),
|
|
||||||
() => {
|
() => {
|
||||||
this[_readyState] = CLOSED;
|
this[_readyState] = CLOSED;
|
||||||
|
|
||||||
|
@ -369,11 +368,7 @@
|
||||||
this[_readyState] = CLOSING;
|
this[_readyState] = CLOSING;
|
||||||
|
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
core.opAsync("op_ws_close", {
|
core.opAsync("op_ws_close", this[_rid], code, reason),
|
||||||
rid: this[_rid],
|
|
||||||
code,
|
|
||||||
reason,
|
|
||||||
}),
|
|
||||||
() => {
|
() => {
|
||||||
this[_readyState] = CLOSED;
|
this[_readyState] = CLOSED;
|
||||||
const event = new CloseEvent("close", {
|
const event = new CloseEvent("close", {
|
||||||
|
@ -473,11 +468,7 @@
|
||||||
this[_idleTimeoutTimeout] = setTimeout(async () => {
|
this[_idleTimeoutTimeout] = setTimeout(async () => {
|
||||||
this[_readyState] = CLOSING;
|
this[_readyState] = CLOSING;
|
||||||
const reason = "No response from ping frame.";
|
const reason = "No response from ping frame.";
|
||||||
await core.opAsync("op_ws_close", {
|
await core.opAsync("op_ws_close", this[_rid], 1001, reason);
|
||||||
rid: this[_rid],
|
|
||||||
code: 1001,
|
|
||||||
reason,
|
|
||||||
});
|
|
||||||
this[_readyState] = CLOSED;
|
this[_readyState] = CLOSED;
|
||||||
|
|
||||||
const errEvent = new ErrorEvent("error", {
|
const errEvent = new ErrorEvent("error", {
|
||||||
|
|
|
@ -145,21 +145,20 @@
|
||||||
};
|
};
|
||||||
options.signal?.[add](abort);
|
options.signal?.[add](abort);
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
core.opAsync("op_ws_create", {
|
core.opAsync(
|
||||||
url: this[_url],
|
"op_ws_create",
|
||||||
protocols: options.protocols
|
this[_url],
|
||||||
|
options.protocols
|
||||||
? ArrayPrototypeJoin(options.protocols, ", ")
|
? ArrayPrototypeJoin(options.protocols, ", ")
|
||||||
: "",
|
: "",
|
||||||
cancelHandle: cancelRid,
|
cancelRid,
|
||||||
headers: headerListFromHeaders(headers),
|
headerListFromHeaders(headers),
|
||||||
}),
|
),
|
||||||
(create) => {
|
(create) => {
|
||||||
options.signal?.[remove](abort);
|
options.signal?.[remove](abort);
|
||||||
if (this[_earlyClose]) {
|
if (this[_earlyClose]) {
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
core.opAsync("op_ws_close", {
|
core.opAsync("op_ws_close", create.rid),
|
||||||
rid: create.rid,
|
|
||||||
}),
|
|
||||||
() => {
|
() => {
|
||||||
PromisePrototypeThen(
|
PromisePrototypeThen(
|
||||||
(async () => {
|
(async () => {
|
||||||
|
@ -369,11 +368,7 @@
|
||||||
this[_earlyClose] = true;
|
this[_earlyClose] = true;
|
||||||
} else if (this[_closed].state === "pending") {
|
} else if (this[_closed].state === "pending") {
|
||||||
PromisePrototypeCatch(
|
PromisePrototypeCatch(
|
||||||
core.opAsync("op_ws_close", {
|
core.opAsync("op_ws_close", this[_rid], code, closeInfo.reason),
|
||||||
rid: this[_rid],
|
|
||||||
code,
|
|
||||||
reason: closeInfo.reason,
|
|
||||||
}),
|
|
||||||
(err) => {
|
(err) => {
|
||||||
this[_rid] && core.tryClose(this[_rid]);
|
this[_rid] && core.tryClose(this[_rid]);
|
||||||
this[_closed].reject(err);
|
this[_closed].reject(err);
|
||||||
|
|
|
@ -214,15 +214,6 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
|
||||||
#[serde(rename_all = "camelCase")]
|
|
||||||
pub struct CreateArgs {
|
|
||||||
url: String,
|
|
||||||
protocols: String,
|
|
||||||
cancel_handle: Option<ResourceId>,
|
|
||||||
headers: Option<Vec<(ByteString, ByteString)>>,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Serialize)]
|
#[derive(Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct CreateResponse {
|
pub struct CreateResponse {
|
||||||
|
@ -234,7 +225,10 @@ pub struct CreateResponse {
|
||||||
#[op]
|
#[op]
|
||||||
pub async fn op_ws_create<WP>(
|
pub async fn op_ws_create<WP>(
|
||||||
state: Rc<RefCell<OpState>>,
|
state: Rc<RefCell<OpState>>,
|
||||||
args: CreateArgs,
|
url: String,
|
||||||
|
protocols: String,
|
||||||
|
cancel_handle: Option<ResourceId>,
|
||||||
|
headers: Option<Vec<(ByteString, ByteString)>>,
|
||||||
) -> Result<CreateResponse, AnyError>
|
) -> Result<CreateResponse, AnyError>
|
||||||
where
|
where
|
||||||
WP: WebSocketPermissions + 'static,
|
WP: WebSocketPermissions + 'static,
|
||||||
|
@ -242,13 +236,13 @@ where
|
||||||
{
|
{
|
||||||
let mut s = state.borrow_mut();
|
let mut s = state.borrow_mut();
|
||||||
s.borrow_mut::<WP>()
|
s.borrow_mut::<WP>()
|
||||||
.check_net_url(&url::Url::parse(&args.url)?)
|
.check_net_url(&url::Url::parse(&url)?)
|
||||||
.expect(
|
.expect(
|
||||||
"Permission check should have been done in op_ws_check_permission",
|
"Permission check should have been done in op_ws_check_permission",
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
let cancel_resource = if let Some(cancel_rid) = args.cancel_handle {
|
let cancel_resource = if let Some(cancel_rid) = cancel_handle {
|
||||||
let r = state
|
let r = state
|
||||||
.borrow_mut()
|
.borrow_mut()
|
||||||
.resource_table
|
.resource_table
|
||||||
|
@ -264,16 +258,16 @@ where
|
||||||
.and_then(|it| it.0.clone());
|
.and_then(|it| it.0.clone());
|
||||||
let root_cert_store = state.borrow().borrow::<WsRootStore>().0.clone();
|
let root_cert_store = state.borrow().borrow::<WsRootStore>().0.clone();
|
||||||
let user_agent = state.borrow().borrow::<WsUserAgent>().0.clone();
|
let user_agent = state.borrow().borrow::<WsUserAgent>().0.clone();
|
||||||
let uri: Uri = args.url.parse()?;
|
let uri: Uri = url.parse()?;
|
||||||
let mut request = Request::builder().method(Method::GET).uri(&uri);
|
let mut request = Request::builder().method(Method::GET).uri(&uri);
|
||||||
|
|
||||||
request = request.header("User-Agent", user_agent);
|
request = request.header("User-Agent", user_agent);
|
||||||
|
|
||||||
if !args.protocols.is_empty() {
|
if !protocols.is_empty() {
|
||||||
request = request.header("Sec-WebSocket-Protocol", args.protocols);
|
request = request.header("Sec-WebSocket-Protocol", protocols);
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(headers) = args.headers {
|
if let Some(headers) = headers {
|
||||||
for (key, value) in headers {
|
for (key, value) in headers {
|
||||||
let name = HeaderName::from_bytes(&key)
|
let name = HeaderName::from_bytes(&key)
|
||||||
.map_err(|err| type_error(err.to_string()))?;
|
.map_err(|err| type_error(err.to_string()))?;
|
||||||
|
@ -339,7 +333,7 @@ where
|
||||||
))
|
))
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
if let Some(cancel_rid) = args.cancel_handle {
|
if let Some(cancel_rid) = cancel_handle {
|
||||||
state.borrow_mut().resource_table.close(cancel_rid).ok();
|
state.borrow_mut().resource_table.close(cancel_rid).ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,23 +395,17 @@ pub async fn op_ws_send(
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
|
||||||
#[serde(rename_all = "camelCase")]
|
|
||||||
pub struct CloseArgs {
|
|
||||||
rid: ResourceId,
|
|
||||||
code: Option<u16>,
|
|
||||||
reason: Option<String>,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[op]
|
#[op]
|
||||||
pub async fn op_ws_close(
|
pub async fn op_ws_close(
|
||||||
state: Rc<RefCell<OpState>>,
|
state: Rc<RefCell<OpState>>,
|
||||||
args: CloseArgs,
|
rid: ResourceId,
|
||||||
|
code: Option<u16>,
|
||||||
|
reason: Option<String>,
|
||||||
) -> Result<(), AnyError> {
|
) -> Result<(), AnyError> {
|
||||||
let rid = args.rid;
|
let rid = rid;
|
||||||
let msg = Message::Close(args.code.map(|c| CloseFrame {
|
let msg = Message::Close(code.map(|c| CloseFrame {
|
||||||
code: CloseCode::from(c),
|
code: CloseCode::from(c),
|
||||||
reason: match args.reason {
|
reason: match reason {
|
||||||
Some(reason) => Cow::from(reason),
|
Some(reason) => Cow::from(reason),
|
||||||
None => Default::default(),
|
None => Default::default(),
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue