-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathserver.js
65 lines (59 loc) · 2.12 KB
/
server.js
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
62
63
64
65
var commander = require('commander');
var fs = require('fs');
var path = require('path');
commander.
option('-p, --port <port>', 'Port to run on', Number).
parse(process.argv);
require('http').createServer(function (request, response) {
request.addListener('end', function() {
console.log(request.url);
// Backwards-compatible support for wordpress, because wordpress allows
// URLs like `/2013/06/06/61/` to map to the blog post `61`
if (request.url.length > 1 &&
request.url.charAt(request.url.length - 1) === '/') {
request.url = request.url.substr(0, request.url.length - 1);
}
if (request.url.indexOf('?') !== -1) {
request.url = request.url.substr(0, request.url.indexOf('?'));
}
// Defend against directory traversals
var p = path.join('./bin', request.url.replace('../', ''));
fs.stat(p, function(err, stats) {
if (err || !stats) {
response.writeHead(404, {
'Cache-Control': 'max-age=7200',
'Content-Type': 'text/plain'
});
return response.end("Not found");
}
if (stats.isFile()) {
var type = path.extname(p);
if (type === '.xml') {
type = 'application/xml'
}
response.writeHead(200, {
'Cache-Control': 'max-age=7200',
'Content-Type': type || 'text/html'
});
fs.createReadStream(p).pipe(response);
} else {
var indexPath = path.join(p, 'index');
fs.stat(indexPath, function(err, stats) {
if (err || !stats || !stats.isFile()) {
response.writeHead(404, {
'Cache-Control': 'max-age=7200',
'Content-Type': 'text/plain'
});
return response.end("Not found");
}
response.writeHead(200, {
'Cache-Control': 'max-age=7200',
'Content-Type': type || 'text/html'
});
fs.createReadStream(indexPath).pipe(response);
});
}
});
}).resume();
}).listen(process.env.PORT || commander.port || 8080);
console.log('Server listening on port ' + (process.env.PORT || commander.port || 8080));