securequ 1.0.10 → 1.0.12
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/client/index.d.ts +25 -0
- package/client/index.js +107 -173
- package/client/index.js.map +1 -1
- package/client/index.mjs +107 -173
- package/client/index.mjs.map +1 -1
- package/client/types.d.ts +17 -0
- package/include/lib/base64.js +12 -12
- package/include/lib/base64.js.map +1 -1
- package/include/lib/base64.mjs +12 -12
- package/include/lib/base64.mjs.map +1 -1
- package/include/lib/cache.js +20 -22
- package/include/lib/cache.js.map +1 -1
- package/include/lib/cache.mjs +20 -22
- package/include/lib/cache.mjs.map +1 -1
- package/include/lib/crypto.js +23 -23
- package/include/lib/crypto.js.map +1 -1
- package/include/lib/crypto.mjs +23 -23
- package/include/lib/crypto.mjs.map +1 -1
- package/include/lib/pako.js +5 -5
- package/include/lib/pako.js.map +1 -1
- package/include/lib/pako.mjs +5 -5
- package/include/lib/pako.mjs.map +1 -1
- package/include/lib/reverser.js +11 -11
- package/include/lib/reverser.js.map +1 -1
- package/include/lib/reverser.mjs +11 -11
- package/include/lib/reverser.mjs.map +1 -1
- package/include/lib/urlpath.js +2 -2
- package/include/lib/urlpath.js.map +1 -1
- package/include/lib/urlpath.mjs +2 -2
- package/include/lib/urlpath.mjs.map +1 -1
- package/include/responseValue.js +4 -4
- package/include/responseValue.js.map +1 -1
- package/include/responseValue.mjs +4 -4
- package/include/responseValue.mjs.map +1 -1
- package/include/signeture.js +12 -12
- package/include/signeture.js.map +1 -1
- package/include/signeture.mjs +12 -12
- package/include/signeture.mjs.map +1 -1
- package/index.d.ts +2 -81
- package/package.json +6 -11
- package/server/index.d.ts +18 -0
- package/server/index.js +105 -176
- package/server/index.js.map +1 -1
- package/server/index.mjs +105 -176
- package/server/index.mjs.map +1 -1
- package/server/types.d.ts +28 -0
package/client/index.mjs
CHANGED
|
@@ -1,52 +1,52 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import crypto from'../include/lib/crypto.mjs';import signeture from'../include/signeture.mjs';import urlpath from'../include/lib/urlpath.mjs';import xanFetch from'xanfetch';import responseValue from'../include/responseValue.mjs';import SecurequCache from'../include/lib/cache.mjs';class SecurequClient {
|
|
2
|
+
constructor(config) {
|
|
3
3
|
this.token = '';
|
|
4
4
|
this.tokenLoading = false;
|
|
5
5
|
this.Cache = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
|
|
6
6
|
this.reqkey = '';
|
|
7
7
|
this.PATH_CACHE = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
|
|
8
|
-
this.config =
|
|
9
|
-
|
|
8
|
+
this.config = Object.assign({}, config);
|
|
9
|
+
const secret = crypto.makeSecret(config.secret);
|
|
10
10
|
this.config.secret = secret;
|
|
11
11
|
this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);
|
|
12
12
|
this.secret = crypto.makeSecret(secret.substring(0, this.secret_length));
|
|
13
13
|
this.signerure = signeture.make(this.secret, this.secret);
|
|
14
14
|
}
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
setCache(path, method, response) {
|
|
16
|
+
const cacheKey = `${method}:${path}`;
|
|
17
17
|
if (this.config.cache === true) {
|
|
18
18
|
this.Cache.set(cacheKey, response);
|
|
19
19
|
}
|
|
20
20
|
else if (this.config.cache) {
|
|
21
21
|
this.config.cache.set(cacheKey, response);
|
|
22
22
|
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
}
|
|
24
|
+
getCache(path, method) {
|
|
25
|
+
const cacheKey = `${method}:${path}`;
|
|
26
26
|
if (this.config.cache === true) {
|
|
27
27
|
return this.Cache.get(cacheKey);
|
|
28
28
|
}
|
|
29
29
|
else if (this.config.cache) {
|
|
30
30
|
return this.config.cache.get(cacheKey);
|
|
31
31
|
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
32
|
+
}
|
|
33
|
+
path(path) {
|
|
34
|
+
let pathKey = path;
|
|
35
|
+
let has = this.PATH_CACHE.get(pathKey);
|
|
36
36
|
if (!has) {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
path =
|
|
37
|
+
const { search, pathname } = new URL(path, window.location.origin);
|
|
38
|
+
const params = new URLSearchParams(search);
|
|
39
|
+
const paramsObject = Object.fromEntries(params.entries());
|
|
40
|
+
let split = pathname.split("/").map((s) => urlpath.encrypt(s)).filter((s) => s.length > 0);
|
|
41
|
+
path = `${this.config.path}/${split.join("/")}`;
|
|
42
42
|
if (Object.keys(paramsObject).length) {
|
|
43
|
-
for (
|
|
43
|
+
for (let key in paramsObject) {
|
|
44
44
|
paramsObject[urlpath.encrypt(key)] = paramsObject[key];
|
|
45
45
|
delete paramsObject[key];
|
|
46
46
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
path +=
|
|
47
|
+
const string = JSON.stringify(paramsObject);
|
|
48
|
+
const text = encodeURIComponent(crypto.encrypt(string, this.token));
|
|
49
|
+
path += `?${this.reqkey}=${text}`;
|
|
50
50
|
}
|
|
51
51
|
this.PATH_CACHE.set(pathKey, path);
|
|
52
52
|
}
|
|
@@ -54,160 +54,94 @@ import {__awaiter,__assign,__generator}from'../node_modules/tslib/tslib.es6.mjs'
|
|
|
54
54
|
path = has;
|
|
55
55
|
}
|
|
56
56
|
return path;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
switch (_d.label) {
|
|
64
|
-
case 0:
|
|
65
|
-
this.tokenLoading = true;
|
|
66
|
-
return [4 /*yield*/, xanFetch(this.path("/handshake"), {
|
|
67
|
-
method: "GET",
|
|
68
|
-
headers: __assign(__assign({}, this.config.headers), (_c = {}, _c[signeture.key] = this.signerure, _c)),
|
|
69
|
-
})];
|
|
70
|
-
case 1:
|
|
71
|
-
res = _d.sent();
|
|
72
|
-
_b = (_a = responseValue).decrypt;
|
|
73
|
-
return [4 /*yield*/, res.text()];
|
|
74
|
-
case 2:
|
|
75
|
-
value = _b.apply(_a, [_d.sent(), this.signerure]);
|
|
76
|
-
token = crypto.decrypt(value, this.secret);
|
|
77
|
-
this.token = token;
|
|
78
|
-
this.reqkey = token.substring(0, token.length / 2);
|
|
79
|
-
this.tokenLoading = false;
|
|
80
|
-
return [2 /*return*/];
|
|
81
|
-
}
|
|
82
|
-
});
|
|
57
|
+
}
|
|
58
|
+
async handshake() {
|
|
59
|
+
this.tokenLoading = true;
|
|
60
|
+
const res = await xanFetch(this.path(`/handshake`), {
|
|
61
|
+
method: "GET",
|
|
62
|
+
headers: Object.assign(Object.assign({}, this.config.headers), { [signeture.key]: this.signerure }),
|
|
83
63
|
});
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
}
|
|
103
|
-
}, 100);
|
|
104
|
-
})];
|
|
105
|
-
case 1:
|
|
106
|
-
_b.sent();
|
|
107
|
-
_b.label = 2;
|
|
108
|
-
case 2:
|
|
109
|
-
if (!!this.token) return [3 /*break*/, 4];
|
|
110
|
-
return [4 /*yield*/, this.handshake()];
|
|
111
|
-
case 3:
|
|
112
|
-
_b.sent();
|
|
113
|
-
_b.label = 4;
|
|
114
|
-
case 4:
|
|
115
|
-
info = __assign(__assign({ method: "GET" }, init), { headers: __assign(__assign(__assign({}, this.config.headers), init === null || init === void 0 ? void 0 : init.headers), (_a = {}, _a[signeture.key] = this.signerure, _a)) });
|
|
116
|
-
cache_res = this.getCache(path, info.method);
|
|
117
|
-
if (cache_res) {
|
|
118
|
-
return [2 /*return*/, cache_res.clone()];
|
|
119
|
-
}
|
|
120
|
-
if (info.body) {
|
|
121
|
-
if (!this.token)
|
|
122
|
-
throw new Error("Token not loaded");
|
|
123
|
-
body = new FormData();
|
|
124
|
-
_data = {};
|
|
125
|
-
hasFile = false;
|
|
126
|
-
for (key in info.body) {
|
|
127
|
-
ukey = urlpath.encrypt(key);
|
|
128
|
-
if (info.body[key] instanceof File) {
|
|
129
|
-
body.append(ukey, info.body[key]);
|
|
130
|
-
hasFile = true;
|
|
131
|
-
}
|
|
132
|
-
else {
|
|
133
|
-
_data[ukey] = info.body[key];
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
body.append(this.reqkey, crypto.encrypt(_data, this.token));
|
|
137
|
-
if (!hasFile) {
|
|
138
|
-
info.body = new URLSearchParams(body);
|
|
139
|
-
if (!info.headers['Content-Type']) {
|
|
140
|
-
info.headers['Content-Type'] = 'application/x-www-form-urlencoded';
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
if (info.method === "GET") {
|
|
145
|
-
info.method = "POST";
|
|
146
|
-
}
|
|
147
|
-
info.body = body;
|
|
148
|
-
if (!info.headers['Content-Type']) {
|
|
149
|
-
info.headers['Content-Type'] = 'multipart/form-data';
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
return [4 /*yield*/, xanFetch(this.path(path), info)];
|
|
154
|
-
case 5:
|
|
155
|
-
response = _b.sent();
|
|
156
|
-
res = response.clone();
|
|
157
|
-
return [4 /*yield*/, response.text()];
|
|
158
|
-
case 6:
|
|
159
|
-
text = _b.sent();
|
|
160
|
-
value = responseValue.decrypt(text, this.signerure);
|
|
161
|
-
res.text = function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
|
162
|
-
return [2 /*return*/, value];
|
|
163
|
-
}); }); };
|
|
164
|
-
if (this.config.cache === true && res.ok) {
|
|
165
|
-
this.setCache(path, info.method, res.clone());
|
|
166
|
-
}
|
|
167
|
-
return [2 /*return*/, res];
|
|
168
|
-
}
|
|
64
|
+
const value = responseValue.decrypt(await res.text(), this.signerure);
|
|
65
|
+
const token = crypto.decrypt(value, this.secret);
|
|
66
|
+
this.token = token;
|
|
67
|
+
this.reqkey = token.substring(0, token.length / 2);
|
|
68
|
+
this.tokenLoading = false;
|
|
69
|
+
}
|
|
70
|
+
async send(path, init) {
|
|
71
|
+
if (path === '/handshake') {
|
|
72
|
+
throw new Error("Path is not allowed");
|
|
73
|
+
}
|
|
74
|
+
if (this.tokenLoading) {
|
|
75
|
+
await new Promise((resolve) => {
|
|
76
|
+
const interval = setInterval(() => {
|
|
77
|
+
if (!this.tokenLoading) {
|
|
78
|
+
clearInterval(interval);
|
|
79
|
+
resolve(null);
|
|
80
|
+
}
|
|
81
|
+
}, 100);
|
|
169
82
|
});
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
83
|
+
}
|
|
84
|
+
if (!this.token) {
|
|
85
|
+
await this.handshake();
|
|
86
|
+
}
|
|
87
|
+
const info = Object.assign(Object.assign({ method: "GET" }, init), { headers: Object.assign(Object.assign(Object.assign({}, this.config.headers), init === null || init === void 0 ? void 0 : init.headers), { [signeture.key]: this.signerure }) });
|
|
88
|
+
const cache_res = this.getCache(path, info.method);
|
|
89
|
+
if (cache_res) {
|
|
90
|
+
return cache_res.clone();
|
|
91
|
+
}
|
|
92
|
+
if (info.body) {
|
|
93
|
+
if (!this.token)
|
|
94
|
+
throw new Error("Token not loaded");
|
|
95
|
+
const body = new FormData();
|
|
96
|
+
let _data = {};
|
|
97
|
+
let hasFile = false;
|
|
98
|
+
for (let key in info.body) {
|
|
99
|
+
let ukey = urlpath.encrypt(key);
|
|
100
|
+
if (info.body[key] instanceof File) {
|
|
101
|
+
body.append(ukey, info.body[key]);
|
|
102
|
+
hasFile = true;
|
|
178
103
|
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
};
|
|
182
|
-
SecurequClient.prototype.post = function (path, body, init) {
|
|
183
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
184
|
-
return __generator(this, function (_a) {
|
|
185
|
-
switch (_a.label) {
|
|
186
|
-
case 0: return [4 /*yield*/, this.send(path, __assign(__assign({}, init), { method: "POST", body: body }))];
|
|
187
|
-
case 1: return [2 /*return*/, _a.sent()];
|
|
104
|
+
else {
|
|
105
|
+
_data[ukey] = info.body[key];
|
|
188
106
|
}
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
switch (_a.label) {
|
|
196
|
-
case 0: return [4 /*yield*/, this.send(path, __assign(__assign({}, init), { method: "PUT", body: body }))];
|
|
197
|
-
case 1: return [2 /*return*/, _a.sent()];
|
|
107
|
+
}
|
|
108
|
+
body.append(this.reqkey, crypto.encrypt(_data, this.token));
|
|
109
|
+
if (!hasFile) {
|
|
110
|
+
info.body = new URLSearchParams(body);
|
|
111
|
+
if (!info.headers['Content-Type']) {
|
|
112
|
+
info.headers['Content-Type'] = 'application/x-www-form-urlencoded';
|
|
198
113
|
}
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
204
|
-
return __generator(this, function (_a) {
|
|
205
|
-
switch (_a.label) {
|
|
206
|
-
case 0: return [4 /*yield*/, this.send(path, __assign(__assign({}, init), { method: "DELETE" }))];
|
|
207
|
-
case 1: return [2 /*return*/, _a.sent()];
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
if (info.method === "GET") {
|
|
117
|
+
info.method = "POST";
|
|
208
118
|
}
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
}
|
|
119
|
+
info.body = body;
|
|
120
|
+
if (!info.headers['Content-Type']) {
|
|
121
|
+
info.headers['Content-Type'] = 'multipart/form-data';
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const response = await xanFetch(this.path(path), info);
|
|
126
|
+
const res = response.clone();
|
|
127
|
+
const text = await response.text();
|
|
128
|
+
const value = responseValue.decrypt(text, this.signerure);
|
|
129
|
+
res.text = async () => value;
|
|
130
|
+
if (this.config.cache === true && res.ok) {
|
|
131
|
+
this.setCache(path, info.method, res.clone());
|
|
132
|
+
}
|
|
133
|
+
return res;
|
|
134
|
+
}
|
|
135
|
+
async get(path, init) {
|
|
136
|
+
return await this.send(path, init);
|
|
137
|
+
}
|
|
138
|
+
async post(path, body, init) {
|
|
139
|
+
return await this.send(path, Object.assign(Object.assign({}, init), { method: "POST", body: body }));
|
|
140
|
+
}
|
|
141
|
+
async put(path, body, init) {
|
|
142
|
+
return await this.send(path, Object.assign(Object.assign({}, init), { method: "PUT", body: body }));
|
|
143
|
+
}
|
|
144
|
+
async delete(path, init) {
|
|
145
|
+
return await this.send(path, Object.assign(Object.assign({}, init), { method: "DELETE" }));
|
|
146
|
+
}
|
|
147
|
+
}export{SecurequClient,SecurequClient as default};//# sourceMappingURL=index.mjs.map
|
package/client/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../src/client/index.ts"],"sourcesContent":["import crypto from \"../include/lib/crypto\";\nimport signeture from \"../include/signeture\";\nimport urlpath from \"../include/lib/urlpath\";\nimport { HttpRequestInit, RequestBody, SecurequClientConfig } from \"./types\";\nimport xanFetch from 'xanfetch'\nimport responseValue from \"../include/responseValue\";\nimport SecurequCache from \"../include/lib/cache\";\n\nexport class SecurequClient {\n private config: SecurequClientConfig;\n private token: string = '';\n private tokenLoading: boolean = false;\n private Cache = new SecurequCache<Response>({ ttl: 1000 * 60 * 60, limit: 100 });\n\n private secret: string;\n private secret_length: number;\n private signerure: string;\n private reqkey: string = '';\n\n constructor(config: SecurequClientConfig) {\n this.config = { ...config }\n const secret = crypto.makeSecret(config.secret)\n this.config.secret = secret;\n this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);\n this.secret = crypto.makeSecret(secret.substring(0, this.secret_length))\n this.signerure = signeture.make(this.secret, this.secret);\n }\n\n private setCache(path: string, method: string, response: any) {\n const cacheKey = `${method}:${path}`;\n if (this.config.cache === true) {\n this.Cache.set(cacheKey, response);\n } else if (this.config.cache) {\n this.config.cache.set(cacheKey, response);\n }\n }\n\n private getCache(path: string, method: string,) {\n const cacheKey = `${method}:${path}`;\n if (this.config.cache === true) {\n return this.Cache.get(cacheKey);\n } else if (this.config.cache) {\n return this.config.cache.get(cacheKey);\n }\n }\n\n private PATH_CACHE = new SecurequCache<string>({ ttl: 1000 * 60 * 60, limit: 100 });\n private path(path: string) {\n let pathKey = path\n let has = this.PATH_CACHE.get(pathKey)\n if (!has) {\n const { search, pathname } = new URL(path, window.location.origin);\n const params = new URLSearchParams(search);\n const paramsObject = Object.fromEntries(params.entries());\n let split = pathname.split(\"/\").map((s) => urlpath.encrypt(s)).filter((s) => s.length > 0);\n path = `${this.config.path}/${split.join(\"/\")}`;\n if (Object.keys(paramsObject).length) {\n for (let key in paramsObject) {\n paramsObject[urlpath.encrypt(key)] = paramsObject[key]\n delete paramsObject[key]\n }\n const string = JSON.stringify(paramsObject)\n const text = encodeURIComponent(crypto.encrypt(string, this.token));\n path += `?${this.reqkey}=${text}`;\n }\n this.PATH_CACHE.set(pathKey, path);\n } else {\n path = has\n }\n return path\n }\n\n private async handshake() {\n this.tokenLoading = true;\n const res = await xanFetch(this.path(`/handshake`), {\n method: \"GET\",\n headers: {\n ...this.config.headers,\n [signeture.key]: this.signerure\n },\n })\n\n const value: any = responseValue.decrypt(await res.text(), this.signerure)\n const token = crypto.decrypt(value, this.secret)\n this.token = token;\n this.reqkey = token.substring(0, token.length / 2);\n this.tokenLoading = false;\n }\n\n async send(path: string, init?: HttpRequestInit): Promise<Response> {\n if (path === '/handshake') {\n throw new Error(\"Path is not allowed\")\n }\n if (this.tokenLoading) {\n await new Promise((resolve) => {\n const interval = setInterval(() => {\n if (!this.tokenLoading) {\n clearInterval(interval);\n resolve(null);\n }\n }, 100);\n })\n }\n\n if (!this.token) {\n await this.handshake();\n }\n\n const info: any = {\n method: \"GET\",\n ...init,\n headers: {\n ...this.config.headers,\n ...init?.headers,\n [signeture.key]: this.signerure\n },\n }\n\n const cache_res = this.getCache(path, info.method);\n if (cache_res) {\n return cache_res.clone();\n }\n\n if (info.body) {\n if (!this.token) throw new Error(\"Token not loaded\")\n const body = new FormData();\n let _data: any = {}\n let hasFile = false;\n for (let key in info.body) {\n let ukey = urlpath.encrypt(key);\n if (info.body[key] instanceof File) {\n body.append(ukey, info.body[key]);\n hasFile = true;\n } else {\n _data[ukey] = info.body[key];\n }\n }\n\n body.append(this.reqkey, crypto.encrypt(_data, this.token));\n\n if (!hasFile) {\n info.body = new URLSearchParams(body as any);\n if (!info.headers['Content-Type']) {\n info.headers['Content-Type'] = 'application/x-www-form-urlencoded';\n }\n } else {\n if (info.method === \"GET\") {\n info.method = \"POST\"\n }\n info.body = body\n if (!info.headers['Content-Type']) {\n info.headers['Content-Type'] = 'multipart/form-data';\n }\n }\n }\n\n const response = await xanFetch(this.path(path), info);\n const res = response.clone();\n const text = await response.text();\n const value: any = responseValue.decrypt(text, this.signerure)\n res.text = async () => value;\n if (this.config.cache === true && res.ok) {\n this.setCache(path, info.method, res.clone());\n }\n return res\n }\n\n async get(path: string, init?: HttpRequestInit) {\n return await this.send(path, init);\n }\n\n async post(path: string, body: RequestBody, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"POST\",\n body: body\n });\n }\n\n async put(path: string, body: RequestBody, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"PUT\",\n body: body\n });\n }\n\n async delete(path: string, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"DELETE\",\n });\n }\n}\n\nexport default SecurequClient;"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/client/index.ts"],"sourcesContent":["import crypto from \"../include/lib/crypto\";\nimport signeture from \"../include/signeture\";\nimport urlpath from \"../include/lib/urlpath\";\nimport { HttpRequestInit, RequestBody, SecurequClientConfig } from \"./types\";\nimport xanFetch from 'xanfetch'\nimport responseValue from \"../include/responseValue\";\nimport SecurequCache from \"../include/lib/cache\";\n\nexport class SecurequClient {\n private config: SecurequClientConfig;\n private token: string = '';\n private tokenLoading: boolean = false;\n private Cache = new SecurequCache<Response>({ ttl: 1000 * 60 * 60, limit: 100 });\n\n private secret: string;\n private secret_length: number;\n private signerure: string;\n private reqkey: string = '';\n\n constructor(config: SecurequClientConfig) {\n this.config = { ...config }\n const secret = crypto.makeSecret(config.secret)\n this.config.secret = secret;\n this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);\n this.secret = crypto.makeSecret(secret.substring(0, this.secret_length))\n this.signerure = signeture.make(this.secret, this.secret);\n }\n\n private setCache(path: string, method: string, response: any) {\n const cacheKey = `${method}:${path}`;\n if (this.config.cache === true) {\n this.Cache.set(cacheKey, response);\n } else if (this.config.cache) {\n this.config.cache.set(cacheKey, response);\n }\n }\n\n private getCache(path: string, method: string,) {\n const cacheKey = `${method}:${path}`;\n if (this.config.cache === true) {\n return this.Cache.get(cacheKey);\n } else if (this.config.cache) {\n return this.config.cache.get(cacheKey);\n }\n }\n\n private PATH_CACHE = new SecurequCache<string>({ ttl: 1000 * 60 * 60, limit: 100 });\n private path(path: string) {\n let pathKey = path\n let has = this.PATH_CACHE.get(pathKey)\n if (!has) {\n const { search, pathname } = new URL(path, window.location.origin);\n const params = new URLSearchParams(search);\n const paramsObject = Object.fromEntries(params.entries());\n let split = pathname.split(\"/\").map((s) => urlpath.encrypt(s)).filter((s) => s.length > 0);\n path = `${this.config.path}/${split.join(\"/\")}`;\n if (Object.keys(paramsObject).length) {\n for (let key in paramsObject) {\n paramsObject[urlpath.encrypt(key)] = paramsObject[key]\n delete paramsObject[key]\n }\n const string = JSON.stringify(paramsObject)\n const text = encodeURIComponent(crypto.encrypt(string, this.token));\n path += `?${this.reqkey}=${text}`;\n }\n this.PATH_CACHE.set(pathKey, path);\n } else {\n path = has\n }\n return path\n }\n\n private async handshake() {\n this.tokenLoading = true;\n const res = await xanFetch(this.path(`/handshake`), {\n method: \"GET\",\n headers: {\n ...this.config.headers,\n [signeture.key]: this.signerure\n },\n })\n\n const value: any = responseValue.decrypt(await res.text(), this.signerure)\n const token = crypto.decrypt(value, this.secret)\n this.token = token;\n this.reqkey = token.substring(0, token.length / 2);\n this.tokenLoading = false;\n }\n\n async send(path: string, init?: HttpRequestInit): Promise<Response> {\n if (path === '/handshake') {\n throw new Error(\"Path is not allowed\")\n }\n if (this.tokenLoading) {\n await new Promise((resolve) => {\n const interval = setInterval(() => {\n if (!this.tokenLoading) {\n clearInterval(interval);\n resolve(null);\n }\n }, 100);\n })\n }\n\n if (!this.token) {\n await this.handshake();\n }\n\n const info: any = {\n method: \"GET\",\n ...init,\n headers: {\n ...this.config.headers,\n ...init?.headers,\n [signeture.key]: this.signerure\n },\n }\n\n const cache_res = this.getCache(path, info.method);\n if (cache_res) {\n return cache_res.clone();\n }\n\n if (info.body) {\n if (!this.token) throw new Error(\"Token not loaded\")\n const body = new FormData();\n let _data: any = {}\n let hasFile = false;\n for (let key in info.body) {\n let ukey = urlpath.encrypt(key);\n if (info.body[key] instanceof File) {\n body.append(ukey, info.body[key]);\n hasFile = true;\n } else {\n _data[ukey] = info.body[key];\n }\n }\n\n body.append(this.reqkey, crypto.encrypt(_data, this.token));\n\n if (!hasFile) {\n info.body = new URLSearchParams(body as any);\n if (!info.headers['Content-Type']) {\n info.headers['Content-Type'] = 'application/x-www-form-urlencoded';\n }\n } else {\n if (info.method === \"GET\") {\n info.method = \"POST\"\n }\n info.body = body\n if (!info.headers['Content-Type']) {\n info.headers['Content-Type'] = 'multipart/form-data';\n }\n }\n }\n\n const response = await xanFetch(this.path(path), info);\n const res = response.clone();\n const text = await response.text();\n const value: any = responseValue.decrypt(text, this.signerure)\n res.text = async () => value;\n if (this.config.cache === true && res.ok) {\n this.setCache(path, info.method, res.clone());\n }\n return res\n }\n\n async get(path: string, init?: HttpRequestInit) {\n return await this.send(path, init);\n }\n\n async post(path: string, body: RequestBody, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"POST\",\n body: body\n });\n }\n\n async put(path: string, body: RequestBody, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"PUT\",\n body: body\n });\n }\n\n async delete(path: string, init?: HttpRequestInit) {\n return await this.send(path, {\n ...init,\n method: \"DELETE\",\n });\n }\n}\n\nexport default SecurequClient;"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
type SecurequClientConfig = {
|
|
2
|
+
secret: string;
|
|
3
|
+
path?: string;
|
|
4
|
+
headers?: Record<string, string>;
|
|
5
|
+
cache?: boolean | {
|
|
6
|
+
get: (key: string) => any;
|
|
7
|
+
set: (key: string, response: Response) => void;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
type RequestBody = {
|
|
11
|
+
[key: string]: any;
|
|
12
|
+
};
|
|
13
|
+
type HttpRequestInit = Omit<RequestInit, 'body'> & {
|
|
14
|
+
body?: RequestBody;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export type { HttpRequestInit, RequestBody, SecurequClientConfig };
|
package/include/lib/base64.js
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
'use strict'
|
|
1
|
+
'use strict';/**
|
|
2
2
|
* Encodes a Uint8Array to Base64 (for browser or Node.js).
|
|
3
3
|
* @param data - The Uint8Array data to encode.
|
|
4
4
|
* @returns The Base64-encoded string.
|
|
5
5
|
*/
|
|
6
6
|
function encode(data) {
|
|
7
|
-
|
|
7
|
+
let base64 = "";
|
|
8
8
|
if (typeof window !== "undefined") {
|
|
9
|
-
base64 = btoa(String.fromCharCode
|
|
9
|
+
base64 = btoa(String.fromCharCode(...Array.from(data)));
|
|
10
10
|
}
|
|
11
11
|
else {
|
|
12
12
|
base64 = Buffer.from(data).toString("base64");
|
|
13
13
|
}
|
|
14
|
-
|
|
14
|
+
let paddingCount = (base64.match(/=+$/) || [''])[0].length;
|
|
15
15
|
if (paddingCount > 0) {
|
|
16
|
-
base64 = base64.replace(/=+$/,
|
|
16
|
+
base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
|
|
17
17
|
}
|
|
18
18
|
return base64;
|
|
19
19
|
}
|
|
@@ -24,11 +24,11 @@ function encode(data) {
|
|
|
24
24
|
*/
|
|
25
25
|
function decode(base64) {
|
|
26
26
|
try {
|
|
27
|
-
base64 = base64.replace(/\$(\d)/,
|
|
27
|
+
base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
|
|
28
28
|
if (typeof window !== "undefined") {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
for (
|
|
29
|
+
const binaryString = atob(base64);
|
|
30
|
+
const byteArray = new Uint8Array(binaryString.length);
|
|
31
|
+
for (let i = 0; i < binaryString.length; i++) {
|
|
32
32
|
byteArray[i] = binaryString.charCodeAt(i);
|
|
33
33
|
}
|
|
34
34
|
return byteArray;
|
|
@@ -41,7 +41,7 @@ function decode(base64) {
|
|
|
41
41
|
throw new Error("Invalid Base64 string.");
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
|
-
|
|
45
|
-
encode
|
|
46
|
-
decode
|
|
44
|
+
const base64 = {
|
|
45
|
+
encode,
|
|
46
|
+
decode
|
|
47
47
|
};module.exports=base64;//# sourceMappingURL=base64.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base64.js","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\n * @param data - The Uint8Array data to encode.\n * @returns The Base64-encoded string.\n */\nfunction encode(data: Uint8Array): string {\n let base64 = \"\";\n if (typeof window !== \"undefined\") {\n base64 = btoa(String.fromCharCode(...Array.from(data)));\n } else {\n base64 = Buffer.from(data).toString(\"base64\");\n }\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\n if (paddingCount > 0) {\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\n }\n return base64\n}\n\n/**\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\n * @param base64String - The Base64 string to decode.\n * @returns The decoded Uint8Array.\n */\nfunction decode(base64: string): Uint8Array {\n try {\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\n if (typeof window !== \"undefined\") {\n const binaryString = atob(base64);\n const byteArray = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n byteArray[i] = binaryString.charCodeAt(i);\n }\n return byteArray;\n } else {\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\n }\n } catch (error) {\n throw new Error(\"Invalid Base64 string.\");\n }\n}\n\nconst base64 = {\n encode,\n decode\n}\n\nexport default base64;"],"names":[
|
|
1
|
+
{"version":3,"file":"base64.js","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\n * @param data - The Uint8Array data to encode.\n * @returns The Base64-encoded string.\n */\nfunction encode(data: Uint8Array): string {\n let base64 = \"\";\n if (typeof window !== \"undefined\") {\n base64 = btoa(String.fromCharCode(...Array.from(data)));\n } else {\n base64 = Buffer.from(data).toString(\"base64\");\n }\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\n if (paddingCount > 0) {\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\n }\n return base64\n}\n\n/**\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\n * @param base64String - The Base64 string to decode.\n * @returns The decoded Uint8Array.\n */\nfunction decode(base64: string): Uint8Array {\n try {\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\n if (typeof window !== \"undefined\") {\n const binaryString = atob(base64);\n const byteArray = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n byteArray[i] = binaryString.charCodeAt(i);\n }\n return byteArray;\n } else {\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\n }\n } catch (error) {\n throw new Error(\"Invalid Base64 string.\");\n }\n}\n\nconst base64 = {\n encode,\n decode\n}\n\nexport default base64;"],"names":[],"mappings":"aAAA;;;;AAIG;AACH,SAAS,MAAM,CAAC,IAAgB,EAAA;IAC7B,IAAI,MAAM,GAAG,EAAE;AACf,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AACzD,IAAA;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;AAC/C,IAAA;AACD,IAAA,IAAI,YAAY,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM;IAC1D,IAAI,YAAY,GAAG,CAAC,EAAE;AACnB,QAAA,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,CAAC;AAC1D,IAAA;AACD,IAAA,OAAO,MAAM;AAChB;AAEA;;;;AAIG;AACH,SAAS,MAAM,CAAC,MAAc,EAAA;IAC3B,IAAI;QACD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,KAAK,KAAK,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AACjF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;YACjC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC;AACrD,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC3C,SAAS,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC;AAC3C,YAAA;AACD,YAAA,OAAO,SAAS;AAClB,QAAA;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACvD,QAAA;AACH,IAAA;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC;AAC3C,IAAA;AACJ;AAEA,MAAM,MAAM,GAAG;IACZ,MAAM;IACN;"}
|
package/include/lib/base64.mjs
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
2
|
* Encodes a Uint8Array to Base64 (for browser or Node.js).
|
|
3
3
|
* @param data - The Uint8Array data to encode.
|
|
4
4
|
* @returns The Base64-encoded string.
|
|
5
5
|
*/
|
|
6
6
|
function encode(data) {
|
|
7
|
-
|
|
7
|
+
let base64 = "";
|
|
8
8
|
if (typeof window !== "undefined") {
|
|
9
|
-
base64 = btoa(String.fromCharCode
|
|
9
|
+
base64 = btoa(String.fromCharCode(...Array.from(data)));
|
|
10
10
|
}
|
|
11
11
|
else {
|
|
12
12
|
base64 = Buffer.from(data).toString("base64");
|
|
13
13
|
}
|
|
14
|
-
|
|
14
|
+
let paddingCount = (base64.match(/=+$/) || [''])[0].length;
|
|
15
15
|
if (paddingCount > 0) {
|
|
16
|
-
base64 = base64.replace(/=+$/,
|
|
16
|
+
base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
|
|
17
17
|
}
|
|
18
18
|
return base64;
|
|
19
19
|
}
|
|
@@ -24,11 +24,11 @@ function encode(data) {
|
|
|
24
24
|
*/
|
|
25
25
|
function decode(base64) {
|
|
26
26
|
try {
|
|
27
|
-
base64 = base64.replace(/\$(\d)/,
|
|
27
|
+
base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
|
|
28
28
|
if (typeof window !== "undefined") {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
for (
|
|
29
|
+
const binaryString = atob(base64);
|
|
30
|
+
const byteArray = new Uint8Array(binaryString.length);
|
|
31
|
+
for (let i = 0; i < binaryString.length; i++) {
|
|
32
32
|
byteArray[i] = binaryString.charCodeAt(i);
|
|
33
33
|
}
|
|
34
34
|
return byteArray;
|
|
@@ -41,7 +41,7 @@ function decode(base64) {
|
|
|
41
41
|
throw new Error("Invalid Base64 string.");
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
|
-
|
|
45
|
-
encode
|
|
46
|
-
decode
|
|
44
|
+
const base64 = {
|
|
45
|
+
encode,
|
|
46
|
+
decode
|
|
47
47
|
};export{base64 as default};//# sourceMappingURL=base64.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base64.mjs","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\n * @param data - The Uint8Array data to encode.\n * @returns The Base64-encoded string.\n */\nfunction encode(data: Uint8Array): string {\n let base64 = \"\";\n if (typeof window !== \"undefined\") {\n base64 = btoa(String.fromCharCode(...Array.from(data)));\n } else {\n base64 = Buffer.from(data).toString(\"base64\");\n }\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\n if (paddingCount > 0) {\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\n }\n return base64\n}\n\n/**\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\n * @param base64String - The Base64 string to decode.\n * @returns The decoded Uint8Array.\n */\nfunction decode(base64: string): Uint8Array {\n try {\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\n if (typeof window !== \"undefined\") {\n const binaryString = atob(base64);\n const byteArray = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n byteArray[i] = binaryString.charCodeAt(i);\n }\n return byteArray;\n } else {\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\n }\n } catch (error) {\n throw new Error(\"Invalid Base64 string.\");\n }\n}\n\nconst base64 = {\n encode,\n decode\n}\n\nexport default base64;"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"base64.mjs","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\n * @param data - The Uint8Array data to encode.\n * @returns The Base64-encoded string.\n */\nfunction encode(data: Uint8Array): string {\n let base64 = \"\";\n if (typeof window !== \"undefined\") {\n base64 = btoa(String.fromCharCode(...Array.from(data)));\n } else {\n base64 = Buffer.from(data).toString(\"base64\");\n }\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\n if (paddingCount > 0) {\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\n }\n return base64\n}\n\n/**\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\n * @param base64String - The Base64 string to decode.\n * @returns The decoded Uint8Array.\n */\nfunction decode(base64: string): Uint8Array {\n try {\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\n if (typeof window !== \"undefined\") {\n const binaryString = atob(base64);\n const byteArray = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n byteArray[i] = binaryString.charCodeAt(i);\n }\n return byteArray;\n } else {\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\n }\n } catch (error) {\n throw new Error(\"Invalid Base64 string.\");\n }\n}\n\nconst base64 = {\n encode,\n decode\n}\n\nexport default base64;"],"names":[],"mappings":"AAAA;;;;AAIG;AACH,SAAS,MAAM,CAAC,IAAgB,EAAA;IAC7B,IAAI,MAAM,GAAG,EAAE;AACf,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AACzD,IAAA;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;AAC/C,IAAA;AACD,IAAA,IAAI,YAAY,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM;IAC1D,IAAI,YAAY,GAAG,CAAC,EAAE;AACnB,QAAA,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,CAAC;AAC1D,IAAA;AACD,IAAA,OAAO,MAAM;AAChB;AAEA;;;;AAIG;AACH,SAAS,MAAM,CAAC,MAAc,EAAA;IAC3B,IAAI;QACD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,KAAK,KAAK,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AACjF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;YACjC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC;AACrD,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC3C,SAAS,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC;AAC3C,YAAA;AACD,YAAA,OAAO,SAAS;AAClB,QAAA;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACvD,QAAA;AACH,IAAA;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC;AAC3C,IAAA;AACJ;AAEA,MAAM,MAAM,GAAG;IACZ,MAAM;IACN;"}
|
package/include/lib/cache.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
1
|
+
'use strict';class SecurequCache {
|
|
2
|
+
constructor(config) {
|
|
3
3
|
this.store = new Map();
|
|
4
4
|
this.defaultTTL = config.ttl;
|
|
5
5
|
this.limit = config.limit;
|
|
@@ -9,11 +9,10 @@
|
|
|
9
9
|
* @param key - Cache key
|
|
10
10
|
* @param value - Cache value
|
|
11
11
|
*/
|
|
12
|
-
|
|
13
|
-
var _this = this;
|
|
12
|
+
set(key, value) {
|
|
14
13
|
// If the cache exceeds the limit, remove the oldest (least recently used) item
|
|
15
14
|
if (this.store.size >= this.limit) {
|
|
16
|
-
|
|
15
|
+
const firstKey = this.store.keys().next().value;
|
|
17
16
|
this.store.delete(firstKey);
|
|
18
17
|
}
|
|
19
18
|
// If the key already exists, remove the old timeout
|
|
@@ -21,19 +20,19 @@
|
|
|
21
20
|
clearTimeout(this.store.get(key).timeout);
|
|
22
21
|
}
|
|
23
22
|
// Set the new expiration timeout
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
const timeout = setTimeout(() => {
|
|
24
|
+
this.store.delete(key); // Delete expired cache entry
|
|
26
25
|
}, this.defaultTTL);
|
|
27
26
|
// Store the value and its expiration info
|
|
28
|
-
this.store.set(key, { value
|
|
29
|
-
}
|
|
27
|
+
this.store.set(key, { value, timeout, expiresAt: Date.now() + this.defaultTTL });
|
|
28
|
+
}
|
|
30
29
|
/**
|
|
31
30
|
* Get a value from the cache and auto-renew the TTL if not expired
|
|
32
31
|
* @param key - Cache key
|
|
33
32
|
* @returns The cached value or null if expired
|
|
34
33
|
*/
|
|
35
|
-
|
|
36
|
-
|
|
34
|
+
get(key) {
|
|
35
|
+
const entry = this.store.get(key);
|
|
37
36
|
if (!entry) {
|
|
38
37
|
return null; // No data found in cache
|
|
39
38
|
}
|
|
@@ -44,31 +43,30 @@
|
|
|
44
43
|
}
|
|
45
44
|
this.set(key, entry.value);
|
|
46
45
|
return entry.value;
|
|
47
|
-
}
|
|
46
|
+
}
|
|
48
47
|
/**
|
|
49
48
|
* Delete a key from the cache
|
|
50
49
|
* @param key - Cache key
|
|
51
50
|
*/
|
|
52
|
-
|
|
53
|
-
|
|
51
|
+
delete(key) {
|
|
52
|
+
const entry = this.store.get(key);
|
|
54
53
|
if (entry) {
|
|
55
54
|
clearTimeout(entry.timeout); // Clear the timeout
|
|
56
55
|
this.store.delete(key); // Delete from cache
|
|
57
56
|
}
|
|
58
|
-
}
|
|
57
|
+
}
|
|
59
58
|
/**
|
|
60
59
|
* Clear the entire cache
|
|
61
60
|
*/
|
|
62
|
-
|
|
63
|
-
this.store.forEach(
|
|
61
|
+
clear() {
|
|
62
|
+
this.store.forEach((entry) => clearTimeout(entry.timeout)); // Clear all timeouts
|
|
64
63
|
this.store.clear(); // Clear the store
|
|
65
|
-
}
|
|
64
|
+
}
|
|
66
65
|
/**
|
|
67
66
|
* Get the current size of the cache
|
|
68
67
|
* @returns The number of items in the cache
|
|
69
68
|
*/
|
|
70
|
-
|
|
69
|
+
size() {
|
|
71
70
|
return this.store.size;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
}());module.exports=SecurequCache;//# sourceMappingURL=cache.js.map
|
|
71
|
+
}
|
|
72
|
+
}module.exports=SecurequCache;//# sourceMappingURL=cache.js.map
|