GraphQL resolver for using router level middlewares at ease.
- Easy to use.
- Actively maintained.
- Zero dependency.
- Handles router-level middleware in graphql just like in expressJs.
$ npm install graphql-router-ware
import Router from 'graphql-router-ware';
// your code here...
const Router = require('graphql-router-ware');
// your code here...
import Router from 'graphql-router-ware';
import { checkPermission } from '../helpers/userhalper';
import Controller from '../controllers/page';
const resolvers = {
Query: {
singlePage: Router(Controller.singlePage)
},
Mutation: {
createPage: Router(checkPermission,Controller.create),
updatePage: Router(checkPermission,Controller.update),
}
}
export default resolvers;
// ....
export checkPermission=({ ctx },next)=>{
if(!ctx.user){
return next(new Error('Not logged in'));
// or throw new Error('Not logged in')
}
// some more permission checks....
return next();
};
// ....
// ....
export create=({ args,ctx })=>{
// Already all the permissions have been verified...
const page = { ...args, userId: ctx.user };
// some more operations....
return page;
};
// ....
It can take any number of functions which are called one by one using the next parameter passed in all functions.
It is passed in each of your functions as the last parameter. To continue the chain you need to return this function call at the end of your function
next() // this will call the next function in chain
next(err) // this will stop the chain and throws error to graphql
You will recieve all the graphql parameters in the first argument and next function as second argument.
Note : You need to return the next() from your router function to continue the chain.