From ceeb4a289d1fb5864d0dea4a628f3f1ea66221b1 Mon Sep 17 00:00:00 2001 From: Benoit Serrano Date: Tue, 30 Apr 2024 17:01:29 +0200 Subject: [PATCH] use email from user info --- lib/oidcAuth.js | 38 +++++++++++++++++++++++--------------- 1 file changed, 23 insertions(+), 15 deletions(-) diff --git a/lib/oidcAuth.js b/lib/oidcAuth.js index 4c6ae9ad..cdf006d4 100644 --- a/lib/oidcAuth.js +++ b/lib/oidcAuth.js @@ -96,23 +96,31 @@ module.exports.finishAuth = async (req) => { return { error: "L'identification a échoué. Entrez votre adresse mail ci-dessous pour recommencer." } } - const tokenSet = await client.callback( - config.HOSTNAME_WITH_PROTOCOL + urlCallback, - params, - { - state: request.state, - nonce: request.nonce - // todo code_verifier: req.session.code_verifier - } - ) - const claims = tokenSet.claims() - console.log(`CLAIMS : ${JSON.stringify(claims)}`) - const userinfo = await client.userinfo(tokenSet) - console.log(`USERINFO : ${JSON.stringify(userinfo)}`) + let tokenSet + try { + tokenSet = await client.callback( + config.HOSTNAME_WITH_PROTOCOL + urlCallback, + params, + { + state: request.state, + nonce: request.nonce + // todo code_verifier: req.session.code_verifier + } + ) + } catch(error){ + console.error("error when requesting token from OIDC", error) + return { error: "L'identification a échoué. Entrez votre adresse mail ci-dessous pour recommencer." } + } + let userinfo + try { + userinfo = await client.userinfo(tokenSet) + } catch(error){ + console.error("error when requesting userinfo from OIDC", error) + return { error: "L'identification a échoué. Entrez votre adresse mail ci-dessous pour recommencer." } + } + const email = userinfo.email - const email = claims.preferred_username - return { email, durationInMinutes: request.durationInMinutes,