2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-12-07 14:21:01 +01:00
|
|
|
import { core, primordials } from "ext:core/mod.js";
|
2023-12-26 18:30:26 -07:00
|
|
|
const {
|
|
|
|
op_net_accept_tls,
|
|
|
|
op_net_connect_tls,
|
2024-01-11 07:37:25 +09:00
|
|
|
op_net_listen_tls,
|
|
|
|
op_tls_handshake,
|
|
|
|
op_tls_start,
|
2023-12-26 18:30:26 -07:00
|
|
|
} = core.ensureFastOps();
|
2024-01-11 07:37:25 +09:00
|
|
|
const {
|
|
|
|
Number,
|
|
|
|
TypeError,
|
|
|
|
} = primordials;
|
|
|
|
|
|
|
|
import { Conn, Listener } from "ext:deno_net/01_net.js";
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
function opStartTls(args) {
|
2023-12-26 18:30:26 -07:00
|
|
|
return op_tls_start(args);
|
2023-02-07 20:22:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function opTlsHandshake(rid) {
|
2023-12-26 18:30:26 -07:00
|
|
|
return op_tls_handshake(rid);
|
2023-02-07 20:22:46 +01:00
|
|
|
}
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
class TlsConn extends Conn {
|
|
|
|
handshake() {
|
|
|
|
return opTlsHandshake(this.rid);
|
2021-10-26 22:27:47 +02:00
|
|
|
}
|
2023-02-07 20:22:46 +01:00
|
|
|
}
|
2021-10-26 22:27:47 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
async function connectTls({
|
|
|
|
port,
|
|
|
|
hostname = "127.0.0.1",
|
|
|
|
transport = "tcp",
|
|
|
|
certFile = undefined,
|
|
|
|
caCerts = [],
|
|
|
|
certChain = undefined,
|
|
|
|
privateKey = undefined,
|
|
|
|
alpnProtocols = undefined,
|
|
|
|
}) {
|
|
|
|
if (transport !== "tcp") {
|
|
|
|
throw new TypeError(`Unsupported transport: '${transport}'`);
|
2021-10-26 22:27:47 +02:00
|
|
|
}
|
2023-12-26 18:30:26 -07:00
|
|
|
const { 0: rid, 1: localAddr, 2: remoteAddr } = await op_net_connect_tls(
|
2023-02-07 20:22:46 +01:00
|
|
|
{ hostname, port },
|
|
|
|
{ certFile, caCerts, certChain, privateKey, alpnProtocols },
|
|
|
|
);
|
|
|
|
localAddr.transport = "tcp";
|
|
|
|
remoteAddr.transport = "tcp";
|
|
|
|
return new TlsConn(rid, remoteAddr, localAddr);
|
|
|
|
}
|
2021-10-26 22:27:47 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
class TlsListener extends Listener {
|
|
|
|
async accept() {
|
2023-12-26 18:30:26 -07:00
|
|
|
const { 0: rid, 1: localAddr, 2: remoteAddr } = await op_net_accept_tls(
|
2023-02-07 20:22:46 +01:00
|
|
|
this.rid,
|
2022-10-25 22:50:55 +02:00
|
|
|
);
|
|
|
|
localAddr.transport = "tcp";
|
|
|
|
remoteAddr.transport = "tcp";
|
|
|
|
return new TlsConn(rid, remoteAddr, localAddr);
|
2020-07-19 19:49:44 +02:00
|
|
|
}
|
2023-02-07 20:22:46 +01:00
|
|
|
}
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
function listenTls({
|
|
|
|
port,
|
|
|
|
cert,
|
|
|
|
certFile,
|
|
|
|
key,
|
|
|
|
keyFile,
|
|
|
|
hostname = "0.0.0.0",
|
|
|
|
transport = "tcp",
|
|
|
|
alpnProtocols = undefined,
|
|
|
|
reusePort = false,
|
|
|
|
}) {
|
|
|
|
if (transport !== "tcp") {
|
|
|
|
throw new TypeError(`Unsupported transport: '${transport}'`);
|
2020-07-19 19:49:44 +02:00
|
|
|
}
|
2024-01-11 07:37:25 +09:00
|
|
|
const { 0: rid, 1: localAddr } = op_net_listen_tls(
|
2023-07-25 15:26:18 +09:00
|
|
|
{ hostname, port: Number(port) },
|
2023-02-07 20:22:46 +01:00
|
|
|
{ cert, certFile, key, keyFile, alpnProtocols, reusePort },
|
|
|
|
);
|
|
|
|
return new TlsListener(rid, localAddr);
|
|
|
|
}
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
async function startTls(
|
|
|
|
conn,
|
|
|
|
{
|
|
|
|
hostname = "127.0.0.1",
|
|
|
|
certFile = undefined,
|
|
|
|
caCerts = [],
|
2021-11-26 10:59:53 -08:00
|
|
|
alpnProtocols = undefined,
|
2023-02-07 20:22:46 +01:00
|
|
|
} = {},
|
|
|
|
) {
|
|
|
|
const { 0: rid, 1: localAddr, 2: remoteAddr } = await opStartTls({
|
|
|
|
rid: conn.rid,
|
|
|
|
hostname,
|
|
|
|
certFile,
|
|
|
|
caCerts,
|
|
|
|
alpnProtocols,
|
|
|
|
});
|
|
|
|
return new TlsConn(rid, remoteAddr, localAddr);
|
|
|
|
}
|
2020-07-19 19:49:44 +02:00
|
|
|
|
2023-02-07 20:22:46 +01:00
|
|
|
export { connectTls, listenTls, startTls, TlsConn, TlsListener };
|