tor-router/src/ControlServer.js

135 lines
3.9 KiB
JavaScript
Raw Normal View History

2017-03-22 16:44:08 +00:00
const TorPool = require('./TorPool');
const SOCKSServer = require('./SOCKSServer');
const DNSServer = require('./DNSServer');
const HTTPServer = require('./HTTPServer');
const rpc = require('jrpc2');
2017-03-22 16:44:08 +00:00
class ControlServer {
constructor(logger, nconf) {
this.torPool = new TorPool(null, null, logger, nconf);
2017-03-22 16:44:08 +00:00
this.logger = logger;
this.nconf = nconf;
2017-03-22 16:44:08 +00:00
let server = this.server = new rpc.Server();
server.expose('createTorPool', this.createTorPool.bind(this));
server.expose('createSOCKSServer', this.createSOCKSServer.bind(this));
server.expose('createDNSServer', this.createDNSServer.bind(this));
server.expose('createHTTPServer', this.createHTTPServer.bind(this));
server.expose('queryInstances', (function () {
return new Promise((resolve, reject) => {
if (!this.torPool)
return reject({ message: 'No pool created' });
resolve(this.torPool.instances.map((i) => ( { dns_port: i.dns_port, socks_port: i.socks_port, process_id: i.process.pid, config: i.definition.Config, weight: i.definition.weight } )) );
});
}).bind(this));
server.expose('createInstances', (function (instances) {
return new Promise((resolve, reject) => {
this.torPool.create(instances, (error, instances) => {
if (error) reject(error);
else resolve();
});
});
}).bind(this) );
2017-03-22 16:44:08 +00:00
server.expose('addInstances', (function (instances) {
return new Promise((resolve, reject) => {
this.torPool.add(instances, (error, instances) => {
if (error) reject(error);
else resolve();
});
});
}).bind(this) );
server.expose('removeInstances', (function (instances) {
return new Promise((resolve, reject) => {
this.torPool.remove(instances, (error) => {
if (error) reject(error);
else resolve();
});
});
}).bind(this) );
server.expose('removeInstanceAt', (function (instance_index) {
return new Promise((resolve, reject) => {
this.torPool.remove_at(instance_index, (error) => {
if (error) reject(error);
else resolve();
});
});
}).bind(this) );
server.expose('newIps', (function() {
this.torPool.new_ips();
return Promise.resolve();
}).bind(this) );
2017-03-22 16:44:08 +00:00
server.expose('newIpAt', (function(index) {
this.torPool.new_ip_at(index);
return Promise.resolve();
}).bind(this) );
server.expose('nextInstance', (function () {
this.torPool.next();
return Promise.resolve();
}).bind(this) );
2017-11-12 22:54:47 +00:00
server.expose('closeInstances', (function () {
this.torPool.exit();
return Promise.resolve();
}).bind(this) );
2017-03-22 16:44:08 +00:00
server.expose('setTorConfig', (function (config) {
this.nconf.set('torConfig', config);
return Promise.resolve();
}).bind(this));
server.expose('getTorConfig', (function (config) {
return Promise.resolve(this.nconf.get('torConfig'));
}).bind(this));
}
listen(port, callback) {
this.tcpTransport = new rpc.tcpTransport({ port });
this.tcpTransport.listen(this.server);
callback();
}
2017-03-22 16:44:08 +00:00
close() {
return this.tcpTransport.tcpServer.close();
2017-03-22 16:44:08 +00:00
}
createTorPool(options) {
this.torPool = new TorPool(null, options, this.logger, this.nconf);
return Promise.resolve();
2017-03-22 16:44:08 +00:00
}
createSOCKSServer(port) {
this.socksServer = new SOCKSServer(this.torPool, this.logger, this.nconf);
2017-03-22 16:44:08 +00:00
this.socksServer.listen(port || 9050);
this.logger && this.logger.info(`[socks]: Listening on ${port}`);
this.socksServer;
return Promise.resolve();
2017-03-22 16:44:08 +00:00
}
2017-12-08 01:21:42 +00:00
createHTTPServer(port) {
this.httpServer = new HTTPServer(this.torPool, this.logger, this.nconf);
2017-12-08 01:21:42 +00:00
this.httpServer.listen(port || 9080);
this.logger && this.logger.info(`[http]: Listening on ${port}`);
this.httpServer;
return Promise.resolve();
2017-12-08 01:21:42 +00:00
}
2017-03-22 16:44:08 +00:00
createDNSServer(port) {
this.dnsServer = new DNSServer(this.torPool, this.logger, this.nconf);
2017-03-22 16:44:08 +00:00
this.dnsServer.serve(port || 9053);
this.logger && this.logger.info(`[dns]: Listening on ${port}`);
this.dnsServer;
return Promise.resolve();
2017-03-22 16:44:08 +00:00
}
};
module.exports = ControlServer;