summaryrefslogtreecommitdiffstats
path: root/tinyserver.js
blob: ac2560b2b1b26cd7f267b59992ac184b6d4c12d0 (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
53
54
55
56
57
58
59
60
61
/*
 * tinyserver.js
 *
 * author: Kyle
 *
 * teh server, what else is new?
 *
 */

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 reqdata = ''; /* for POST data */

    req.on('data', function(chunk) { reqdata += chunk; } );
    req.on('close', function() { util.log('[reqlistener] client terminated before we could respond'); });
    req.on('end', function() {
        util.log(util.format('[reqlistener] finished recv data%s', (reqdata.length == 0) ? '' : ', got ' + reqdata.length + ' bytes'));

        /* 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, reqdata, res);
    });
}

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 */
    util.log('[server] listening on port ' + serverConfig.port);
});

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);
});