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.
Files changed (46) hide show
  1. package/client/index.d.ts +25 -0
  2. package/client/index.js +107 -173
  3. package/client/index.js.map +1 -1
  4. package/client/index.mjs +107 -173
  5. package/client/index.mjs.map +1 -1
  6. package/client/types.d.ts +17 -0
  7. package/include/lib/base64.js +12 -12
  8. package/include/lib/base64.js.map +1 -1
  9. package/include/lib/base64.mjs +12 -12
  10. package/include/lib/base64.mjs.map +1 -1
  11. package/include/lib/cache.js +20 -22
  12. package/include/lib/cache.js.map +1 -1
  13. package/include/lib/cache.mjs +20 -22
  14. package/include/lib/cache.mjs.map +1 -1
  15. package/include/lib/crypto.js +23 -23
  16. package/include/lib/crypto.js.map +1 -1
  17. package/include/lib/crypto.mjs +23 -23
  18. package/include/lib/crypto.mjs.map +1 -1
  19. package/include/lib/pako.js +5 -5
  20. package/include/lib/pako.js.map +1 -1
  21. package/include/lib/pako.mjs +5 -5
  22. package/include/lib/pako.mjs.map +1 -1
  23. package/include/lib/reverser.js +11 -11
  24. package/include/lib/reverser.js.map +1 -1
  25. package/include/lib/reverser.mjs +11 -11
  26. package/include/lib/reverser.mjs.map +1 -1
  27. package/include/lib/urlpath.js +2 -2
  28. package/include/lib/urlpath.js.map +1 -1
  29. package/include/lib/urlpath.mjs +2 -2
  30. package/include/lib/urlpath.mjs.map +1 -1
  31. package/include/responseValue.js +4 -4
  32. package/include/responseValue.js.map +1 -1
  33. package/include/responseValue.mjs +4 -4
  34. package/include/responseValue.mjs.map +1 -1
  35. package/include/signeture.js +12 -12
  36. package/include/signeture.js.map +1 -1
  37. package/include/signeture.mjs +12 -12
  38. package/include/signeture.mjs.map +1 -1
  39. package/index.d.ts +2 -81
  40. package/package.json +6 -11
  41. package/server/index.d.ts +18 -0
  42. package/server/index.js +105 -176
  43. package/server/index.js.map +1 -1
  44. package/server/index.mjs +105 -176
  45. package/server/index.mjs.map +1 -1
  46. package/server/types.d.ts +28 -0
