Use the new router
This commit is contained in:
parent
1dbaa54811
commit
167c7c4adb
3
TODO.md
3
TODO.md
@ -8,6 +8,9 @@
|
||||
* Proper markdown highlighting
|
||||
* Better about page text
|
||||
* test new interface in browsers
|
||||
* compress assets
|
||||
* cache static assets in memory with connect
|
||||
* look for a better way to do router
|
||||
|
||||
|
||||
# shared version only
|
||||
|
@ -7,7 +7,7 @@
|
||||
|
||||
"maxLength": 400000,
|
||||
|
||||
"cacheStaticAssets": false,
|
||||
"staticMaxAge": 86400,
|
||||
|
||||
"logging": [
|
||||
{
|
||||
|
@ -19,7 +19,8 @@
|
||||
|
||||
"dependencies": {
|
||||
"winston": "*",
|
||||
"hashlib": "*"
|
||||
"hashlib": "*",
|
||||
"connect": "*"
|
||||
},
|
||||
|
||||
"devDependencies": {
|
||||
|
45
server.js
45
server.js
@ -3,8 +3,8 @@ var url = require('url');
|
||||
var fs = require('fs');
|
||||
|
||||
var winston = require('winston');
|
||||
var connect = require('connect');
|
||||
|
||||
var StaticHandler = require('./lib/static_handler');
|
||||
var DocumentHandler = require('./lib/document_handler');
|
||||
|
||||
// Load the configuration and set some defaults
|
||||
@ -52,9 +52,6 @@ for (var name in config.documents) {
|
||||
});
|
||||
}
|
||||
|
||||
// Configure a static handler for the static files
|
||||
var staticHandler = new StaticHandler('./static', !!config.cacheStaticAssets);
|
||||
|
||||
// Configure the document handler
|
||||
var documentHandler = new DocumentHandler({
|
||||
store: preferredStore,
|
||||
@ -62,21 +59,31 @@ var documentHandler = new DocumentHandler({
|
||||
keyLength: config.keyLength
|
||||
});
|
||||
|
||||
// Set the server up and listen forever
|
||||
http.createServer(function(request, response) {
|
||||
var incoming = url.parse(request.url, false);
|
||||
var handler = null;
|
||||
// Looking to add a new doc
|
||||
if (incoming.pathname.match(/^\/documents$/) && request.method == 'POST') {
|
||||
// Set the server up with a static cache
|
||||
connect.createServer(
|
||||
connect.router(function(app) {
|
||||
// add documents
|
||||
app.post('/documents', function(request, response, next) {
|
||||
return documentHandler.handlePost(request, response);
|
||||
}
|
||||
// Looking up a doc
|
||||
var match = incoming.pathname.match(/^\/documents\/([A-Za-z0-9]+)$/);
|
||||
if (request.method == 'GET' && match) {
|
||||
return documentHandler.handleGet(match[1], response);
|
||||
}
|
||||
// Otherwise, look for static file
|
||||
staticHandler.handle(incoming.pathname, response);
|
||||
}).listen(config.port, config.host);
|
||||
});
|
||||
// get documents
|
||||
app.get('/documents/:id', function(request, response, next) {
|
||||
return documentHandler.handleGet(req.params.id, response);
|
||||
});
|
||||
}),
|
||||
// Otherwise, static
|
||||
connect.staticCache(),
|
||||
connect.static(__dirname + '/static', { maxAge: config.staticMaxAge }),
|
||||
// Then we can loop back - and change these into '/' TODO
|
||||
connect.router(function(app) {
|
||||
app.get('/:id', function(request, response, next) {
|
||||
request.url = request.originalUrl = '/';
|
||||
next();
|
||||
});
|
||||
}),
|
||||
// Static
|
||||
connect.staticCache(),
|
||||
connect.static(__dirname + '/static', { maxAge: config.staticMaxAge })
|
||||
).listen(config.port, config.host);
|
||||
|
||||
winston.info('listening on ' + config.host + ':' + config.port);
|
||||
|
Loading…
Reference in New Issue
Block a user