securequ 1.0.11 → 1.0.13

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 +146 -146
  3. package/client/index.js.map +1 -1
  4. package/client/index.mjs +146 -146
  5. package/client/index.mjs.map +1 -1
  6. package/client/types.d.ts +17 -0
  7. package/include/lib/base64.js +47 -47
  8. package/include/lib/base64.js.map +1 -1
  9. package/include/lib/base64.mjs +46 -46
  10. package/include/lib/base64.mjs.map +1 -1
  11. package/include/lib/cache.js +72 -72
  12. package/include/lib/cache.js.map +1 -1
  13. package/include/lib/cache.mjs +71 -71
  14. package/include/lib/cache.mjs.map +1 -1
  15. package/include/lib/crypto.js +69 -69
  16. package/include/lib/crypto.js.map +1 -1
  17. package/include/lib/crypto.mjs +68 -68
  18. package/include/lib/crypto.mjs.map +1 -1
  19. package/include/lib/pako.js +27 -27
  20. package/include/lib/pako.js.map +1 -1
  21. package/include/lib/pako.mjs +27 -27
  22. package/include/lib/pako.mjs.map +1 -1
  23. package/include/lib/reverser.js +25 -25
  24. package/include/lib/reverser.js.map +1 -1
  25. package/include/lib/reverser.mjs +24 -24
  26. package/include/lib/reverser.mjs.map +1 -1
  27. package/include/lib/urlpath.js +10 -10
  28. package/include/lib/urlpath.js.map +1 -1
  29. package/include/lib/urlpath.mjs +9 -9
  30. package/include/lib/urlpath.mjs.map +1 -1
  31. package/include/responseValue.js +10 -10
  32. package/include/responseValue.js.map +1 -1
  33. package/include/responseValue.mjs +9 -9
  34. package/include/responseValue.mjs.map +1 -1
  35. package/include/signeture.js +20 -20
  36. package/include/signeture.js.map +1 -1
  37. package/include/signeture.mjs +19 -19
  38. package/include/signeture.mjs.map +1 -1
  39. package/index.d.ts +2 -81
  40. package/package.json +5 -10
  41. package/server/index.d.ts +18 -0
  42. package/server/index.js +115 -115
  43. package/server/index.js.map +1 -1
  44. package/server/index.mjs +115 -115
  45. package/server/index.mjs.map +1 -1
  46. package/server/types.d.ts +28 -0
