Skip to main content
Http2Stream - http2 - Node documentation
interface Http2Stream
extends [stream.Duplex]

Usage in Deno

import { type Http2Stream } from "node:http2";
<div class="alert alert-warning"><div><svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"> <path stroke="none" d="M0 0h24v24H0z" fill="none" /> <path d="M12 9v4" /> <path d="M10.363 3.591l-8.106 13.534a1.914 1.914 0 0 0 1.636 2.871h16.214a1.914 1.914 0 0 0 1.636 -2.87l-8.106 -13.536a1.914 1.914 0 0 0 -3.274 0z" /> <path d="M12 16h.01" /> </svg> Deno compatibility</div><div><p> The following methods are non-functional stubs: <ul> <li>aborted</li> <li>bufferSize</li> <li>endAfterHeaders</li> <li>id</li> <li>pending</li> <li>priority</li> <li>rstCode</li> <li>sentHeaders</li> <li>sentInfoHeaders</li> <li>sentTrailers</li> <li>state</li> </ul> </p> </div></div>

Properties

readonly
aborted: boolean

Set to true if the Http2Stream instance was aborted abnormally. When set, the 'aborted' event will have been emitted.

readonly
bufferSize: number

This property shows the number of characters currently buffered to be written. See net.Socket.bufferSize for details.

readonly
closed: boolean

Set to true if the Http2Stream instance has been closed.

readonly
destroyed: boolean

Set to true if the Http2Stream instance has been destroyed and is no longer usable.

readonly
endAfterHeaders: boolean

Set to true if the END_STREAM flag was set in the request or response HEADERS frame received, indicating that no additional data should be received and the readable side of the Http2Stream will be closed.

readonly
optional
id: number | undefined

The numeric stream identifier of this Http2Stream instance. Set to undefined if the stream identifier has not yet been assigned.

readonly
pending: boolean

Set to true if the Http2Stream instance has not yet been assigned a numeric stream identifier.

readonly
rstCode: number

Set to the RST_STREAM error code reported when the Http2Stream is destroyed after either receiving an RST_STREAM frame from the connected peer, calling http2stream.close(), or http2stream.destroy(). Will be undefined if the Http2Stream has not been closed.

An object containing the outbound headers sent for this Http2Stream.

readonly
optional
sentInfoHeaders: OutgoingHttpHeaders[] | undefined

An array of objects containing the outbound informational (additional) headers sent for this Http2Stream.

readonly
optional
sentTrailers: OutgoingHttpHeaders | undefined

An object containing the outbound trailers sent for this HttpStream.

readonly
session: Http2Session | undefined

A reference to the Http2Session instance that owns this Http2Stream. The value will be undefined after the Http2Stream instance is destroyed.

Provides miscellaneous information about the current state of the Http2Stream.

A current state of this Http2Stream.

Methods

close(
code?: number,
callback?: () => void,
): void

Closes the Http2Stream instance by sending an RST_STREAM frame to the connected HTTP/2 peer.

Updates the priority for this Http2Stream instance.

setTimeout(
msecs: number,
callback?: () => void,
): void
import http2 from 'node:http2';
const client = http2.connect('http://example.org:8000');
const { NGHTTP2_CANCEL } = http2.constants;
const req = client.request({ ':path': '/' });

// Cancel the stream if there's no activity after 5 seconds
req.setTimeout(5000, () => req.close(NGHTTP2_CANCEL));

Sends a trailing HEADERS frame to the connected HTTP/2 peer. This method will cause the Http2Stream to be immediately closed and must only be called after the 'wantTrailers' event has been emitted. When sending a request or sending a response, the options.waitForTrailers option must be set in order to keep the Http2Stream open after the final DATA frame so that trailers can be sent.

import http2 from 'node:http2';
const server = http2.createServer();
server.on('stream', (stream) => {
  stream.respond(undefined, { waitForTrailers: true });
  stream.on('wantTrailers', () => {
    stream.sendTrailers({ xyz: 'abc' });
  });
  stream.end('Hello World');
});

The HTTP/1 specification forbids trailers from containing HTTP/2 pseudo-header fields (e.g. ':method', ':path', etc).

