@push.rocks/smartproxy 3.3.0 → 3.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist_ts/00_commitinfo_data.js +1 -1
- package/dist_ts/smartproxy.plugins.d.ts +2 -1
- package/dist_ts/smartproxy.plugins.js +3 -2
- package/dist_ts/smartproxy.portproxy.d.ts +3 -4
- package/dist_ts/smartproxy.portproxy.js +4 -6
- package/package.json +1 -1
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/smartproxy.plugins.ts +2 -1
- package/ts/smartproxy.portproxy.ts +7 -9
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
5
|
name: '@push.rocks/smartproxy',
|
|
6
|
-
version: '3.3.
|
|
6
|
+
version: '3.3.1',
|
|
7
7
|
description: 'a proxy for handling high workloads of proxying'
|
|
8
8
|
};
|
|
9
9
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSx3QkFBd0I7SUFDOUIsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLGlEQUFpRDtDQUMvRCxDQUFBIn0=
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import * as http from 'http';
|
|
2
2
|
import * as https from 'https';
|
|
3
3
|
import * as net from 'net';
|
|
4
|
+
import * as tls from 'tls';
|
|
4
5
|
import * as url from 'url';
|
|
5
|
-
export { http, https, net, url };
|
|
6
|
+
export { http, https, net, tls, url };
|
|
6
7
|
import * as tsclass from '@tsclass/tsclass';
|
|
7
8
|
export { tsclass };
|
|
8
9
|
import * as lik from '@push.rocks/lik';
|
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
import * as http from 'http';
|
|
3
3
|
import * as https from 'https';
|
|
4
4
|
import * as net from 'net';
|
|
5
|
+
import * as tls from 'tls';
|
|
5
6
|
import * as url from 'url';
|
|
6
|
-
export { http, https, net, url };
|
|
7
|
+
export { http, https, net, tls, url };
|
|
7
8
|
// tsclass scope
|
|
8
9
|
import * as tsclass from '@tsclass/tsclass';
|
|
9
10
|
export { tsclass };
|
|
@@ -19,4 +20,4 @@ import * as ws from 'ws';
|
|
|
19
20
|
import wsDefault from 'ws';
|
|
20
21
|
import { minimatch } from 'minimatch';
|
|
21
22
|
export { wsDefault, ws, minimatch };
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRwcm94eS5wbHVnaW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRwcm94eS5wbHVnaW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9CQUFvQjtBQUNwQixPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEtBQUssS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMvQixPQUFPLEtBQUssR0FBRyxNQUFNLEtBQUssQ0FBQztBQUMzQixPQUFPLEtBQUssR0FBRyxNQUFNLEtBQUssQ0FBQztBQUMzQixPQUFPLEtBQUssR0FBRyxNQUFNLEtBQUssQ0FBQztBQUUzQixPQUFPLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDO0FBRXRDLGdCQUFnQjtBQUNoQixPQUFPLEtBQUssT0FBTyxNQUFNLGtCQUFrQixDQUFDO0FBRTVDLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQztBQUVuQixrQkFBa0I7QUFDbEIsT0FBTyxLQUFLLEdBQUcsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEtBQUssVUFBVSxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sS0FBSyxZQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxLQUFLLFlBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEtBQUssV0FBVyxNQUFNLHlCQUF5QixDQUFDO0FBRXZELE9BQU8sRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLENBQUM7QUFFcEUsb0JBQW9CO0FBQ3BCLE9BQU8sS0FBSyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3pCLE9BQU8sU0FBUyxNQUFNLElBQUksQ0FBQztBQUMzQixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRXRDLE9BQU8sRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDIn0=
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import * as plugins from './smartproxy.plugins.js';
|
|
2
|
-
import * as tls from 'tls';
|
|
3
2
|
export interface DomainConfig {
|
|
4
3
|
domain: string;
|
|
5
4
|
allowedIPs: string[];
|
|
@@ -7,15 +6,15 @@ export interface DomainConfig {
|
|
|
7
6
|
export interface ProxySettings {
|
|
8
7
|
domains: DomainConfig[];
|
|
9
8
|
sniEnabled?: boolean;
|
|
10
|
-
tlsOptions?: tls.TlsOptions;
|
|
9
|
+
tlsOptions?: plugins.tls.TlsOptions;
|
|
11
10
|
defaultAllowedIPs?: string[];
|
|
12
11
|
}
|
|
13
12
|
export declare class PortProxy {
|
|
14
|
-
netServer: plugins.net.Server;
|
|
13
|
+
netServer: plugins.net.Server | plugins.tls.Server;
|
|
15
14
|
fromPort: number;
|
|
16
15
|
toPort: number;
|
|
17
16
|
settings: ProxySettings;
|
|
18
|
-
constructor(fromPortArg: number, toPortArg: number, settings: ProxySettings);
|
|
17
|
+
constructor(fromPortArg: number, toPortArg: number, settings: plugins.tls.TlsOptions & ProxySettings);
|
|
19
18
|
start(): Promise<void>;
|
|
20
19
|
stop(): Promise<void>;
|
|
21
20
|
}
|
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import * as plugins from './smartproxy.plugins.js';
|
|
2
|
-
import * as net from 'net';
|
|
3
|
-
import * as tls from 'tls';
|
|
4
2
|
export class PortProxy {
|
|
5
3
|
constructor(fromPortArg, toPortArg, settings) {
|
|
6
4
|
this.fromPort = fromPortArg;
|
|
@@ -24,10 +22,10 @@ export class PortProxy {
|
|
|
24
22
|
const findMatchingDomain = (serverName) => {
|
|
25
23
|
return this.settings.domains.find(config => plugins.minimatch(serverName, config.domain));
|
|
26
24
|
};
|
|
27
|
-
const server = this.settings.sniEnabled ? tls.createServer(this.settings.tlsOptions || {}) : net.createServer();
|
|
25
|
+
const server = this.settings.sniEnabled ? plugins.tls.createServer(this.settings.tlsOptions || {}) : plugins.net.createServer();
|
|
28
26
|
this.netServer = server.on('connection', (from) => {
|
|
29
27
|
const remoteIP = from.remoteAddress || '';
|
|
30
|
-
if (this.settings.sniEnabled && from instanceof tls.TLSSocket) {
|
|
28
|
+
if (this.settings.sniEnabled && from instanceof plugins.tls.TLSSocket) {
|
|
31
29
|
const serverName = from.servername || '';
|
|
32
30
|
const domainConfig = findMatchingDomain(serverName);
|
|
33
31
|
if (!domainConfig) {
|
|
@@ -52,7 +50,7 @@ export class PortProxy {
|
|
|
52
50
|
from.end();
|
|
53
51
|
return;
|
|
54
52
|
}
|
|
55
|
-
const to = net.createConnection({
|
|
53
|
+
const to = plugins.net.createConnection({
|
|
56
54
|
host: 'localhost',
|
|
57
55
|
port: this.toPort,
|
|
58
56
|
});
|
|
@@ -95,4 +93,4 @@ export class PortProxy {
|
|
|
95
93
|
await done.promise;
|
|
96
94
|
}
|
|
97
95
|
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRwcm94eS5wb3J0cHJveHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9zbWFydHByb3h5LnBvcnRwcm94eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHlCQUF5QixDQUFDO0FBZW5ELE1BQU0sT0FBTyxTQUFTO0lBTXBCLFlBQVksV0FBbUIsRUFBRSxTQUFpQixFQUFFLFFBQWdEO1FBQ2xHLElBQUksQ0FBQyxRQUFRLEdBQUcsV0FBVyxDQUFDO1FBQzVCLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0lBQzNCLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixNQUFNLGNBQWMsR0FBRyxDQUFDLElBQXdCLEVBQUUsRUFBc0IsRUFBRSxFQUFFO1lBQzFFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNYLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQzFCLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQ3hCLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNkLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNmLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNmLENBQUMsQ0FBQztRQUNGLE1BQU0sU0FBUyxHQUFHLENBQUMsS0FBYSxFQUFFLFFBQWtCLEVBQVcsRUFBRTtZQUMvRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ3JFLENBQUMsQ0FBQztRQUVGLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxVQUFrQixFQUE0QixFQUFFO1lBQzFFLE9B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
|
package/package.json
CHANGED
package/ts/00_commitinfo_data.ts
CHANGED
package/ts/smartproxy.plugins.ts
CHANGED
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
import * as http from 'http';
|
|
3
3
|
import * as https from 'https';
|
|
4
4
|
import * as net from 'net';
|
|
5
|
+
import * as tls from 'tls';
|
|
5
6
|
import * as url from 'url';
|
|
6
7
|
|
|
7
|
-
export { http, https, net, url };
|
|
8
|
+
export { http, https, net, tls, url };
|
|
8
9
|
|
|
9
10
|
// tsclass scope
|
|
10
11
|
import * as tsclass from '@tsclass/tsclass';
|
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import * as plugins from './smartproxy.plugins.js';
|
|
2
|
-
import * as net from 'net';
|
|
3
|
-
import * as tls from 'tls';
|
|
4
2
|
|
|
5
3
|
|
|
6
4
|
export interface DomainConfig {
|
|
@@ -11,17 +9,17 @@ export interface DomainConfig {
|
|
|
11
9
|
export interface ProxySettings {
|
|
12
10
|
domains: DomainConfig[];
|
|
13
11
|
sniEnabled?: boolean;
|
|
14
|
-
tlsOptions?: tls.TlsOptions;
|
|
12
|
+
tlsOptions?: plugins.tls.TlsOptions;
|
|
15
13
|
defaultAllowedIPs?: string[]; // Optional default IP patterns if no matching domain found
|
|
16
14
|
}
|
|
17
15
|
|
|
18
16
|
export class PortProxy {
|
|
19
|
-
netServer: plugins.net.Server;
|
|
17
|
+
netServer: plugins.net.Server | plugins.tls.Server;
|
|
20
18
|
fromPort: number;
|
|
21
19
|
toPort: number;
|
|
22
20
|
settings: ProxySettings;
|
|
23
21
|
|
|
24
|
-
constructor(fromPortArg: number, toPortArg: number, settings: ProxySettings) {
|
|
22
|
+
constructor(fromPortArg: number, toPortArg: number, settings: plugins.tls.TlsOptions & ProxySettings) {
|
|
25
23
|
this.fromPort = fromPortArg;
|
|
26
24
|
this.toPort = toPortArg;
|
|
27
25
|
this.settings = settings;
|
|
@@ -46,11 +44,11 @@ export class PortProxy {
|
|
|
46
44
|
return this.settings.domains.find(config => plugins.minimatch(serverName, config.domain));
|
|
47
45
|
};
|
|
48
46
|
|
|
49
|
-
const server = this.settings.sniEnabled ? tls.createServer(this.settings.tlsOptions || {}) : net.createServer();
|
|
47
|
+
const server = this.settings.sniEnabled ? plugins.tls.createServer(this.settings.tlsOptions || {}) : plugins.net.createServer();
|
|
50
48
|
|
|
51
|
-
this.netServer = server.on('connection', (from: net.Socket) => {
|
|
49
|
+
this.netServer = server.on('connection', (from: plugins.net.Socket) => {
|
|
52
50
|
const remoteIP = from.remoteAddress || '';
|
|
53
|
-
if (this.settings.sniEnabled && from instanceof tls.TLSSocket) {
|
|
51
|
+
if (this.settings.sniEnabled && from instanceof plugins.tls.TLSSocket) {
|
|
54
52
|
const serverName = (from as any).servername || '';
|
|
55
53
|
const domainConfig = findMatchingDomain(serverName);
|
|
56
54
|
|
|
@@ -75,7 +73,7 @@ export class PortProxy {
|
|
|
75
73
|
return;
|
|
76
74
|
}
|
|
77
75
|
|
|
78
|
-
const to = net.createConnection({
|
|
76
|
+
const to = plugins.net.createConnection({
|
|
79
77
|
host: 'localhost',
|
|
80
78
|
port: this.toPort,
|
|
81
79
|
});
|