summaryrefslogtreecommitdiffstats
path: root/tinyserver.js
blob: fd9d37dbb3e8b356a0c7feb3c55502a2b4495db0 (plain)
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
var http = require('http');
var util = require('util');
var url  = require('url');

var router = require('./route');

var serverConfig = {
    port: 8080,
    hostname: 'localhost' /* eth interface ip? */
};

/* current list of active users, key-value pairs */
var activeUsers = [];

/* this function is poked upon 'request' event */
function requestListener(req, res) {
    var datareq = '';

    req.on('data', function(chunk) { datareq += chunk; } );
    req.on('end', function() {
        util.log('[reqlistener] finished recv data');
        //console.log('data: %s', datareq.length == 0 ? 'empty' : datareq);

        /* should be some logic, e.g. blueprint 1 */
        util.log('[reqlistener] request kind: ' + req.method);
        /* routing for pathname, figure out what request we have */
        var urlquery = url.parse(req.url);
        //console.log('[reqlistener] query dump:\n' + util.inspect(urlquery));
        router.route(urlquery, res);
    });
    req.on('close', function() { util.log('[reqlistener] client terminated before we could respond'); });
}

var server = http.createServer(requestListener);
server.listen(serverConfig.port, serverConfig.hostname, function() {
    /* could use for proxy stuff? this function is called when listening event is emitted */
});

server.on('connection', function(socket) {
    util.log('[server] new connection from ' + socket.remoteAddress + ':' + socket.remotePort
    + ', read ' + socket.bytesRead + ' bytes');
    //console.log(util.inspect(socket), false /* do not show non-enum props */, true);
});

server.on('close', function() {
    util.log('[server] server shutdown');
});

server.on('clientError', function(exception) {
    util.log('[server] ' + exception);
});