Removes domains
This commit is contained in:
commit
a8b68ef5ec
|
@ -1,6 +1,5 @@
|
||||||
const http = require('http');
|
const http = require('http');
|
||||||
const Server = http.Server;
|
const Server = http.Server;
|
||||||
const domain = require('domain');
|
|
||||||
const socks = require('socksv5');
|
const socks = require('socksv5');
|
||||||
const URL = require('url');
|
const URL = require('url');
|
||||||
const SocksProxyAgent = require('socks-proxy-agent');
|
const SocksProxyAgent = require('socks-proxy-agent');
|
||||||
|
@ -8,14 +7,6 @@ const SocksProxyAgent = require('socks-proxy-agent');
|
||||||
class HTTPServer extends Server {
|
class HTTPServer extends Server {
|
||||||
constructor(tor_pool, logger) {
|
constructor(tor_pool, logger) {
|
||||||
let handle_http_connections = (req, res) => {
|
let handle_http_connections = (req, res) => {
|
||||||
let d = domain.create();
|
|
||||||
d.on('error', (error) => {
|
|
||||||
logger.error(`[http-proxy]: an error occured: ${error.message}`)
|
|
||||||
res.end();
|
|
||||||
});
|
|
||||||
d.add(req);
|
|
||||||
d.add(res);
|
|
||||||
|
|
||||||
let url = URL.parse(req.url);
|
let url = URL.parse(req.url);
|
||||||
url.port = url.port || 80;
|
url.port = url.port || 80;
|
||||||
|
|
||||||
|
@ -31,13 +22,14 @@ class HTTPServer extends Server {
|
||||||
|
|
||||||
req.on('data', onIncomingData);
|
req.on('data', onIncomingData);
|
||||||
req.on('end', preConnectClosed);
|
req.on('end', preConnectClosed);
|
||||||
|
req.on('error', function (err) {
|
||||||
|
logger.error("[http-proxy]: an error occured\n"+err.stack);
|
||||||
|
});
|
||||||
|
|
||||||
let connect = (tor_instance) => {
|
let connect = (tor_instance) => {
|
||||||
let socks_port = tor_instance.socks_port;
|
let socks_port = tor_instance.socks_port;
|
||||||
logger.verbose(`[http-proxy]: ${req.connection.remoteAddress}:${req.connection.remotePort} → 127.0.0.1:${socks_port} → ${url.hostname}:${url.port}`);
|
logger.verbose(`[http-proxy]: ${req.connection.remoteAddress}:${req.connection.remotePort} → 127.0.0.1:${socks_port} → ${url.hostname}:${url.port}`);
|
||||||
|
|
||||||
d.run(() => {
|
|
||||||
let proxy_req = http.request({
|
let proxy_req = http.request({
|
||||||
method: req.method,
|
method: req.method,
|
||||||
hostname: url.hostname,
|
hostname: url.hostname,
|
||||||
|
@ -75,9 +67,8 @@ class HTTPServer extends Server {
|
||||||
if (req.finished)
|
if (req.finished)
|
||||||
proxy_req.end();
|
proxy_req.end();
|
||||||
|
|
||||||
d.add(proxy_req);
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if (tor_pool.instances.length) {
|
if (tor_pool.instances.length) {
|
||||||
connect(tor_pool.next());
|
connect(tor_pool.next());
|
||||||
} else {
|
} else {
|
||||||
|
@ -87,10 +78,6 @@ class HTTPServer extends Server {
|
||||||
};
|
};
|
||||||
|
|
||||||
let handle_connect_connections = (req, inbound_socket, head) => {
|
let handle_connect_connections = (req, inbound_socket, head) => {
|
||||||
let d = domain.create();
|
|
||||||
|
|
||||||
d.add(inbound_socket);
|
|
||||||
|
|
||||||
let hostname = req.url.split(':').shift();
|
let hostname = req.url.split(':').shift();
|
||||||
let port = Number(req.url.split(':').pop());
|
let port = Number(req.url.split(':').pop());
|
||||||
|
|
||||||
|
@ -107,20 +94,13 @@ class HTTPServer extends Server {
|
||||||
|
|
||||||
if (error)
|
if (error)
|
||||||
this.logger.error(`[http-connect]: an error occured: ${error.message}`)
|
this.logger.error(`[http-connect]: an error occured: ${error.message}`)
|
||||||
|
|
||||||
d.exit();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
d.on('error', onClose);
|
|
||||||
|
|
||||||
d.add(inbound_socket);
|
|
||||||
|
|
||||||
var buffer = [head];
|
var buffer = [head];
|
||||||
let onInboundData = function (data) {
|
let onInboundData = function (data) {
|
||||||
buffer.push(data);
|
buffer.push(data);
|
||||||
};
|
};
|
||||||
|
|
||||||
d.run(() => {
|
|
||||||
socks.connect({
|
socks.connect({
|
||||||
host: hostname,
|
host: hostname,
|
||||||
port: port,
|
port: port,
|
||||||
|
@ -130,7 +110,6 @@ class HTTPServer extends Server {
|
||||||
auths: [ socks.auth.None() ]
|
auths: [ socks.auth.None() ]
|
||||||
}, ($outbound_socket) => {
|
}, ($outbound_socket) => {
|
||||||
outbound_socket = $outbound_socket;
|
outbound_socket = $outbound_socket;
|
||||||
d.add(outbound_socket);
|
|
||||||
outbound_socket && outbound_socket.on('close', onClose);
|
outbound_socket && outbound_socket.on('close', onClose);
|
||||||
outbound_socket && outbound_socket.on('error', onClose);
|
outbound_socket && outbound_socket.on('error', onClose);
|
||||||
|
|
||||||
|
@ -139,7 +118,6 @@ class HTTPServer extends Server {
|
||||||
|
|
||||||
outbound_socket.pipe(inbound_socket);
|
outbound_socket.pipe(inbound_socket);
|
||||||
inbound_socket.pipe(outbound_socket);
|
inbound_socket.pipe(outbound_socket);
|
||||||
})
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
if (tor_pool.instances.length) {
|
if (tor_pool.instances.length) {
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
const socks = require('socksv5');
|
const socks = require('socksv5');
|
||||||
const SOCKS5Server = socks.Server;
|
const SOCKS5Server = socks.Server;
|
||||||
const domain = require('domain');
|
|
||||||
|
|
||||||
class SOCKSServer extends SOCKS5Server{
|
class SOCKSServer extends SOCKS5Server{
|
||||||
constructor(tor_pool, logger) {
|
constructor(tor_pool, logger) {
|
||||||
let handleConnection = (info, accept, deny) => {
|
let handleConnection = (info, accept, deny) => {
|
||||||
let d = domain.create();
|
|
||||||
|
|
||||||
let inbound_socket = accept(true);
|
let inbound_socket = accept(true);
|
||||||
d.add(inbound_socket);
|
|
||||||
var outbound_socket;
|
var outbound_socket;
|
||||||
let buffer = [];
|
let buffer = [];
|
||||||
|
|
||||||
|
@ -22,8 +18,6 @@ class SOCKSServer extends SOCKS5Server{
|
||||||
|
|
||||||
if (error)
|
if (error)
|
||||||
this.logger.error(`[socks]: an error occured: ${error.message}`)
|
this.logger.error(`[socks]: an error occured: ${error.message}`)
|
||||||
|
|
||||||
d.exit();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!inbound_socket) return;
|
if (!inbound_socket) return;
|
||||||
|
@ -36,9 +30,6 @@ class SOCKSServer extends SOCKS5Server{
|
||||||
let socks_port = tor_instance.socks_port;
|
let socks_port = tor_instance.socks_port;
|
||||||
logger.verbose(`[socks]: ${info.srcAddr}:${info.srcPort} → 127.0.0.1:${socks_port}${tor_instance.definition.Name ? ' ('+tor_instance.definition.Name+')' : '' } → ${info.dstAddr}:${info.dstPort}`)
|
logger.verbose(`[socks]: ${info.srcAddr}:${info.srcPort} → 127.0.0.1:${socks_port}${tor_instance.definition.Name ? ' ('+tor_instance.definition.Name+')' : '' } → ${info.dstAddr}:${info.dstPort}`)
|
||||||
|
|
||||||
d.on('error', onClose);
|
|
||||||
|
|
||||||
d.run(() => {
|
|
||||||
socks.connect({
|
socks.connect({
|
||||||
host: info.dstAddr,
|
host: info.dstAddr,
|
||||||
port: info.dstPort,
|
port: info.dstPort,
|
||||||
|
@ -48,7 +39,6 @@ class SOCKSServer extends SOCKS5Server{
|
||||||
auths: [ socks.auth.None() ]
|
auths: [ socks.auth.None() ]
|
||||||
}, ($outbound_socket) => {
|
}, ($outbound_socket) => {
|
||||||
outbound_socket = $outbound_socket;
|
outbound_socket = $outbound_socket;
|
||||||
d.add(outbound_socket);
|
|
||||||
outbound_socket && outbound_socket.on('close', onClose);
|
outbound_socket && outbound_socket.on('close', onClose);
|
||||||
|
|
||||||
inbound_socket && inbound_socket.removeListener('data', onInboundData);
|
inbound_socket && inbound_socket.removeListener('data', onInboundData);
|
||||||
|
@ -65,7 +55,6 @@ class SOCKSServer extends SOCKS5Server{
|
||||||
while (buffer && buffer.length && outbound_socket) {
|
while (buffer && buffer.length && outbound_socket) {
|
||||||
outbound_socket.write(buffer.shift());
|
outbound_socket.write(buffer.shift());
|
||||||
}
|
}
|
||||||
})
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
if (tor_pool.instances.length) {
|
if (tor_pool.instances.length) {
|
||||||
|
|
Loading…
Reference in a new issue