Compare commits
14 Commits
Author | SHA1 | Date | |
---|---|---|---|
da19fab8d8 | |||
8d318dca28 | |||
d03bfcc793 | |||
4ba2686977 | |||
d24c4d4b7a | |||
e1d4d6cf38 | |||
11344ac0df | |||
85fcfc3c36 | |||
e9ac7b2347 | |||
2c59540768 | |||
0f82d63f5c | |||
b5fcdadd3d | |||
6168b07414 | |||
588179335a |
2
package-lock.json
generated
2
package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/smartproxy",
|
"name": "@pushrocks/smartproxy",
|
||||||
"version": "2.0.5",
|
"version": "2.0.12",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/smartproxy",
|
"name": "@pushrocks/smartproxy",
|
||||||
"version": "2.0.5",
|
"version": "2.0.12",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "a proxy for handling high workloads of proxying",
|
"description": "a proxy for handling high workloads of proxying",
|
||||||
"main": "dist_ts/index.js",
|
"main": "dist_ts/index.js",
|
||||||
|
@ -8,6 +8,7 @@ export class ProxyWorker {
|
|||||||
public port = 8001;
|
public port = 8001;
|
||||||
public router = new SmartproxyRouter();
|
public router = new SmartproxyRouter();
|
||||||
public socketMap = new plugins.lik.ObjectMap<plugins.net.Socket>();
|
public socketMap = new plugins.lik.ObjectMap<plugins.net.Socket>();
|
||||||
|
public defaultHeaders: {[key: string]: string} = {};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* starts the proxyInstance
|
* starts the proxyInstance
|
||||||
@ -161,6 +162,7 @@ JNj2Dr5H0XoLFFnvuvzcRbhlJ9J67JzR+7g=
|
|||||||
{
|
{
|
||||||
method: req.method,
|
method: req.method,
|
||||||
headers: req.headers,
|
headers: req.headers,
|
||||||
|
keepAlive: true
|
||||||
},
|
},
|
||||||
true, // lets make this streaming
|
true, // lets make this streaming
|
||||||
(request) => {
|
(request) => {
|
||||||
@ -174,6 +176,9 @@ JNj2Dr5H0XoLFFnvuvzcRbhlJ9J67JzR+7g=
|
|||||||
);
|
);
|
||||||
res.statusCode = response.statusCode;
|
res.statusCode = response.statusCode;
|
||||||
console.log(response.statusCode);
|
console.log(response.statusCode);
|
||||||
|
for (const defaultHeader of Object.keys(this.defaultHeaders)) {
|
||||||
|
res.setHeader(defaultHeader, this.defaultHeaders[defaultHeader]);
|
||||||
|
}
|
||||||
for (const header of Object.keys(response.headers)) {
|
for (const header of Object.keys(response.headers)) {
|
||||||
res.setHeader(header, response.headers[header]);
|
res.setHeader(header, response.headers[header]);
|
||||||
}
|
}
|
||||||
@ -220,10 +225,24 @@ JNj2Dr5H0XoLFFnvuvzcRbhlJ9J67JzR+7g=
|
|||||||
this.httpsServer.keepAliveTimeout = 61000;
|
this.httpsServer.keepAliveTimeout = 61000;
|
||||||
this.httpsServer.headersTimeout = 65000;
|
this.httpsServer.headersTimeout = 65000;
|
||||||
|
|
||||||
this.httpsServer.on('connection', (connection) => {
|
this.httpsServer.on('connection', (connection: plugins.net.Socket) => {
|
||||||
|
connection.setTimeout(120000);
|
||||||
this.socketMap.add(connection);
|
this.socketMap.add(connection);
|
||||||
connection.on('close', () => {
|
connection.on('close', () => {
|
||||||
this.socketMap.remove(connection);
|
this.socketMap.remove(connection);
|
||||||
|
connection.destroy();
|
||||||
|
});
|
||||||
|
connection.on('error', () => {
|
||||||
|
this.socketMap.remove(connection);
|
||||||
|
connection.destroy();
|
||||||
|
});
|
||||||
|
connection.on('end', () => {
|
||||||
|
this.socketMap.remove(connection);
|
||||||
|
connection.destroy();
|
||||||
|
});
|
||||||
|
connection.on('timeout', () => {
|
||||||
|
this.socketMap.remove(connection);
|
||||||
|
connection.destroy();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -270,6 +289,7 @@ const proxyWorkerCalls = {
|
|||||||
updateReverseConfigs: async (configArray: plugins.tsclass.network.IReverseProxyConfig[]) => {
|
updateReverseConfigs: async (configArray: plugins.tsclass.network.IReverseProxyConfig[]) => {
|
||||||
await proxyWorkerInstance.updateProxyConfigs(configArray);
|
await proxyWorkerInstance.updateProxyConfigs(configArray);
|
||||||
},
|
},
|
||||||
|
addDefaultHeaders: async (headers: {[key: string]: string}) => {}
|
||||||
};
|
};
|
||||||
|
|
||||||
export type TProxyWorkerCalls = typeof proxyWorkerCalls;
|
export type TProxyWorkerCalls = typeof proxyWorkerCalls;
|
||||||
|
@ -45,6 +45,10 @@ export class SmartProxy {
|
|||||||
console.log('successfully spawned portproxy and proxyworkers!');
|
console.log('successfully spawned portproxy and proxyworkers!');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async updateDefaultHeaders(defaultHeadersArg: {[key: string]: string}) {
|
||||||
|
await this.proxyWorkerFunctions.addDefaultHeaders(defaultHeadersArg);
|
||||||
|
}
|
||||||
|
|
||||||
public async stop() {
|
public async stop() {
|
||||||
await this.proxyWorkerFunctions.stop();
|
await this.proxyWorkerFunctions.stop();
|
||||||
await plugins.smartspawn.Thread.terminate(this.proxyWorkerFunctions);
|
await plugins.smartspawn.Thread.terminate(this.proxyWorkerFunctions);
|
||||||
|
@ -22,9 +22,11 @@ const portProxyCalls = {
|
|||||||
from.end();
|
from.end();
|
||||||
to.end();
|
to.end();
|
||||||
from.removeAllListeners();
|
from.removeAllListeners();
|
||||||
to.removeEventListener();
|
to.removeAllListeners();
|
||||||
from.unpipe();
|
from.unpipe();
|
||||||
to.unpipe();
|
to.unpipe();
|
||||||
|
from.destroy();
|
||||||
|
to.destroy();
|
||||||
}
|
}
|
||||||
netServer = net
|
netServer = net
|
||||||
.createServer((from) => {
|
.createServer((from) => {
|
||||||
@ -32,6 +34,7 @@ const portProxyCalls = {
|
|||||||
host: 'localhost',
|
host: 'localhost',
|
||||||
port: 8001,
|
port: 8001,
|
||||||
});
|
});
|
||||||
|
from.setTimeout(120000);
|
||||||
from.pipe(to);
|
from.pipe(to);
|
||||||
to.pipe(from);
|
to.pipe(from);
|
||||||
from.on('error', () => {
|
from.on('error', () => {
|
||||||
|
Reference in New Issue
Block a user