@entity-access/server-pages 1.0.31 → 1.0.32
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/dist/ServerPages.d.ts +1 -1
- package/dist/ServerPages.d.ts.map +1 -1
- package/dist/ServerPages.js +7 -2
- package/dist/ServerPages.js.map +1 -1
- package/dist/ssl/{ACME.d.ts → AcmeCertificateService.d.ts} +3 -2
- package/dist/ssl/AcmeCertificateService.d.ts.map +1 -0
- package/dist/ssl/{ACME.js → AcmeCertificateService.js} +17 -39
- package/dist/ssl/AcmeCertificateService.js.map +1 -0
- package/dist/ssl/{ChallengeStore.d.ts → AcmeChallengeStore.d.ts} +2 -3
- package/dist/ssl/AcmeChallengeStore.d.ts.map +1 -0
- package/dist/ssl/{ChallengeStore.js → AcmeChallengeStore.js} +2 -2
- package/dist/ssl/AcmeChallengeStore.js.map +1 -0
- package/dist/ssl/CertificateStore.d.ts +15 -0
- package/dist/ssl/CertificateStore.d.ts.map +1 -0
- package/dist/ssl/CertificateStore.js +65 -0
- package/dist/ssl/CertificateStore.js.map +1 -0
- package/dist/ssl/ChallengeServer.d.ts +5 -0
- package/dist/ssl/ChallengeServer.d.ts.map +1 -0
- package/dist/ssl/ChallengeServer.js +45 -0
- package/dist/ssl/ChallengeServer.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/ServerPages.ts +9 -2
- package/src/ssl/{ACME.ts → AcmeCertificateService.ts} +225 -247
- package/src/ssl/{ChallengeStore.ts → AcmeChallengeStore.ts} +25 -25
- package/src/ssl/CertificateStore.ts +68 -0
- package/src/ssl/ChallengeServer.ts +34 -0
- package/dist/ssl/ACME.d.ts.map +0 -1
- package/dist/ssl/ACME.js.map +0 -1
- package/dist/ssl/ChallengeStore.d.ts.map +0 -1
- package/dist/ssl/ChallengeStore.js.map +0 -1
package/dist/ServerPages.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ import { ServiceProvider } from "@entity-access/entity-access/dist/di/di.js";
|
|
|
5
5
|
import * as http from "http";
|
|
6
6
|
import * as http2 from "http2";
|
|
7
7
|
import { SecureContext } from "node:tls";
|
|
8
|
-
import { IAcmeOptions } from "./ssl/
|
|
8
|
+
import { IAcmeOptions } from "./ssl/AcmeCertificateService.js";
|
|
9
9
|
export default class ServerPages {
|
|
10
10
|
static create(globalServiceProvider?: ServiceProvider): ServerPages;
|
|
11
11
|
private root;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServerPages.d.ts","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;AACA,OAAO,EAAqB,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAOhG,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,
|
|
1
|
+
{"version":3,"file":"ServerPages.d.ts","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;AACA,OAAO,EAAqB,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAOhG,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAA+B,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAIvF,MAAM,CAAC,OAAO,OAAO,WAAW;WAEd,MAAM,CAAC,qBAAqB,GAAE,eAAuC;IAKnF,OAAO,CAAC,IAAI,CAA8B;IAE1C;;;;OAIG;IACI,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,GAAE,MAAY;IASlD,oBAAoB;IAI3B;;;OAGG;IACU,KAAK,CAAC,EACf,mBAA0B,EAC1B,IAAW,EACX,QAAiB,EACjB,mBAA2B,EAC3B,WAAW,EACX,WAAW,EACd,EAAC;QACE,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,IAAI,EAAE,MAAM,CAAC;QACb,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,QAAQ,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;QACtC,WAAW,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,KAAK,GAAG,IAAI,EAAE,GAAG,CAAC,EAAE,aAAa,KAAK,IAAI,KAAK,IAAI,CAAC;QACjG,WAAW,CAAC,EAAE,YAAY,CAAA;KAC7B;cA0De,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG;CAgF9C"}
|
package/dist/ServerPages.js
CHANGED
|
@@ -55,7 +55,8 @@ import * as http from "http";
|
|
|
55
55
|
import * as http2 from "http2";
|
|
56
56
|
import SocketService from "./socket/SocketService.js";
|
|
57
57
|
import { Wrapped } from "./core/Wrapped.js";
|
|
58
|
-
import
|
|
58
|
+
import AcmeCertficateService from "./ssl/AcmeCertificateService.js";
|
|
59
|
+
import ChallengeServer from "./ssl/ChallengeServer.js";
|
|
59
60
|
RegisterSingleton;
|
|
60
61
|
export default class ServerPages {
|
|
61
62
|
constructor() {
|
|
@@ -102,7 +103,7 @@ export default class ServerPages {
|
|
|
102
103
|
case "https2":
|
|
103
104
|
let sc = null;
|
|
104
105
|
SNICallback ??= (name, cb) => {
|
|
105
|
-
const acme = ServiceProvider.resolve(this,
|
|
106
|
+
const acme = ServiceProvider.resolve(this, AcmeCertficateService);
|
|
106
107
|
acme.getSecureContext({ ...(acmeOptions ?? {}), host: name }).then((v) => {
|
|
107
108
|
cb(null, v);
|
|
108
109
|
}, cb);
|
|
@@ -110,6 +111,10 @@ export default class ServerPages {
|
|
|
110
111
|
httpServer = http2.createSecureServer({
|
|
111
112
|
SNICallback
|
|
112
113
|
}, (req, res) => this.process(req, res));
|
|
114
|
+
if (acmeOptions) {
|
|
115
|
+
const cs = ServiceProvider.resolve(this, ChallengeServer);
|
|
116
|
+
cs.start();
|
|
117
|
+
}
|
|
113
118
|
break;
|
|
114
119
|
case "http2":
|
|
115
120
|
httpServer = http2.createSecureServer({}, (req, res) => this.process(req, res));
|
package/dist/ServerPages.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServerPages.js","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAChG,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,OAAO,MAAM,cAAc,CAAC;AACnC,OAAO,SAAS,MAAM,qBAAqB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,aAAa,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAQ,
|
|
1
|
+
{"version":3,"file":"ServerPages.js","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,8 +12,9 @@ export interface IAcmeOptions {
|
|
|
12
12
|
export interface ICertOptions extends IAcmeOptions {
|
|
13
13
|
host: string;
|
|
14
14
|
}
|
|
15
|
-
export default class
|
|
15
|
+
export default class AcmeCertficateService {
|
|
16
16
|
private challengeStore;
|
|
17
|
+
private certificateStore;
|
|
17
18
|
private map;
|
|
18
19
|
getSecureContext(options: ICertOptions): Promise<tls.SecureContext>;
|
|
19
20
|
setup({ host, sslMode, accountPrivateKeyPath, emailAddress, mode, endPoint, eabKid, eabHmac }: {
|
|
@@ -34,4 +35,4 @@ export default class ACME {
|
|
|
34
35
|
cert: any;
|
|
35
36
|
};
|
|
36
37
|
}
|
|
37
|
-
//# sourceMappingURL=
|
|
38
|
+
//# sourceMappingURL=AcmeCertificateService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AcmeCertificateService.d.ts","sourceRoot":"","sources":["../../src/ssl/AcmeCertificateService.ts"],"names":[],"mappings":";AAUA,OAAO,KAAK,GAAG,MAAM,UAAU,CAAC;AAGhC,MAAM,WAAW,YAAY;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,IAAI,CAAC,EAAG,YAAY,GAAG,aAAa,GAAG,SAAS,CAAC;IACjD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,YAAa,SAAQ,YAAY;IAC9C,IAAI,EAAE,MAAM,CAAC;CAChB;AAGD,MAAM,CAAC,OAAO,OAAO,qBAAqB;IAGtC,OAAO,CAAC,cAAc,CAAiB;IAGvC,OAAO,CAAC,gBAAgB,CAAmB;IAE3C,OAAO,CAAC,GAAG,CAAwC;IAEtC,gBAAgB,CAAC,OAAO,EAAE,YAAY;IAatC,KAAK,CAAC,EACf,IAAI,EACJ,OAAc,EACd,qBAA4B,EAC5B,YAAiB,EACjB,IAA+D,EAC/D,QAAa,EACb,MAAW,EACX,OAAY,EACf;;;;;;;;;KAAA;;;;IA4FM,eAAe,CAAC,OAAO,SAAO;;;;CAwExC"}
|
|
@@ -11,15 +11,15 @@ import * as forge from "node-forge";
|
|
|
11
11
|
import * as crypto from "crypto";
|
|
12
12
|
import * as acme from "acme-client";
|
|
13
13
|
import DateTime from "@entity-access/entity-access/dist/types/DateTime.js";
|
|
14
|
-
import
|
|
15
|
-
import { existsSync, writeFileSync, readFileSync, unlinkSync } from "fs";
|
|
14
|
+
import { existsSync, writeFileSync, readFileSync } from "fs";
|
|
16
15
|
import { join } from "path";
|
|
17
|
-
import ensureDir
|
|
16
|
+
import ensureDir from "../core/FileApi.js";
|
|
18
17
|
import Inject, { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
19
|
-
import ChallengeStore from "./
|
|
18
|
+
import ChallengeStore from "./AcmeChallengeStore.js";
|
|
20
19
|
import * as tls from "node:tls";
|
|
20
|
+
import CertificateStore from "./CertificateStore.js";
|
|
21
21
|
;
|
|
22
|
-
let
|
|
22
|
+
let AcmeCertficateService = class AcmeCertficateService {
|
|
23
23
|
constructor() {
|
|
24
24
|
this.map = new Map();
|
|
25
25
|
}
|
|
@@ -52,43 +52,17 @@ let ACME = class ACME {
|
|
|
52
52
|
hmacKey: eabHmac
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
|
-
let cert;
|
|
56
|
-
let key;
|
|
57
|
-
if (!existsSync(keyPath)) {
|
|
58
|
-
deleteIfExists(certPath);
|
|
59
|
-
key = (await acme.crypto.createPrivateRsaKey()).toString();
|
|
60
|
-
writeFileSync(keyPath, key);
|
|
61
|
-
console.log(`Creating key at ${keyPath}`);
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
key = readFileSync(keyPath, "utf8");
|
|
65
|
-
}
|
|
55
|
+
let { cert, key } = await this.certificateStore.get({ host });
|
|
66
56
|
// load cert...
|
|
67
|
-
if (
|
|
68
|
-
cert = readFileSync(certPath, "utf8");
|
|
57
|
+
if (cert) {
|
|
69
58
|
const certificate = new crypto.X509Certificate(cert);
|
|
70
59
|
const validTo = DateTime.parse(certificate.validTo).diff(DateTime.now);
|
|
71
60
|
if (validTo.totalDays > 30) {
|
|
72
61
|
console.log(`Reusing certificate, valid for ${validTo.totalDays}`);
|
|
73
62
|
return { cert, key };
|
|
74
63
|
}
|
|
75
|
-
console.log(`Deleting old certificates`);
|
|
76
|
-
unlinkSync(certPath);
|
|
77
|
-
}
|
|
78
|
-
if (!cluster.isPrimary) {
|
|
79
|
-
console.log(`Generating Self Signed SSL Certificate for ${host} in cluster worker. Contact administrator.`);
|
|
80
|
-
return this.setupSelfSigned();
|
|
81
|
-
}
|
|
82
|
-
let accountKey;
|
|
83
|
-
if (existsSync(accountPrivateKeyPath)) {
|
|
84
|
-
console.log("Reusing the account private key.");
|
|
85
|
-
accountKey = readFileSync(accountPrivateKeyPath);
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
console.log("Creating new private key.");
|
|
89
|
-
accountKey = await acme.crypto.createPrivateKey();
|
|
90
|
-
writeFileSync(accountPrivateKeyPath, accountKey);
|
|
91
64
|
}
|
|
65
|
+
const accountKey = await this.certificateStore.getAccountKey();
|
|
92
66
|
acme.setLogger((message) => {
|
|
93
67
|
// console.log(message);
|
|
94
68
|
logs.push(message);
|
|
@@ -192,9 +166,13 @@ let ACME = class ACME {
|
|
|
192
166
|
__decorate([
|
|
193
167
|
Inject,
|
|
194
168
|
__metadata("design:type", ChallengeStore)
|
|
195
|
-
],
|
|
196
|
-
|
|
169
|
+
], AcmeCertficateService.prototype, "challengeStore", void 0);
|
|
170
|
+
__decorate([
|
|
171
|
+
Inject,
|
|
172
|
+
__metadata("design:type", CertificateStore)
|
|
173
|
+
], AcmeCertficateService.prototype, "certificateStore", void 0);
|
|
174
|
+
AcmeCertficateService = __decorate([
|
|
197
175
|
RegisterSingleton
|
|
198
|
-
],
|
|
199
|
-
export default
|
|
200
|
-
//# sourceMappingURL=
|
|
176
|
+
], AcmeCertficateService);
|
|
177
|
+
export default AcmeCertficateService;
|
|
178
|
+
//# sourceMappingURL=AcmeCertificateService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AcmeCertificateService.js","sourceRoot":"","sources":["../../src/ssl/AcmeCertificateService.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
2
1
|
export default class ChallengeStore {
|
|
3
2
|
constructor();
|
|
4
|
-
get(name: string): Promise<
|
|
3
|
+
get(name: string): Promise<string>;
|
|
5
4
|
save(name: string, value: string): Promise<void>;
|
|
6
5
|
remove(name: string): Promise<void>;
|
|
7
6
|
}
|
|
8
|
-
//# sourceMappingURL=
|
|
7
|
+
//# sourceMappingURL=AcmeChallengeStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AcmeChallengeStore.d.ts","sourceRoot":"","sources":["../../src/ssl/AcmeChallengeStore.ts"],"names":[],"mappings":"AAQA,MAAM,CAAC,OAAO,OAAO,cAAc;;IAMzB,GAAG,CAAC,IAAI,EAAE,MAAM;IAIhB,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAIhC,MAAM,CAAC,IAAI,EAAE,MAAM;CAG5B"}
|
|
@@ -17,7 +17,7 @@ let ChallengeStore = class ChallengeStore {
|
|
|
17
17
|
ensureDir(path);
|
|
18
18
|
}
|
|
19
19
|
async get(name) {
|
|
20
|
-
return readFileSync(join(path, name));
|
|
20
|
+
return readFileSync(join(path, name), "utf8");
|
|
21
21
|
}
|
|
22
22
|
async save(name, value) {
|
|
23
23
|
writeFileSync(join(path, name), value, "utf8");
|
|
@@ -31,4 +31,4 @@ ChallengeStore = __decorate([
|
|
|
31
31
|
__metadata("design:paramtypes", [])
|
|
32
32
|
], ChallengeStore);
|
|
33
33
|
export default ChallengeStore;
|
|
34
|
-
//# sourceMappingURL=
|
|
34
|
+
//# sourceMappingURL=AcmeChallengeStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AcmeChallengeStore.js","sourceRoot":"","sources":["../../src/ssl/AcmeChallengeStore.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAC/E,OAAO,SAAS,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAC7D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,MAAM,IAAI,GAAG,cAAc,CAAC;AAGb,IAAM,cAAc,GAApB,MAAM,cAAc;IAE/B;QACI,SAAS,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,IAAY;QAClB,OAAO,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAY,EAAE,KAAa;QAClC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAY;QACrB,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACjC,CAAC;CACJ,CAAA;AAjBoB,cAAc;IADlC,iBAAiB;;GACG,cAAc,CAiBlC;eAjBoB,cAAc"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
export interface ICertificate {
|
|
3
|
+
host?: string;
|
|
4
|
+
key?: Buffer;
|
|
5
|
+
cert?: string;
|
|
6
|
+
}
|
|
7
|
+
export default class CertificateStore {
|
|
8
|
+
get folder(): string;
|
|
9
|
+
set folder(v: string);
|
|
10
|
+
getAccountKey(): Promise<Buffer>;
|
|
11
|
+
get({ host }: ICertificate): Promise<ICertificate>;
|
|
12
|
+
save({ host, cert, key }: ICertificate): Promise<void>;
|
|
13
|
+
private getPaths;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=CertificateStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CertificateStore.d.ts","sourceRoot":"","sources":["../../src/ssl/CertificateStore.ts"],"names":[],"mappings":";AAMA,MAAM,WAAW,YAAY;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB;AAKD,MAAM,CAAC,OAAO,OAAO,gBAAgB;IAEjC,IAAW,MAAM,IAII,MAAM,CAF1B;IAED,IAAW,MAAM,CAAC,CAAC,EAAE,MAAM,EAE1B;IAEY,aAAa;IAcb,GAAG,CAAE,EAAE,IAAI,EAAE,EAAE,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;IAcnD,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,YAAY;IAMnD,OAAO,CAAC,QAAQ;CAQnB"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
8
|
+
import { join } from "node:path";
|
|
9
|
+
import ensureDir from "../core/FileApi.js";
|
|
10
|
+
import { existsSync, readFileSync, writeFileSync } from "node:fs";
|
|
11
|
+
import * as acme from "acme-client";
|
|
12
|
+
let folder = "./certs";
|
|
13
|
+
let CertificateStore = class CertificateStore {
|
|
14
|
+
get folder() {
|
|
15
|
+
return folder;
|
|
16
|
+
}
|
|
17
|
+
set folder(v) {
|
|
18
|
+
folder = v;
|
|
19
|
+
}
|
|
20
|
+
async getAccountKey() {
|
|
21
|
+
const keyPath = join(folder, "keys");
|
|
22
|
+
let key;
|
|
23
|
+
ensureDir(keyPath);
|
|
24
|
+
if (!existsSync(keyPath)) {
|
|
25
|
+
key = await acme.crypto.createPrivateRsaKey();
|
|
26
|
+
writeFileSync(keyPath, key);
|
|
27
|
+
console.log(`Creating New Account key: ${keyPath}`);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
key = readFileSync(keyPath);
|
|
31
|
+
}
|
|
32
|
+
return key;
|
|
33
|
+
}
|
|
34
|
+
async get({ host }) {
|
|
35
|
+
const { certPath, keyPath } = this.getPaths(folder, host);
|
|
36
|
+
const cert = existsSync(certPath) ? readFileSync(certPath, "utf8") : "";
|
|
37
|
+
let key;
|
|
38
|
+
if (!existsSync(keyPath)) {
|
|
39
|
+
key = await acme.crypto.createPrivateRsaKey();
|
|
40
|
+
writeFileSync(keyPath, key);
|
|
41
|
+
console.log(`Creating New key: ${keyPath}`);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
key = readFileSync(keyPath);
|
|
45
|
+
}
|
|
46
|
+
return { host, cert, key };
|
|
47
|
+
}
|
|
48
|
+
async save({ host, cert, key }) {
|
|
49
|
+
const { certPath, keyPath } = this.getPaths(folder, host);
|
|
50
|
+
writeFileSync(certPath, cert, "utf8");
|
|
51
|
+
writeFileSync(keyPath, key);
|
|
52
|
+
}
|
|
53
|
+
getPaths(folder, host) {
|
|
54
|
+
const hostRoot = join(folder, host);
|
|
55
|
+
ensureDir(hostRoot);
|
|
56
|
+
const certPath = join(hostRoot, "cert.crt");
|
|
57
|
+
const keyPath = join(hostRoot, "key.pem");
|
|
58
|
+
return { certPath, keyPath };
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
CertificateStore = __decorate([
|
|
62
|
+
RegisterSingleton
|
|
63
|
+
], CertificateStore);
|
|
64
|
+
export default CertificateStore;
|
|
65
|
+
//# sourceMappingURL=CertificateStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CertificateStore.js","sourceRoot":"","sources":["../../src/ssl/CertificateStore.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeServer.d.ts","sourceRoot":"","sources":["../../src/ssl/ChallengeServer.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,OAAO,OAAO,eAAe;IAGhC,OAAO,CAAC,cAAc,CAAiB;IAEvC,KAAK;CAuBR"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import * as http from "node:http";
|
|
11
|
+
import Inject, { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
12
|
+
import ChallengeStore from "./AcmeChallengeStore.js";
|
|
13
|
+
let ChallengeServer = class ChallengeServer {
|
|
14
|
+
start() {
|
|
15
|
+
const server = http.createServer(async (req, res) => {
|
|
16
|
+
try {
|
|
17
|
+
const url = new URL(req.url, `https://${req.headers.host || "localhost"}`);
|
|
18
|
+
const path = url.pathname.split("/").filter((x) => x);
|
|
19
|
+
if (url.pathname.startsWith("/.well-known/acme-challenge/")) {
|
|
20
|
+
const token = path[2];
|
|
21
|
+
const value = await this.challengeStore.get(token);
|
|
22
|
+
res.writeHead(200, { "content-type": "text/plain" });
|
|
23
|
+
await new Promise((resolve, reject) => res.write(Buffer.from(value), (error) => error ? reject(error) : resolve()));
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
res.writeHead(301, { location: url.toString() });
|
|
27
|
+
}
|
|
28
|
+
await new Promise((resolve) => res.end(resolve));
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
console.error(error);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
server.listen(80);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
__decorate([
|
|
38
|
+
Inject,
|
|
39
|
+
__metadata("design:type", ChallengeStore)
|
|
40
|
+
], ChallengeServer.prototype, "challengeStore", void 0);
|
|
41
|
+
ChallengeServer = __decorate([
|
|
42
|
+
RegisterSingleton
|
|
43
|
+
], ChallengeServer);
|
|
44
|
+
export default ChallengeServer;
|
|
45
|
+
//# sourceMappingURL=ChallengeServer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeServer.js","sourceRoot":"","sources":["../../src/ssl/ChallengeServer.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAClC,OAAO,MAAM,EAAE,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,cAAc,MAAM,yBAAyB,CAAC;AAGtC,IAAM,eAAe,GAArB,MAAM,eAAe;IAKhC,KAAK;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YAChD,IAAI,CAAC;gBACD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,WAAW,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,WAAW,EAAE,CAAC,CAAC;gBAC3E,MAAM,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;gBACtD,IAAG,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,8BAA8B,CAAC,EAAE,CAAC;oBACzD,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;oBACtB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACnD,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,YAAY,EAAE,CAAC,CAAC;oBACrD,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;gBAC9H,CAAC;qBAAM,CAAC;oBACJ,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;gBACrD,CAAC;gBACD,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;YAE3D,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACtB,CAAC;CAEJ,CAAA;AAzBW;IADP,MAAM;8BACiB,cAAc;uDAAC;AAHtB,eAAe;IADnC,iBAAiB;GACG,eAAe,CA4BnC;eA5BoB,eAAe"}
|