2023-10-19 14:39:21 +02:00
|
|
|
const openidClient = require('openid-client');
|
|
|
|
|
2024-04-09 15:12:46 +02:00
|
|
|
/**
|
|
|
|
* oidc hook
|
|
|
|
*
|
|
|
|
* @description :: A hook definition. Extends Sails by adding shadow routes, implicit actions,
|
|
|
|
* and/or initialization logic.
|
|
|
|
* @docs :: https://sailsjs.com/docs/concepts/extending-sails/hooks
|
|
|
|
*/
|
|
|
|
|
|
|
|
module.exports = function defineOidcHook(sails) {
|
2023-10-19 14:39:21 +02:00
|
|
|
let client = null;
|
|
|
|
|
|
|
|
return {
|
|
|
|
/**
|
|
|
|
* Runs when this Sails app loads/lifts.
|
|
|
|
*/
|
|
|
|
async initialize() {
|
2024-11-18 23:38:52 +02:00
|
|
|
if (!this.isActive()) {
|
2024-04-09 15:12:46 +02:00
|
|
|
return;
|
2023-10-19 14:39:21 +02:00
|
|
|
}
|
2024-04-09 15:12:46 +02:00
|
|
|
|
|
|
|
sails.log.info('Initializing custom hook (`oidc`)');
|
2024-11-18 23:38:52 +02:00
|
|
|
},
|
2024-04-09 15:12:46 +02:00
|
|
|
|
2024-11-18 23:38:52 +02:00
|
|
|
async getClient() {
|
|
|
|
if (client === null && this.isActive()) {
|
|
|
|
sails.log.info('Initializing OIDC client');
|
2024-04-09 15:12:46 +02:00
|
|
|
|
2024-11-18 23:38:52 +02:00
|
|
|
const issuer = await openidClient.Issuer.discover(sails.config.custom.oidcIssuer);
|
2024-07-16 12:19:27 +02:00
|
|
|
|
2024-11-18 23:38:52 +02:00
|
|
|
const metadata = {
|
|
|
|
client_id: sails.config.custom.oidcClientId,
|
|
|
|
client_secret: sails.config.custom.oidcClientSecret,
|
|
|
|
redirect_uris: [sails.config.custom.oidcRedirectUri],
|
|
|
|
response_types: ['code'],
|
|
|
|
userinfo_signed_response_alg: sails.config.custom.oidcUserinfoSignedResponseAlg,
|
|
|
|
};
|
2024-07-16 12:19:27 +02:00
|
|
|
|
2024-11-18 23:38:52 +02:00
|
|
|
if (sails.config.custom.oidcIdTokenSignedResponseAlg) {
|
|
|
|
metadata.id_token_signed_response_alg = sails.config.custom.oidcIdTokenSignedResponseAlg;
|
|
|
|
}
|
|
|
|
|
|
|
|
client = new issuer.Client(metadata);
|
|
|
|
}
|
2023-10-19 14:39:21 +02:00
|
|
|
|
|
|
|
return client;
|
|
|
|
},
|
|
|
|
|
|
|
|
isActive() {
|
2024-11-18 23:38:52 +02:00
|
|
|
return sails.config.custom.oidcIssuer !== undefined;
|
2023-10-19 14:39:21 +02:00
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|