forked from authts/oidc-client-ts
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUserInfoService.ts
More file actions
58 lines (49 loc) · 1.93 KB
/
Copy pathUserInfoService.ts
File metadata and controls
58 lines (49 loc) · 1.93 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Copyright (c) Brock Allen & Dominick Baier. All rights reserved.
// Licensed under the Apache License, Version 2.0. See LICENSE in the project root for license information.
import { Logger, JwtUtils } from "./utils";
import { JsonService } from "./JsonService";
import type { MetadataService } from "./MetadataService";
import type { JwtClaims } from "./Claims";
import type { OidcClientSettingsStore } from "./OidcClientSettings";
/**
* @internal
*/
export class UserInfoService {
protected readonly _logger = new Logger("UserInfoService");
private readonly _jsonService: JsonService;
public constructor(private readonly _settings: OidcClientSettingsStore,
private readonly _metadataService: MetadataService,
) {
this._jsonService = new JsonService(
undefined,
this._getClaimsFromJwt,
this._settings.extraHeaders,
);
}
public async getClaims(token: string): Promise<JwtClaims> {
const logger = this._logger.create("getClaims");
if (!token) {
this._logger.throw(new Error("No token passed"));
}
const url = await this._metadataService.getUserInfoEndpoint();
logger.debug("got userinfo url", url);
const claims = await this._jsonService.getJson(url, {
token,
credentials: this._settings.fetchRequestCredentials,
timeoutInSeconds: this._settings.requestTimeoutInSeconds,
});
logger.debug("got claims", claims);
return claims;
}
protected _getClaimsFromJwt = async (responseText: string): Promise<JwtClaims> => {
const logger = this._logger.create("_getClaimsFromJwt");
try {
const payload = JwtUtils.decode(responseText);
logger.debug("JWT decoding successful");
return payload;
} catch (err) {
logger.error("Error parsing JWT response");
throw err;
}
};
}