@entity-access/server-pages 1.0.6 → 1.0.7
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/ClusterInstance.d.ts +25 -0
- package/dist/ClusterInstance.d.ts.map +1 -0
- package/dist/ClusterInstance.js +87 -0
- package/dist/ClusterInstance.js.map +1 -0
- package/dist/Content.d.ts +46 -0
- package/dist/Content.d.ts.map +1 -0
- package/dist/Content.js +135 -0
- package/dist/Content.js.map +1 -0
- package/dist/Invokable.d.ts +11 -0
- package/dist/Invokable.d.ts.map +1 -0
- package/dist/Invokable.js +51 -0
- package/dist/Invokable.js.map +1 -0
- package/dist/NotFoundPage.d.ts +6 -0
- package/dist/NotFoundPage.d.ts.map +1 -0
- package/dist/NotFoundPage.js +7 -0
- package/dist/NotFoundPage.js.map +1 -0
- package/dist/Page.d.ts +91 -0
- package/dist/Page.d.ts.map +1 -0
- package/dist/Page.js +97 -0
- package/dist/Page.js.map +1 -0
- package/dist/ServerPages.d.ts +19 -0
- package/dist/ServerPages.d.ts.map +1 -0
- package/dist/ServerPages.js +172 -0
- package/dist/ServerPages.js.map +1 -0
- package/dist/core/LocalFile.d.ts +23 -0
- package/dist/core/LocalFile.d.ts.map +1 -0
- package/dist/core/LocalFile.js +76 -0
- package/dist/core/LocalFile.js.map +1 -0
- package/dist/core/RouteTree.d.ts +24 -0
- package/dist/core/RouteTree.d.ts.map +1 -0
- package/dist/core/RouteTree.js +94 -0
- package/dist/core/RouteTree.js.map +1 -0
- package/dist/core/SessionUser.d.ts +42 -0
- package/dist/core/SessionUser.d.ts.map +1 -0
- package/dist/core/SessionUser.js +62 -0
- package/dist/core/SessionUser.js.map +1 -0
- package/dist/core/TempFolder.d.ts +8 -0
- package/dist/core/TempFolder.d.ts.map +1 -0
- package/dist/core/TempFolder.js +35 -0
- package/dist/core/TempFolder.js.map +1 -0
- package/dist/html/HtmlDocument.d.ts +5 -0
- package/dist/html/HtmlDocument.d.ts.map +1 -0
- package/dist/html/HtmlDocument.js +5 -0
- package/dist/html/HtmlDocument.js.map +1 -0
- package/dist/html/XNode.d.ts +9 -0
- package/dist/html/XNode.d.ts.map +1 -0
- package/dist/html/XNode.js +45 -0
- package/dist/html/XNode.js.map +1 -0
- package/dist/services/CookieService.d.ts +13 -0
- package/dist/services/CookieService.d.ts.map +1 -0
- package/dist/services/CookieService.js +136 -0
- package/dist/services/CookieService.js.map +1 -0
- package/dist/services/KeyProvider.d.ts +13 -0
- package/dist/services/KeyProvider.d.ts.map +1 -0
- package/dist/services/KeyProvider.js +59 -0
- package/dist/services/KeyProvider.js.map +1 -0
- package/dist/services/TokenService.d.ts +30 -0
- package/dist/services/TokenService.d.ts.map +1 -0
- package/dist/services/TokenService.js +65 -0
- package/dist/services/TokenService.js.map +1 -0
- package/dist/services/UserSessionProvider.d.ts +5 -0
- package/dist/services/UserSessionProvider.d.ts.map +1 -0
- package/dist/services/UserSessionProvider.js +19 -0
- package/dist/services/UserSessionProvider.js.map +1 -0
- package/dist/tests/logger/api/log/post.d.ts +3 -0
- package/dist/tests/logger/api/log/post.d.ts.map +1 -0
- package/dist/tests/logger/api/log/post.js +5 -0
- package/dist/tests/logger/api/log/post.js.map +1 -0
- package/dist/tests/logger/index.d.ts +4 -0
- package/dist/tests/logger/index.d.ts.map +1 -0
- package/dist/tests/logger/index.js +14 -0
- package/dist/tests/logger/index.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
export default class XNode {
|
|
2
|
+
static create(
|
|
3
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
4
|
+
name, attribs, ...nodes) {
|
|
5
|
+
if (typeof name === "function") {
|
|
6
|
+
return name(attribs ?? {}, ...nodes);
|
|
7
|
+
}
|
|
8
|
+
return new XNode(name, attribs, nodes);
|
|
9
|
+
}
|
|
10
|
+
constructor(name, attributes, children) {
|
|
11
|
+
this.name = name;
|
|
12
|
+
this.attributes = attributes;
|
|
13
|
+
this.children = children;
|
|
14
|
+
}
|
|
15
|
+
render(nest = "") {
|
|
16
|
+
const { name, attributes } = this;
|
|
17
|
+
const children = [];
|
|
18
|
+
let a = "";
|
|
19
|
+
if (attributes) {
|
|
20
|
+
for (const key in attributes) {
|
|
21
|
+
if (Object.prototype.hasOwnProperty.call(attributes, key)) {
|
|
22
|
+
const element = attributes[key];
|
|
23
|
+
a += ` ${key}=${JSON.stringify(element)}`;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (this.children) {
|
|
28
|
+
for (const child of this.children) {
|
|
29
|
+
if (typeof child === "string") {
|
|
30
|
+
children.push(child);
|
|
31
|
+
continue;
|
|
32
|
+
}
|
|
33
|
+
if (!child) {
|
|
34
|
+
continue;
|
|
35
|
+
}
|
|
36
|
+
children.push(child.render(nest + "\t"));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
if (!name) {
|
|
40
|
+
return `\n${nest}\t${children.join("\n\t")}`;
|
|
41
|
+
}
|
|
42
|
+
return `${nest}<${name}${a}>\n${nest}\t${children.join("\n\t")}\n${nest}</${name}>`;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=XNode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"XNode.js","sourceRoot":"","sources":["../../src/html/XNode.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAO,KAAK;IAEf,MAAM,CAAC,MAAM;IAChB,wDAAwD;IACxD,IAAuB,EACvB,OAA4B,EAC5B,GAAI,KAAyB;QAC7B,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,GAAI,KAAK,CAAC,CAAC;QAC1C,CAAC;QACD,OAAO,IAAI,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED,YACoB,IAAY,EACZ,UAA+B,EAC/B,QAA4B;QAF5B,SAAI,GAAJ,IAAI,CAAQ;QACZ,eAAU,GAAV,UAAU,CAAqB;QAC/B,aAAQ,GAAR,QAAQ,CAAoB;IAGhD,CAAC;IAEM,MAAM,CAAC,IAAI,GAAG,EAAE;QACnB,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;QAClC,MAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,IAAI,UAAU,EAAE,CAAC;YACb,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAC3B,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,EAAE,CAAC;oBACxD,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;oBAChC,CAAC,IAAI,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC9C,CAAC;YACL,CAAC;QACL,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;oBAC5B,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACrB,SAAS;gBACb,CAAC;gBACD,IAAI,CAAC,KAAK,EAAE,CAAC;oBACT,SAAS;gBACb,CAAC;gBACD,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC;YAC7C,CAAC;QACL,CAAC;QACD,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,OAAO,KAAK,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACjD,CAAC;QACD,OAAO,GAAG,IAAI,IAAI,IAAI,GAAG,CAAC,MAAM,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,IAAI,GAAG,CAAC;IACxF,CAAC;CAEJ"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Request, Response } from "express";
|
|
2
|
+
import SessionUser from "../core/SessionUser.js";
|
|
3
|
+
export default class CookieService {
|
|
4
|
+
private tokenService;
|
|
5
|
+
private userSessionProvider;
|
|
6
|
+
constructor();
|
|
7
|
+
clearCache(userID: number, broadcast?: boolean): void;
|
|
8
|
+
createSessionUser(req: Request, resp: Response): Promise<void>;
|
|
9
|
+
createSessionUserFromCookie(cookie: string, ip: string, resp?: Response): Promise<SessionUser>;
|
|
10
|
+
private getVerifiedUser;
|
|
11
|
+
private createUserInfo;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=CookieService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CookieService.d.ts","sourceRoot":"","sources":["../../src/services/CookieService.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE5C,OAAO,WAAW,MAAM,wBAAwB,CAAC;AAmBjD,MAAM,CAAC,OAAO,OAAO,aAAa;IAG9B,OAAO,CAAC,YAAY,CAAe;IAGnC,OAAO,CAAC,mBAAmB,CAAsB;;IAU1C,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,UAAO;IA0B5C,iBAAiB,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ;IAM9C,2BAA2B,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,QAAQ;IA0B7E,OAAO,CAAC,eAAe;YAwBT,cAAc;CAa/B"}
|
|
@@ -0,0 +1,136 @@
|
|
|
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 Inject, { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
11
|
+
import TokenService from "./TokenService.js";
|
|
12
|
+
import TimedCache from "@entity-access/entity-access/dist/common/cache/TimedCache.js";
|
|
13
|
+
import cluster from "cluster";
|
|
14
|
+
import SessionUser from "../core/SessionUser.js";
|
|
15
|
+
import UserSessionProvider from "./UserSessionProvider.js";
|
|
16
|
+
/**
|
|
17
|
+
* This will track userID,cookie pair so we can
|
|
18
|
+
* clear the logged in user's file permissions
|
|
19
|
+
*/
|
|
20
|
+
const userCookies = new Map();
|
|
21
|
+
const sessionCache = new TimedCache();
|
|
22
|
+
let cookieName = null;
|
|
23
|
+
const tagForCache = Symbol("tagForCache");
|
|
24
|
+
const cacheFR = new FinalizationRegistry((heldValue) => {
|
|
25
|
+
userCookies.delete(heldValue);
|
|
26
|
+
});
|
|
27
|
+
let CookieService = class CookieService {
|
|
28
|
+
constructor() {
|
|
29
|
+
process.on("message", (msg) => {
|
|
30
|
+
if (msg.type === "cookie-service-clear-cache") {
|
|
31
|
+
this.clearCache(msg.userID, false);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
clearCache(userID, broadcast = true) {
|
|
36
|
+
const cookie = userCookies.get(userID);
|
|
37
|
+
if (cookie) {
|
|
38
|
+
sessionCache.delete(cookie);
|
|
39
|
+
}
|
|
40
|
+
if (!broadcast) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const clearMessage = {
|
|
44
|
+
type: "cookie-service-clear-cache",
|
|
45
|
+
userID
|
|
46
|
+
};
|
|
47
|
+
if (cluster.isWorker) {
|
|
48
|
+
process.send(clearMessage);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
if (cluster.workers) {
|
|
52
|
+
for (const key in cluster.workers) {
|
|
53
|
+
if (Object.prototype.hasOwnProperty.call(cluster.workers, key)) {
|
|
54
|
+
const element = cluster.workers[key];
|
|
55
|
+
element.send(clearMessage);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async createSessionUser(req, resp) {
|
|
62
|
+
cookieName ??= this.tokenService.authCookieName;
|
|
63
|
+
const sessionCookie = req.cookies[cookieName];
|
|
64
|
+
req.user = await this.createSessionUserFromCookie(sessionCookie, req.ip, resp);
|
|
65
|
+
}
|
|
66
|
+
async createSessionUserFromCookie(cookie, ip, resp) {
|
|
67
|
+
const user = new SessionUser(resp, cookieName, this.tokenService);
|
|
68
|
+
try {
|
|
69
|
+
user.ipAddress = ip;
|
|
70
|
+
if (cookie) {
|
|
71
|
+
const userInfo = await this.getVerifiedUser(cookie);
|
|
72
|
+
if (userInfo?.sessionID) {
|
|
73
|
+
user.sessionID = userInfo.sessionID;
|
|
74
|
+
}
|
|
75
|
+
if (userInfo?.userID) {
|
|
76
|
+
user[tagForCache] = userInfo;
|
|
77
|
+
for (const key in userInfo) {
|
|
78
|
+
if (Object.prototype.hasOwnProperty.call(userInfo, key)) {
|
|
79
|
+
const element = userInfo[key];
|
|
80
|
+
user[key] = element;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return user;
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
console.error(error);
|
|
89
|
+
return user;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
getVerifiedUser(cookie) {
|
|
93
|
+
return sessionCache.getOrCreateAsync(cookie, async (k) => {
|
|
94
|
+
const parsedCookie = JSON.parse(cookie);
|
|
95
|
+
if (!parsedCookie.id) {
|
|
96
|
+
return {};
|
|
97
|
+
}
|
|
98
|
+
if (!await this.tokenService.verifyContent(parsedCookie, false)) {
|
|
99
|
+
return {};
|
|
100
|
+
}
|
|
101
|
+
if (!parsedCookie.active) {
|
|
102
|
+
return {
|
|
103
|
+
sessionID: parsedCookie.id
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
const r = await this.createUserInfo(parsedCookie.id, cookie);
|
|
107
|
+
return r;
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
async createUserInfo(id, cookie) {
|
|
111
|
+
const r = await this.userSessionProvider.getUserSession(id);
|
|
112
|
+
if (r === null) {
|
|
113
|
+
return {};
|
|
114
|
+
}
|
|
115
|
+
if (r.expiry.getTime() < Date.now() || r.invalid) {
|
|
116
|
+
return {};
|
|
117
|
+
}
|
|
118
|
+
cacheFR.register(r, r.userID);
|
|
119
|
+
userCookies.set(r.userID, cookie);
|
|
120
|
+
return r;
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
__decorate([
|
|
124
|
+
Inject,
|
|
125
|
+
__metadata("design:type", TokenService)
|
|
126
|
+
], CookieService.prototype, "tokenService", void 0);
|
|
127
|
+
__decorate([
|
|
128
|
+
Inject,
|
|
129
|
+
__metadata("design:type", UserSessionProvider)
|
|
130
|
+
], CookieService.prototype, "userSessionProvider", void 0);
|
|
131
|
+
CookieService = __decorate([
|
|
132
|
+
RegisterSingleton,
|
|
133
|
+
__metadata("design:paramtypes", [])
|
|
134
|
+
], CookieService);
|
|
135
|
+
export default CookieService;
|
|
136
|
+
//# sourceMappingURL=CookieService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CookieService.js","sourceRoot":"","sources":["../../src/services/CookieService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import DateTime from "@entity-access/entity-access/dist/types/DateTime.js";
|
|
2
|
+
export interface IAuthKey {
|
|
3
|
+
publicKey: string;
|
|
4
|
+
privateKey: string;
|
|
5
|
+
expires: DateTime;
|
|
6
|
+
}
|
|
7
|
+
export default class KeyProvider {
|
|
8
|
+
keyPath: string;
|
|
9
|
+
private key;
|
|
10
|
+
getKeys(): Promise<IAuthKey[]>;
|
|
11
|
+
private generateKey;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=KeyProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyProvider.d.ts","sourceRoot":"","sources":["../../src/services/KeyProvider.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,qDAAqD,CAAC;AAK3E,MAAM,WAAW,QAAQ;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,QAAQ,CAAA;CACpB;AAID,MAAM,CAAC,OAAO,OAAO,WAAW;IAErB,OAAO,EAAE,MAAM,CAAgB;IAEtC,OAAO,CAAC,GAAG,CAAW;IAET,OAAO;IAmBpB,OAAO,CAAC,WAAW;CAsBtB"}
|
|
@@ -0,0 +1,59 @@
|
|
|
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 { generateKeyPair } from "node:crypto";
|
|
9
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
|
|
10
|
+
import { join } from "node:path";
|
|
11
|
+
let KeyProvider = class KeyProvider {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.keyPath = "/data/keys";
|
|
14
|
+
}
|
|
15
|
+
async getKeys() {
|
|
16
|
+
if (this.key) {
|
|
17
|
+
return [this.key];
|
|
18
|
+
}
|
|
19
|
+
// check if we have key stored
|
|
20
|
+
const keyPath = this.keyPath;
|
|
21
|
+
if (!existsSync(keyPath)) {
|
|
22
|
+
mkdirSync(keyPath, { recursive: true });
|
|
23
|
+
}
|
|
24
|
+
const file = join(keyPath, "cookie-key.json");
|
|
25
|
+
if (existsSync(file)) {
|
|
26
|
+
this.key = JSON.parse(readFileSync(file, "utf-8"));
|
|
27
|
+
return [this.key];
|
|
28
|
+
}
|
|
29
|
+
this.key = await this.generateKey(null);
|
|
30
|
+
writeFileSync(file, JSON.stringify(this.key, undefined, 2));
|
|
31
|
+
return [this.key];
|
|
32
|
+
}
|
|
33
|
+
generateKey(expires) {
|
|
34
|
+
return new Promise((resolve, reject) => {
|
|
35
|
+
generateKeyPair('rsa', {
|
|
36
|
+
modulusLength: 2048,
|
|
37
|
+
publicKeyEncoding: {
|
|
38
|
+
type: 'spki',
|
|
39
|
+
format: 'pem'
|
|
40
|
+
},
|
|
41
|
+
privateKeyEncoding: {
|
|
42
|
+
type: 'pkcs8',
|
|
43
|
+
format: 'pem'
|
|
44
|
+
}
|
|
45
|
+
}, (error, publicKey, privateKey) => {
|
|
46
|
+
resolve({
|
|
47
|
+
publicKey,
|
|
48
|
+
privateKey,
|
|
49
|
+
expires
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
KeyProvider = __decorate([
|
|
56
|
+
RegisterSingleton
|
|
57
|
+
], KeyProvider);
|
|
58
|
+
export default KeyProvider;
|
|
59
|
+
//# sourceMappingURL=KeyProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyProvider.js","sourceRoot":"","sources":["../../src/services/KeyProvider.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAE/E,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAUlB,IAAM,WAAW,GAAjB,MAAM,WAAW;IAAjB;QAEJ,YAAO,GAAW,YAAY,CAAC;IA6C1C,CAAC;IAzCU,KAAK,CAAC,OAAO;QAChB,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;YACX,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;QACD,8BAA8B;QAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YACvB,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC;QAC3C,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAC9C,IAAI,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACnB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;YACnD,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;QACD,IAAI,CAAC,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACtB,CAAC;IAEO,WAAW,CAAC,OAAiB;QACjC,OAAO,IAAI,OAAO,CAAW,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC7C,eAAe,CAAC,KAAK,EAAE;gBACnB,aAAa,EAAE,IAAI;gBACnB,iBAAiB,EAAE;oBACjB,IAAI,EAAE,MAAM;oBACZ,MAAM,EAAE,KAAK;iBACd;gBACD,kBAAkB,EAAE;oBAClB,IAAI,EAAE,OAAO;oBACb,MAAM,EAAE,KAAK;iBACd;aACJ,EACE,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,EAAE;gBAChC,OAAO,CAAC;oBACJ,SAAS;oBACT,UAAU;oBACV,OAAO;iBACV,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AA/CoB,WAAW;IAD/B,iBAAiB;GACG,WAAW,CA+C/B;eA/CoB,WAAW"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import DateTime from "@entity-access/entity-access/dist/types/DateTime.js";
|
|
2
|
+
export interface IAuthCookie {
|
|
3
|
+
id: number;
|
|
4
|
+
expiry: Date;
|
|
5
|
+
sign: string;
|
|
6
|
+
version: string;
|
|
7
|
+
active?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface IAuthKey {
|
|
10
|
+
publicKey: string;
|
|
11
|
+
privateKey: string;
|
|
12
|
+
expires: DateTime;
|
|
13
|
+
}
|
|
14
|
+
export type ISignedContent<T> = T & {
|
|
15
|
+
sign: string;
|
|
16
|
+
};
|
|
17
|
+
export default class TokenService {
|
|
18
|
+
authCookieName: string;
|
|
19
|
+
shareCookieName: string;
|
|
20
|
+
private keyProvider;
|
|
21
|
+
getAuthToken(authCookie: Omit<IAuthCookie, "sign">): Promise<{
|
|
22
|
+
cookieName: string;
|
|
23
|
+
cookie: string;
|
|
24
|
+
}>;
|
|
25
|
+
signContent<T>(content: T): Promise<ISignedContent<T>>;
|
|
26
|
+
verifyContent<T>(content: ISignedContent<T>, fail?: boolean): Promise<boolean>;
|
|
27
|
+
private sign;
|
|
28
|
+
private verify;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=TokenService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenService.d.ts","sourceRoot":"","sources":["../../src/services/TokenService.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,qDAAqD,CAAC;AAM3E,MAAM,WAAW,WAAW;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,IAAI,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,QAAQ;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,QAAQ,CAAA;CACpB;AAED,MAAM,MAAM,cAAc,CAAC,CAAC,IAAI,CAAC,GAAG;IAChC,IAAI,EAAE,MAAM,CAAC;CAChB,CAAC;AAGF,MAAM,CAAC,OAAO,OAAO,YAAY;IAEtB,cAAc,SAAW;IAEzB,eAAe,SAAY;IAGlC,OAAO,CAAC,WAAW,CAAc;IAEpB,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAC,CAAC;IAKnG,WAAW,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IAMtD,aAAa,CAAC,CAAC,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,IAAI,UAAO;IAarE,OAAO,CAAC,IAAI;IAOZ,OAAO,CAAC,MAAM;CAajB"}
|
|
@@ -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
|
+
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 Inject, { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
11
|
+
import { createSign, createVerify } from "node:crypto";
|
|
12
|
+
import KeyProvider from "./KeyProvider.js";
|
|
13
|
+
let TokenService = class TokenService {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.authCookieName = "ea-c1";
|
|
16
|
+
this.shareCookieName = "ea-ca1";
|
|
17
|
+
}
|
|
18
|
+
async getAuthToken(authCookie) {
|
|
19
|
+
const cookie = await this.signContent(authCookie);
|
|
20
|
+
return { cookieName: this.authCookieName, cookie: JSON.stringify(cookie) };
|
|
21
|
+
}
|
|
22
|
+
async signContent(content) {
|
|
23
|
+
const [key] = await this.keyProvider.getKeys();
|
|
24
|
+
const sign = this.sign(JSON.stringify(content), key);
|
|
25
|
+
return { ...content, sign };
|
|
26
|
+
}
|
|
27
|
+
async verifyContent(content, fail = true) {
|
|
28
|
+
const { sign, ...c } = content;
|
|
29
|
+
const keys = await this.keyProvider.getKeys();
|
|
30
|
+
for (const iterator of keys) {
|
|
31
|
+
if (this.verify(JSON.stringify(c), sign, iterator, false)) {
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
if (fail) {
|
|
36
|
+
throw new Error("Signature verification failed");
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
sign(content, key) {
|
|
40
|
+
const sign = createSign("SHA256");
|
|
41
|
+
sign.write(content);
|
|
42
|
+
sign.end();
|
|
43
|
+
return sign.sign(key.privateKey, "hex");
|
|
44
|
+
}
|
|
45
|
+
verify(content, signature, key, fail = true) {
|
|
46
|
+
const verify = createVerify("SHA256");
|
|
47
|
+
verify.write(content);
|
|
48
|
+
verify.end();
|
|
49
|
+
if (verify.verify(key.publicKey, signature, "hex")) {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
if (fail) {
|
|
53
|
+
throw new Error("Invalid signature");
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
__decorate([
|
|
58
|
+
Inject,
|
|
59
|
+
__metadata("design:type", KeyProvider)
|
|
60
|
+
], TokenService.prototype, "keyProvider", void 0);
|
|
61
|
+
TokenService = __decorate([
|
|
62
|
+
RegisterSingleton
|
|
63
|
+
], TokenService);
|
|
64
|
+
export default TokenService;
|
|
65
|
+
//# sourceMappingURL=TokenService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenService.js","sourceRoot":"","sources":["../../src/services/TokenService.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,MAAM,EAAE,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAEvF,OAAO,EAAE,UAAU,EAAE,YAAY,EAAmB,MAAM,aAAa,CAAC;AAGxE,OAAO,WAAW,MAAM,kBAAkB,CAAC;AAqB5B,IAAM,YAAY,GAAlB,MAAM,YAAY;IAAlB;QAEJ,mBAAc,GAAG,OAAO,CAAC;QAEzB,oBAAe,GAAG,QAAQ,CAAC;IAiDtC,CAAC;IA5CU,KAAK,CAAC,YAAY,CAAC,UAAqC;QAC3D,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClD,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,cAAc,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;IAC/E,CAAC;IAEM,KAAK,CAAC,WAAW,CAAI,OAAU;QAClC,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC;QACrD,OAAO,EAAE,GAAI,OAAO,EAAE,IAAI,EAAC,CAAC;IAChC,CAAC;IAEM,KAAK,CAAC,aAAa,CAAI,OAA0B,EAAE,IAAI,GAAG,IAAI;QACjE,MAAM,EAAE,IAAI,EAAG,GAAI,CAAC,EAAE,GAAG,OAAO,CAAC;QACjC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC9C,KAAK,MAAM,QAAQ,IAAI,IAAI,EAAE,CAAC;YAC1B,IAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC;gBACvD,OAAO,IAAI,CAAC;YAChB,CAAC;QACL,CAAC;QACD,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACrD,CAAC;IACL,CAAC;IAEO,IAAI,CAAC,OAAe,EAAE,GAAa;QACvC,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;QAClC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACpB,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAEO,MAAM,CAAC,OAAwB,EAAE,SAAiB,EAAE,GAAa,EAAE,IAAI,GAAG,IAAI;QAClF,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACtB,MAAM,CAAC,GAAG,EAAE,CAAC;QACb,IAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC;YAChD,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACzC,CAAC;IACL,CAAC;CAGJ,CAAA;AA9CW;IADP,MAAM;8BACc,WAAW;iDAAC;AAPhB,YAAY;IADhC,iBAAiB;GACG,YAAY,CAqDhC;eArDoB,YAAY"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserSessionProvider.d.ts","sourceRoot":"","sources":["../../src/services/UserSessionProvider.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,wBAAwB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,mBAAmB;IAE9B,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;CAMlE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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
|
+
let UserSessionProvider = class UserSessionProvider {
|
|
9
|
+
async getUserSession(id) {
|
|
10
|
+
return {
|
|
11
|
+
userID: 1,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
UserSessionProvider = __decorate([
|
|
16
|
+
RegisterSingleton
|
|
17
|
+
], UserSessionProvider);
|
|
18
|
+
export default UserSessionProvider;
|
|
19
|
+
//# sourceMappingURL=UserSessionProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserSessionProvider.js","sourceRoot":"","sources":["../../src/services/UserSessionProvider.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAIhE,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAEpC,KAAK,CAAC,cAAc,CAAC,EAAU;QAC3B,OAAO;YACH,MAAM,EAAE,CAAC;SACZ,CAAA;IACL,CAAC;CAEJ,CAAA;AARoB,mBAAmB;IADvC,iBAAiB;GACG,mBAAmB,CAQvC;eARoB,mBAAmB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"post.d.ts","sourceRoot":"","sources":["../../../../../src/tests/logger/api/log/post.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAEvC,MAAM,CAAC,OAAO,WAAU,IAAI,EAAE,IAAI,4CAGjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"post.js","sourceRoot":"","sources":["../../../../../src/tests/logger/api/log/post.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO;IACV,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;AACpD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tests/logger/index.tsx"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,kBAAkB,CAAC;AACvC,OAAO,IAAI,MAAM,eAAe,CAAC;AAIjC,MAAM,CAAC,OAAO,WAAU,IAAI,EAAE,IAAI,8BAcjC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import Content from "../../Content.js";
|
|
2
|
+
import HtmlDocument from "../../html/HtmlDocument.js";
|
|
3
|
+
import XNode from "../../html/XNode.js";
|
|
4
|
+
export default function () {
|
|
5
|
+
const [child] = this.childPath;
|
|
6
|
+
if (child) {
|
|
7
|
+
if (!/^index\.htm/i.test(child)) {
|
|
8
|
+
return this.notFound();
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
return Content.html(XNode.create(HtmlDocument, null,
|
|
12
|
+
XNode.create("body", null, "Test 1")));
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tests/logger/index.tsx"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,kBAAkB,CAAC;AAEvC,OAAO,YAAY,MAAM,4BAA4B,CAAC;AACtD,OAAO,KAAK,MAAM,qBAAqB,CAAC;AAExC,MAAM,CAAC,OAAO;IAEV,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;IAC/B,IAAI,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,OAAO,OAAO,CAAC,IAAI,CAAC,aAAC,YAAY;QAC7B,oCAEO,CACI,CAAC,CAAC;AACrB,CAAC"}
|