A small extension of Express routing.
$ npm install @novice1/routing
It keeps all the functionalities of Express router and extends them.
A JSON object can be sent as the path
parameter when using route methods (get
, post
, ...), all
and route
. That object must have the property path
and can also have the following properties:
name
: (string)description
: (string)parameters
: (object)responses
: (any)tags
: (string[])auth
: (boolean)preValidators
: (function[])
Example:
var router = require('@novice1/routing')()
router.get({
path: '/',
name: 'Home',
description: 'Home page',
parameters: {
// ...
},
responses: {
// ...
},
tags: ['Index']
}, function (req, res) {
// information about the current route
// can be found at req.meta
res.json(req.meta)
})
From those properties, only path
and auth
influence the routing.
When you need to verify the client's authentication the same way for a router's route, you can set middlewares with the method setAuthHandlers
. Those middlewares will only be executed for routes with auth
set to true
.
var router = require('@novice1/routing')()
// set middleware(s) to handle authentication
router.setAuthHandlers(function (req, res, next) {
// do something
next()
}, function (req, res, next) {
// do something else
next()
})
router.get({
name: 'Home',
path: '/'
}, function (req, res) {
res.send('hello world')
})
router.get({
auth: true, // handle the authentication for this route
name: 'Management',
path: '/admin'
}, function (req, res) {
res.send('hello admin')
})
setAuthHandlers
can be called before or after creating the routes.
You can use setValidators
to set handlers that valid the client's request.
Those middlewares have access to req.meta
so you could make use of the property parameters
for example.
var router = require('@novice1/routing')()
router.get({
name: 'Main app',
// set parameters
parameters: {
query: {
version: "number" // e.g.: the type that the query variable 'version' should have
}
},
path: '/app'
}, function (req, res) {
res.json(req.meta)
})
// check requests for this router
router.setValidators(function (req, res, next) {
if(req.meta.parameters.query.version == 'number') {
if(!isNaN(req.query.version)) {
// ok
next()
} else {
// client's request is not valid
res.status(400).send('Bad request')
}
} else {
// ok
next()
}
})
setValidators
can be called before or after creating the routes.
As a router can be a middleware of another router (use
method), you might want to keep different auth
and validator
handlers for some routers. For example a router might have its own auth
handlers while being use
d by a router also having auth
handlers. For that purpose there are some methods:
setAuthHandlersIfNone
setValidatorsIfNone
Example:
var routing = require('@novice1/routing')
var routerChild = routing()
routerChild.get('/', function (req, res) {
res.json(req.meta)
})
routerChild.setValidators(function (req, res, next) {
next()
})
var routerParent = routing()
routerParent.put('/', function (req, res) {
res.json(req.meta)
})
// use 'routerChild' in 'routerParent'
routerParent.use(routerChild)
// set validators for routes except for
// those already having validators
routerParent.setValidatorsIfNone(function (req, res, next) {
next()
})
This package extends Request
interface from express so you can always extend it more depending on your needs.
Example:
declare global {
namespace Express {
interface Request {
// add a property
session?: Record<string, any>;
}
}
}