package/client/index.mjs CHANGED
@@ -1,52 +1,52 @@
1
- import {__awaiter,__assign,__generator}from'../node_modules/tslib/tslib.es6.mjs';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';var SecurequClient = /** @class */ (function () {
2
- function SecurequClient(config) {
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 = __assign({}, config);
9
- var secret = crypto.makeSecret(config.secret);
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
- SecurequClient.prototype.setCache = function (path, method, response) {
16
- var cacheKey = "".concat(method, ":").concat(path);
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
- SecurequClient.prototype.getCache = function (path, method) {
25
- var cacheKey = "".concat(method, ":").concat(path);
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
- SecurequClient.prototype.path = function (path) {
34
- var pathKey = path;
35
- var has = this.PATH_CACHE.get(pathKey);
32
+ }
33
+ path(path) {
34
+ let pathKey = path;
35
+ let has = this.PATH_CACHE.get(pathKey);
36
36
  if (!has) {
37
- var _a = new URL(path, window.location.origin), search = _a.search, pathname = _a.pathname;
38
- var params = new URLSearchParams(search);
39
- var paramsObject = Object.fromEntries(params.entries());
40
- var split = pathname.split("/").map(function (s) { return urlpath.encrypt(s); }).filter(function (s) { return s.length > 0; });
41
- path = "".concat(this.config.path, "/").concat(split.join("/"));
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 (var key in paramsObject) {
43
+ for (let key in paramsObject) {
44
44
  paramsObject[urlpath.encrypt(key)] = paramsObject[key];
45
45
  delete paramsObject[key];
46
46
  }
47
- var string = JSON.stringify(paramsObject);
48
- var text = encodeURIComponent(crypto.encrypt(string, this.token));
49
- path += "?".concat(this.reqkey, "=").concat(text);
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
- SecurequClient.prototype.handshake = function () {
59
- return __awaiter(this, void 0, void 0, function () {
60
- var res, value, _a, _b, token;
61
- var _c;
62
- return __generator(this, function (_d) {
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
- SecurequClient.prototype.send = function (path, init) {
86
- return __awaiter(this, void 0, void 0, function () {
87
- var info, cache_res, body, _data, hasFile, key, ukey, response, res, text, value;
88
- var _a;
89
- var _this = this;
90
- return __generator(this, function (_b) {
91
- switch (_b.label) {
92
- case 0:
93
- if (path === '/handshake') {
94
- throw new Error("Path is not allowed");
95
- }
96
- if (!this.tokenLoading) return [3 /*break*/, 2];
97
- return [4 /*yield*/, new Promise(function (resolve) {
98
- var interval = setInterval(function () {
99
- if (!_this.tokenLoading) {
100
- clearInterval(interval);
101
- resolve(null);
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
- SecurequClient.prototype.get = function (path, init) {
173
- return __awaiter(this, void 0, void 0, function () {
174
- return __generator(this, function (_a) {
175
- switch (_a.label) {
176
- case 0: return [4 /*yield*/, this.send(path, init)];
177
- case 1: return [2 /*return*/, _a.sent()];
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
- SecurequClient.prototype.put = function (path, body, init) {
193
- return __awaiter(this, void 0, void 0, function () {
194
- return __generator(this, function (_a) {
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
- SecurequClient.prototype.delete = function (path, init) {
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
- return SecurequClient;
213
- }());export{SecurequClient,SecurequClient as default};//# sourceMappingURL=index.mjs.map
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
@@ -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 };
@@ -1,19 +1,19 @@
1
- 'use strict';var tslib_es6=require('../../node_modules/tslib/tslib.es6.js');/**
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
- var base64 = "";
7
+ let base64 = "";
8
8
  if (typeof window !== "undefined") {
9
- base64 = btoa(String.fromCharCode.apply(String, tslib_es6.__spreadArray([], tslib_es6.__read(Array.from(data)), false)));
9
+ base64 = btoa(String.fromCharCode(...Array.from(data)));
10
10
  }
11
11
  else {
12
12
  base64 = Buffer.from(data).toString("base64");
13
13
  }
14
- var paddingCount = (base64.match(/=+$/) || [''])[0].length;
14
+ let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
15
  if (paddingCount > 0) {
16
- base64 = base64.replace(/=+$/, function () { return "$".concat(paddingCount); });
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)/, function (_match, count) { return '='.repeat(parseInt(count)); });
27
+ base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
28
  if (typeof window !== "undefined") {
29
- var binaryString = atob(base64);
30
- var byteArray = new Uint8Array(binaryString.length);
31
- for (var i = 0; i < binaryString.length; i++) {
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
- var base64 = {
45
- encode: encode,
46
- decode: 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":["__spreadArray","__read"],"mappings":"4EAAA;;;;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,CAAnB,KAAA,CAAA,MAAM,EAAiBA,uBAAA,CAAA,EAAA,EAAAC,gBAAA,CAAA,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAE;AACzD;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;AAC/C;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,YAAM,EAAA,OAAA,WAAI,YAAY,CAAE,CAAlB,EAAkB,CAAC;AAC1D;AACD,IAAA,OAAO,MAAM;AAChB;AAEA;;;;AAIG;AACH,SAAS,MAAM,CAAC,MAAc,EAAA;IAC3B,IAAI;QACD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,UAAC,MAAM,EAAE,KAAK,EAAA,EAAK,OAAA,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAA,EAAA,CAAC;AACjF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,IAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;YACjC,IAAM,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;AACD,YAAA,OAAO,SAAS;AAClB;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACvD;AACH;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC;AAC3C;AACJ;AAEA,IAAM,MAAM,GAAG;AACZ,IAAA,MAAM,EAAA,MAAA;AACN,IAAA,MAAM,EAAA;"}
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;"}
@@ -1,19 +1,19 @@
1
- import {__spreadArray,__read}from'../../node_modules/tslib/tslib.es6.mjs';/**
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
- var base64 = "";
7
+ let base64 = "";
8
8
  if (typeof window !== "undefined") {
9
- base64 = btoa(String.fromCharCode.apply(String, __spreadArray([], __read(Array.from(data)), false)));
9
+ base64 = btoa(String.fromCharCode(...Array.from(data)));
10
10
  }
11
11
  else {
12
12
  base64 = Buffer.from(data).toString("base64");
13
13
  }
14
- var paddingCount = (base64.match(/=+$/) || [''])[0].length;
14
+ let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
15
  if (paddingCount > 0) {
16
- base64 = base64.replace(/=+$/, function () { return "$".concat(paddingCount); });
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)/, function (_match, count) { return '='.repeat(parseInt(count)); });
27
+ base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
28
  if (typeof window !== "undefined") {
29
- var binaryString = atob(base64);
30
- var byteArray = new Uint8Array(binaryString.length);
31
- for (var i = 0; i < binaryString.length; i++) {
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
- var base64 = {
45
- encode: encode,
46
- decode: 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":"0EAAA;;;;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,CAAnB,KAAA,CAAA,MAAM,EAAiB,aAAA,CAAA,EAAA,EAAA,MAAA,CAAA,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAE;AACzD;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;AAC/C;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,YAAM,EAAA,OAAA,WAAI,YAAY,CAAE,CAAlB,EAAkB,CAAC;AAC1D;AACD,IAAA,OAAO,MAAM;AAChB;AAEA;;;;AAIG;AACH,SAAS,MAAM,CAAC,MAAc,EAAA;IAC3B,IAAI;QACD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,UAAC,MAAM,EAAE,KAAK,EAAA,EAAK,OAAA,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAA,EAAA,CAAC;AACjF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,IAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;YACjC,IAAM,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;AACD,YAAA,OAAO,SAAS;AAClB;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACvD;AACH;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC;AAC3C;AACJ;AAEA,IAAM,MAAM,GAAG;AACZ,IAAA,MAAM,EAAA,MAAA;AACN,IAAA,MAAM,EAAA;"}
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;"}
@@ -1,5 +1,5 @@
1
- 'use strict';var SecurequCache = /** @class */ (function () {
2
- function SecurequCache(config) {
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
- SecurequCache.prototype.set = function (key, value) {
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
- var firstKey = this.store.keys().next().value;
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
- var timeout = setTimeout(function () {
25
- _this.store.delete(key); // Delete expired cache entry
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: value, timeout: timeout, expiresAt: Date.now() + this.defaultTTL });
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
- SecurequCache.prototype.get = function (key) {
36
- var entry = this.store.get(key);
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
- SecurequCache.prototype.delete = function (key) {
53
- var entry = this.store.get(key);
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
- SecurequCache.prototype.clear = function () {
63
- this.store.forEach(function (entry) { return clearTimeout(entry.timeout); }); // Clear all timeouts
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
- SecurequCache.prototype.size = function () {
69
+ size() {
71
70
  return this.store.size;
72
- };
73
- return SecurequCache;
74
- }());module.exports=SecurequCache;//# sourceMappingURL=cache.js.map
71
+ }
72
+ }module.exports=SecurequCache;//# sourceMappingURL=cache.js.map