Skip to content

Latest commit

 

History

History
64 lines (50 loc) · 1.85 KB

README.md

File metadata and controls

64 lines (50 loc) · 1.85 KB

argyle

A basic SOCKS5 server library written for node.js.

Features/Limitations

argyle supports the most basic features of SOCKS and not a whole lot more, namely:

  • 'No authentication' auth mode only
  • CONNECT commmand only

In the future I may add support for more auth modes and commands, but currently this implementation works well for my main use case (sitting between a local browser and server).

Usage

Example: "Normal" proxy server

var argyle = require('argyle');

var server = argyle(8080, '127.0.0.1');
server.on('connected', function(req, dest) {
	req.pipe(dest);
	dest.pipe(req);
});

Example: Throttled proxy server using node-throttled-stream

var argyle = require('argyle'),
	throttle = require('throttled-stream'),
	kbpsUp = 32,
	kbpsDown = 128;

var server = argyle(8080, '127.0.0.1');
server.on('connected', function(req, dest) {
	var tReq = throttle(req, kbpsUp * 1024),
		tDest = throttle(dest, kbpsDown * 1024);
	
	dest.once('error', function(err) { req.end(); })
		.on('close', function() { req.end(); });
	
	tReq.on('data', function(chunk) {
		dest.write(chunk);
	});
	tDest.on('data', function(chunk) {
		req.write(chunk);
	});
});

Methods

argyle([port = 8080], [host = 127.0.0.1], [debug = false])

Sets up a new SOCKS server on the specified port and host. If debug is specified, the server will output messages about the status of connections.

Events

'connected'

A new client connected to the server and the socket to their requested destination is now open. Handlers for this event are passed a request socket, corresponding to the client that made the request from the server, and a destination socket, corresponding to the server that they requested to connect to.

Installation

With npm:

npm install argyle

License

WTFPL