Usage in Deno
import { Http2ServerResponse } from "node:http2";
This object is created internally by an HTTP server, not by the user. It is
passed as the second parameter to the 'request' event.
Http2ServerResponse(stream: ServerHttp2Stream)
      
    
connection: net.Socket | tls.TLSSocket
      
    See response.socket.
finished: boolean
      
    Boolean value that indicates whether the response has completed. Starts
as false. After response.end() executes, the value will be true.
headersSent: boolean
      
    True if headers were sent, false otherwise (read-only).
req: Http2ServerRequest
      
    A reference to the original HTTP2 request object.
sendDate: boolean
      
    When true, the Date header will be automatically generated and sent in the response if it is not already present in the headers. Defaults to true.
This should only be disabled for testing; HTTP requires the Date header in responses.
socket: net.Socket | tls.TLSSocket
      
    Returns a Proxy object that acts as a net.Socket (or tls.TLSSocket) but
applies getters, setters, and methods based on HTTP/2 logic.
destroyed, readable, and writable properties will be retrieved from and
set on response.stream.
destroy, emit, end, on and once methods will be called onresponse.stream.
setTimeout method will be called on response.stream.session.
pause, read, resume, and write will throw an error with codeERR_HTTP2_NO_SOCKET_MANIPULATION. See Http2Session and Sockets for
more information.
All other interactions will be routed directly to the socket.
const http2 = require('node:http2'); const server = http2.createServer((req, res) => { const ip = req.socket.remoteAddress; const port = req.socket.remotePort; res.end(`Your IP address is ${ip} and your source port is ${port}.`); }).listen(3000);
statusCode: number
      
    When using implicit headers (not calling response.writeHead() explicitly),
this property controls the status code that will be sent to the client when
the headers get flushed.
response.statusCode = 404;
After response header was sent to the client, this property indicates the status code which was sent out.
statusMessage: ""
      
    Status message is not supported by HTTP/2 (RFC 7540 8.1.2.4). It returns an empty string.
stream: ServerHttp2Stream
      
    The Http2Stream object backing the response.
addListener(event: "close",listener: () => void,): this
      
    
addListener(event: "drain",listener: () => void,): this
      
    
addListener(event: "error",listener: (error: Error) => void,): this
      
    
addListener(event: "finish",listener: () => void,): this
      
    
addListener(event: "pipe",listener: (src: stream.Readable) => void,): this
      
    
addListener(event: "unpipe",listener: (src: stream.Readable) => void,): this
      
    
addListener(event: string | symbol,listener: (...args: any[]) => void,): this
      
    
addTrailers(trailers: OutgoingHttpHeaders): void
      
    This method adds HTTP trailing headers (a header but at the end of the message) to the response.
Attempting to set a header field name or value that contains invalid characters
will result in a TypeError being thrown.
createPushResponse(headers: OutgoingHttpHeaders,callback: (err: Error | null,res: Http2ServerResponse,) => void,): void
      
    Call http2stream.pushStream() with the given headers, and wrap the
given Http2Stream on a newly created Http2ServerResponse as the callback
parameter if successful. When Http2ServerRequest is closed, the callback is
called with an error ERR_HTTP2_INVALID_STREAM.
emit(event: "close"): boolean
      
    
emit(event: "drain"): boolean
      
    
emit(event: "error",error: Error,): boolean
      
    
emit(event: "finish"): boolean
      
    
emit(event: "pipe",src: stream.Readable,): boolean
      
    
emit(event: "unpipe",src: stream.Readable,): boolean
      
    
emit(event: string | symbol,...args: any[],): boolean
      
    
end(callback?: () => void): this
      
    This method signals to the server that all of the response headers and body
have been sent; that server should consider this message complete.
The method, response.end(), MUST be called on each response.
If data is specified, it is equivalent to calling response.write(data, encoding) followed by response.end(callback).
If callback is specified, it will be called when the response stream
is finished.
end(data: string | Uint8Array,callback?: () => void,): this
      
    
end(data: string | Uint8Array,encoding: BufferEncoding,callback?: () => void,): this
      
    
getHeader(name: string): string
      
    Reads out a header that has already been queued but not sent to the client. The name is case-insensitive.
