60 lines
1.3 KiB
JavaScript
Raw Normal View History

2020-10-17 18:42:50 +02:00
/**
* @overview
* @author Matthew Caruana Galizia <m@m.cg>
* @license MIT
* @copyright Copyright (c) 2013, Matthew Caruana Galizia
*/
'use strict';
/*jshint node:true*/
var tls = require('tls');
var https = require('https');
var inherits = require('util').inherits;
var socksClient = require('socks5-client');
function createConnection(options) {
var socksSocket, onProxied;
socksSocket = socksClient.createConnection(options);
onProxied = socksSocket.onProxied;
socksSocket.onProxied = function() {
options.socket = socksSocket.socket;
if (options.hostname) {
options.servername = options.hostname;
} else if (options.host) {
options.servername = options.host.split(':')[0];
}
socksSocket.socket = tls.connect(options, function() {
// Set the 'authorized flag for clients that check it.
socksSocket.authorized = socksSocket.socket.authorized;
onProxied.call(socksSocket);
});
socksSocket.socket.on('error', function(err) {
socksSocket.emit('error', err);
});
};
return socksSocket;
}
function Agent(options) {
https.Agent.call(this, options);
this.socksHost = options.socksHost || 'localhost';
this.socksPort = options.socksPort || 1080;
this.createConnection = createConnection;
}
inherits(Agent, https.Agent);
module.exports = Agent;