#i8
Basic express wrapper. More than express, it's a freeway. It's a tribute to San Diego, CA
###Hello World:
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
var handler = {
get: [{
path: '/', action: function (req, res, next) {
res.send('Hello World');
}
}]
}
server.use(i8.handleToRouter(handler), 'TestRouter');
server.startup();
The i8 server provides the following functions:
- env.json configuration (server.getConfig)
- Default and extensible error handling
- 404 handling
- server.use(), server.static() and i8.createRouter()
###req setup The server will create a req.i8 with logger and config.
var i8 = require('../main/index.js');
var logger = require('bunyan').createLogger({name: 'testApp'});
var server = new i8.Server(logger);
server.use('/', function (req, res, next) {
req.i8.logger.info('Showing config');
res.jsonp(req.i8.config);
});
server.startup();
###env.json configuration Given an env.json file
{ "development": {
"dbUrl": "mongo://localhost/dev"
},
"production": {
"dbUrl": "mongo://localhost/prd"
}
}
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
var config = server.getConfig();
console.dir(config)
It will display mongo://localhost/dev (By default the i8 server considers the environment as development).
But, if the NODE_ENV is defined to 'production'
process.env.NODE_ENV = 'production';
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
var config = server.getConfig();
console.dir(config)
It will display mongo://localhost/prd
###Default and extensible error handling The default error handler will set the status code to 500 (only if it is 200) log the url and the stacktrace. If the url starts with /api it will return an object with the error message {message: xyz}. Otherwise, not /api, it will check for a registred errorCallback and if it is registred, calls it. If no function is registred then it will return a page with statusCode: message
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
var router = i8.createRouter();
router.get('/', function (req, res, next) {
res.send('<ul>'+
'<li><a href="error">error</a></li>' +
'<li><a href="api/error">api/error</a></li>' +
'</ul>');
});
server.registerErrorCallback(function(err, req, res, next) {
res.send('The error ' + err.message + ' ocurred and your request cannot be completed.');
});
router.get('/error', function(req, res, next) {
throw Error('TestError');
})
router.get('/api/error', function(req, res, next) {
throw Error('ApiTestError');
})
server.startup();
You can also override server.setErorHandler(fn) before the startup if the current behaviour does not fit your needs.
server.setErrorHandler(function(err, req, res, next) {
res.send('SERVER_ERROR!');
});
###404 handling When a route is not found in the server, the i8 will set the status to 404 and throw an error (that will be handled by the errorHandler). You can override this, simply by registering a 404callback function. If you do that you have to handle the '/api' request too (maybe with a next(Error(notFound)?)
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
server.register404Callback(function(req, res, next) {
res.send('You requested the url ' + req.url + ' but it does not exist on our servers.');
});
server.startup();
Those are wrappers to remove the need of the express dependency on your project.
var i8 = require('i8');
var logger = require('bunyan').createLogger({ name: 'serverTest'});
var server = i8.Server(logger);
server.static('/static', './web');
var router = i8.createRouter();
router.get('/hello', function (req, res, next) {
res.send('Hello world!!');
});
server.use('/router', router);
server.startup();
Creates a new server instance.
- logger is a required bunnyan logger.
Starts listening on configured ports with registred routes.
- callback to be called after the server is started.
Register a route or middleware*
- arg1 could be a path or a middleware.
- arg2 if arg1 is a path, arg2 must be a router, else, it will be use as a log message to the middleare addition.
Register the path to serve static files.
- url network url
- path filesystem path
Register a function to be called when an error occur.
- callback
Register a function to be called when a path is not found.
Sets another errorhandler.
Returns the configuration used by the server.
Returns a function handle(err, data)
- 200 + jsonData
- 204 (noData)
- next(err)
Returns an express router.