const contentType = response.getHeader('content-type');
getHeaderNames(): string[]
      
    Returns an array containing the unique names of the current outgoing headers. All header names are lowercase.
response.setHeader('Foo', 'bar'); response.setHeader('Set-Cookie', ['foo=bar', 'bar=baz']); const headerNames = response.getHeaderNames(); // headerNames === ['foo', 'set-cookie']
Returns a shallow copy of the current outgoing headers. Since a shallow copy is used, array values may be mutated without additional calls to various header-related http module methods. The keys of the returned object are the header names and the values are the respective header values. All header names are lowercase.
The object returned by the response.getHeaders() method _does not_prototypically inherit from the JavaScript Object. This means that typicalObject methods such as obj.toString(),
obj.hasOwnProperty(), and others
are not defined and will not work.
response.setHeader('Foo', 'bar'); response.setHeader('Set-Cookie', ['foo=bar', 'bar=baz']); const headers = response.getHeaders(); // headers === { foo: 'bar', 'set-cookie': ['foo=bar', 'bar=baz'] }
hasHeader(name: string): boolean
      
    Returns true if the header identified by name is currently set in the
outgoing headers. The header name matching is case-insensitive.
const hasContentType = response.hasHeader('content-type');
on(event: "close",listener: () => void,): this
      
    
on(event: "drain",listener: () => void,): this
      
    
on(event: "error",listener: (error: Error) => void,): this
      
    
on(event: "finish",listener: () => void,): this
      
    
on(event: "pipe",listener: (src: stream.Readable) => void,): this
      
    
on(event: "unpipe",listener: (src: stream.Readable) => void,): this
      
    
on(event: string | symbol,listener: (...args: any[]) => void,): this
      
    
once(event: "close",listener: () => void,): this
      
    
once(event: "drain",listener: () => void,): this
      
    
once(event: "error",listener: (error: Error) => void,): this
      
    
once(event: "finish",listener: () => void,): this
      
    
once(event: "pipe",listener: (src: stream.Readable) => void,): this
      
    
once(event: "unpipe",listener: (src: stream.Readable) => void,): this
      
    
once(event: string | symbol,listener: (...args: any[]) => void,): this
      
    
prependListener(event: "close",listener: () => void,): this
      
    
prependListener(event: "drain",listener: () => void,): this
      
    
prependListener(event: "error",listener: (error: Error) => void,): this
      
    
prependListener(event: "finish",listener: () => void,): this
      
    
prependListener(event: "pipe",listener: (src: stream.Readable) => void,): this
      
    
prependListener(event: "unpipe",listener: (src: stream.Readable) => void,): this
      
    
prependListener(event: string | symbol,listener: (...args: any[]) => void,): this
      
    
prependOnceListener(event: "close",listener: () => void,): this
      
    
prependOnceListener(event: "drain",listener: () => void,): this
      
    
prependOnceListener(event: "error",listener: (error: Error) => void,): this
      
    
prependOnceListener(event: "finish",listener: () => void,): this
      
    
prependOnceListener(event: "pipe",listener: (src: stream.Readable) => void,): this
      
    
prependOnceListener(event: "unpipe",listener: (src: stream.Readable) => void,): this
      
    
prependOnceListener(event: string | symbol,listener: (...args: any[]) => void,): this
      
    
removeHeader(name: string): void
      
    Removes a header that has been queued for implicit sending.
response.removeHeader('Content-Encoding');
setHeader(name: string,value: number
 | string
 | readonly string[],): void
      
    Sets a single header value for implicit headers. If this header already exists in the to-be-sent headers, its value will be replaced. Use an array of strings here to send multiple headers with the same name.
response.setHeader('Content-Type', 'text/html; charset=utf-8');
or
response.setHeader('Set-Cookie', ['type=ninja', 'language=javascript']);
Attempting to set a header field name or value that contains invalid characters
will result in a TypeError being thrown.
When headers have been set with response.setHeader(), they will be merged
with any headers passed to response.writeHead(), with the headers passed
to response.writeHead() given precedence.
// Returns content-type = text/plain const server = http2.createServer((req, res) => { res.setHeader('Content-Type', 'text/html; charset=utf-8'); res.setHeader('X-Foo', 'bar'); res.writeHead(200, { 'Content-Type': 'text/plain; charset=utf-8' }); res.end('ok'); });
setTimeout(msecs: number,callback?: () => void,): void
      
    Sets the Http2Stream's timeout value to msecs. If a callback is
