| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 | 
							- var http = require('http'),
 
-     https = require('https'),
 
-     url = require('url');
 
-     
 
- var port = 1234,
 
-     log  = true,
 
-     request_auth = false;
 
- http.createServer(function(request, response) {
 
-   console.log(request.headers);
 
-   console.log("Got request: " + request.url);
 
-   console.log("Forwarding request to " + request.headers['host']);
 
-   if (request_auth) {
 
-       if (!request.headers['proxy-authorization']) {
 
-         response.writeHead(407, {'Proxy-Authenticate': 'Basic realm="proxy.com"'})
 
-         return response.end('Hello.');        
 
-       }
 
-   }
 
-   var remote = url.parse(request.url);
 
-   var protocol = remote.protocol == 'https:' ? https : http;
 
-   var opts = {
 
-     host: request.headers['host'],
 
-     port: remote.port || (remote.protocol == 'https:' ? 443 : 80),
 
-     method: request.method,
 
-     path: remote.pathname,
 
-     headers: request.headers
 
-   }
 
-   var proxy_request = protocol.request(opts, function(proxy_response){
 
-     proxy_response.on('data', function(chunk) {
 
-       if (log) console.log(chunk.toString());
 
-       response.write(chunk, 'binary');
 
-     });
 
-     proxy_response.on('end', function() {
 
-       response.end();
 
-     });
 
-     response.writeHead(proxy_response.statusCode, proxy_response.headers);
 
-   });
 
-   request.on('data', function(chunk) {
 
-     if (log) console.log(chunk.toString());
 
-     proxy_request.write(chunk, 'binary');
 
-   });
 
-   request.on('end', function() {
 
-     proxy_request.end();
 
-   });
 
- }).listen(port);
 
- process.on('uncaughtException', function(err){
 
-   console.log('Uncaught exception!');
 
-   console.log(err);
 
- });
 
- console.log("Proxy server listening on port " + port);
 
 
  |