Udaru is a Policy Based Access Control (PBAC) authorization module. It supports Organizations, Teams and User entities that are used to build the access model. The policies attached to these entities define the 'Actions' that can be performed by an entity on various 'Resources'.
See the Udaru website for complete documentation on Udaru.
To install via npm:
npm install @nearform/udaru-hapi-plugin
const Hapi = require('hapi')
const UdaruPlugin = require('@nearform/udaru-hapi-plugin')
...
const server = Hapi.server()
await server.register({register: UdaruPlugin})
In order to register udaru hooks, just provide a hooks
key in the plugin options where keys are the names and values are handler functions (or array of functions).
const Hapi = require('hapi')
const UdaruPlugin = require('@nearform/udaru-hapi-plugin')
...
const server = new Hapi.server()
await server.register({
register: UdaruPlugin,
options: {
// Other options here
hooks: {
'authorize:isUserAuthorized': [
async function (error, args, result) {
if (error) {
console.error(`Authorization errored: ${error}`)
} else {
console.log(`Access to ${args[0]} got access: ${result[0].access}`)
}
}
]
}
}
})
Copyright nearForm Ltd 2017. Licensed under MIT.