provided, then it is added as a listener on the 'timeout' event on
the response object.
If no 'timeout' listener is added to the request, the response, or
the server, then Http2Stream s are destroyed when they time out. If a
handler is assigned to the request, the response, or the server's 'timeout'events, timed out sockets must be handled explicitly.
write(chunk: string | Uint8Array,callback?: (err: Error) => void,): boolean
      
    If this method is called and response.writeHead() has not been called,
it will switch to implicit header mode and flush the implicit headers.
This sends a chunk of the response body. This method may be called multiple times to provide successive parts of the body.
In the node:http module, the response body is omitted when the
request is a HEAD request. Similarly, the 204 and 304 responses must not include a message body.
chunk can be a string or a buffer. If chunk is a string,
the second parameter specifies how to encode it into a byte stream.
By default the encoding is 'utf8'. callback will be called when this chunk
of data is flushed.
This is the raw HTTP body and has nothing to do with higher-level multi-part body encodings that may be used.
The first time response.write() is called, it will send the buffered
header information and the first chunk of the body to the client. The second
time response.write() is called, Node.js assumes data will be streamed,
and sends the new data separately. That is, the response is buffered up to the
first chunk of the body.
Returns true if the entire data was flushed successfully to the kernel
buffer. Returns false if all or part of the data was queued in user memory.'drain' will be emitted when the buffer is free again.
write(chunk: string | Uint8Array,encoding: BufferEncoding,callback?: (err: Error) => void,): boolean
      
    
writeContinue(): void
      
    Sends a status 100 Continue to the client, indicating that the request body
should be sent. See the 'checkContinue' event on Http2Server andHttp2SecureServer.
writeEarlyHints(hints: Record<string, string | string[]>): void
      
    Sends a status 103 Early Hints to the client with a Link header,
indicating that the user agent can preload/preconnect the linked resources.
The hints is an object containing the values of headers to be sent with
early hints message.
Example
const earlyHintsLink = '</styles.css>; rel=preload; as=style'; response.writeEarlyHints({ 'link': earlyHintsLink, }); const earlyHintsLinks = [ '</styles.css>; rel=preload; as=style', '</scripts.js>; rel=preload; as=script', ]; response.writeEarlyHints({ 'link': earlyHintsLinks, });
writeHead(statusCode: number,headers?: OutgoingHttpHeaders,): this
      
    Sends a response header to the request. The status code is a 3-digit HTTP
status code, like 404. The last argument, headers, are the response headers.
Returns a reference to the Http2ServerResponse, so that calls can be chained.
For compatibility with HTTP/1, a human-readable statusMessage may be
passed as the second argument. However, because the statusMessage has no
meaning within HTTP/2, the argument will have no effect and a process warning
will be emitted.
const body = 'hello world'; response.writeHead(200, { 'Content-Length': Buffer.byteLength(body), 'Content-Type': 'text/plain; charset=utf-8', });
Content-Length is given in bytes not characters. TheBuffer.byteLength() API may be used to determine the number of bytes in a
given encoding. On outbound messages, Node.js does not check if Content-Length
and the length of the body being transmitted are equal or not. However, when
receiving messages, Node.js will automatically reject messages when theContent-Length does not match the actual payload size.
This method may be called at most one time on a message before response.end() is called.
If response.write() or response.end() are called before calling
this, the implicit/mutable headers will be calculated and call this function.
When headers have been set with response.setHeader(), they will be merged
with any headers passed to response.writeHead(), with the headers passed
to response.writeHead() given precedence.
// Returns content-type = text/plain const server = http2.createServer((req, res) => { res.setHeader('Content-Type', 'text/html; charset=utf-8'); res.setHeader('X-Foo', 'bar'); res.writeHead(200, { 'Content-Type': 'text/plain; charset=utf-8' }); res.end('ok'); });
Attempting to set a header field name or value that contains invalid characters
will result in a TypeError being thrown.
writeHead(): this