mirror of
https://github.com/denoland/deno.git
synced 2024-10-31 09:14:20 -04:00
0d7a417f33
This adds support for using in memory CA certificates for `Deno.startTLS`, `Deno.connectTLS` and `Deno.createHttpClient`. `certFile` is deprecated in `startTls` and `connectTls`, and removed from `Deno.createHttpClient`.
92 lines
1.8 KiB
JavaScript
92 lines
1.8 KiB
JavaScript
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
|
"use strict";
|
|
|
|
((window) => {
|
|
const core = window.Deno.core;
|
|
const { Listener, Conn } = window.__bootstrap.net;
|
|
|
|
function opConnectTls(
|
|
args,
|
|
) {
|
|
return core.opAsync("op_connect_tls", args);
|
|
}
|
|
|
|
function opAcceptTLS(rid) {
|
|
return core.opAsync("op_accept_tls", rid);
|
|
}
|
|
|
|
function opListenTls(args) {
|
|
return core.opSync("op_listen_tls", args);
|
|
}
|
|
|
|
function opStartTls(args) {
|
|
return core.opAsync("op_start_tls", args);
|
|
}
|
|
|
|
async function connectTls({
|
|
port,
|
|
hostname = "127.0.0.1",
|
|
transport = "tcp",
|
|
certFile = undefined,
|
|
caCerts = [],
|
|
certChain = undefined,
|
|
privateKey = undefined,
|
|
}) {
|
|
const res = await opConnectTls({
|
|
port,
|
|
hostname,
|
|
transport,
|
|
certFile,
|
|
caCerts,
|
|
certChain,
|
|
privateKey,
|
|
});
|
|
return new Conn(res.rid, res.remoteAddr, res.localAddr);
|
|
}
|
|
|
|
class TLSListener extends Listener {
|
|
async accept() {
|
|
const res = await opAcceptTLS(this.rid);
|
|
return new Conn(res.rid, res.remoteAddr, res.localAddr);
|
|
}
|
|
}
|
|
|
|
function listenTls({
|
|
port,
|
|
certFile,
|
|
keyFile,
|
|
hostname = "0.0.0.0",
|
|
transport = "tcp",
|
|
alpnProtocols,
|
|
}) {
|
|
const res = opListenTls({
|
|
port,
|
|
certFile,
|
|
keyFile,
|
|
hostname,
|
|
transport,
|
|
alpnProtocols,
|
|
});
|
|
return new TLSListener(res.rid, res.localAddr);
|
|
}
|
|
|
|
async function startTls(
|
|
conn,
|
|
{ hostname = "127.0.0.1", certFile = undefined, caCerts = [] } = {},
|
|
) {
|
|
const res = await opStartTls({
|
|
rid: conn.rid,
|
|
hostname,
|
|
certFile,
|
|
caCerts,
|
|
});
|
|
return new Conn(res.rid, res.remoteAddr, res.localAddr);
|
|
}
|
|
|
|
window.__bootstrap.tls = {
|
|
startTls,
|
|
listenTls,
|
|
connectTls,
|
|
TLSListener,
|
|
};
|
|
})(this);
|