Comments (3)
After some researching I found a different solution to this problem by using server.dependency()
:
'use strict';
const Hapi = require('@hapi/hapi');
const Credentials = require('some-credentials-plugin');
const Bell = require('@hapi/bell');
const Routes = {
name: 'routes',
register(server) {
server.dependency('some-credentials-plugin', (srv) => {
// at this point credentials are already available because server has already been initialized
const credentials = server.plugins.credentials.get('the-client-type');
srv.auth.strategy('third-party', 'bell', credentials);
srv.route({
path: '/login',
method: ['GET', 'POST'],
options: {
auth: 'third-party',
handler() {
return 'welcome';
},
},
});
});
},
};
async function run() {
const server = Hapi.server();
await server.register([
Bell,
Routes,
{
plugin: Credentials,
options: {
type: 'the-client-type',
scopes: ['scope-a'],
},
},
]);
await server.initialize();
}
As usual, the framework is always as flexible as one would wish!
from bell.
I'm not well-versed with bell mecanism but it seems like a reasonable feature to me.
from bell.
That's a nifty solution @jonathansamines. Well done!
from bell.
Related Issues (20)
- How to get facebook profile picture with custom size? HOT 5
- Support for idp with self signed certificates HOT 3
- Only node 12
- Require hapi 19
- Change plugin name to @hapi/bell
- Expose public API to refresh tokens HOT 2
- Replace Yahoo Social Directory Web Service HOT 2
- Issue with the meetup provider HOT 1
- "Failed obtaining twitch user profile" when using Twitch provider HOT 4
- Support functions for `provider.auth` and `provider.token` HOT 2
- Sign in with apple HOT 5
- Using for 3rd party tenants HOT 3
- docs: api page tutorial links to dead page HOT 1
- Improve the debugging experience when a payload is involved HOT 1
- Please document usage of local strategy
- Improve handling of rate limiting by Okta provider
- Add timeout configuration for requests
- Change callback path HOT 4
- Big cookie size
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from bell.