2023-01-02 16:00:42 -05:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
2021-06-29 01:43:03 +02:00
|
|
|
|
|
|
|
/// <reference no-default-lib="true" />
|
|
|
|
/// <reference lib="esnext" />
|
|
|
|
|
|
|
|
declare namespace Deno {
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface NetAddr {
|
|
|
|
transport: "tcp" | "udp";
|
|
|
|
hostname: string;
|
|
|
|
port: number;
|
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface UnixAddr {
|
|
|
|
transport: "unix" | "unixpacket";
|
|
|
|
path: string;
|
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export type Addr = NetAddr | UnixAddr;
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** A generic network listener for stream-oriented protocols.
|
|
|
|
*
|
|
|
|
* @category Network
|
|
|
|
*/
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface Listener extends AsyncIterable<Conn> {
|
|
|
|
/** Waits for and resolves to the next connection to the `Listener`. */
|
|
|
|
accept(): Promise<Conn>;
|
|
|
|
/** Close closes the listener. Any pending accept promises will be rejected
|
2021-09-02 18:28:12 -04:00
|
|
|
* with errors. */
|
2021-06-29 01:43:03 +02:00
|
|
|
close(): void;
|
|
|
|
/** Return the address of the `Listener`. */
|
|
|
|
readonly addr: Addr;
|
|
|
|
|
|
|
|
/** Return the rid of the `Listener`. */
|
|
|
|
readonly rid: number;
|
|
|
|
|
|
|
|
[Symbol.asyncIterator](): AsyncIterableIterator<Conn>;
|
2023-01-20 16:32:55 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Make the listener block the event loop from finishing.
|
|
|
|
*
|
|
|
|
* Note: the listener blocks the event loop from finishing by default.
|
|
|
|
* This method is only meaningful after `.unref()` is called.
|
|
|
|
*/
|
|
|
|
ref(): void;
|
|
|
|
|
|
|
|
/** Make the listener not block the event loop from finishing. */
|
|
|
|
unref(): void;
|
2021-06-29 01:43:03 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** Specialized listener that accepts TLS connections.
|
|
|
|
*
|
|
|
|
* @category Network
|
|
|
|
*/
|
2021-10-26 22:27:47 +02:00
|
|
|
export interface TlsListener extends Listener, AsyncIterable<TlsConn> {
|
|
|
|
/** Waits for a TLS client to connect and accepts the connection. */
|
|
|
|
accept(): Promise<TlsConn>;
|
|
|
|
[Symbol.asyncIterator](): AsyncIterableIterator<TlsConn>;
|
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface Conn extends Reader, Writer, Closer {
|
|
|
|
/** The local address of the connection. */
|
|
|
|
readonly localAddr: Addr;
|
|
|
|
/** The remote address of the connection. */
|
|
|
|
readonly remoteAddr: Addr;
|
|
|
|
/** The resource ID of the connection. */
|
|
|
|
readonly rid: number;
|
|
|
|
/** Shuts down (`shutdown(2)`) the write side of the connection. Most
|
2021-09-02 18:28:12 -04:00
|
|
|
* callers should just use `close()`. */
|
2021-06-29 01:43:03 +02:00
|
|
|
closeWrite(): Promise<void>;
|
2022-02-15 13:35:22 +01:00
|
|
|
|
2022-12-28 10:29:48 +01:00
|
|
|
/** **UNSTABLE**: New API, yet to be vetted.
|
|
|
|
*
|
|
|
|
* Make the connection block the event loop from finishing.
|
|
|
|
*
|
|
|
|
* Note: the connection blocks the event loop from finishing by default.
|
|
|
|
* This method is only meaningful after `.unref()` is called.
|
|
|
|
*/
|
|
|
|
ref(): void;
|
|
|
|
/** **UNSTABLE**: New API, yet to be vetted.
|
|
|
|
*
|
|
|
|
* Make the connection not block the event loop from finishing.
|
|
|
|
*/
|
|
|
|
unref(): void;
|
|
|
|
|
2022-02-15 13:35:22 +01:00
|
|
|
readonly readable: ReadableStream<Uint8Array>;
|
|
|
|
readonly writable: WritableStream<Uint8Array>;
|
2021-06-29 01:43:03 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-11-26 10:59:53 -08:00
|
|
|
// deno-lint-ignore no-empty-interface
|
|
|
|
export interface TlsHandshakeInfo {}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-10-26 22:27:47 +02:00
|
|
|
export interface TlsConn extends Conn {
|
|
|
|
/** Runs the client or server handshake protocol to completion if that has
|
|
|
|
* not happened yet. Calling this method is optional; the TLS handshake
|
|
|
|
* will be completed automatically as soon as data is sent or received. */
|
2021-11-26 10:59:53 -08:00
|
|
|
handshake(): Promise<TlsHandshakeInfo>;
|
2021-10-26 22:27:47 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface ListenOptions {
|
|
|
|
/** The port to listen on. */
|
|
|
|
port: number;
|
|
|
|
/** A literal IP address or host name that can be resolved to an IP address.
|
2021-09-07 16:26:21 +09:00
|
|
|
*
|
|
|
|
* __Note about `0.0.0.0`__ While listening `0.0.0.0` works on all platforms,
|
|
|
|
* the browsers on Windows don't work with the address `0.0.0.0`.
|
|
|
|
* You should show the message like `server running on localhost:8080` instead of
|
2022-12-13 14:14:41 +01:00
|
|
|
* `server running on 0.0.0.0:8080` if your program supports Windows.
|
|
|
|
*
|
|
|
|
* @default {"0.0.0.0"} */
|
2021-06-29 01:43:03 +02:00
|
|
|
hostname?: string;
|
|
|
|
}
|
|
|
|
|
2022-10-26 21:04:27 +02:00
|
|
|
/** @category Network */
|
|
|
|
// deno-lint-ignore no-empty-interface
|
|
|
|
export interface TcpListenOptions extends ListenOptions {
|
|
|
|
}
|
|
|
|
|
2021-06-29 01:43:03 +02:00
|
|
|
/** Listen announces on the local transport address.
|
2021-09-02 18:28:12 -04:00
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const listener1 = Deno.listen({ port: 80 })
|
|
|
|
* const listener2 = Deno.listen({ hostname: "192.0.2.1", port: 80 })
|
|
|
|
* const listener3 = Deno.listen({ hostname: "[2001:db8::1]", port: 80 });
|
|
|
|
* const listener4 = Deno.listen({ hostname: "golang.org", port: 80, transport: "tcp" });
|
|
|
|
* ```
|
|
|
|
*
|
2022-08-17 13:12:24 +10:00
|
|
|
* Requires `allow-net` permission.
|
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-net
|
2022-08-17 13:12:24 +10:00
|
|
|
* @category Network
|
|
|
|
*/
|
2021-06-29 01:43:03 +02:00
|
|
|
export function listen(
|
2022-10-26 21:04:27 +02:00
|
|
|
options: TcpListenOptions & { transport?: "tcp" },
|
2021-06-29 01:43:03 +02:00
|
|
|
): Listener;
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2022-10-26 21:04:27 +02:00
|
|
|
export interface ListenTlsOptions extends TcpListenOptions {
|
2022-02-24 13:16:56 +09:00
|
|
|
/** Server private key in PEM format */
|
|
|
|
key?: string;
|
|
|
|
/** Cert chain in PEM format */
|
|
|
|
cert?: string;
|
2021-08-09 15:55:00 +02:00
|
|
|
/** Path to a file containing a PEM formatted CA certificate. Requires
|
2022-02-24 13:16:56 +09:00
|
|
|
* `--allow-read`.
|
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-read
|
2022-02-24 13:16:56 +09:00
|
|
|
* @deprecated This option is deprecated and will be removed in Deno 2.0.
|
|
|
|
*/
|
|
|
|
certFile?: string;
|
|
|
|
/** Server private key file. Requires `--allow-read`.
|
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-read
|
2022-02-24 13:16:56 +09:00
|
|
|
* @deprecated This option is deprecated and will be removed in Deno 2.0.
|
|
|
|
*/
|
|
|
|
keyFile?: string;
|
2021-06-29 01:43:03 +02:00
|
|
|
|
|
|
|
transport?: "tcp";
|
2023-07-04 15:28:50 +02:00
|
|
|
|
|
|
|
/** Application-Layer Protocol Negotiation (ALPN) protocols to announce to
|
|
|
|
* the client. If not specified, no ALPN extension will be included in the
|
|
|
|
* TLS handshake.
|
|
|
|
*/
|
|
|
|
alpnProtocols?: string[];
|
2021-06-29 01:43:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Listen announces on the local transport address over TLS (transport layer
|
2021-09-02 18:28:12 -04:00
|
|
|
* security).
|
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const lstnr = Deno.listenTls({ port: 443, certFile: "./server.crt", keyFile: "./server.key" });
|
|
|
|
* ```
|
|
|
|
*
|
2022-08-17 13:12:24 +10:00
|
|
|
* Requires `allow-net` permission.
|
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-net
|
2022-08-17 13:12:24 +10:00
|
|
|
* @category Network
|
|
|
|
*/
|
2021-10-26 22:27:47 +02:00
|
|
|
export function listenTls(options: ListenTlsOptions): TlsListener;
|
2021-06-29 01:43:03 +02:00
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface ConnectOptions {
|
|
|
|
/** The port to connect to. */
|
|
|
|
port: number;
|
|
|
|
/** A literal IP address or host name that can be resolved to an IP address.
|
2022-12-13 14:14:41 +01:00
|
|
|
* If not specified,
|
|
|
|
*
|
|
|
|
* @default {"127.0.0.1"} */
|
2021-06-29 01:43:03 +02:00
|
|
|
hostname?: string;
|
|
|
|
transport?: "tcp";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-09-02 18:28:12 -04:00
|
|
|
* Connects to the hostname (default is "127.0.0.1") and port on the named
|
|
|
|
* transport (default is "tcp"), and resolves to the connection (`Conn`).
|
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const conn1 = await Deno.connect({ port: 80 });
|
|
|
|
* const conn2 = await Deno.connect({ hostname: "192.0.2.1", port: 80 });
|
|
|
|
* const conn3 = await Deno.connect({ hostname: "[2001:db8::1]", port: 80 });
|
|
|
|
* const conn4 = await Deno.connect({ hostname: "golang.org", port: 80, transport: "tcp" });
|
|
|
|
* ```
|
|
|
|
*
|
2022-08-17 13:12:24 +10:00
|
|
|
* Requires `allow-net` permission for "tcp".
|
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-net
|
2022-08-17 13:12:24 +10:00
|
|
|
* @category Network
|
|
|
|
*/
|
2022-02-27 15:18:30 +01:00
|
|
|
export function connect(options: ConnectOptions): Promise<TcpConn>;
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2022-02-27 15:18:30 +01:00
|
|
|
export interface TcpConn extends Conn {
|
|
|
|
/**
|
2022-12-13 14:14:41 +01:00
|
|
|
* Enable/disable the use of Nagle's algorithm.
|
|
|
|
*
|
2022-12-14 00:54:11 +01:00
|
|
|
* @param [noDelay=true]
|
2022-02-27 15:18:30 +01:00
|
|
|
*/
|
2022-12-14 00:54:11 +01:00
|
|
|
setNoDelay(noDelay?: boolean): void;
|
|
|
|
/** Enable/disable keep-alive functionality. */
|
|
|
|
setKeepAlive(keepAlive?: boolean): void;
|
2022-02-27 15:18:30 +01:00
|
|
|
}
|
2021-06-29 01:43:03 +02:00
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2022-03-04 20:33:13 +01:00
|
|
|
// deno-lint-ignore no-empty-interface
|
|
|
|
export interface UnixConn extends Conn {}
|
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-06-29 01:43:03 +02:00
|
|
|
export interface ConnectTlsOptions {
|
|
|
|
/** The port to connect to. */
|
|
|
|
port: number;
|
|
|
|
/** A literal IP address or host name that can be resolved to an IP address.
|
2022-12-13 14:14:41 +01:00
|
|
|
*
|
|
|
|
* @default {"127.0.0.1"} */
|
2021-06-29 01:43:03 +02:00
|
|
|
hostname?: string;
|
2021-09-30 09:26:15 +02:00
|
|
|
/**
|
2021-12-10 11:05:50 +11:00
|
|
|
* Server certificate file.
|
|
|
|
*
|
2021-09-30 09:26:15 +02:00
|
|
|
* @deprecated This option is deprecated and will be removed in a future
|
|
|
|
* release.
|
|
|
|
*/
|
2021-06-29 01:43:03 +02:00
|
|
|
certFile?: string;
|
2021-09-30 09:26:15 +02:00
|
|
|
/** A list of root certificates that will be used in addition to the
|
|
|
|
* default root certificates to verify the peer's certificate.
|
|
|
|
*
|
|
|
|
* Must be in PEM format. */
|
|
|
|
caCerts?: string[];
|
2023-07-04 15:28:50 +02:00
|
|
|
/** Application-Layer Protocol Negotiation (ALPN) protocols supported by
|
|
|
|
* the client. If not specified, no ALPN extension will be included in the
|
|
|
|
* TLS handshake.
|
|
|
|
*/
|
|
|
|
alpnProtocols?: string[];
|
2021-06-29 01:43:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Establishes a secure connection over TLS (transport layer security) using
|
2021-09-02 18:28:12 -04:00
|
|
|
* an optional cert file, hostname (default is "127.0.0.1") and port. The
|
|
|
|
* cert file is optional and if not included Mozilla's root certificates will
|
|
|
|
* be used (see also https://github.com/ctz/webpki-roots for specifics)
|
|
|
|
*
|
|
|
|
* ```ts
|
2021-09-30 09:26:15 +02:00
|
|
|
* const caCert = await Deno.readTextFile("./certs/my_custom_root_CA.pem");
|
2021-09-02 18:28:12 -04:00
|
|
|
* const conn1 = await Deno.connectTls({ port: 80 });
|
2021-09-30 09:26:15 +02:00
|
|
|
* const conn2 = await Deno.connectTls({ caCerts: [caCert], hostname: "192.0.2.1", port: 80 });
|
2021-09-02 18:28:12 -04:00
|
|
|
* const conn3 = await Deno.connectTls({ hostname: "[2001:db8::1]", port: 80 });
|
2021-09-30 09:26:15 +02:00
|
|
|
* const conn4 = await Deno.connectTls({ caCerts: [caCert], hostname: "golang.org", port: 80});
|
2021-09-02 18:28:12 -04:00
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* Requires `allow-net` permission.
|
2022-08-17 13:12:24 +10:00
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-net
|
2022-08-17 13:12:24 +10:00
|
|
|
* @category Network
|
2021-09-02 18:28:12 -04:00
|
|
|
*/
|
2021-10-26 22:27:47 +02:00
|
|
|
export function connectTls(options: ConnectTlsOptions): Promise<TlsConn>;
|
2021-06-29 01:43:03 +02:00
|
|
|
|
2022-08-17 13:12:24 +10:00
|
|
|
/** @category Network */
|
2021-10-29 17:13:31 +02:00
|
|
|
export interface StartTlsOptions {
|
|
|
|
/** A literal IP address or host name that can be resolved to an IP address.
|
2022-12-13 14:14:41 +01:00
|
|
|
*
|
|
|
|
* @default {"127.0.0.1"} */
|
2021-10-29 17:13:31 +02:00
|
|
|
hostname?: string;
|
|
|
|
/** A list of root certificates that will be used in addition to the
|
|
|
|
* default root certificates to verify the peer's certificate.
|
|
|
|
*
|
|
|
|
* Must be in PEM format. */
|
|
|
|
caCerts?: string[];
|
2023-07-04 15:28:50 +02:00
|
|
|
/** Application-Layer Protocol Negotiation (ALPN) protocols to announce to
|
|
|
|
* the client. If not specified, no ALPN extension will be included in the
|
|
|
|
* TLS handshake.
|
|
|
|
*/
|
|
|
|
alpnProtocols?: string[];
|
2021-10-29 17:13:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Start TLS handshake from an existing connection using an optional list of
|
|
|
|
* CA certificates, and hostname (default is "127.0.0.1"). Specifying CA certs
|
|
|
|
* is optional. By default the configured root certificates are used. Using
|
|
|
|
* this function requires that the other end of the connection is prepared for
|
|
|
|
* a TLS handshake.
|
|
|
|
*
|
2022-10-18 11:28:27 +09:00
|
|
|
* Note that this function *consumes* the TCP connection passed to it, thus the
|
|
|
|
* original TCP connection will be unusable after calling this. Additionally,
|
|
|
|
* you need to ensure that the TCP connection is not being used elsewhere when
|
|
|
|
* calling this function in order for the TCP connection to be consumed properly.
|
|
|
|
* For instance, if there is a `Promise` that is waiting for read operation on
|
|
|
|
* the TCP connection to complete, it is considered that the TCP connection is
|
|
|
|
* being used elsewhere. In such a case, this function will fail.
|
|
|
|
*
|
2021-10-29 17:13:31 +02:00
|
|
|
* ```ts
|
|
|
|
* const conn = await Deno.connect({ port: 80, hostname: "127.0.0.1" });
|
|
|
|
* const caCert = await Deno.readTextFile("./certs/my_custom_root_CA.pem");
|
2022-10-18 11:28:27 +09:00
|
|
|
* // `conn` becomes unusable after calling `Deno.startTls`
|
2021-10-29 17:13:31 +02:00
|
|
|
* const tlsConn = await Deno.startTls(conn, { caCerts: [caCert], hostname: "localhost" });
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* Requires `allow-net` permission.
|
2022-08-17 13:12:24 +10:00
|
|
|
*
|
2022-08-23 10:57:01 +10:00
|
|
|
* @tags allow-net
|
2022-08-17 13:12:24 +10:00
|
|
|
* @category Network
|
2021-10-29 17:13:31 +02:00
|
|
|
*/
|
|
|
|
export function startTls(
|
|
|
|
conn: Conn,
|
|
|
|
options?: StartTlsOptions,
|
|
|
|
): Promise<TlsConn>;
|
|
|
|
|
2021-06-29 01:43:03 +02:00
|
|
|
/** Shutdown socket send operations.
|
2021-09-02 18:28:12 -04:00
|
|
|
*
|
|
|
|
* Matches behavior of POSIX shutdown(3).
|
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const listener = Deno.listen({ port: 80 });
|
|
|
|
* const conn = await listener.accept();
|
|
|
|
* Deno.shutdown(conn.rid);
|
|
|
|
* ```
|
2022-08-17 13:12:24 +10:00
|
|
|
*
|
|
|
|
* @category Network
|
2021-09-02 18:28:12 -04:00
|
|
|
*/
|
2021-06-29 01:43:03 +02:00
|
|
|
export function shutdown(rid: number): Promise<void>;
|
|
|
|
}
|