sliftutils 1.1.0 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitignore +1 -0
- package/index.d.ts +14 -0
- package/misc/https/httpsCerts.ts +18 -1
- package/misc/https/ip.d.ts +10 -0
- package/misc/https/ip.ts +21 -0
- package/package.json +1 -1
package/.gitignore
CHANGED
package/index.d.ts
CHANGED
|
@@ -176,6 +176,20 @@ declare module "sliftutils/misc/https/httpsCerts" {
|
|
|
176
176
|
|
|
177
177
|
}
|
|
178
178
|
|
|
179
|
+
declare module "sliftutils/misc/https/ip" {
|
|
180
|
+
export declare const getExternalIP: {
|
|
181
|
+
(): Promise<string>;
|
|
182
|
+
reset(): void;
|
|
183
|
+
set(newValue: Promise<string>): void;
|
|
184
|
+
};
|
|
185
|
+
export declare const getPublicIP: {
|
|
186
|
+
(): Promise<string>;
|
|
187
|
+
reset(): void;
|
|
188
|
+
set(newValue: Promise<string>): void;
|
|
189
|
+
};
|
|
190
|
+
|
|
191
|
+
}
|
|
192
|
+
|
|
179
193
|
declare module "sliftutils/misc/https/node-forge-ed25519" {
|
|
180
194
|
|
|
181
195
|
|
package/misc/https/httpsCerts.ts
CHANGED
|
@@ -5,11 +5,22 @@ import * as forge from "node-forge";
|
|
|
5
5
|
import acme from "acme-client";
|
|
6
6
|
import { magenta, red } from "socket-function/src/formatting/logColors";
|
|
7
7
|
import { formatDateTime, formatTime } from "socket-function/src/formatting/format";
|
|
8
|
-
import { timeInMinute } from "socket-function/src/misc";
|
|
8
|
+
import { timeInHour, timeInMinute } from "socket-function/src/misc";
|
|
9
9
|
import { delay } from "socket-function/src/batching";
|
|
10
10
|
import fs from "fs";
|
|
11
11
|
import { getKeyStore } from "./persistentLocalStorage";
|
|
12
12
|
|
|
13
|
+
// For example:
|
|
14
|
+
/*
|
|
15
|
+
let domain = "querysubtest.com";
|
|
16
|
+
await loadIdentityCA(domain);
|
|
17
|
+
|
|
18
|
+
let listenPublic = false;
|
|
19
|
+
let port = 9823;
|
|
20
|
+
let localDomain = "127-0-0-1." + domain;
|
|
21
|
+
await addRecord("A", localDomain, "127.0.0.1");
|
|
22
|
+
let keyCert = await getHTTPSCert(domain);
|
|
23
|
+
*/
|
|
13
24
|
|
|
14
25
|
// Expire EXPIRATION_THRESHOLD% of the way through the certificate's lifetime
|
|
15
26
|
const EXPIRATION_THRESHOLD = 0.4;
|
|
@@ -19,6 +30,12 @@ export const getHTTPSCert = cache(async (domain: string): Promise<{ key: string;
|
|
|
19
30
|
if (!domain.endsWith(".")) {
|
|
20
31
|
domain = domain + ".";
|
|
21
32
|
}
|
|
33
|
+
|
|
34
|
+
// No matter what, reset this from the in-memory cache in an hour. This is fine. We'll just see the cache on disk and see that it hasn't expired. Or we might see that it has expired, and then we will get the new value.
|
|
35
|
+
setTimeout(() => {
|
|
36
|
+
getHTTPSCert.clear(domain);
|
|
37
|
+
}, timeInHour);
|
|
38
|
+
|
|
22
39
|
let keyCert: { key: string; cert: string } | undefined;
|
|
23
40
|
let path = domain + ".cert";
|
|
24
41
|
|
package/misc/https/ip.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { lazy } from "socket-function/src/caching";
|
|
2
|
+
import { httpsRequest } from "socket-function/src/https";
|
|
3
|
+
|
|
4
|
+
const ipServers = [
|
|
5
|
+
"http://quentinbrooks.com:4283",
|
|
6
|
+
"https://ipinfo.io/ip",
|
|
7
|
+
"https://api.ipify.org"
|
|
8
|
+
];
|
|
9
|
+
|
|
10
|
+
export const getExternalIP = lazy((async function getExternalIP(): Promise<string> {
|
|
11
|
+
for (let server of ipServers) {
|
|
12
|
+
try {
|
|
13
|
+
return (await httpsRequest(server, undefined, undefined, false)).toString();
|
|
14
|
+
} catch (e) {
|
|
15
|
+
console.warn(`Failed to get external ip from ${server}: ${e}`);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
throw new Error(`Failed to get external ip from any server`);
|
|
19
|
+
}));
|
|
20
|
+
|
|
21
|
+
export const getPublicIP = getExternalIP;
|