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