本文整理匯總了TypeScript中idam/idamClient.IdamClient.retrieveUserFor方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript IdamClient.retrieveUserFor方法的具體用法?TypeScript IdamClient.retrieveUserFor怎麽用?TypeScript IdamClient.retrieveUserFor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類idam/idamClient.IdamClient
的用法示例。
在下文中一共展示了IdamClient.retrieveUserFor方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: Cookies
ErrorHandling.apply(async (req: express.Request,
res: express.Response,
next: express.NextFunction): Promise<void> => {
const cookies = new Cookies(req, res)
let user
try {
const authenticationToken = await getAuthToken(req)
if (authenticationToken) {
user = await IdamClient.retrieveUserFor(authenticationToken)
res.locals.isLoggedIn = true
res.locals.user = user
setAuthCookie(cookies, authenticationToken)
}
} catch (err) {
return loginErrorHandler(req, res, cookies, next, err)
}
if (res.locals.isLoggedIn) {
if (isDefendantFirstContactPinLogin(req)) {
// re-set state cookie as it was cleared above, we need it in this case
cookies.set(stateCookieName, req.query.state)
return res.redirect(FirstContactPaths.claimSummaryPage.uri)
} else {
await claimStoreClient.linkDefendant(user)
res.redirect(await retrieveRedirectForLandingPage(req, res))
}
} else {
if (res.locals.code) {
trackCustomEvent('Authentication token undefined (jwt defined)',
{ requestValue: req.query.state })
}
res.redirect(OAuthHelper.forLogin(req, res))
}
}))
示例2: authorizationRequestHandler
async function authorizationRequestHandler (req: express.Request, res: express.Response, next: express.NextFunction) {
const jwt: string = JwtExtractor.extract(req)
if (jwt) {
try {
await IdamClient.retrieveUserFor(jwt)
res.locals.isLoggedIn = true
} catch (err) {
if (!hasTokenExpired(err)) {
next(err)
return
}
}
}
next()
}
示例3: return
return (req: express.Request, res: express.Response, next: express.NextFunction) => {
const jwt: string = JwtExtractor.extract(req)
if (isPathUnprotected(req.path)) {
logger.debug(`Unprotected path - access to ${req.path} granted`)
return next()
}
if (!jwt) {
logger.debug(`Protected path - no JWT - access to ${req.path} rejected`)
return accessDeniedCallback(req, res)
} else {
IdamClient
.retrieveUserFor(jwt)
.then((user: User) => {
if (!user.isInRoles(...requiredRoles)) {
logger.error(`Protected path - valid JWT but user not in ${requiredRoles} roles - redirecting to access denied page`)
return accessDeniedCallback(req, res)
} else {
res.locals.isLoggedIn = true
res.locals.user = user
logger.debug(`Protected path - valid JWT & role - access to ${req.path} granted`)
return next()
}
})
.catch((err) => {
if (hasTokenExpired(err)) {
const cookies = new Cookies(req, res)
cookies.set(sessionCookieName, '')
logger.debug(`Protected path - invalid JWT - access to ${req.path} rejected`)
return accessDeniedCallback(req, res)
}
return next(err)
})
}
}