| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var net = require('net'); | 
					
						
							|  |  |  | var jwt = require('jsonwebtoken'); | 
					
						
							|  |  |  | var sni = require('sni'); | 
					
						
							|  |  |  | // TODO ask oauth3.org where to connect
 | 
					
						
							|  |  |  | // TODO reconnect on disconnect
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Assumption: will not get next tcp packet unless previous packet succeeded
 | 
					
						
							|  |  |  | //var services = { 'ssh': 22, 'http': 80, 'https': 443 };
 | 
					
						
							|  |  |  | var services = { 'ssh': 22, 'http': 4080, 'https': 8443 }; | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  | var hostname = 'aj.daplie.me'; // 'pokemap.hellabit.com'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function addrToId(address) { | 
					
						
							|  |  |  |   return address.family + ',' + address.address + ',' + address.port; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | function socketToAddr(socket) { | 
					
						
							|  |  |  |   return { family: socket.remoteFamily, address: socket.remoteAddress, port: socket.remotePort }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function socketToId(socket) { | 
					
						
							|  |  |  |   return addrToId(socketToAddr(socket)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var tunneler = net.connect({ port: 5443 , host: hostname }, function () { | 
					
						
							|  |  |  |   var token = jwt.sign({ name: hostname }, 'shhhhh'); | 
					
						
							|  |  |  |   var localclients = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   setInterval(function () { | 
					
						
							|  |  |  |     console.log(''); | 
					
						
							|  |  |  |     console.log('localclients.length:', Object.keys(localclients).length); | 
					
						
							|  |  |  |     console.log(''); | 
					
						
							|  |  |  |   }, 5000); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   tunneler.write(token); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // BaaS / Backendless / noBackend / horizon.io
 | 
					
						
							|  |  |  |   // user authentication
 | 
					
						
							|  |  |  |   // a place to store data
 | 
					
						
							|  |  |  |   // file management
 | 
					
						
							|  |  |  |   // Synergy Teamwork Paradigm = Jabberwocky
 | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |   var pack = require('tunnel-packer').pack; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function onMessage(opts) { | 
					
						
							|  |  |  |     var id = addrToId(opts); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |     var service = 'https'; | 
					
						
							|  |  |  |     var port = services[service]; | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |     var lclient; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (opts.data.byteLength < 20) { | 
					
						
							|  |  |  |       if ('|__ERROR__|' === opts.data.toString('utf8') | 
					
						
							|  |  |  |         || '|__END__|' === opts.data.toString('utf8')) { | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |         console.log("end '" + opts.address + "'"); | 
					
						
							|  |  |  |         if (localclients[id]) { | 
					
						
							|  |  |  |           localclients[id].end(); | 
					
						
							|  |  |  |           delete localclients[id]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (localclients[id]) { | 
					
						
							|  |  |  |       console.log("received data from '" + opts.address + "'", opts.data.byteLength); | 
					
						
							|  |  |  |       localclients[id].write(opts.data); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var servername = sni(opts.data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!servername) { | 
					
						
							|  |  |  |       console.warn("no servername found for '" + id + "'"); | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |       tunneler.write(pack(opts, Buffer.from('|__ERROR__|'))); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     console.log("servername: '" + servername + "'"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |     lclient = localclients[id] = net.createConnection({ port: port, host: '127.0.0.1' }, function () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       lclient.on('data', function (chunk) { | 
					
						
							|  |  |  |         console.log("client '" + opts.address + "' sent ", chunk.byteLength, "bytes"); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |         tunneler.write(pack(opts, chunk)); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |       lclient.on('error', function (err) { | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |         console.error('client Error'); | 
					
						
							|  |  |  |         console.error(err); | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |         delete localclients[id]; | 
					
						
							|  |  |  |         tunneler.write(pack(opts, Buffer.from('|__ERROR__|'))); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |       lclient.on('end', function () { | 
					
						
							|  |  |  |         console.log('client End'); | 
					
						
							|  |  |  |         delete localclients[id]; | 
					
						
							|  |  |  |         tunneler.write(pack(opts, Buffer.from('|__END__|'))); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |       console.log('received data', opts.data.byteLength); | 
					
						
							|  |  |  |       lclient.write(opts.data); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-09-22 16:18:35 -06:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   var machine = require('tunnel-packer').create({ onMessage: onMessage }); | 
					
						
							| 
									
										
										
										
											2016-09-21 18:42:57 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   tunneler.on('data', machine.fns.addChunk); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   tunneler.on('end', function () { | 
					
						
							|  |  |  |     console.log('end'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | }); |