securequ 1.1.9 → 1.1.10
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/Base.d.ts +18 -18
- package/client/Base.js +146 -146
- package/client/Base.js.map +1 -1
- package/client/Base.mjs +146 -146
- package/client/Base.mjs.map +1 -1
- package/client/index.d.ts +8 -8
- package/client/index.js +138 -138
- package/client/index.js.map +1 -1
- package/client/index.mjs +138 -138
- package/client/index.mjs.map +1 -1
- package/client/types.d.ts +34 -34
- package/include/File.js +59 -59
- package/include/File.js.map +1 -1
- package/include/File.mjs +59 -59
- package/include/File.mjs.map +1 -1
- package/include/FileScaner.js +94 -94
- package/include/FileScaner.js.map +1 -1
- package/include/FileScaner.mjs +94 -94
- package/include/FileScaner.mjs.map +1 -1
- package/include/compress.d.ts +9 -9
- package/include/compress.js +18 -18
- package/include/compress.js.map +1 -1
- package/include/compress.mjs +18 -18
- package/include/compress.mjs.map +1 -1
- package/include/crypto.d.ts +15 -15
- package/include/crypto.js +54 -54
- package/include/crypto.js.map +1 -1
- package/include/crypto.mjs +54 -54
- package/include/crypto.mjs.map +1 -1
- package/package.json +1 -1
- package/readme.md +312 -312
- package/server/Base.d.ts +20 -20
- package/server/Base.js +105 -105
- package/server/Base.js.map +1 -1
- package/server/Base.mjs +105 -105
- package/server/Base.mjs.map +1 -1
- package/server/Router.d.ts +7 -7
- package/server/Router.js +29 -29
- package/server/Router.js.map +1 -1
- package/server/Router.mjs +29 -29
- package/server/Router.mjs.map +1 -1
- package/server/index.d.ts +5 -5
- package/server/index.js +187 -181
- package/server/index.js.map +1 -1
- package/server/index.mjs +187 -181
- package/server/index.mjs.map +1 -1
- package/server/types.d.ts +72 -72
package/client/Base.d.ts
CHANGED
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
import { SecurequClientConfig, HandshakeInfo, HttpRequestInit, SecurequClientResponse } from './types.js';
|
|
2
2
|
|
|
3
|
-
declare class Base {
|
|
4
|
-
protected config: SecurequClientConfig;
|
|
5
|
-
protected loadingHandshake: boolean;
|
|
6
|
-
protected secret_length: number;
|
|
7
|
-
protected handshakeInfo: HandshakeInfo | null;
|
|
8
|
-
readonly CONTENT_TYPE = "application/octet-stream";
|
|
9
|
-
constructor(config: SecurequClientConfig);
|
|
10
|
-
protected hooksCall(hook: keyof NonNullable<SecurequClientConfig['hooks']>, ...args: any[]): any;
|
|
11
|
-
protected getSecret(): Promise<{
|
|
12
|
-
full: string;
|
|
13
|
-
secret: string;
|
|
14
|
-
hash: string;
|
|
15
|
-
}>;
|
|
16
|
-
protected url(path: string): Promise<URL>;
|
|
17
|
-
protected getHeaders(path: string, init?: HttpRequestInit): Promise<any>;
|
|
18
|
-
protected awaitForHandshake(): Promise<void>;
|
|
19
|
-
handshake(): Promise<void>;
|
|
20
|
-
protected fetch(path: string, init?: HttpRequestInit): Promise<SecurequClientResponse>;
|
|
3
|
+
declare class Base {
|
|
4
|
+
protected config: SecurequClientConfig;
|
|
5
|
+
protected loadingHandshake: boolean;
|
|
6
|
+
protected secret_length: number;
|
|
7
|
+
protected handshakeInfo: HandshakeInfo | null;
|
|
8
|
+
readonly CONTENT_TYPE = "application/octet-stream";
|
|
9
|
+
constructor(config: SecurequClientConfig);
|
|
10
|
+
protected hooksCall(hook: keyof NonNullable<SecurequClientConfig['hooks']>, ...args: any[]): any;
|
|
11
|
+
protected getSecret(): Promise<{
|
|
12
|
+
full: string;
|
|
13
|
+
secret: string;
|
|
14
|
+
hash: string;
|
|
15
|
+
}>;
|
|
16
|
+
protected url(path: string): Promise<URL>;
|
|
17
|
+
protected getHeaders(path: string, init?: HttpRequestInit): Promise<any>;
|
|
18
|
+
protected awaitForHandshake(): Promise<void>;
|
|
19
|
+
handshake(): Promise<void>;
|
|
20
|
+
protected fetch(path: string, init?: HttpRequestInit): Promise<SecurequClientResponse>;
|
|
21
21
|
}
|
|
22
22
|
|
|
23
23
|
export { Base as default };
|
package/client/Base.js
CHANGED
|
@@ -1,147 +1,147 @@
|
|
|
1
|
-
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var crypto=require('../include/crypto.js'),xanFetch=require('xanfetch');const Clients = new Map();
|
|
2
|
-
class Base {
|
|
3
|
-
constructor(config) {
|
|
4
|
-
this.loadingHandshake = false;
|
|
5
|
-
this.secret_length = 0;
|
|
6
|
-
this.handshakeInfo = null;
|
|
7
|
-
this.CONTENT_TYPE = "application/octet-stream";
|
|
8
|
-
this.config = Object.assign({ defaultOptions: {} }, config);
|
|
9
|
-
const url = new URL(config.url);
|
|
10
|
-
if (url.search || url.hash)
|
|
11
|
-
throw new Error(`Invalid config url ${config.url}. Search params or Hash url is not supported in config.url`);
|
|
12
|
-
config.url = `${url.origin}${url.pathname}`;
|
|
13
|
-
if (Clients.has(config.url)) {
|
|
14
|
-
throw new Error(`Client is Blocked!`);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
hooksCall(hook, ...args) {
|
|
18
|
-
if (this.config.hooks && this.config.hooks[hook]) {
|
|
19
|
-
return this.config.hooks[hook](...args);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
async getSecret() {
|
|
23
|
-
let full = this.config.secret;
|
|
24
|
-
let secret = full.substring(0, this.secret_length);
|
|
25
|
-
let hash = (await crypto.default.hash(secret)).substring(0, this.secret_length);
|
|
26
|
-
return { full, secret, hash };
|
|
27
|
-
}
|
|
28
|
-
async url(path) {
|
|
29
|
-
const secret = await this.getSecret();
|
|
30
|
-
const base = this.config.url;
|
|
31
|
-
if (path === '/')
|
|
32
|
-
path = '';
|
|
33
|
-
path = path.trim();
|
|
34
|
-
path = path.startsWith('/') ? path.substring(1) : path;
|
|
35
|
-
path = path.endsWith('/') ? path.substring(0, path.length - 1) : path;
|
|
36
|
-
if (path)
|
|
37
|
-
path = `/${path}`;
|
|
38
|
-
return new URL(`${base}/${secret.hash}${path}`);
|
|
39
|
-
}
|
|
40
|
-
async getHeaders(path, init) {
|
|
41
|
-
var _a, _b, _c;
|
|
42
|
-
const url = await this.url(path);
|
|
43
|
-
const secret = await this.getSecret();
|
|
44
|
-
let headers = {};
|
|
45
|
-
if (this.handshakeInfo) {
|
|
46
|
-
headers["X-SIGNETURE"] = await crypto.default.encrypt({
|
|
47
|
-
signeture: (_a = this.handshakeInfo) === null || _a === void 0 ? void 0 : _a.signeture,
|
|
48
|
-
expire: Date.now() + this.handshakeInfo.timeDiffarenc + 10000 // 10 seconds
|
|
49
|
-
}, secret.secret) || '';
|
|
50
|
-
}
|
|
51
|
-
headers = Object.assign(Object.assign(Object.assign(Object.assign({}, (_c = (_b = this.config) === null || _b === void 0 ? void 0 : _b.defaultOptions) === null || _c === void 0 ? void 0 : _c.headers), init === null || init === void 0 ? void 0 : init.headers), headers), { 'Content-Type': this.CONTENT_TYPE, "X-ORIGIN": url.origin, "X-METHOD": ((init === null || init === void 0 ? void 0 : init.method) || 'GET').toUpperCase() });
|
|
52
|
-
return headers;
|
|
53
|
-
}
|
|
54
|
-
async awaitForHandshake() {
|
|
55
|
-
if (this.loadingHandshake) {
|
|
56
|
-
await new Promise((resolve) => {
|
|
57
|
-
const interval = setInterval(() => {
|
|
58
|
-
if (!this.loadingHandshake) {
|
|
59
|
-
clearInterval(interval);
|
|
60
|
-
resolve(null);
|
|
61
|
-
}
|
|
62
|
-
}, 100);
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
if (!this.handshakeInfo) {
|
|
66
|
-
await this.handshake();
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
async handshake() {
|
|
70
|
-
await this.hooksCall('beforeHandshake');
|
|
71
|
-
this.handshakeInfo = null;
|
|
72
|
-
this.loadingHandshake = true;
|
|
73
|
-
let max = this.config.secret.length;
|
|
74
|
-
let min = Math.floor(max / 4) * 3;
|
|
75
|
-
this.secret_length = Math.floor(Math.random() * (max - min + 1)) + min;
|
|
76
|
-
const secret = await this.getSecret();
|
|
77
|
-
const res = await this.fetch('/', {
|
|
78
|
-
method: 'POST',
|
|
79
|
-
body: {
|
|
80
|
-
hash: secret.hash,
|
|
81
|
-
clientTime: new Date().toISOString(),
|
|
82
|
-
secret: secret.secret,
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
this.handshakeInfo = res.data;
|
|
86
|
-
this.loadingHandshake = false;
|
|
87
|
-
await this.hooksCall('afterHandshake', this.handshakeInfo);
|
|
88
|
-
}
|
|
89
|
-
async fetch(path, init) {
|
|
90
|
-
var _a, _b;
|
|
91
|
-
const isDev = path !== '/' && ((_a = this.handshakeInfo) === null || _a === void 0 ? void 0 : _a.dev);
|
|
92
|
-
const secret = await this.getSecret();
|
|
93
|
-
const url = await this.url(path);
|
|
94
|
-
let sparams = Object.fromEntries(url.searchParams.entries());
|
|
95
|
-
const _init = Object.assign({}, init);
|
|
96
|
-
let params = Object.assign({}, sparams);
|
|
97
|
-
if (Object.keys(sparams).length > 0) {
|
|
98
|
-
for (let key in sparams) {
|
|
99
|
-
url.searchParams.delete(key);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
if (_init === null || _init === void 0 ? void 0 : _init.params) {
|
|
103
|
-
for (let key in _init.params) {
|
|
104
|
-
params[key] = _init.params[key];
|
|
105
|
-
}
|
|
106
|
-
delete _init.params;
|
|
107
|
-
}
|
|
108
|
-
if (Object.keys(params).length > 0) {
|
|
109
|
-
if (isDev) {
|
|
110
|
-
_init.params = params;
|
|
111
|
-
}
|
|
112
|
-
else {
|
|
113
|
-
const key = Math.random().toString(36).substring(2, 8);
|
|
114
|
-
const enc = await crypto.default.encrypt({ params, key }, secret.secret);
|
|
115
|
-
url.href = `${url.href}?${key}=${encodeURIComponent(enc)}`;
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
const httpOption = Object.assign(Object.assign(Object.assign({ method: "GET" }, (_b = this.config) === null || _b === void 0 ? void 0 : _b.defaultOptions), _init), { headers: await this.getHeaders(path, _init) });
|
|
119
|
-
if (httpOption === null || httpOption === void 0 ? void 0 : httpOption.body) {
|
|
120
|
-
if (isDev) {
|
|
121
|
-
httpOption.body = JSON.stringify(httpOption.body);
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
httpOption.body = await crypto.default.encryptBuffer(httpOption.body, secret.secret);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
const res = await xanFetch(url.href, httpOption);
|
|
128
|
-
if (isDev) {
|
|
129
|
-
const value = await res.text();
|
|
130
|
-
const val = JSON.parse(value);
|
|
131
|
-
return {
|
|
132
|
-
success: res.ok,
|
|
133
|
-
message: res.ok ? res.statusText : val,
|
|
134
|
-
data: res.ok ? val : null,
|
|
135
|
-
code: res.status
|
|
136
|
-
};
|
|
137
|
-
}
|
|
138
|
-
const value = await res.arrayBuffer();
|
|
139
|
-
const val = await crypto.default.decryptBuffer(new Uint8Array(value), secret.secret);
|
|
140
|
-
return {
|
|
141
|
-
success: res.ok,
|
|
142
|
-
message: res.ok ? res.statusText : (val || res.statusText),
|
|
143
|
-
data: res.ok ? val : null,
|
|
144
|
-
code: res.status
|
|
145
|
-
};
|
|
146
|
-
}
|
|
1
|
+
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var crypto=require('../include/crypto.js'),xanFetch=require('xanfetch');const Clients = new Map();
|
|
2
|
+
class Base {
|
|
3
|
+
constructor(config) {
|
|
4
|
+
this.loadingHandshake = false;
|
|
5
|
+
this.secret_length = 0;
|
|
6
|
+
this.handshakeInfo = null;
|
|
7
|
+
this.CONTENT_TYPE = "application/octet-stream";
|
|
8
|
+
this.config = Object.assign({ defaultOptions: {} }, config);
|
|
9
|
+
const url = new URL(config.url);
|
|
10
|
+
if (url.search || url.hash)
|
|
11
|
+
throw new Error(`Invalid config url ${config.url}. Search params or Hash url is not supported in config.url`);
|
|
12
|
+
config.url = `${url.origin}${url.pathname}`;
|
|
13
|
+
if (Clients.has(config.url)) {
|
|
14
|
+
throw new Error(`Client is Blocked!`);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
hooksCall(hook, ...args) {
|
|
18
|
+
if (this.config.hooks && this.config.hooks[hook]) {
|
|
19
|
+
return this.config.hooks[hook](...args);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async getSecret() {
|
|
23
|
+
let full = this.config.secret;
|
|
24
|
+
let secret = full.substring(0, this.secret_length);
|
|
25
|
+
let hash = (await crypto.default.hash(secret)).substring(0, this.secret_length);
|
|
26
|
+
return { full, secret, hash };
|
|
27
|
+
}
|
|
28
|
+
async url(path) {
|
|
29
|
+
const secret = await this.getSecret();
|
|
30
|
+
const base = this.config.url;
|
|
31
|
+
if (path === '/')
|
|
32
|
+
path = '';
|
|
33
|
+
path = path.trim();
|
|
34
|
+
path = path.startsWith('/') ? path.substring(1) : path;
|
|
35
|
+
path = path.endsWith('/') ? path.substring(0, path.length - 1) : path;
|
|
36
|
+
if (path)
|
|
37
|
+
path = `/${path}`;
|
|
38
|
+
return new URL(`${base}/${secret.hash}${path}`);
|
|
39
|
+
}
|
|
40
|
+
async getHeaders(path, init) {
|
|
41
|
+
var _a, _b, _c;
|
|
42
|
+
const url = await this.url(path);
|
|
43
|
+
const secret = await this.getSecret();
|
|
44
|
+
let headers = {};
|
|
45
|
+
if (this.handshakeInfo) {
|
|
46
|
+
headers["X-SIGNETURE"] = await crypto.default.encrypt({
|
|
47
|
+
signeture: (_a = this.handshakeInfo) === null || _a === void 0 ? void 0 : _a.signeture,
|
|
48
|
+
expire: Date.now() + this.handshakeInfo.timeDiffarenc + 10000 // 10 seconds
|
|
49
|
+
}, secret.secret) || '';
|
|
50
|
+
}
|
|
51
|
+
headers = Object.assign(Object.assign(Object.assign(Object.assign({}, (_c = (_b = this.config) === null || _b === void 0 ? void 0 : _b.defaultOptions) === null || _c === void 0 ? void 0 : _c.headers), init === null || init === void 0 ? void 0 : init.headers), headers), { 'Content-Type': this.CONTENT_TYPE, "X-ORIGIN": url.origin, "X-METHOD": ((init === null || init === void 0 ? void 0 : init.method) || 'GET').toUpperCase() });
|
|
52
|
+
return headers;
|
|
53
|
+
}
|
|
54
|
+
async awaitForHandshake() {
|
|
55
|
+
if (this.loadingHandshake) {
|
|
56
|
+
await new Promise((resolve) => {
|
|
57
|
+
const interval = setInterval(() => {
|
|
58
|
+
if (!this.loadingHandshake) {
|
|
59
|
+
clearInterval(interval);
|
|
60
|
+
resolve(null);
|
|
61
|
+
}
|
|
62
|
+
}, 100);
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
if (!this.handshakeInfo) {
|
|
66
|
+
await this.handshake();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async handshake() {
|
|
70
|
+
await this.hooksCall('beforeHandshake');
|
|
71
|
+
this.handshakeInfo = null;
|
|
72
|
+
this.loadingHandshake = true;
|
|
73
|
+
let max = this.config.secret.length;
|
|
74
|
+
let min = Math.floor(max / 4) * 3;
|
|
75
|
+
this.secret_length = Math.floor(Math.random() * (max - min + 1)) + min;
|
|
76
|
+
const secret = await this.getSecret();
|
|
77
|
+
const res = await this.fetch('/', {
|
|
78
|
+
method: 'POST',
|
|
79
|
+
body: {
|
|
80
|
+
hash: secret.hash,
|
|
81
|
+
clientTime: new Date().toISOString(),
|
|
82
|
+
secret: secret.secret,
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
this.handshakeInfo = res.data;
|
|
86
|
+
this.loadingHandshake = false;
|
|
87
|
+
await this.hooksCall('afterHandshake', this.handshakeInfo);
|
|
88
|
+
}
|
|
89
|
+
async fetch(path, init) {
|
|
90
|
+
var _a, _b;
|
|
91
|
+
const isDev = path !== '/' && ((_a = this.handshakeInfo) === null || _a === void 0 ? void 0 : _a.dev);
|
|
92
|
+
const secret = await this.getSecret();
|
|
93
|
+
const url = await this.url(path);
|
|
94
|
+
let sparams = Object.fromEntries(url.searchParams.entries());
|
|
95
|
+
const _init = Object.assign({}, init);
|
|
96
|
+
let params = Object.assign({}, sparams);
|
|
97
|
+
if (Object.keys(sparams).length > 0) {
|
|
98
|
+
for (let key in sparams) {
|
|
99
|
+
url.searchParams.delete(key);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
if (_init === null || _init === void 0 ? void 0 : _init.params) {
|
|
103
|
+
for (let key in _init.params) {
|
|
104
|
+
params[key] = _init.params[key];
|
|
105
|
+
}
|
|
106
|
+
delete _init.params;
|
|
107
|
+
}
|
|
108
|
+
if (Object.keys(params).length > 0) {
|
|
109
|
+
if (isDev) {
|
|
110
|
+
_init.params = params;
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
const key = Math.random().toString(36).substring(2, 8);
|
|
114
|
+
const enc = await crypto.default.encrypt({ params, key }, secret.secret);
|
|
115
|
+
url.href = `${url.href}?${key}=${encodeURIComponent(enc)}`;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
const httpOption = Object.assign(Object.assign(Object.assign({ method: "GET" }, (_b = this.config) === null || _b === void 0 ? void 0 : _b.defaultOptions), _init), { headers: await this.getHeaders(path, _init) });
|
|
119
|
+
if (httpOption === null || httpOption === void 0 ? void 0 : httpOption.body) {
|
|
120
|
+
if (isDev) {
|
|
121
|
+
httpOption.body = JSON.stringify(httpOption.body);
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
httpOption.body = await crypto.default.encryptBuffer(httpOption.body, secret.secret);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
const res = await xanFetch(url.href, httpOption);
|
|
128
|
+
if (isDev) {
|
|
129
|
+
const value = await res.text();
|
|
130
|
+
const val = JSON.parse(value);
|
|
131
|
+
return {
|
|
132
|
+
success: res.ok,
|
|
133
|
+
message: res.ok ? res.statusText : val,
|
|
134
|
+
data: res.ok ? val : null,
|
|
135
|
+
code: res.status
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
const value = await res.arrayBuffer();
|
|
139
|
+
const val = await crypto.default.decryptBuffer(new Uint8Array(value), secret.secret);
|
|
140
|
+
return {
|
|
141
|
+
success: res.ok,
|
|
142
|
+
message: res.ok ? res.statusText : (val || res.statusText),
|
|
143
|
+
data: res.ok ? val : null,
|
|
144
|
+
code: res.status
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
147
|
}exports.default=Base;//# sourceMappingURL=Base.js.map
|
package/client/Base.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Base.js","sources":["../../src/client/Base.ts"],"sourcesContent":["import crypto from \"../include/crypto\";\nimport { HandshakeInfo, HttpRequestInit, SecurequClientConfig, SecurequClientResponse } from \"./types\";\nimport xanFetch from 'xanfetch'\n\n\nconst Clients = new Map<string, Base>()\n\nclass Base {\n protected config: SecurequClientConfig;\n protected loadingHandshake: boolean = false;\n protected secret_length: number = 0;\n protected handshakeInfo: HandshakeInfo | null = null;\n readonly CONTENT_TYPE = \"application/octet-stream\";\n\n constructor(config: SecurequClientConfig) {\n this.config = {\n defaultOptions: {},\n ...config,\n }\n const url = new URL(config.url)\n if (url.search || url.hash) throw new Error(`Invalid config url ${config.url}. Search params or Hash url is not supported in config.url`)\n config.url = `${url.origin}${url.pathname}`\n\n if (Clients.has(config.url)) {\n throw new Error(`Client is Blocked!`);\n }\n }\n\n protected hooksCall(hook: keyof NonNullable<SecurequClientConfig['hooks']>, ...args: any[]) {\n if (this.config.hooks && this.config.hooks[hook]) {\n return (this.config.hooks[hook] as Function)(...args)\n }\n }\n\n protected async getSecret() {\n let full = this.config.secret\n let secret = full.substring(0, this.secret_length)\n let hash = (await crypto.hash(secret)).substring(0, this.secret_length)\n return { full, secret, hash }\n }\n\n protected async url(path: string) {\n const secret = await this.getSecret()\n const base = this.config.url;\n if (path === '/') path = ''\n path = path.trim();\n path = path.startsWith('/') ? path.substring(1) : path\n path = path.endsWith('/') ? path.substring(0, path.length - 1) : path\n if (path) path = `/${path}`\n return new URL(`${base}/${secret.hash}${path}`);\n }\n\n protected async getHeaders(path: string, init?: HttpRequestInit) {\n const url = await this.url(path)\n const secret = await this.getSecret()\n let headers: any = {};\n if (this.handshakeInfo) {\n headers[\"X-SIGNETURE\"] = await crypto.encrypt({\n signeture: this.handshakeInfo?.signeture,\n expire: Date.now() + this.handshakeInfo!.timeDiffarenc + 10000 // 10 seconds\n }, secret.secret) || '';\n }\n\n headers = {\n ...this.config?.defaultOptions?.headers,\n ...init?.headers,\n ...headers,\n 'Content-Type': this.CONTENT_TYPE,\n \"X-ORIGIN\": url.origin,\n \"X-METHOD\": (init?.method || 'GET').toUpperCase()\n }\n\n return headers;\n }\n\n protected async awaitForHandshake() {\n if (this.loadingHandshake) {\n await new Promise((resolve) => {\n const interval = setInterval(() => {\n if (!this.loadingHandshake) {\n clearInterval(interval);\n resolve(null);\n }\n }, 100);\n })\n }\n if (!this.handshakeInfo) {\n await this.handshake();\n }\n }\n\n async handshake() {\n await this.hooksCall('beforeHandshake');\n this.handshakeInfo = null;\n this.loadingHandshake = true;\n\n let max = this.config.secret.length\n let min = Math.floor(max / 4) * 3\n this.secret_length = Math.floor(Math.random() * (max - min + 1)) + min\n\n const secret = await this.getSecret()\n const res = await this.fetch('/', {\n method: 'POST',\n body: {\n hash: secret.hash,\n clientTime: new Date().toISOString(),\n secret: secret.secret,\n }\n })\n this.handshakeInfo = res.data\n this.loadingHandshake = false;\n await this.hooksCall('afterHandshake', this.handshakeInfo);\n }\n\n protected async fetch(path: string, init?: HttpRequestInit): Promise<SecurequClientResponse> {\n const isDev = path !== '/' && this.handshakeInfo?.dev\n const secret = await this.getSecret()\n const url = await this.url(path)\n let sparams = Object.fromEntries(url.searchParams.entries())\n const _init = { ...init }\n let params: any = {\n ...sparams,\n }\n\n if (Object.keys(sparams).length > 0) {\n for (let key in sparams) {\n url.searchParams.delete(key)\n }\n }\n\n if (_init?.params) {\n for (let key in _init.params) {\n params[key] = _init.params[key]\n }\n delete _init.params\n }\n\n if (Object.keys(params).length > 0) {\n if (isDev) {\n _init.params = params\n } else {\n const key = Math.random().toString(36).substring(2, 8);\n const enc = await crypto.encrypt({ params, key }, secret.secret)\n url.href = `${url.href}?${key}=${encodeURIComponent(enc)}`\n }\n }\n\n const httpOption: any = {\n method: \"GET\",\n ...this.config?.defaultOptions,\n ..._init,\n headers: await this.getHeaders(path, _init)\n }\n\n if (httpOption?.body) {\n if (isDev) {\n httpOption.body = JSON.stringify(httpOption.body)\n } else {\n httpOption.body = await crypto.encryptBuffer(httpOption.body, secret.secret);\n }\n }\n const res = await xanFetch(url.href, httpOption)\n if (isDev) {\n const value = await res.text()\n const val = JSON.parse(value)\n return {\n success: res.ok,\n message: res.ok ? res.statusText : val,\n data: res.ok ? val : null,\n code: res.status\n }\n }\n const value = await res.arrayBuffer()\n const val = await crypto.decryptBuffer(new Uint8Array(value), secret.secret) as any\n\n return {\n success: res.ok,\n message: res.ok ? res.statusText : (val || res.statusText),\n data: res.ok ? val : null,\n code: res.status\n }\n }\n\n}\n\nexport default Base;\n"],"names":["crypto"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Base.js","sources":["../../src/client/Base.ts"],"sourcesContent":["import crypto from \"../include/crypto\";\r\nimport { HandshakeInfo, HttpRequestInit, SecurequClientConfig, SecurequClientResponse } from \"./types\";\r\nimport xanFetch from 'xanfetch'\r\n\r\n\r\nconst Clients = new Map<string, Base>()\r\n\r\nclass Base {\r\n protected config: SecurequClientConfig;\r\n protected loadingHandshake: boolean = false;\r\n protected secret_length: number = 0;\r\n protected handshakeInfo: HandshakeInfo | null = null;\r\n readonly CONTENT_TYPE = \"application/octet-stream\";\r\n\r\n constructor(config: SecurequClientConfig) {\r\n this.config = {\r\n defaultOptions: {},\r\n ...config,\r\n }\r\n const url = new URL(config.url)\r\n if (url.search || url.hash) throw new Error(`Invalid config url ${config.url}. Search params or Hash url is not supported in config.url`)\r\n config.url = `${url.origin}${url.pathname}`\r\n\r\n if (Clients.has(config.url)) {\r\n throw new Error(`Client is Blocked!`);\r\n }\r\n }\r\n\r\n protected hooksCall(hook: keyof NonNullable<SecurequClientConfig['hooks']>, ...args: any[]) {\r\n if (this.config.hooks && this.config.hooks[hook]) {\r\n return (this.config.hooks[hook] as Function)(...args)\r\n }\r\n }\r\n\r\n protected async getSecret() {\r\n let full = this.config.secret\r\n let secret = full.substring(0, this.secret_length)\r\n let hash = (await crypto.hash(secret)).substring(0, this.secret_length)\r\n return { full, secret, hash }\r\n }\r\n\r\n protected async url(path: string) {\r\n const secret = await this.getSecret()\r\n const base = this.config.url;\r\n if (path === '/') path = ''\r\n path = path.trim();\r\n path = path.startsWith('/') ? path.substring(1) : path\r\n path = path.endsWith('/') ? path.substring(0, path.length - 1) : path\r\n if (path) path = `/${path}`\r\n return new URL(`${base}/${secret.hash}${path}`);\r\n }\r\n\r\n protected async getHeaders(path: string, init?: HttpRequestInit) {\r\n const url = await this.url(path)\r\n const secret = await this.getSecret()\r\n let headers: any = {};\r\n if (this.handshakeInfo) {\r\n headers[\"X-SIGNETURE\"] = await crypto.encrypt({\r\n signeture: this.handshakeInfo?.signeture,\r\n expire: Date.now() + this.handshakeInfo!.timeDiffarenc + 10000 // 10 seconds\r\n }, secret.secret) || '';\r\n }\r\n\r\n headers = {\r\n ...this.config?.defaultOptions?.headers,\r\n ...init?.headers,\r\n ...headers,\r\n 'Content-Type': this.CONTENT_TYPE,\r\n \"X-ORIGIN\": url.origin,\r\n \"X-METHOD\": (init?.method || 'GET').toUpperCase()\r\n }\r\n\r\n return headers;\r\n }\r\n\r\n protected async awaitForHandshake() {\r\n if (this.loadingHandshake) {\r\n await new Promise((resolve) => {\r\n const interval = setInterval(() => {\r\n if (!this.loadingHandshake) {\r\n clearInterval(interval);\r\n resolve(null);\r\n }\r\n }, 100);\r\n })\r\n }\r\n if (!this.handshakeInfo) {\r\n await this.handshake();\r\n }\r\n }\r\n\r\n async handshake() {\r\n await this.hooksCall('beforeHandshake');\r\n this.handshakeInfo = null;\r\n this.loadingHandshake = true;\r\n\r\n let max = this.config.secret.length\r\n let min = Math.floor(max / 4) * 3\r\n this.secret_length = Math.floor(Math.random() * (max - min + 1)) + min\r\n\r\n const secret = await this.getSecret()\r\n const res = await this.fetch('/', {\r\n method: 'POST',\r\n body: {\r\n hash: secret.hash,\r\n clientTime: new Date().toISOString(),\r\n secret: secret.secret,\r\n }\r\n })\r\n this.handshakeInfo = res.data\r\n this.loadingHandshake = false;\r\n await this.hooksCall('afterHandshake', this.handshakeInfo);\r\n }\r\n\r\n protected async fetch(path: string, init?: HttpRequestInit): Promise<SecurequClientResponse> {\r\n const isDev = path !== '/' && this.handshakeInfo?.dev\r\n const secret = await this.getSecret()\r\n const url = await this.url(path)\r\n let sparams = Object.fromEntries(url.searchParams.entries())\r\n const _init = { ...init }\r\n let params: any = {\r\n ...sparams,\r\n }\r\n\r\n if (Object.keys(sparams).length > 0) {\r\n for (let key in sparams) {\r\n url.searchParams.delete(key)\r\n }\r\n }\r\n\r\n if (_init?.params) {\r\n for (let key in _init.params) {\r\n params[key] = _init.params[key]\r\n }\r\n delete _init.params\r\n }\r\n\r\n if (Object.keys(params).length > 0) {\r\n if (isDev) {\r\n _init.params = params\r\n } else {\r\n const key = Math.random().toString(36).substring(2, 8);\r\n const enc = await crypto.encrypt({ params, key }, secret.secret)\r\n url.href = `${url.href}?${key}=${encodeURIComponent(enc)}`\r\n }\r\n }\r\n\r\n const httpOption: any = {\r\n method: \"GET\",\r\n ...this.config?.defaultOptions,\r\n ..._init,\r\n headers: await this.getHeaders(path, _init)\r\n }\r\n\r\n if (httpOption?.body) {\r\n if (isDev) {\r\n httpOption.body = JSON.stringify(httpOption.body)\r\n } else {\r\n httpOption.body = await crypto.encryptBuffer(httpOption.body, secret.secret);\r\n }\r\n }\r\n const res = await xanFetch(url.href, httpOption)\r\n if (isDev) {\r\n const value = await res.text()\r\n const val = JSON.parse(value)\r\n return {\r\n success: res.ok,\r\n message: res.ok ? res.statusText : val,\r\n data: res.ok ? val : null,\r\n code: res.status\r\n }\r\n }\r\n const value = await res.arrayBuffer()\r\n const val = await crypto.decryptBuffer(new Uint8Array(value), secret.secret) as any\r\n\r\n return {\r\n success: res.ok,\r\n message: res.ok ? res.statusText : (val || res.statusText),\r\n data: res.ok ? val : null,\r\n code: res.status\r\n }\r\n }\r\n\r\n}\r\n\r\nexport default Base;\r\n"],"names":["crypto"],"mappings":"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"}
|