public
Last active

Running a "full-featured" REPL using a net.Server and net.Socket

  • Download Gist
repl-client.js
JavaScript
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
var net = require('net')
 
var sock = net.connect(1337)
 
process.stdin.pipe(sock)
sock.pipe(process.stdout)
 
sock.on('connect', function () {
process.stdin.resume();
process.stdin.setRawMode(true)
})
 
sock.on('close', function done () {
process.stdin.setRawMode(false)
process.stdin.pause()
sock.removeListener('close', done)
})
 
process.stdin.on('end', function () {
sock.destroy()
console.log()
})
 
process.stdin.on('data', function (b) {
if (b.length === 1 && b[0] === 4) {
process.stdin.emit('end')
}
})
repl-server.js
JavaScript
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
var repl = require('repl')
var net = require('net')
 
net.createServer(function (socket) {
var r = repl.start({
prompt: 'socket '+socket.remoteAddress+':'+socket.remotePort+'> '
, input: socket
, output: socket
, terminal: true
, useGlobal: false
})
r.on('exit', function () {
socket.end()
})
r.context.socket = socket
}).listen(1337)

Hi Nate,
I'm trying to set up a repl with stdout piped to it, this seems like a good demo. But when I run this with node 0.6.19, I get this error:

repl-client.js:10
  process.stdin.setRawMode(true)
                ^
TypeError: Object #<ReadStream> has no method 'setRawMode'
    at Socket.<anonymous> (nodejs/repl-demo/repl-client.js:10:17)
    at Socket.emit (events.js:64:17)
    at Object.afterConnect [as oncomplete] (net.js:652:10)

What am I missing?
Thanks!

@newleafdigital You need node v0.8.0 for this example.

Is there any way in 0.6 to pipe stdout / console.log to a repl, so while I'm running commands, I can see the logs? It seems like it should be straightforward, but I can't get it to work.

    r.context.inspect = function(value) {
        r.outputStream.write('\n' + r.writer(value) + '\n');
        r.displayPrompt();
    };

This method is useful as callback to inspect values when console.log() is unavailable.
Example of usage:

socket 127.0.0.1:39022> setTimeout(function() {inspect(user);}, 1000);null;
null // immediate reaction
socket 127.0.0.1:39022> 
{ coins: 10 } // after the timeout
socket 127.0.0.1:39022>

Though please be careful: this code crashes the server if repl client disconnects before the timeout.

Looks like this stopped working with 0.10.0, running the client results in the following error.

_stream_readable.js:683
throw new Error('Cannot switch to old mode now.');

I'm curious, too -- I'd like a remote REPL participant to be able to see the results of whatever they do, in their own REPL, instead of having that output "leak" back into the terminal where the program is running.

var socket = require('engine.io-client');
console.log(socket.remoteAddress);

i am not getting remote addeess and it gives undefined

req.headers['x-forwarded-for'] it gives local ip address ...

i want remote ip address

Please sign in to comment on this gist.

Something went wrong with that request. Please try again.