2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2019-10-21 20:38:28 +02:00
|
|
|
import { sendAsync, sendSync } from "./dispatch_json.ts";
|
2019-09-23 14:40:38 -04:00
|
|
|
import * as dispatch from "./dispatch.ts";
|
2019-10-21 20:38:28 +02:00
|
|
|
import { Listener, Transport, Conn, ConnImpl, ListenerImpl } from "./net.ts";
|
2019-09-23 14:40:38 -04:00
|
|
|
|
|
|
|
// TODO(ry) There are many configuration options to add...
|
|
|
|
// https://docs.rs/rustls/0.16.0/rustls/struct.ClientConfig.html
|
2020-01-18 18:35:12 +01:00
|
|
|
interface ConnectTLSOptions {
|
2019-09-23 14:40:38 -04:00
|
|
|
port: number;
|
|
|
|
hostname?: string;
|
2019-10-21 20:38:28 +02:00
|
|
|
certFile?: string;
|
2019-09-23 14:40:38 -04:00
|
|
|
}
|
2020-01-18 18:35:12 +01:00
|
|
|
const connectTLSDefaults = { hostname: "127.0.0.1", transport: "tcp" };
|
2019-09-23 14:40:38 -04:00
|
|
|
|
|
|
|
/**
|
2020-01-18 18:35:12 +01:00
|
|
|
* Establishes a secure connection over TLS (transport layer security).
|
2019-09-23 14:40:38 -04:00
|
|
|
*/
|
2020-01-18 18:35:12 +01:00
|
|
|
export async function connectTLS(options: ConnectTLSOptions): Promise<Conn> {
|
|
|
|
options = Object.assign(connectTLSDefaults, options);
|
|
|
|
const res = await sendAsync(dispatch.OP_CONNECT_TLS, options);
|
2019-09-23 14:40:38 -04:00
|
|
|
return new ConnImpl(res.rid, res.remoteAddr!, res.localAddr!);
|
|
|
|
}
|
2019-10-21 20:38:28 +02:00
|
|
|
|
|
|
|
class TLSListenerImpl extends ListenerImpl {
|
|
|
|
async accept(): Promise<Conn> {
|
|
|
|
const res = await sendAsync(dispatch.OP_ACCEPT_TLS, { rid: this.rid });
|
|
|
|
return new ConnImpl(res.rid, res.remoteAddr, res.localAddr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ListenTLSOptions {
|
|
|
|
port: number;
|
|
|
|
hostname?: string;
|
|
|
|
transport?: Transport;
|
|
|
|
certFile: string;
|
|
|
|
keyFile: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Listen announces on the local transport address over TLS (transport layer security).
|
|
|
|
*
|
|
|
|
* @param options
|
|
|
|
* @param options.port The port to connect to. (Required.)
|
|
|
|
* @param options.hostname A literal IP address or host name that can be
|
|
|
|
* resolved to an IP address. If not specified, defaults to 0.0.0.0
|
|
|
|
* @param options.certFile Server certificate file
|
|
|
|
* @param options.keyFile Server public key file
|
|
|
|
*
|
|
|
|
* Examples:
|
|
|
|
*
|
|
|
|
* Deno.listenTLS({ port: 443, certFile: "./my_server.crt", keyFile: "./my_server.key" })
|
|
|
|
*/
|
|
|
|
export function listenTLS(options: ListenTLSOptions): Listener {
|
|
|
|
const hostname = options.hostname || "0.0.0.0";
|
|
|
|
const transport = options.transport || "tcp";
|
|
|
|
const res = sendSync(dispatch.OP_LISTEN_TLS, {
|
|
|
|
hostname,
|
|
|
|
port: options.port,
|
|
|
|
transport,
|
|
|
|
certFile: options.certFile,
|
|
|
|
keyFile: options.keyFile
|
|
|
|
});
|
|
|
|
return new TLSListenerImpl(res.rid, transport, res.localAddr);
|
|
|
|
}
|