(session: any)
| 528 | } |
| 529 | |
| 530 | public async onWebTransportSession(session: any) { |
| 531 | if (this.middlewares.length > 0) { |
| 532 | // middlewares expect an IncomingMessage argument, which cannot be created from the WebTransport session object |
| 533 | // see also: https://github.com/fails-components/webtransport/issues/448 |
| 534 | debug( |
| 535 | "closing session since WebTransport is not compatible with middlewares", |
| 536 | ); |
| 537 | return session.close(); |
| 538 | } |
| 539 | |
| 540 | const timeout = setTimeout(() => { |
| 541 | debug( |
| 542 | "the client failed to establish a bidirectional stream in the given period", |
| 543 | ); |
| 544 | session.close(); |
| 545 | }, this.opts.upgradeTimeout); |
| 546 | |
| 547 | const streamReader = session.incomingBidirectionalStreams.getReader(); |
| 548 | const result = await streamReader.read(); |
| 549 | |
| 550 | if (result.done) { |
| 551 | clearTimeout(timeout); |
| 552 | debug("session is closed"); |
| 553 | return; |
| 554 | } |
| 555 | |
| 556 | const stream = result.value; |
| 557 | const transformStream = createPacketDecoderStream( |
| 558 | this.opts.maxHttpBufferSize, |
| 559 | "nodebuffer", |
| 560 | ); |
| 561 | const reader = stream.readable.pipeThrough(transformStream).getReader(); |
| 562 | |
| 563 | const closeSession = async () => { |
| 564 | try { |
| 565 | await reader.cancel(); |
| 566 | } catch (e) { |
| 567 | debug( |
| 568 | "error while canceling WebTransport stream reader: %s", |
| 569 | e.message, |
| 570 | ); |
| 571 | } |
| 572 | reader.releaseLock(); |
| 573 | session.close(); |
| 574 | }; |
| 575 | |
| 576 | // reading the first packet of the stream |
| 577 | const { value, done } = await reader.read(); |
| 578 | clearTimeout(timeout); |
| 579 | |
| 580 | if (done) { |
| 581 | debug("stream is closed"); |
| 582 | reader.releaseLock(); |
| 583 | return; |
| 584 | } |
| 585 | |
| 586 | if (value.type !== "open") { |
| 587 | debug("invalid WebTransport handshake"); |
nothing calls this directly
no test coverage detected