Routes loader for Node.js Express applications.
npm install --save fi-routesvar routes = require('fi-routes');You must call it with your Express' application instance and a configuration object:
var routes = require('fi-routes');
var express = require('express');
var app = express();
routes(app, config);
app.listen(0);The configuration option can have the following properties:
- debug: This is optional and can be a
Functionto log into or aBoolean. Iftrueit will useconsole.log. - basedir: This is required and must be a
String. This is the absolute path where the route modules are located. - arguments: This is optional and can be an array of values you wish to pass to each route module after the router.
{
basedir: path.join(__basedir, 'routes'),
debug: require('debug')('app:routes'),
arguments: [
require('mongoose')
]
}The route modules inside your config.basedir folder must be like this:
module.exports = function (router) {
router.get('/', function (req, res, next) {
//...
});
router.post('/', function (req, res, next) {
//...
});
router.get('/filtered', function (req, res, next) {
//...
});
};The exported function will receive the router instance as created with express.Router() and the additional arguments. If the module's file name is index.js then its route will be / relative to its folder.
The first parameter will always be express.Router() so you can define your routes. The rest of the parameters will be the ones you define in the config.arguments Array:
config.arguments = [
/* Second argument */
require('mongoose'),
/* Third argument */
function aFunction() {
//...
}
/* And so on... */
];Will be passed as:
/* express.Router() will always be the first argument */
module.exports = function (router, mongoose, aFunction) {
router.get('/filtered', function (req, res, next) {
//...
});
//...
};Folders are also respected, so if a socket module is located in <...>/routes/api/resources.js then its path will be /api/resources and if its file name is index.js inside that same folder then its path will be /api.
As you can see, you can declare sub paths inside each route module so be aware of the order that routes are processed and double check not to mix-up a declared route module path with a sub folder module name or path.