package/client/index.mjs CHANGED
@@ -1,147 +1,147 @@
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
- this.token = '';
4
- this.tokenLoading = false;
5
- this.Cache = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
6
- this.reqkey = '';
7
- this.PATH_CACHE = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
8
- this.config = Object.assign({}, config);
9
- const secret = crypto.makeSecret(config.secret);
10
- this.config.secret = secret;
11
- this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);
12
- this.secret = crypto.makeSecret(secret.substring(0, this.secret_length));
13
- this.signerure = signeture.make(this.secret, this.secret);
14
- }
15
- setCache(path, method, response) {
16
- const cacheKey = `${method}:${path}`;
17
- if (this.config.cache === true) {
18
- this.Cache.set(cacheKey, response);
19
- }
20
- else if (this.config.cache) {
21
- this.config.cache.set(cacheKey, response);
22
- }
23
- }
24
- getCache(path, method) {
25
- const cacheKey = `${method}:${path}`;
26
- if (this.config.cache === true) {
27
- return this.Cache.get(cacheKey);
28
- }
29
- else if (this.config.cache) {
30
- return this.config.cache.get(cacheKey);
31
- }
32
- }
33
- path(path) {
34
- let pathKey = path;
35
- let has = this.PATH_CACHE.get(pathKey);
36
- if (!has) {
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
- if (Object.keys(paramsObject).length) {
43
- for (let key in paramsObject) {
44
- paramsObject[urlpath.encrypt(key)] = paramsObject[key];
45
- delete paramsObject[key];
46
- }
47
- const string = JSON.stringify(paramsObject);
48
- const text = encodeURIComponent(crypto.encrypt(string, this.token));
49
- path += `?${this.reqkey}=${text}`;
50
- }
51
- this.PATH_CACHE.set(pathKey, path);
52
- }
53
- else {
54
- path = has;
55
- }
56
- return path;
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 }),
63
- });
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);
82
- });
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;
103
- }
104
- else {
105
- _data[ukey] = info.body[key];
106
- }
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';
113
- }
114
- }
115
- else {
116
- if (info.method === "GET") {
117
- info.method = "POST";
118
- }
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
- }
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
+ this.token = '';
4
+ this.tokenLoading = false;
5
+ this.Cache = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
6
+ this.reqkey = '';
7
+ this.PATH_CACHE = new SecurequCache({ ttl: 1000 * 60 * 60, limit: 100 });
8
+ this.config = Object.assign({}, config);
9
+ const secret = crypto.makeSecret(config.secret);
10
+ this.config.secret = secret;
11
+ this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);
12
+ this.secret = crypto.makeSecret(secret.substring(0, this.secret_length));
13
+ this.signerure = signeture.make(this.secret, this.secret);
14
+ }
15
+ setCache(path, method, response) {
16
+ const cacheKey = `${method}:${path}`;
17
+ if (this.config.cache === true) {
18
+ this.Cache.set(cacheKey, response);
19
+ }
20
+ else if (this.config.cache) {
21
+ this.config.cache.set(cacheKey, response);
22
+ }
23
+ }
24
+ getCache(path, method) {
25
+ const cacheKey = `${method}:${path}`;
26
+ if (this.config.cache === true) {
27
+ return this.Cache.get(cacheKey);
28
+ }
29
+ else if (this.config.cache) {
30
+ return this.config.cache.get(cacheKey);
31
+ }
32
+ }
33
+ path(path) {
34
+ let pathKey = path;
35
+ let has = this.PATH_CACHE.get(pathKey);
36
+ if (!has) {
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
+ if (Object.keys(paramsObject).length) {
43
+ for (let key in paramsObject) {
44
+ paramsObject[urlpath.encrypt(key)] = paramsObject[key];
45
+ delete paramsObject[key];
46
+ }
47
+ const string = JSON.stringify(paramsObject);
48
+ const text = encodeURIComponent(crypto.encrypt(string, this.token));
49
+ path += `?${this.reqkey}=${text}`;
50
+ }
51
+ this.PATH_CACHE.set(pathKey, path);
52
+ }
53
+ else {
54
+ path = has;
55
+ }
56
+ return path;
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 }),
63
+ });
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);
82
+ });
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;
103
+ }
104
+ else {
105
+ _data[ukey] = info.body[key];
106
+ }
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';
113
+ }
114
+ }
115
+ else {
116
+ if (info.method === "GET") {
117
+ info.method = "POST";
118
+ }
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
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\";\r\nimport signeture from \"../include/signeture\";\r\nimport urlpath from \"../include/lib/urlpath\";\r\nimport { HttpRequestInit, RequestBody, SecurequClientConfig } from \"./types\";\r\nimport xanFetch from 'xanfetch'\r\nimport responseValue from \"../include/responseValue\";\r\nimport SecurequCache from \"../include/lib/cache\";\r\n\r\nexport class SecurequClient {\r\n private config: SecurequClientConfig;\r\n private token: string = '';\r\n private tokenLoading: boolean = false;\r\n private Cache = new SecurequCache<Response>({ ttl: 1000 * 60 * 60, limit: 100 });\r\n\r\n private secret: string;\r\n private secret_length: number;\r\n private signerure: string;\r\n private reqkey: string = '';\r\n\r\n constructor(config: SecurequClientConfig) {\r\n this.config = { ...config }\r\n const secret = crypto.makeSecret(config.secret)\r\n this.config.secret = secret;\r\n this.secret_length = secret.length - (Math.floor(Math.random() * 11) + 5);\r\n this.secret = crypto.makeSecret(secret.substring(0, this.secret_length))\r\n this.signerure = signeture.make(this.secret, this.secret);\r\n }\r\n\r\n private setCache(path: string, method: string, response: any) {\r\n const cacheKey = `${method}:${path}`;\r\n if (this.config.cache === true) {\r\n this.Cache.set(cacheKey, response);\r\n } else if (this.config.cache) {\r\n this.config.cache.set(cacheKey, response);\r\n }\r\n }\r\n\r\n private getCache(path: string, method: string,) {\r\n const cacheKey = `${method}:${path}`;\r\n if (this.config.cache === true) {\r\n return this.Cache.get(cacheKey);\r\n } else if (this.config.cache) {\r\n return this.config.cache.get(cacheKey);\r\n }\r\n }\r\n\r\n private PATH_CACHE = new SecurequCache<string>({ ttl: 1000 * 60 * 60, limit: 100 });\r\n private path(path: string) {\r\n let pathKey = path\r\n let has = this.PATH_CACHE.get(pathKey)\r\n if (!has) {\r\n const { search, pathname } = new URL(path, window.location.origin);\r\n const params = new URLSearchParams(search);\r\n const paramsObject = Object.fromEntries(params.entries());\r\n let split = pathname.split(\"/\").map((s) => urlpath.encrypt(s)).filter((s) => s.length > 0);\r\n path = `${this.config.path}/${split.join(\"/\")}`;\r\n if (Object.keys(paramsObject).length) {\r\n for (let key in paramsObject) {\r\n paramsObject[urlpath.encrypt(key)] = paramsObject[key]\r\n delete paramsObject[key]\r\n }\r\n const string = JSON.stringify(paramsObject)\r\n const text = encodeURIComponent(crypto.encrypt(string, this.token));\r\n path += `?${this.reqkey}=${text}`;\r\n }\r\n this.PATH_CACHE.set(pathKey, path);\r\n } else {\r\n path = has\r\n }\r\n return path\r\n }\r\n\r\n private async handshake() {\r\n this.tokenLoading = true;\r\n const res = await xanFetch(this.path(`/handshake`), {\r\n method: \"GET\",\r\n headers: {\r\n ...this.config.headers,\r\n [signeture.key]: this.signerure\r\n },\r\n })\r\n\r\n const value: any = responseValue.decrypt(await res.text(), this.signerure)\r\n const token = crypto.decrypt(value, this.secret)\r\n this.token = token;\r\n this.reqkey = token.substring(0, token.length / 2);\r\n this.tokenLoading = false;\r\n }\r\n\r\n async send(path: string, init?: HttpRequestInit): Promise<Response> {\r\n if (path === '/handshake') {\r\n throw new Error(\"Path is not allowed\")\r\n }\r\n if (this.tokenLoading) {\r\n await new Promise((resolve) => {\r\n const interval = setInterval(() => {\r\n if (!this.tokenLoading) {\r\n clearInterval(interval);\r\n resolve(null);\r\n }\r\n }, 100);\r\n })\r\n }\r\n\r\n if (!this.token) {\r\n await this.handshake();\r\n }\r\n\r\n const info: any = {\r\n method: \"GET\",\r\n ...init,\r\n headers: {\r\n ...this.config.headers,\r\n ...init?.headers,\r\n [signeture.key]: this.signerure\r\n },\r\n }\r\n\r\n const cache_res = this.getCache(path, info.method);\r\n if (cache_res) {\r\n return cache_res.clone();\r\n }\r\n\r\n if (info.body) {\r\n if (!this.token) throw new Error(\"Token not loaded\")\r\n const body = new FormData();\r\n let _data: any = {}\r\n let hasFile = false;\r\n for (let key in info.body) {\r\n let ukey = urlpath.encrypt(key);\r\n if (info.body[key] instanceof File) {\r\n body.append(ukey, info.body[key]);\r\n hasFile = true;\r\n } else {\r\n _data[ukey] = info.body[key];\r\n }\r\n }\r\n\r\n body.append(this.reqkey, crypto.encrypt(_data, this.token));\r\n\r\n if (!hasFile) {\r\n info.body = new URLSearchParams(body as any);\r\n if (!info.headers['Content-Type']) {\r\n info.headers['Content-Type'] = 'application/x-www-form-urlencoded';\r\n }\r\n } else {\r\n if (info.method === \"GET\") {\r\n info.method = \"POST\"\r\n }\r\n info.body = body\r\n if (!info.headers['Content-Type']) {\r\n info.headers['Content-Type'] = 'multipart/form-data';\r\n }\r\n }\r\n }\r\n\r\n const response = await xanFetch(this.path(path), info);\r\n const res = response.clone();\r\n const text = await response.text();\r\n const value: any = responseValue.decrypt(text, this.signerure)\r\n res.text = async () => value;\r\n if (this.config.cache === true && res.ok) {\r\n this.setCache(path, info.method, res.clone());\r\n }\r\n return res\r\n }\r\n\r\n async get(path: string, init?: HttpRequestInit) {\r\n return await this.send(path, init);\r\n }\r\n\r\n async post(path: string, body: RequestBody, init?: HttpRequestInit) {\r\n return await this.send(path, {\r\n ...init,\r\n method: \"POST\",\r\n body: body\r\n });\r\n }\r\n\r\n async put(path: string, body: RequestBody, init?: HttpRequestInit) {\r\n return await this.send(path, {\r\n ...init,\r\n method: \"PUT\",\r\n body: body\r\n });\r\n }\r\n\r\n async delete(path: string, init?: HttpRequestInit) {\r\n return await this.send(path, {\r\n ...init,\r\n method: \"DELETE\",\r\n });\r\n }\r\n}\r\n\r\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,47 +1,47 @@
1
- 'use strict';/**
2
- * Encodes a Uint8Array to Base64 (for browser or Node.js).
3
- * @param data - The Uint8Array data to encode.
4
- * @returns The Base64-encoded string.
5
- */
6
- function encode(data) {
7
- let base64 = "";
8
- if (typeof window !== "undefined") {
9
- base64 = btoa(String.fromCharCode(...Array.from(data)));
10
- }
11
- else {
12
- base64 = Buffer.from(data).toString("base64");
13
- }
14
- let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
- if (paddingCount > 0) {
16
- base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
17
- }
18
- return base64;
19
- }
20
- /**
21
- * Decodes a Base64 string to a Uint8Array (for browser or Node.js).
22
- * @param base64String - The Base64 string to decode.
23
- * @returns The decoded Uint8Array.
24
- */
25
- function decode(base64) {
26
- try {
27
- base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
- if (typeof window !== "undefined") {
29
- const binaryString = atob(base64);
30
- const byteArray = new Uint8Array(binaryString.length);
31
- for (let i = 0; i < binaryString.length; i++) {
32
- byteArray[i] = binaryString.charCodeAt(i);
33
- }
34
- return byteArray;
35
- }
36
- else {
37
- return Uint8Array.from(Buffer.from(base64, "base64"));
38
- }
39
- }
40
- catch (error) {
41
- throw new Error("Invalid Base64 string.");
42
- }
43
- }
44
- const base64 = {
45
- encode,
46
- decode
47
- };module.exports=base64;//# sourceMappingURL=base64.js.map
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});/**
2
+ * Encodes a Uint8Array to Base64 (for browser or Node.js).
3
+ * @param data - The Uint8Array data to encode.
4
+ * @returns The Base64-encoded string.
5
+ */
6
+ function encode(data) {
7
+ let base64 = "";
8
+ if (typeof window !== "undefined") {
9
+ base64 = btoa(String.fromCharCode(...Array.from(data)));
10
+ }
11
+ else {
12
+ base64 = Buffer.from(data).toString("base64");
13
+ }
14
+ let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
+ if (paddingCount > 0) {
16
+ base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
17
+ }
18
+ return base64;
19
+ }
20
+ /**
21
+ * Decodes a Base64 string to a Uint8Array (for browser or Node.js).
22
+ * @param base64String - The Base64 string to decode.
23
+ * @returns The decoded Uint8Array.
24
+ */
25
+ function decode(base64) {
26
+ try {
27
+ base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
+ if (typeof window !== "undefined") {
29
+ const binaryString = atob(base64);
30
+ const byteArray = new Uint8Array(binaryString.length);
31
+ for (let i = 0; i < binaryString.length; i++) {
32
+ byteArray[i] = binaryString.charCodeAt(i);
33
+ }
34
+ return byteArray;
35
+ }
36
+ else {
37
+ return Uint8Array.from(Buffer.from(base64, "base64"));
38
+ }
39
+ }
40
+ catch (error) {
41
+ throw new Error("Invalid Base64 string.");
42
+ }
43
+ }
44
+ const base64 = {
45
+ encode,
46
+ decode
47
+ };exports.default=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":[],"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;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,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,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,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;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,MAAM,MAAM,GAAG;IACZ,MAAM;IACN;"}
1
+ {"version":3,"file":"base64.js","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\r\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\r\n * @param data - The Uint8Array data to encode.\r\n * @returns The Base64-encoded string.\r\n */\r\nfunction encode(data: Uint8Array): string {\r\n let base64 = \"\";\r\n if (typeof window !== \"undefined\") {\r\n base64 = btoa(String.fromCharCode(...Array.from(data)));\r\n } else {\r\n base64 = Buffer.from(data).toString(\"base64\");\r\n }\r\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\r\n if (paddingCount > 0) {\r\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\r\n }\r\n return base64\r\n}\r\n\r\n/**\r\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\r\n * @param base64String - The Base64 string to decode.\r\n * @returns The decoded Uint8Array.\r\n */\r\nfunction decode(base64: string): Uint8Array {\r\n try {\r\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\r\n if (typeof window !== \"undefined\") {\r\n const binaryString = atob(base64);\r\n const byteArray = new Uint8Array(binaryString.length);\r\n for (let i = 0; i < binaryString.length; i++) {\r\n byteArray[i] = binaryString.charCodeAt(i);\r\n }\r\n return byteArray;\r\n } else {\r\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\r\n }\r\n } catch (error) {\r\n throw new Error(\"Invalid Base64 string.\");\r\n }\r\n}\r\n\r\nconst base64 = {\r\n encode,\r\n decode\r\n}\r\n\r\nexport default base64;"],"names":[],"mappings":"sEAAA;;;;AAIG;AACH,SAAS,MAAM,CAAC,IAAgB,EAAA;IAC7B,IAAI,MAAM,GAAG,EAAE,CAAC;AAChB,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,CAAC;AAC1D,IAAA,CAAA;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAChD,IAAA,CAAA;AACD,IAAA,IAAI,YAAY,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAC3D,IAAI,YAAY,GAAG,CAAC,EAAE;AACnB,QAAA,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,CAAC,CAAC;AAC3D,IAAA,CAAA;AACD,IAAA,OAAO,MAAM,CAAA;AAChB,CAAC;AAED;;;;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,CAAC;AAClF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;AACtD,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,CAAC;AAC5C,YAAA,CAAA;AACD,YAAA,OAAO,SAAS,CAAC;AACnB,QAAA,CAAA;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;AACxD,QAAA,CAAA;AACH,IAAA,CAAA;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;AAC5C,IAAA,CAAA;AACJ,CAAC;AAED,MAAM,MAAM,GAAG;IACZ,MAAM;IACN,MAAM;"}
@@ -1,47 +1,47 @@
1
- /**
2
- * Encodes a Uint8Array to Base64 (for browser or Node.js).
3
- * @param data - The Uint8Array data to encode.
4
- * @returns The Base64-encoded string.
5
- */
6
- function encode(data) {
7
- let base64 = "";
8
- if (typeof window !== "undefined") {
9
- base64 = btoa(String.fromCharCode(...Array.from(data)));
10
- }
11
- else {
12
- base64 = Buffer.from(data).toString("base64");
13
- }
14
- let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
- if (paddingCount > 0) {
16
- base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
17
- }
18
- return base64;
19
- }
20
- /**
21
- * Decodes a Base64 string to a Uint8Array (for browser or Node.js).
22
- * @param base64String - The Base64 string to decode.
23
- * @returns The decoded Uint8Array.
24
- */
25
- function decode(base64) {
26
- try {
27
- base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
- if (typeof window !== "undefined") {
29
- const binaryString = atob(base64);
30
- const byteArray = new Uint8Array(binaryString.length);
31
- for (let i = 0; i < binaryString.length; i++) {
32
- byteArray[i] = binaryString.charCodeAt(i);
33
- }
34
- return byteArray;
35
- }
36
- else {
37
- return Uint8Array.from(Buffer.from(base64, "base64"));
38
- }
39
- }
40
- catch (error) {
41
- throw new Error("Invalid Base64 string.");
42
- }
43
- }
44
- const base64 = {
45
- encode,
46
- decode
1
+ /**
2
+ * Encodes a Uint8Array to Base64 (for browser or Node.js).
3
+ * @param data - The Uint8Array data to encode.
4
+ * @returns The Base64-encoded string.
5
+ */
6
+ function encode(data) {
7
+ let base64 = "";
8
+ if (typeof window !== "undefined") {
9
+ base64 = btoa(String.fromCharCode(...Array.from(data)));
10
+ }
11
+ else {
12
+ base64 = Buffer.from(data).toString("base64");
13
+ }
14
+ let paddingCount = (base64.match(/=+$/) || [''])[0].length;
15
+ if (paddingCount > 0) {
16
+ base64 = base64.replace(/=+$/, () => `$${paddingCount}`);
17
+ }
18
+ return base64;
19
+ }
20
+ /**
21
+ * Decodes a Base64 string to a Uint8Array (for browser or Node.js).
22
+ * @param base64String - The Base64 string to decode.
23
+ * @returns The decoded Uint8Array.
24
+ */
25
+ function decode(base64) {
26
+ try {
27
+ base64 = base64.replace(/\$(\d)/, (_match, count) => '='.repeat(parseInt(count)));
28
+ if (typeof window !== "undefined") {
29
+ const binaryString = atob(base64);
30
+ const byteArray = new Uint8Array(binaryString.length);
31
+ for (let i = 0; i < binaryString.length; i++) {
32
+ byteArray[i] = binaryString.charCodeAt(i);
33
+ }
34
+ return byteArray;
35
+ }
36
+ else {
37
+ return Uint8Array.from(Buffer.from(base64, "base64"));
38
+ }
39
+ }
40
+ catch (error) {
41
+ throw new Error("Invalid Base64 string.");
42
+ }
43
+ }
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":"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;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,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,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,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;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,MAAM,MAAM,GAAG;IACZ,MAAM;IACN;"}
1
+ {"version":3,"file":"base64.mjs","sources":["../../../src/include/lib/base64.ts"],"sourcesContent":["/**\r\n * Encodes a Uint8Array to Base64 (for browser or Node.js).\r\n * @param data - The Uint8Array data to encode.\r\n * @returns The Base64-encoded string.\r\n */\r\nfunction encode(data: Uint8Array): string {\r\n let base64 = \"\";\r\n if (typeof window !== \"undefined\") {\r\n base64 = btoa(String.fromCharCode(...Array.from(data)));\r\n } else {\r\n base64 = Buffer.from(data).toString(\"base64\");\r\n }\r\n let paddingCount = (base64.match(/=+$/) || [''])[0].length;\r\n if (paddingCount > 0) {\r\n base64 = base64.replace(/=+$/, () => `$${paddingCount}`);\r\n }\r\n return base64\r\n}\r\n\r\n/**\r\n * Decodes a Base64 string to a Uint8Array (for browser or Node.js).\r\n * @param base64String - The Base64 string to decode.\r\n * @returns The decoded Uint8Array.\r\n */\r\nfunction decode(base64: string): Uint8Array {\r\n try {\r\n base64 = base64.replace(/\\$(\\d)/, (_match, count) => '='.repeat(parseInt(count)));\r\n if (typeof window !== \"undefined\") {\r\n const binaryString = atob(base64);\r\n const byteArray = new Uint8Array(binaryString.length);\r\n for (let i = 0; i < binaryString.length; i++) {\r\n byteArray[i] = binaryString.charCodeAt(i);\r\n }\r\n return byteArray;\r\n } else {\r\n return Uint8Array.from(Buffer.from(base64, \"base64\"));\r\n }\r\n } catch (error) {\r\n throw new Error(\"Invalid Base64 string.\");\r\n }\r\n}\r\n\r\nconst base64 = {\r\n encode,\r\n decode\r\n}\r\n\r\nexport default base64;"],"names":[],"mappings":"AAAA;;;;AAIG;AACH,SAAS,MAAM,CAAC,IAAgB,EAAA;IAC7B,IAAI,MAAM,GAAG,EAAE,CAAC;AAChB,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,CAAC;AAC1D,IAAA,CAAA;AAAM,SAAA;AACJ,QAAA,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAChD,IAAA,CAAA;AACD,IAAA,IAAI,YAAY,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAC3D,IAAI,YAAY,GAAG,CAAC,EAAE;AACnB,QAAA,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAA,CAAA,EAAI,YAAY,CAAA,CAAE,CAAC,CAAC;AAC3D,IAAA,CAAA;AACD,IAAA,OAAO,MAAM,CAAA;AAChB,CAAC;AAED;;;;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,CAAC;AAClF,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;AACtD,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,CAAC;AAC5C,YAAA,CAAA;AACD,YAAA,OAAO,SAAS,CAAC;AACnB,QAAA,CAAA;AAAM,aAAA;AACJ,YAAA,OAAO,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;AACxD,QAAA,CAAA;AACH,IAAA,CAAA;AAAC,IAAA,OAAO,KAAK,EAAE;AACb,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;AAC5C,IAAA,CAAA;AACJ,CAAC;AAED,MAAM,MAAM,GAAG;IACZ,MAAM;IACN,MAAM;"}