addListener(
event: "aborted",
listener: () => void,
): this
addListener(
event: "close",
listener: () => void,
): this
addListener(
event: "data",
listener: (chunk: Buffer | string) => void,
): this
addListener(
event: "drain",
listener: () => void,
): this
addListener(
event: "end",
listener: () => void,
): this
addListener(
event: "error",
listener: (err: Error) => void,
): this
addListener(
event: "finish",
listener: () => void,
): this
addListener(
event: "frameError",
listener: (
frameType: number,
errorCode: number,
) => void
,
): this
addListener(
event: "pipe",
listener: (src: stream.Readable) => void,
): this
addListener(
event: "unpipe",
listener: (src: stream.Readable) => void,
): this
addListener(
event: "streamClosed",
listener: (code: number) => void,
): this
addListener(
event: "timeout",
listener: () => void,
): this
addListener(
event: "trailers",
listener: (
flags: number,
) => void
,
): this
addListener(
event: "wantTrailers",
listener: () => void,
): this
addListener(
event: string | symbol,
listener: (...args: any[]) => void,
): this
emit(event: "aborted"): boolean
emit(event: "close"): boolean
emit(
event: "data",
chunk: Buffer | string,
): boolean
emit(event: "drain"): boolean
emit(event: "end"): boolean
emit(
event: "error",
err: Error,
): boolean
emit(event: "finish"): boolean
emit(
event: "frameError",
frameType: number,
errorCode: number,
): boolean
emit(
event: "pipe",
src: stream.Readable,
): boolean
emit(
event: "unpipe",
src: stream.Readable,
): boolean
emit(
event: "streamClosed",
code: number,
): boolean
emit(event: "timeout"): boolean
emit(
event: "trailers",
flags: number,
): boolean
emit(event: "wantTrailers"): boolean
emit(
event: string | symbol,
...args: any[],
): boolean
on(
event: "aborted",
listener: () => void,
): this
on(
event: "close",
listener: () => void,
): this
on(
event: "data",
listener: (chunk: Buffer | string) => void,
): this
on(
event: "drain",
listener: () => void,
): this
on(
event: "end",
listener: () => void,
): this
on(
event: "error",
listener: (err: Error) => void,
): this
on(
event: "finish",
listener: () => void,
): this
on(
event: "frameError",
listener: (
frameType: number,
errorCode: number,
) => void
,
): this
on(
event: "pipe",
listener: (src: stream.Readable) => void,
): this
on(
event: "unpipe",
listener: (src: stream.Readable) => void,
): this
on(
event: "streamClosed",
listener: (code: number) => void,
): this
on(
event: "timeout",
listener: () => void,
): this
on(
event: "trailers",
listener: (
flags: number,
) => void
,
): this
on(
event: "wantTrailers",
listener: () => void,
): this
on(
event: string | symbol,
listener: (...args: any[]) => void,
): this
once(
event: "aborted",
listener: () => void,
): this
once(
event: "close",
listener: () => void,
): this
once(
event: "data",
listener: (chunk: Buffer | string) => void,
): this
once(
event: "drain",
listener: () => void,
): this
once(
event: "end",
listener: () => void,
): this
once(
event: "error",
listener: (err: Error) => void,
): this
once(
event: "finish",
listener: () => void,
): this
once(
event: "frameError",
listener: (
frameType: number,
errorCode: number,
) => void
,
): this
once(
event: "pipe",
listener: (src: stream.Readable) => void,
): this
once(
event: "unpipe",
listener: (src: stream.Readable) => void,
): this
once(
event: "streamClosed",
listener: (code: number) => void,
): this
once(
event: "timeout",
listener: () => void,
): this
once(
event: "trailers",
listener: (
flags: number,
) => void
,
): this
once(
event: "wantTrailers",
listener: () => void,
): this
once(
event: string | symbol,
listener: (...args: any[]) => void,
): this
prependListener(
event: "aborted",
listener: () => void,
): this
prependListener(
event: "close",
listener: () => void,
): this
prependListener(
event: "data",
listener: (chunk: Buffer | string) => void,
): this
prependListener(
event: "drain",
listener: () => void,
): this
prependListener(
event: "end",
listener: () => void,
): this
prependListener(
event: "error",
listener: (err: Error) => void,
): this
prependListener(
event: "finish",
listener: () => void,
): this
prependListener(
event: "frameError",
listener: (
frameType: number,
errorCode: number,
) => void
,
): this
prependListener(
event: "pipe",
listener: (src: stream.Readable) => void,
): this
prependListener(
event: "unpipe",
listener: (src: stream.Readable) => void,
): this
prependListener(
event: "streamClosed",
listener: (code: number) => void,
): this
prependListener(
event: "timeout",
listener: () => void,
): this
prependListener(
event: "trailers",
listener: (
flags: number,
) => void
,
): this
prependListener(
event: "wantTrailers",
listener: () => void,
): this
prependListener(
event: string | symbol,
listener: (...args: any[]) => void,
): this
prependOnceListener(
event: "aborted",
listener: () => void,
): this
prependOnceListener(
event: "close",
listener: () => void,
): this
prependOnceListener(
event: "data",
listener: (chunk: Buffer | string) => void,
): this
prependOnceListener(
event: "drain",
listener: () => void,
): this
prependOnceListener(
event: "end",
listener: () => void,
): this
prependOnceListener(
event: "error",
listener: (err: Error) => void,
): this
prependOnceListener(
event: "finish",
listener: () => void,
): this
prependOnceListener(
event: "frameError",
listener: (
frameType: number,
errorCode: number,
) => void
,
): this
prependOnceListener(
event: "pipe",
listener: (src: stream.Readable) => void,
): this
prependOnceListener(
event: "unpipe",
listener: (src: stream.Readable) => void,
): this
prependOnceListener(
event: "streamClosed",
listener: (code: number) => void,
): this
prependOnceListener(
event: "timeout",
listener: () => void,
): this
prependOnceListener(
event: "trailers",
listener: (
flags: number,
) => void
,
): this
prependOnceListener(
event: "wantTrailers",
listener: () => void,
): this
prependOnceListener(
event: string | symbol,
listener: (...args: any[]) => void,
): this