@kolektor/nucleus-identity 0.0.12-pre.7931 → 0.1.0-pre.128
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -0
- package/esm2022/index.mjs +7 -0
- package/esm2022/kolektor-nucleus-identity.mjs +5 -0
- package/esm2022/lib/models/client-registration.mjs +8 -0
- package/esm2022/lib/models/device-code.mjs +19 -0
- package/esm2022/lib/models/identity.mjs +52 -0
- package/esm2022/lib/models/otp.mjs +11 -0
- package/esm2022/lib/models/service-principal.mjs +16 -0
- package/esm2022/lib/nucleus-identity-config.mjs +7 -0
- package/esm2022/lib/nucleus-identity.module.mjs +32 -0
- package/esm2022/lib/nucleus-identity.service.mjs +350 -0
- package/esm2022/lib/nucleus-token-interceptor.service.mjs +69 -0
- package/esm2022/lib/utils/angular-requestor.mjs +44 -0
- package/esm2022/lib/utils/authorization-service-configuration.mjs +28 -0
- package/esm2022/lib/utils/location.service.mjs +72 -0
- package/esm2022/lib/utils/nucleus-authorization-notifier.mjs +15 -0
- package/esm2022/lib/utils/oidc-configuration.service.mjs +95 -0
- package/esm2022/lib/utils/secrets-store.mjs +120 -0
- package/esm2022/lib/utils/token-client.mjs +140 -0
- package/{fesm2020 → fesm2022}/kolektor-nucleus-identity.mjs +980 -1012
- package/fesm2022/kolektor-nucleus-identity.mjs.map +1 -0
- package/index.d.ts +6 -5
- package/lib/models/client-registration.d.ts +11 -11
- package/lib/models/device-code.d.ts +19 -19
- package/lib/models/identity.d.ts +14 -14
- package/lib/models/otp.d.ts +14 -14
- package/lib/models/service-principal.d.ts +12 -12
- package/lib/nucleus-identity-config.d.ts +12 -12
- package/lib/nucleus-identity.module.d.ts +9 -9
- package/lib/nucleus-identity.service.d.ts +63 -63
- package/lib/nucleus-token-interceptor.service.d.ts +19 -19
- package/lib/utils/angular-requestor.d.ts +11 -11
- package/lib/utils/authorization-service-configuration.d.ts +12 -12
- package/lib/utils/location.service.d.ts +25 -25
- package/lib/utils/nucleus-authorization-notifier.d.ts +9 -9
- package/lib/utils/oidc-configuration.service.d.ts +23 -23
- package/lib/utils/secrets-store.d.ts +33 -33
- package/lib/utils/token-client.d.ts +23 -23
- package/package.json +29 -33
- package/esm2020/kolektor-nucleus-identity.mjs +0 -5
- package/esm2020/lib/models/client-registration.mjs +0 -8
- package/esm2020/lib/models/device-code.mjs +0 -19
- package/esm2020/lib/models/identity.mjs +0 -49
- package/esm2020/lib/models/otp.mjs +0 -11
- package/esm2020/lib/models/service-principal.mjs +0 -16
- package/esm2020/lib/nucleus-identity-config.mjs +0 -8
- package/esm2020/lib/nucleus-identity.module.mjs +0 -28
- package/esm2020/lib/nucleus-identity.service.mjs +0 -341
- package/esm2020/lib/nucleus-token-interceptor.service.mjs +0 -64
- package/esm2020/lib/utils/angular-requestor.mjs +0 -38
- package/esm2020/lib/utils/authorization-service-configuration.mjs +0 -23
- package/esm2020/lib/utils/location.service.mjs +0 -72
- package/esm2020/lib/utils/nucleus-authorization-notifier.mjs +0 -13
- package/esm2020/lib/utils/nucleus-crypto.mjs +0 -68
- package/esm2020/lib/utils/oidc-configuration.service.mjs +0 -90
- package/esm2020/lib/utils/secrets-store.mjs +0 -120
- package/esm2020/lib/utils/token-client.mjs +0 -140
- package/esm2020/public-api.mjs +0 -11
- package/fesm2015/kolektor-nucleus-identity.mjs +0 -1139
- package/fesm2015/kolektor-nucleus-identity.mjs.map +0 -1
- package/fesm2020/kolektor-nucleus-identity.mjs.map +0 -1
- package/lib/utils/nucleus-crypto.d.ts +0 -9
- package/public-api.d.ts +0 -7
package/README.md
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './lib/nucleus-identity.module';
|
|
2
|
+
export * from './lib/nucleus-identity.service';
|
|
3
|
+
export * from './lib/nucleus-identity-config';
|
|
4
|
+
export { OtpResponse, OtpStatus, OtpType } from './lib/models/otp';
|
|
5
|
+
export { DeviceCode } from './lib/models/device-code';
|
|
6
|
+
export { ServicePrincipalRegistrationStatus } from './lib/models/service-principal';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25FLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL251Y2xldXMtaWRlbnRpdHkubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL251Y2xldXMtaWRlbnRpdHkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9udWNsZXVzLWlkZW50aXR5LWNvbmZpZyc7XG5leHBvcnQgeyBPdHBSZXNwb25zZSwgT3RwU3RhdHVzLCBPdHBUeXBlIH0gZnJvbSAnLi9saWIvbW9kZWxzL290cCc7XG5leHBvcnQgeyBEZXZpY2VDb2RlIH0gZnJvbSAnLi9saWIvbW9kZWxzL2RldmljZS1jb2RlJztcbmV4cG9ydCB7IFNlcnZpY2VQcmluY2lwYWxSZWdpc3RyYXRpb25TdGF0dXMgfSBmcm9tICcuL2xpYi9tb2RlbHMvc2VydmljZS1wcmluY2lwYWwnO1xuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia29sZWt0b3ItbnVjbGV1cy1pZGVudGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvbmcvbnVjbGV1cy1pZGVudGl0eS9zcmMva29sZWt0b3ItbnVjbGV1cy1pZGVudGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export class ClientRegistrationResponse {
|
|
2
|
+
constructor(response) {
|
|
3
|
+
this.clientId = response.client_id;
|
|
4
|
+
this.clientSecret = response.client_secret;
|
|
5
|
+
this.secretExpirationDate = new Date(response.client_secret_expires_at * 1000);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LXJlZ2lzdHJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmcvbnVjbGV1cy1pZGVudGl0eS9zcmMvbGliL21vZGVscy9jbGllbnQtcmVnaXN0cmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE1BQU0sT0FBTywwQkFBMEI7SUFDckMsWUFBWSxRQUF3QztRQUNsRCxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDbkMsSUFBSSxDQUFDLFlBQVksR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDO1FBQzNDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLElBQUksQ0FDbEMsUUFBUSxDQUFDLHdCQUF3QixHQUFHLElBQUksQ0FDekMsQ0FBQztJQUNKLENBQUM7Q0FLRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2xpZW50UmVnaXN0cmF0aW9uUmVzcG9uc2VKc29uIHtcbiAgY2xpZW50X2lkOiBzdHJpbmc7XG4gIGNsaWVudF9zZWNyZXQ6IHN0cmluZztcbiAgY2xpZW50X3NlY3JldF9leHBpcmVzX2F0OiBudW1iZXI7XG59XG5cbmV4cG9ydCBjbGFzcyBDbGllbnRSZWdpc3RyYXRpb25SZXNwb25zZSB7XG4gIGNvbnN0cnVjdG9yKHJlc3BvbnNlOiBDbGllbnRSZWdpc3RyYXRpb25SZXNwb25zZUpzb24pIHtcbiAgICB0aGlzLmNsaWVudElkID0gcmVzcG9uc2UuY2xpZW50X2lkO1xuICAgIHRoaXMuY2xpZW50U2VjcmV0ID0gcmVzcG9uc2UuY2xpZW50X3NlY3JldDtcbiAgICB0aGlzLnNlY3JldEV4cGlyYXRpb25EYXRlID0gbmV3IERhdGUoXG4gICAgICByZXNwb25zZS5jbGllbnRfc2VjcmV0X2V4cGlyZXNfYXQgKiAxMDAwXG4gICAgKTtcbiAgfVxuXG4gIGNsaWVudElkOiBzdHJpbmc7XG4gIGNsaWVudFNlY3JldDogc3RyaW5nO1xuICBzZWNyZXRFeHBpcmF0aW9uRGF0ZTogRGF0ZTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { nowInSeconds } from '@openid/appauth';
|
|
2
|
+
export class DeviceCode {
|
|
3
|
+
constructor(response) {
|
|
4
|
+
this.deviceCode = response.device_code;
|
|
5
|
+
this.userCode = response.user_code;
|
|
6
|
+
this.verificationUrl = response.verification_uri;
|
|
7
|
+
this.verificationUrlComplete = response.verification_uri_complete;
|
|
8
|
+
this.expiresIn = parseInt(response.expires_in, 10);
|
|
9
|
+
this.issuedAt = nowInSeconds();
|
|
10
|
+
}
|
|
11
|
+
isExpired(buffer = 60) {
|
|
12
|
+
return this.secondsLeft(buffer) <= 0;
|
|
13
|
+
}
|
|
14
|
+
secondsLeft(buffer = 60) {
|
|
15
|
+
const now = nowInSeconds();
|
|
16
|
+
return this.issuedAt + this.expiresIn - buffer - now;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV2aWNlLWNvZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2xpYi9tb2RlbHMvZGV2aWNlLWNvZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBVy9DLE1BQU0sT0FBTyxVQUFVO0lBQ3JCLFlBQVksUUFBd0I7UUFDbEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLFNBQVMsQ0FBQztRQUNuQyxJQUFJLENBQUMsZUFBZSxHQUFHLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQztRQUNqRCxJQUFJLENBQUMsdUJBQXVCLEdBQUcsUUFBUSxDQUFDLHlCQUF5QixDQUFDO1FBQ2xFLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLFFBQVEsR0FBRyxZQUFZLEVBQUUsQ0FBQztJQUNqQyxDQUFDO0lBVUQsU0FBUyxDQUFDLE1BQU0sR0FBRyxFQUFFO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVELFdBQVcsQ0FBQyxNQUFNLEdBQUcsRUFBRTtRQUNyQixNQUFNLEdBQUcsR0FBRyxZQUFZLEVBQUUsQ0FBQztRQUMzQixPQUFPLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLEdBQUcsR0FBRyxDQUFDO0lBQ3ZELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG5vd0luU2Vjb25kcyB9IGZyb20gJ0BvcGVuaWQvYXBwYXV0aCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGV2aWNlQ29kZUpzb24ge1xuICBkZXZpY2VfY29kZTogc3RyaW5nO1xuICB1c2VyX2NvZGU6IHN0cmluZztcbiAgdmVyaWZpY2F0aW9uX3VyaTogc3RyaW5nO1xuICB2ZXJpZmljYXRpb25fdXJpX2NvbXBsZXRlOiBzdHJpbmc7XG4gIGV4cGlyZXNfaW46IHN0cmluZztcbiAgbWVzc2FnZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgRGV2aWNlQ29kZSB7XG4gIGNvbnN0cnVjdG9yKHJlc3BvbnNlOiBEZXZpY2VDb2RlSnNvbikge1xuICAgIHRoaXMuZGV2aWNlQ29kZSA9IHJlc3BvbnNlLmRldmljZV9jb2RlO1xuICAgIHRoaXMudXNlckNvZGUgPSByZXNwb25zZS51c2VyX2NvZGU7XG4gICAgdGhpcy52ZXJpZmljYXRpb25VcmwgPSByZXNwb25zZS52ZXJpZmljYXRpb25fdXJpO1xuICAgIHRoaXMudmVyaWZpY2F0aW9uVXJsQ29tcGxldGUgPSByZXNwb25zZS52ZXJpZmljYXRpb25fdXJpX2NvbXBsZXRlO1xuICAgIHRoaXMuZXhwaXJlc0luID0gcGFyc2VJbnQocmVzcG9uc2UuZXhwaXJlc19pbiwgMTApO1xuICAgIHRoaXMuaXNzdWVkQXQgPSBub3dJblNlY29uZHMoKTtcbiAgfVxuXG4gIHByaXZhdGUgZXhwaXJlc0luOiBudW1iZXI7XG4gIHByaXZhdGUgaXNzdWVkQXQ6IG51bWJlcjtcblxuICBwdWJsaWMgZGV2aWNlQ29kZTogc3RyaW5nO1xuICBwdWJsaWMgdXNlckNvZGU6IHN0cmluZztcbiAgcHVibGljIHZlcmlmaWNhdGlvblVybDogc3RyaW5nO1xuICBwdWJsaWMgdmVyaWZpY2F0aW9uVXJsQ29tcGxldGU6IHN0cmluZztcblxuICBpc0V4cGlyZWQoYnVmZmVyID0gNjApIHtcbiAgICByZXR1cm4gdGhpcy5zZWNvbmRzTGVmdChidWZmZXIpIDw9IDA7XG4gIH1cblxuICBzZWNvbmRzTGVmdChidWZmZXIgPSA2MCkge1xuICAgIGNvbnN0IG5vdyA9IG5vd0luU2Vjb25kcygpO1xuICAgIHJldHVybiB0aGlzLmlzc3VlZEF0ICsgdGhpcy5leHBpcmVzSW4gLSBidWZmZXIgLSBub3c7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export class Claim {
|
|
2
|
+
constructor(name, values) {
|
|
3
|
+
this.name = name;
|
|
4
|
+
this.values = values;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export class Identity {
|
|
8
|
+
constructor(res) {
|
|
9
|
+
this.claims = [];
|
|
10
|
+
if (!res.idToken) {
|
|
11
|
+
throw Error("There is no id token in the token response!");
|
|
12
|
+
}
|
|
13
|
+
const token = this.decodeToken(res.idToken);
|
|
14
|
+
this.name = token.name;
|
|
15
|
+
this.subject = token.sub;
|
|
16
|
+
for (const key in token) {
|
|
17
|
+
if ({}.hasOwnProperty.call(token, key)) {
|
|
18
|
+
let vals = token[key];
|
|
19
|
+
if (!Array.isArray(vals)) {
|
|
20
|
+
vals = [vals];
|
|
21
|
+
}
|
|
22
|
+
const claim = new Claim(key, vals);
|
|
23
|
+
this.claims.push(claim);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
28
|
+
decodeToken(jwt) {
|
|
29
|
+
if (!jwt) {
|
|
30
|
+
throw new Error('NucleusIdentity: There was no identity token in the response!');
|
|
31
|
+
}
|
|
32
|
+
try {
|
|
33
|
+
const arr = jwt.split('.');
|
|
34
|
+
// var header = arr[0];
|
|
35
|
+
const payload = this.b64DecodeUnicode(arr[1]);
|
|
36
|
+
// var signature = arr[2];
|
|
37
|
+
return JSON.parse(payload);
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
console.error('Error while decoding identity token', error);
|
|
41
|
+
console.error('Error while decoding identity token JWT', jwt);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
b64DecodeUnicode(str) {
|
|
45
|
+
str = str.replace(/-/g, '+').replace(/_/g, '/'); // Qlector fix :)
|
|
46
|
+
return decodeURIComponent(atob(str)
|
|
47
|
+
.split('')
|
|
48
|
+
.map((c) => '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2))
|
|
49
|
+
.join(''));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRlbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2xpYi9tb2RlbHMvaWRlbnRpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLEtBQUs7SUFJaEIsWUFBWSxJQUFZLEVBQUUsTUFBZ0I7UUFDeEMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdkIsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLFFBQVE7SUFNbkIsWUFBWSxHQUFrQjtRQUZ2QixXQUFNLEdBQVksRUFBRSxDQUFDO1FBRzFCLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFO1lBQ2hCLE1BQU0sS0FBSyxDQUFDLDZDQUE2QyxDQUFDLENBQUM7U0FDNUQ7UUFFRCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUU1QyxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUM7UUFDdkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDO1FBQ3pCLEtBQUssTUFBTSxHQUFHLElBQUksS0FBSyxFQUFFO1lBQ3ZCLElBQUksRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxFQUFFO2dCQUN0QyxJQUFJLElBQUksR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBRXRCLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUN4QixJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztpQkFDZjtnQkFFRCxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7Z0JBQ25DLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQ3pCO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsOERBQThEO0lBQ3RELFdBQVcsQ0FBQyxHQUFXO1FBQzdCLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDUixNQUFNLElBQUksS0FBSyxDQUNiLCtEQUErRCxDQUNoRSxDQUFDO1NBQ0g7UUFFRCxJQUFJO1lBQ0YsTUFBTSxHQUFHLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUMzQix1QkFBdUI7WUFDdkIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlDLDBCQUEwQjtZQUMxQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDNUI7UUFBQyxPQUFPLEtBQUssRUFBRTtZQUNkLE9BQU8sQ0FBQyxLQUFLLENBQUMscUNBQXFDLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDNUQsT0FBTyxDQUFDLEtBQUssQ0FBQyx5Q0FBeUMsRUFBRSxHQUFHLENBQUMsQ0FBQztTQUMvRDtJQUNILENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxHQUFXO1FBQ2xDLEdBQUcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsaUJBQWlCO1FBQ2xFLE9BQU8sa0JBQWtCLENBQ3ZCLElBQUksQ0FBQyxHQUFHLENBQUM7YUFDTixLQUFLLENBQUMsRUFBRSxDQUFDO2FBQ1QsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNqRSxJQUFJLENBQUMsRUFBRSxDQUFDLENBQ1osQ0FBQztJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRva2VuUmVzcG9uc2UgfSBmcm9tICdAb3BlbmlkL2FwcGF1dGgnO1xuXG5leHBvcnQgY2xhc3MgQ2xhaW0ge1xuICBwdWJsaWMgbmFtZTogc3RyaW5nO1xuICBwdWJsaWMgdmFsdWVzOiBzdHJpbmdbXTtcblxuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIHZhbHVlczogc3RyaW5nW10pIHtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgIHRoaXMudmFsdWVzID0gdmFsdWVzO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBJZGVudGl0eSB7XG4gIHB1YmxpYyBuYW1lOiBzdHJpbmc7XG4gIHB1YmxpYyBzdWJqZWN0OiBzdHJpbmc7XG5cbiAgcHVibGljIGNsYWltczogQ2xhaW1bXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHJlczogVG9rZW5SZXNwb25zZSkge1xuICAgIGlmICghcmVzLmlkVG9rZW4pIHtcbiAgICAgIHRocm93IEVycm9yKFwiVGhlcmUgaXMgbm8gaWQgdG9rZW4gaW4gdGhlIHRva2VuIHJlc3BvbnNlIVwiKTtcbiAgICB9XG5cbiAgICBjb25zdCB0b2tlbiA9IHRoaXMuZGVjb2RlVG9rZW4ocmVzLmlkVG9rZW4pO1xuXG4gICAgdGhpcy5uYW1lID0gdG9rZW4ubmFtZTtcbiAgICB0aGlzLnN1YmplY3QgPSB0b2tlbi5zdWI7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gdG9rZW4pIHtcbiAgICAgIGlmICh7fS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHRva2VuLCBrZXkpKSB7XG4gICAgICAgIGxldCB2YWxzID0gdG9rZW5ba2V5XTtcblxuICAgICAgICBpZiAoIUFycmF5LmlzQXJyYXkodmFscykpIHtcbiAgICAgICAgICB2YWxzID0gW3ZhbHNdO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgY2xhaW0gPSBuZXcgQ2xhaW0oa2V5LCB2YWxzKTtcbiAgICAgICAgdGhpcy5jbGFpbXMucHVzaChjbGFpbSk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgcHJpdmF0ZSBkZWNvZGVUb2tlbihqd3Q6IHN0cmluZyk6IGFueSB7XG4gICAgaWYgKCFqd3QpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ051Y2xldXNJZGVudGl0eTogVGhlcmUgd2FzIG5vIGlkZW50aXR5IHRva2VuIGluIHRoZSByZXNwb25zZSEnXG4gICAgICApO1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBhcnIgPSBqd3Quc3BsaXQoJy4nKTtcbiAgICAgIC8vIHZhciBoZWFkZXIgPSBhcnJbMF07XG4gICAgICBjb25zdCBwYXlsb2FkID0gdGhpcy5iNjREZWNvZGVVbmljb2RlKGFyclsxXSk7XG4gICAgICAvLyB2YXIgc2lnbmF0dXJlID0gYXJyWzJdO1xuICAgICAgcmV0dXJuIEpTT04ucGFyc2UocGF5bG9hZCk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ0Vycm9yIHdoaWxlIGRlY29kaW5nIGlkZW50aXR5IHRva2VuJywgZXJyb3IpO1xuICAgICAgY29uc29sZS5lcnJvcignRXJyb3Igd2hpbGUgZGVjb2RpbmcgaWRlbnRpdHkgdG9rZW4gSldUJywgand0KTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGI2NERlY29kZVVuaWNvZGUoc3RyOiBzdHJpbmcpIHtcbiAgICBzdHIgPSBzdHIucmVwbGFjZSgvLS9nLCAnKycpLnJlcGxhY2UoL18vZywgJy8nKTsgLy8gUWxlY3RvciBmaXggOilcbiAgICByZXR1cm4gZGVjb2RlVVJJQ29tcG9uZW50KFxuICAgICAgYXRvYihzdHIpXG4gICAgICAgIC5zcGxpdCgnJylcbiAgICAgICAgLm1hcCgoYykgPT4gJyUnICsgKCcwMCcgKyBjLmNoYXJDb2RlQXQoMCkudG9TdHJpbmcoMTYpKS5zbGljZSgtMikpXG4gICAgICAgIC5qb2luKCcnKVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export class OtpResponse {
|
|
2
|
+
}
|
|
3
|
+
export class OtpStatus {
|
|
4
|
+
}
|
|
5
|
+
export var OtpType;
|
|
6
|
+
(function (OtpType) {
|
|
7
|
+
OtpType[OtpType["SimpleNumbers"] = 0] = "SimpleNumbers";
|
|
8
|
+
OtpType[OtpType["SimpleAlfanumeric"] = 1] = "SimpleAlfanumeric";
|
|
9
|
+
OtpType[OtpType["Complex"] = 2] = "Complex";
|
|
10
|
+
})(OtpType || (OtpType = {}));
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3RwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZy9udWNsZXVzLWlkZW50aXR5L3NyYy9saWIvbW9kZWxzL290cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sV0FBVztDQUd2QjtBQUVELE1BQU0sT0FBTyxTQUFTO0NBSXJCO0FBRUQsTUFBTSxDQUFOLElBQVksT0FJWDtBQUpELFdBQVksT0FBTztJQUNqQix1REFBaUIsQ0FBQTtJQUNqQiwrREFBcUIsQ0FBQTtJQUNyQiwyQ0FBVyxDQUFBO0FBQ2IsQ0FBQyxFQUpXLE9BQU8sS0FBUCxPQUFPLFFBSWxCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIE90cFJlc3BvbnNlIHtcbiAgcHVibGljIHBhc3N3b3JkITogc3RyaW5nO1xuICBwdWJsaWMgcGFzc3dvcmRJZCE6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIE90cFN0YXR1cyB7XG4gIHB1YmxpYyBpc0V4cGlyZWQhOiBib29sZWFuO1xuICBwdWJsaWMgaXNVc2VkITogYm9vbGVhbjtcbiAgcHVibGljIHNlY29uZHNUb0V4cGlyYXRpb24hOiBudW1iZXI7XG59XG5cbmV4cG9ydCBlbnVtIE90cFR5cGUge1xuICBTaW1wbGVOdW1iZXJzID0gMCxcbiAgU2ltcGxlQWxmYW51bWVyaWMgPSAxLFxuICBDb21wbGV4ID0gMixcbn1cbiJdfQ==
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export class ServicePrincipal {
|
|
2
|
+
}
|
|
3
|
+
export class ServicePrincipalRegistrationStatus {
|
|
4
|
+
constructor(servicePrincipal) {
|
|
5
|
+
this.isRegistered = false;
|
|
6
|
+
if (servicePrincipal) {
|
|
7
|
+
this.isRegistered = true;
|
|
8
|
+
this.id = servicePrincipal.id;
|
|
9
|
+
this.expiresAt = servicePrincipal.expiresAt;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
get isExpired() {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS1wcmluY2lwYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2xpYi9tb2RlbHMvc2VydmljZS1wcmluY2lwYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGdCQUFnQjtDQUk1QjtBQUVELE1BQU0sT0FBTyxrQ0FBa0M7SUFLN0MsWUFBWSxnQkFBeUM7UUFIOUMsaUJBQVksR0FBRyxLQUFLLENBQUM7UUFJMUIsSUFBSSxnQkFBZ0IsRUFBRTtZQUNwQixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztZQUN6QixJQUFJLENBQUMsRUFBRSxHQUFHLGdCQUFnQixDQUFDLEVBQUUsQ0FBQztZQUM5QixJQUFJLENBQUMsU0FBUyxHQUFHLGdCQUFnQixDQUFDLFNBQVMsQ0FBQztTQUM3QztJQUNILENBQUM7SUFFRCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgU2VydmljZVByaW5jaXBhbCB7XG4gIHB1YmxpYyBpZCE6IHN0cmluZztcbiAgcHVibGljIHNlY3JldCE6IHN0cmluZztcbiAgcHVibGljIGV4cGlyZXNBdCE6IERhdGU7XG59XG5cbmV4cG9ydCBjbGFzcyBTZXJ2aWNlUHJpbmNpcGFsUmVnaXN0cmF0aW9uU3RhdHVzIHtcbiAgcHVibGljIGlkITogc3RyaW5nO1xuICBwdWJsaWMgaXNSZWdpc3RlcmVkID0gZmFsc2U7XG4gIHB1YmxpYyBleHBpcmVzQXQhOiBEYXRlO1xuXG4gIGNvbnN0cnVjdG9yKHNlcnZpY2VQcmluY2lwYWw6IFNlcnZpY2VQcmluY2lwYWwgfCBudWxsKSB7XG4gICAgaWYgKHNlcnZpY2VQcmluY2lwYWwpIHtcbiAgICAgIHRoaXMuaXNSZWdpc3RlcmVkID0gdHJ1ZTtcbiAgICAgIHRoaXMuaWQgPSBzZXJ2aWNlUHJpbmNpcGFsLmlkO1xuICAgICAgdGhpcy5leHBpcmVzQXQgPSBzZXJ2aWNlUHJpbmNpcGFsLmV4cGlyZXNBdDtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0IGlzRXhwaXJlZCgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export class NucleusIdentityConfig {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.httpInterceptorUrls = [];
|
|
4
|
+
this.automaticLoginOnHttp401 = false;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGV1cy1pZGVudGl0eS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2xpYi9udWNsZXVzLWlkZW50aXR5LWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8scUJBQXFCO0lBQWxDO1FBV1Msd0JBQW1CLEdBQWMsRUFBRSxDQUFDO1FBRXBDLDRCQUF1QixHQUFHLEtBQUssQ0FBQztJQU96QyxDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgTnVjbGV1c0lkZW50aXR5Q29uZmlnIHtcbiAgcHVibGljIGF1dGhvcml0eSE6IHN0cmluZztcblxuICBwdWJsaWMgY2xpZW50SWQhOiBzdHJpbmc7XG5cbiAgcHVibGljIHJlZGlyZWN0VXJpPzogc3RyaW5nO1xuXG4gIHB1YmxpYyBhbmRyb2lkUmVkaXJlY3RVcmk/OiBzdHJpbmc7XG5cbiAgcHVibGljIGlPU1JlZGlyZWN0VXJpPzogc3RyaW5nO1xuXG4gIHB1YmxpYyBodHRwSW50ZXJjZXB0b3JVcmxzPzogc3RyaW5nW10gPSBbXTtcblxuICBwdWJsaWMgYXV0b21hdGljTG9naW5Pbkh0dHA0MDEgPSBmYWxzZTtcblxuICBwdWJsaWMgcmVxdWVzdGVkU2NvcGVzPzogc3RyaW5nO1xuXG4gIHB1YmxpYyBzZXJ2aWNlUHJpbmNpcGFsUmVxdWVzdGVkU2NvcGVzPzogc3RyaW5nO1xuXG4gIHB1YmxpYyBhdXRoUHJvdmlkZXJIaW50Pzogc3RyaW5nO1xufVxuIl19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
3
|
+
import { NucleusTokenInterceptor } from './nucleus-token-interceptor.service';
|
|
4
|
+
import { NucleusIdentityConfig } from './nucleus-identity-config';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NucleusIdentityModule {
|
|
7
|
+
static forRoot(config) {
|
|
8
|
+
return {
|
|
9
|
+
ngModule: NucleusIdentityModule,
|
|
10
|
+
providers: [
|
|
11
|
+
{ provide: NucleusIdentityConfig, useValue: config },
|
|
12
|
+
{
|
|
13
|
+
provide: HTTP_INTERCEPTORS,
|
|
14
|
+
useClass: NucleusTokenInterceptor,
|
|
15
|
+
multi: true,
|
|
16
|
+
},
|
|
17
|
+
],
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
21
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityModule }); }
|
|
22
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityModule }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityModule, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
imports: [],
|
|
28
|
+
declarations: [],
|
|
29
|
+
exports: [],
|
|
30
|
+
}]
|
|
31
|
+
}] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGV1cy1pZGVudGl0eS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nL251Y2xldXMtaWRlbnRpdHkvc3JjL2xpYi9udWNsZXVzLWlkZW50aXR5Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7QUFPbEUsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxNQUFNLENBQUMsT0FBTyxDQUNaLE1BQTZCO1FBRTdCLE9BQU87WUFDTCxRQUFRLEVBQUUscUJBQXFCO1lBQy9CLFNBQVMsRUFBRTtnQkFDVCxFQUFFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFO2dCQUNwRDtvQkFDRSxPQUFPLEVBQUUsaUJBQWlCO29CQUMxQixRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxLQUFLLEVBQUUsSUFBSTtpQkFDWjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7K0dBZlUscUJBQXFCO2dIQUFyQixxQkFBcUI7Z0hBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFMakMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsRUFBRTtvQkFDWCxZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLEVBQUU7aUJBQ1oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSFRUUF9JTlRFUkNFUFRPUlMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBOdWNsZXVzVG9rZW5JbnRlcmNlcHRvciB9IGZyb20gJy4vbnVjbGV1cy10b2tlbi1pbnRlcmNlcHRvci5zZXJ2aWNlJztcbmltcG9ydCB7IE51Y2xldXNJZGVudGl0eUNvbmZpZyB9IGZyb20gJy4vbnVjbGV1cy1pZGVudGl0eS1jb25maWcnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXSxcbiAgZGVjbGFyYXRpb25zOiBbXSxcbiAgZXhwb3J0czogW10sXG59KVxuZXhwb3J0IGNsYXNzIE51Y2xldXNJZGVudGl0eU1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KFxuICAgIGNvbmZpZzogTnVjbGV1c0lkZW50aXR5Q29uZmlnXG4gICk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TnVjbGV1c0lkZW50aXR5TW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBOdWNsZXVzSWRlbnRpdHlNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgeyBwcm92aWRlOiBOdWNsZXVzSWRlbnRpdHlDb25maWcsIHVzZVZhbHVlOiBjb25maWcgfSxcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLFxuICAgICAgICAgIHVzZUNsYXNzOiBOdWNsZXVzVG9rZW5JbnRlcmNlcHRvcixcbiAgICAgICAgICBtdWx0aTogdHJ1ZSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
import { AuthorizationRequest, RedirectRequestHandler, BasicQueryStringUtils, LocalStorageBackend, AppAuthError, DefaultCrypto, } from '@openid/appauth';
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { App } from '@capacitor/app';
|
|
4
|
+
import { Browser } from '@capacitor/browser';
|
|
5
|
+
import { Device } from '@capacitor/device';
|
|
6
|
+
import { NucleusAppService } from '@kolektor/nucleus-common';
|
|
7
|
+
import { LocationService } from './utils/location.service';
|
|
8
|
+
import { NucleusAuthorizationNotifier } from './utils/nucleus-authorization-notifier';
|
|
9
|
+
import { HttpClient } from '@angular/common/http';
|
|
10
|
+
import { SecretsStore } from './utils/secrets-store';
|
|
11
|
+
import { OidcConfigurationService } from './utils/oidc-configuration.service';
|
|
12
|
+
import { TokenClient } from './utils/token-client';
|
|
13
|
+
import { ServicePrincipalRegistrationStatus } from './models/service-principal';
|
|
14
|
+
import { lastValueFrom } from 'rxjs';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "@kolektor/nucleus-common";
|
|
17
|
+
import * as i2 from "./utils/location.service";
|
|
18
|
+
import * as i3 from "@angular/common/http";
|
|
19
|
+
import * as i4 from "./utils/oidc-configuration.service";
|
|
20
|
+
import * as i5 from "./utils/token-client";
|
|
21
|
+
export class NucleusIdentityService {
|
|
22
|
+
constructor(appService, location, http, config, tokenClient) {
|
|
23
|
+
this.appService = appService;
|
|
24
|
+
this.http = http;
|
|
25
|
+
this.config = config;
|
|
26
|
+
this.tokenClient = tokenClient;
|
|
27
|
+
this._authorizationNotifier = new NucleusAuthorizationNotifier();
|
|
28
|
+
this._initStarted = false;
|
|
29
|
+
this._initialized = false;
|
|
30
|
+
this._refreshTokenPromise = null;
|
|
31
|
+
this._getTokenPromise = null;
|
|
32
|
+
this._getServicePrincipalTokenPromise = null;
|
|
33
|
+
this._servicePrincipalTokenId = '_svcp';
|
|
34
|
+
const storage = new LocalStorageBackend();
|
|
35
|
+
this._crypto = new DefaultCrypto();
|
|
36
|
+
this._authorizationHandler = new RedirectRequestHandler(storage, new BasicQueryStringUtils(), location, this._crypto);
|
|
37
|
+
this._authorizationHandler.setAuthorizationNotifier(this._authorizationNotifier);
|
|
38
|
+
this._store = new SecretsStore(config.clientId);
|
|
39
|
+
}
|
|
40
|
+
get identity() {
|
|
41
|
+
return this._store.getIdentity();
|
|
42
|
+
}
|
|
43
|
+
get isAuthenticated() {
|
|
44
|
+
return this.identity != null;
|
|
45
|
+
}
|
|
46
|
+
get servicePrincipalIdentity() {
|
|
47
|
+
return this._store.getIdentity(this._servicePrincipalTokenId);
|
|
48
|
+
}
|
|
49
|
+
get isServicePrincipalAuthenticated() {
|
|
50
|
+
return this.servicePrincipalIdentity != null;
|
|
51
|
+
}
|
|
52
|
+
get isIdentityServicePrincipal() {
|
|
53
|
+
return this._store.defaultIdentityId === this._servicePrincipalTokenId;
|
|
54
|
+
}
|
|
55
|
+
async init(startLogin = false) {
|
|
56
|
+
if (this._initStarted || this._initialized) {
|
|
57
|
+
console.warn("Nucleus.Identity: Auth initialization was already started. Don't call init() multiple times!");
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
this._initStarted = true;
|
|
61
|
+
this.handleLaunchCodeHash();
|
|
62
|
+
await this._authorizationHandler.completeAuthorizationRequestIfPossible();
|
|
63
|
+
const authErr = this._authorizationNotifier.error;
|
|
64
|
+
if (authErr) {
|
|
65
|
+
throw new Error('Authorization err: ' + authErr.error + ': ' + authErr.errorDescription);
|
|
66
|
+
}
|
|
67
|
+
else if (this._authorizationNotifier.response) {
|
|
68
|
+
window.location.hash = '';
|
|
69
|
+
const request = this._authorizationNotifier.request;
|
|
70
|
+
const response = this._authorizationNotifier.response;
|
|
71
|
+
const codeVerifier = (request.internal) ? request.internal['code_verifier'] : undefined;
|
|
72
|
+
const res = await this.tokenClient.getByAuthorizationCode(request.redirectUri, response.code, codeVerifier);
|
|
73
|
+
this._store.setDefaultIdentityId(null);
|
|
74
|
+
await this._store.setToken(res);
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
const res = await this._store.getToken();
|
|
78
|
+
if (!res && startLogin) {
|
|
79
|
+
await this.login();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
this._initialized = true;
|
|
83
|
+
}
|
|
84
|
+
async loginWithSecret(provider, secret) {
|
|
85
|
+
this._store.removeToken();
|
|
86
|
+
const assertionToken = await this.getServicePrincipalAccessToken();
|
|
87
|
+
const scope = this.prepareScope(true, this.config?.requestedScopes);
|
|
88
|
+
const res = await this.tokenClient.getBySecret(provider, secret, assertionToken, scope);
|
|
89
|
+
this._store.setDefaultIdentityId(null);
|
|
90
|
+
await this._store.setToken(res);
|
|
91
|
+
}
|
|
92
|
+
async login() {
|
|
93
|
+
this._store.removeToken();
|
|
94
|
+
const config = await this.config.getConfiguration();
|
|
95
|
+
const request = this.prepareAuthorizationRequest();
|
|
96
|
+
if (this.appService.isNative) {
|
|
97
|
+
const listener = App.addListener('appUrlOpen', (data) => {
|
|
98
|
+
if (this.appService.platform === 'ios') {
|
|
99
|
+
Browser.close();
|
|
100
|
+
}
|
|
101
|
+
listener.remove();
|
|
102
|
+
const hash = this.getCodeHash(data.url);
|
|
103
|
+
if (hash) {
|
|
104
|
+
const targetUrl = window.location.origin + window.location.pathname + '#' + hash;
|
|
105
|
+
window.location.assign(targetUrl);
|
|
106
|
+
window.location.reload();
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
console.warn('Nucleus.Identity: Redirect url did not contain authorization code!', data);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
this._authorizationHandler.performAuthorizationRequest(config, request);
|
|
114
|
+
}
|
|
115
|
+
async logout() {
|
|
116
|
+
this._store.removeToken();
|
|
117
|
+
const config = await this.config.getConfiguration();
|
|
118
|
+
const redirectUrl = this.config.redirectUrl;
|
|
119
|
+
const logoutUrl = config.endSessionEndpoint +
|
|
120
|
+
'?post_logout_redirect_uri=' +
|
|
121
|
+
encodeURI(redirectUrl);
|
|
122
|
+
if (this.appService.isNative) {
|
|
123
|
+
const listener = App.addListener('appUrlOpen', () => {
|
|
124
|
+
Device.getInfo().then((info) => {
|
|
125
|
+
if (info.platform === 'ios') {
|
|
126
|
+
Browser.close();
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
listener.remove();
|
|
130
|
+
});
|
|
131
|
+
Browser.open({ url: logoutUrl });
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
window.location.assign(logoutUrl);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
async getAccessToken() {
|
|
138
|
+
if (!this._getTokenPromise) {
|
|
139
|
+
this._getTokenPromise = this.getAccessTokenInternal();
|
|
140
|
+
}
|
|
141
|
+
try {
|
|
142
|
+
return await this._getTokenPromise;
|
|
143
|
+
}
|
|
144
|
+
finally {
|
|
145
|
+
this._getTokenPromise = null;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
async getServicePrincipalAccessToken() {
|
|
149
|
+
if (!this._getServicePrincipalTokenPromise) {
|
|
150
|
+
this._getServicePrincipalTokenPromise =
|
|
151
|
+
this.getServicePrincipalAccessTokenInternal();
|
|
152
|
+
}
|
|
153
|
+
try {
|
|
154
|
+
return await this._getServicePrincipalTokenPromise;
|
|
155
|
+
}
|
|
156
|
+
finally {
|
|
157
|
+
this._getServicePrincipalTokenPromise = null;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
async loginServicePrincipal() {
|
|
161
|
+
const sp = await this._store.getServicePrincipal();
|
|
162
|
+
if (sp) {
|
|
163
|
+
const scope = this.prepareScope(false, this.config.servicePrincipalRequestedScopes);
|
|
164
|
+
const res = await this.tokenClient.getByClientCredentials(sp.id, sp.secret, scope);
|
|
165
|
+
await this._store.setToken(res, this._servicePrincipalTokenId);
|
|
166
|
+
return res;
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
throw Error('Service principal is not registered!');
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
async loginAsServicePrincipal() {
|
|
173
|
+
const token = await this._store.getToken(this._servicePrincipalTokenId);
|
|
174
|
+
if (!token) {
|
|
175
|
+
await this.loginServicePrincipal();
|
|
176
|
+
}
|
|
177
|
+
this._store.setDefaultIdentityId(this._servicePrincipalTokenId);
|
|
178
|
+
}
|
|
179
|
+
async getOtp(type, expiresIn = -1) {
|
|
180
|
+
let url = this.config.getServerUrl(`/otp/create?type=${type}`);
|
|
181
|
+
if (expiresIn > 0) {
|
|
182
|
+
url += `&expiresIn=${expiresIn}`;
|
|
183
|
+
}
|
|
184
|
+
return lastValueFrom(this.http.get(url));
|
|
185
|
+
}
|
|
186
|
+
async getOtpStatus(id) {
|
|
187
|
+
const url = this.config.getServerUrl(`/otp/status/${id}`);
|
|
188
|
+
return lastValueFrom(this.http.get(url));
|
|
189
|
+
}
|
|
190
|
+
getOtpUrl(redirectUrl, password) {
|
|
191
|
+
const encoded = encodeURIComponent(redirectUrl);
|
|
192
|
+
const url = `/otp/auth?otpValue=${password}&returnUrl=${encoded}`;
|
|
193
|
+
return this.config.getServerUrl(url);
|
|
194
|
+
}
|
|
195
|
+
async startServicePrincipalRegistration() {
|
|
196
|
+
const sp = await this._store.getServicePrincipal();
|
|
197
|
+
return await this.tokenClient.getRegistrationCode(sp?.id);
|
|
198
|
+
}
|
|
199
|
+
async completeServicePrincipalRegistration(deviceCode) {
|
|
200
|
+
const tokenRes = await this.waitForDeviceToken(deviceCode);
|
|
201
|
+
const regRes = await this.tokenClient.registerServicePrincipal(tokenRes.accessToken);
|
|
202
|
+
await this._store.setServicePrincipal({
|
|
203
|
+
id: regRes.clientId,
|
|
204
|
+
secret: regRes.clientSecret,
|
|
205
|
+
expiresAt: regRes.secretExpirationDate,
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
removeServicePrincipalRegistration() {
|
|
209
|
+
return this._store.removeServicePrincipal();
|
|
210
|
+
}
|
|
211
|
+
async getServicePrincipalRegistrationStatus() {
|
|
212
|
+
const sp = await this._store.getServicePrincipal();
|
|
213
|
+
return new ServicePrincipalRegistrationStatus(sp);
|
|
214
|
+
}
|
|
215
|
+
async startDeviceCodeLogin() {
|
|
216
|
+
const scope = this.prepareScope(true, this.config.requestedScopes);
|
|
217
|
+
return await this.tokenClient.getDeviceCode(scope);
|
|
218
|
+
}
|
|
219
|
+
async completeDeviceCodeLogin(deviceCode) {
|
|
220
|
+
const res = await this.waitForDeviceToken(deviceCode);
|
|
221
|
+
await this._store.setToken(res);
|
|
222
|
+
}
|
|
223
|
+
async waitForDeviceToken(deviceCode) {
|
|
224
|
+
let res = null;
|
|
225
|
+
do {
|
|
226
|
+
if (deviceCode.isExpired()) {
|
|
227
|
+
throw Error('Device code is expired!');
|
|
228
|
+
}
|
|
229
|
+
try {
|
|
230
|
+
res = await this.tokenClient.getByDeviceCode(deviceCode.deviceCode);
|
|
231
|
+
}
|
|
232
|
+
catch (error) {
|
|
233
|
+
if (error instanceof AppAuthError &&
|
|
234
|
+
error.message === 'authorization_pending') {
|
|
235
|
+
await this.delay(2000);
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
throw error;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
} while (!res);
|
|
242
|
+
return res;
|
|
243
|
+
}
|
|
244
|
+
prepareAuthorizationRequest() {
|
|
245
|
+
const redirectUri = this.config.redirectUrl;
|
|
246
|
+
const params = {
|
|
247
|
+
response_mode: 'fragment',
|
|
248
|
+
prompt: 'consent',
|
|
249
|
+
access_type: 'offline',
|
|
250
|
+
auth_provider_hint: this.config.authProviderHint,
|
|
251
|
+
};
|
|
252
|
+
return new AuthorizationRequest({
|
|
253
|
+
client_id: this.config.clientId,
|
|
254
|
+
redirect_uri: redirectUri,
|
|
255
|
+
response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,
|
|
256
|
+
scope: this.prepareScope(true, this.config.requestedScopes),
|
|
257
|
+
extras: params,
|
|
258
|
+
}, this._crypto, true);
|
|
259
|
+
}
|
|
260
|
+
async getServicePrincipalAccessTokenInternal() {
|
|
261
|
+
let token = await this._store.getToken(this._servicePrincipalTokenId);
|
|
262
|
+
if (!token?.isValid()) {
|
|
263
|
+
token = await this.loginServicePrincipal();
|
|
264
|
+
}
|
|
265
|
+
return token?.accessToken;
|
|
266
|
+
}
|
|
267
|
+
async getAccessTokenInternal() {
|
|
268
|
+
let token = await this._store.getToken();
|
|
269
|
+
if (token && !token.isValid()) {
|
|
270
|
+
token = await this.loginWithRefreshToken(token);
|
|
271
|
+
}
|
|
272
|
+
return token?.accessToken ?? null;
|
|
273
|
+
}
|
|
274
|
+
async loginWithRefreshToken(token) {
|
|
275
|
+
if (!this._refreshTokenPromise) {
|
|
276
|
+
this._refreshTokenPromise = this.loginWithRefreshTokenInternal(token);
|
|
277
|
+
}
|
|
278
|
+
try {
|
|
279
|
+
return await this._refreshTokenPromise;
|
|
280
|
+
}
|
|
281
|
+
finally {
|
|
282
|
+
this._refreshTokenPromise = null;
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
async loginWithRefreshTokenInternal(token) {
|
|
286
|
+
if (token?.refreshToken) {
|
|
287
|
+
try {
|
|
288
|
+
const res = await this.tokenClient.getByRefreshToken(token.refreshToken);
|
|
289
|
+
await this._store.setToken(res);
|
|
290
|
+
return res;
|
|
291
|
+
}
|
|
292
|
+
catch (err) {
|
|
293
|
+
console.warn('Nucleus.Identity: Failed to login with refresh token.', err);
|
|
294
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
295
|
+
if (err.message === 'invalid_grant') {
|
|
296
|
+
await this.logout();
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
else {
|
|
301
|
+
console.warn('Nucleus.Identity: There is no refresh token available.');
|
|
302
|
+
}
|
|
303
|
+
return null;
|
|
304
|
+
}
|
|
305
|
+
getCodeHash(url) {
|
|
306
|
+
const arr = url.split('#');
|
|
307
|
+
if (arr.length > 1) {
|
|
308
|
+
const hash = arr[1];
|
|
309
|
+
if (hash.startsWith('code=')) {
|
|
310
|
+
return hash;
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
return null;
|
|
314
|
+
}
|
|
315
|
+
handleLaunchCodeHash() {
|
|
316
|
+
if (this.appService.isNative && this.appService.launchUrl) {
|
|
317
|
+
const hash = this.getCodeHash(this.appService.launchUrl);
|
|
318
|
+
if (hash) {
|
|
319
|
+
console.log('Nucleus.Identity: Got authorization code from launchUrl, will assign it to hash.');
|
|
320
|
+
window.location.hash = '#' + hash;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
prepareScope(offlineAccess, aditionalScope) {
|
|
325
|
+
let scope = 'openid';
|
|
326
|
+
if (offlineAccess) {
|
|
327
|
+
scope += ' offline_access';
|
|
328
|
+
}
|
|
329
|
+
if (aditionalScope) {
|
|
330
|
+
scope += ' ' + aditionalScope;
|
|
331
|
+
}
|
|
332
|
+
return scope;
|
|
333
|
+
}
|
|
334
|
+
delay(miliseconds) {
|
|
335
|
+
return new Promise((resolve) => {
|
|
336
|
+
setTimeout(() => {
|
|
337
|
+
resolve();
|
|
338
|
+
}, miliseconds);
|
|
339
|
+
});
|
|
340
|
+
}
|
|
341
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityService, deps: [{ token: i1.NucleusAppService }, { token: i2.LocationService }, { token: i3.HttpClient }, { token: i4.OidcConfigurationService }, { token: i5.TokenClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
342
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityService, providedIn: 'root' }); }
|
|
343
|
+
}
|
|
344
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NucleusIdentityService, decorators: [{
|
|
345
|
+
type: Injectable,
|
|
346
|
+
args: [{
|
|
347
|
+
providedIn: 'root',
|
|
348
|
+
}]
|
|
349
|
+
}], ctorParameters: function () { return [{ type: i1.NucleusAppService }, { type: i2.LocationService }, { type: i3.HttpClient }, { type: i4.OidcConfigurationService }, { type: i5.TokenClient }]; } });
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nucleus-identity.service.js","sourceRoot":"","sources":["../../../../../../libs/ng/nucleus-identity/src/lib/nucleus-identity.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuthorizationRequest,\n  TokenResponse,\n  Crypto,\n  RedirectRequestHandler,\n  BasicQueryStringUtils,\n  LocalStorageBackend,\n  AppAuthError,\n  DefaultCrypto,\n  StringMap,\n} from '@openid/appauth';\n\nimport { Injectable } from '@angular/core';\nimport { App } from '@capacitor/app';\nimport { Browser } from '@capacitor/browser';\nimport { Device } from '@capacitor/device';\nimport { NucleusAppService } from '@kolektor/nucleus-common';\nimport { LocationService } from './utils/location.service';\nimport { AuthorizationRequestHandler } from '@openid/appauth';\nimport { NucleusAuthorizationNotifier } from './utils/nucleus-authorization-notifier';\nimport { HttpClient } from '@angular/common/http';\nimport { OtpResponse, OtpStatus, OtpType } from './models/otp';\nimport { SecretsStore } from './utils/secrets-store';\nimport { OidcConfigurationService } from './utils/oidc-configuration.service';\nimport { TokenClient } from './utils/token-client';\nimport { DeviceCode } from './models/device-code';\nimport { ServicePrincipalRegistrationStatus } from './models/service-principal';\nimport { lastValueFrom } from 'rxjs';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NucleusIdentityService {\n  constructor(\n    private appService: NucleusAppService,\n    location: LocationService,\n    private http: HttpClient,\n    private config: OidcConfigurationService,\n    private tokenClient: TokenClient\n  ) {\n    const storage = new LocalStorageBackend();\n    this._crypto = new DefaultCrypto();\n    this._authorizationHandler = new RedirectRequestHandler(\n      storage,\n      new BasicQueryStringUtils(),\n      location,\n      this._crypto\n    );\n    this._authorizationHandler.setAuthorizationNotifier(\n      this._authorizationNotifier\n    );\n    this._store = new SecretsStore(config.clientId);\n  }\n\n  private _authorizationHandler: AuthorizationRequestHandler;\n  private _authorizationNotifier = new NucleusAuthorizationNotifier();\n  private _crypto: Crypto;\n  private _initStarted = false;\n  private _initialized = false;\n  private _refreshTokenPromise: Promise<TokenResponse | null> | null = null;\n  private _getTokenPromise: Promise<string | null> | null = null;\n  private _getServicePrincipalTokenPromise: Promise<string> | null = null;\n  private _servicePrincipalTokenId = '_svcp';\n  private _store: SecretsStore;\n\n  public get identity() {\n    return this._store.getIdentity();\n  }\n\n  public get isAuthenticated() {\n    return this.identity != null;\n  }\n\n  public get servicePrincipalIdentity() {\n    return this._store.getIdentity(this._servicePrincipalTokenId);\n  }\n\n  public get isServicePrincipalAuthenticated() {\n    return this.servicePrincipalIdentity != null;\n  }\n\n  public get isIdentityServicePrincipal() {\n    return this._store.defaultIdentityId === this._servicePrincipalTokenId;\n  }\n\n  public async init(startLogin = false): Promise<void> {\n    if (this._initStarted || this._initialized) {\n      console.warn(\n        \"Nucleus.Identity: Auth initialization was already started. Don't call init() multiple times!\"\n      );\n      return;\n    }\n    this._initStarted = true;\n\n    this.handleLaunchCodeHash();\n    await this._authorizationHandler.completeAuthorizationRequestIfPossible();\n\n    const authErr = this._authorizationNotifier.error;\n    if (authErr) {\n      throw new Error(\n        'Authorization err: ' + authErr.error + ': ' + authErr.errorDescription\n      );\n    } else if (this._authorizationNotifier.response) {\n      window.location.hash = '';\n      const request = this._authorizationNotifier.request;\n      const response = this._authorizationNotifier.response;\n\n      const codeVerifier = (request.internal) ? request.internal['code_verifier'] : undefined;\n      const res = await this.tokenClient.getByAuthorizationCode(request.redirectUri, response.code, codeVerifier);\n      this._store.setDefaultIdentityId(null);\n      await this._store.setToken(res);\n    } else {\n      const res = await this._store.getToken();\n      if (!res && startLogin) {\n        await this.login();\n      }\n    }\n    this._initialized = true;\n  }\n\n  public async loginWithSecret(\n    provider: string,\n    secret: string\n  ): Promise<void> {\n    this._store.removeToken();\n    const assertionToken = await this.getServicePrincipalAccessToken();\n    const scope = this.prepareScope(true, this.config?.requestedScopes);\n    const res = await this.tokenClient.getBySecret(\n      provider,\n      secret,\n      assertionToken,\n      scope\n    );\n    this._store.setDefaultIdentityId(null);\n    await this._store.setToken(res);\n  }\n\n  public async login(): Promise<void> {\n    this._store.removeToken();\n    const config = await this.config.getConfiguration();\n    const request = this.prepareAuthorizationRequest();\n    if (this.appService.isNative) {\n      const listener = App.addListener('appUrlOpen', (data) => {\n        if (this.appService.platform === 'ios') {\n          Browser.close();\n        }\n        listener.remove();\n        const hash = this.getCodeHash(data.url);\n        if (hash) {\n          const targetUrl =\n            window.location.origin + window.location.pathname + '#' + hash;\n          window.location.assign(targetUrl);\n          window.location.reload();\n        } else {\n          console.warn(\n            'Nucleus.Identity: Redirect url did not contain authorization code!',\n            data\n          );\n        }\n      });\n    }\n    this._authorizationHandler.performAuthorizationRequest(config, request);\n  }\n\n  public async logout(): Promise<void> {\n    this._store.removeToken();\n    const config = await this.config.getConfiguration();\n    const redirectUrl = this.config.redirectUrl;\n    const logoutUrl =\n      config.endSessionEndpoint +\n      '?post_logout_redirect_uri=' +\n      encodeURI(redirectUrl);\n    if (this.appService.isNative) {\n      const listener = App.addListener('appUrlOpen', () => {\n        Device.getInfo().then((info) => {\n          if (info.platform === 'ios') {\n            Browser.close();\n          }\n        });\n        listener.remove();\n      });\n      Browser.open({ url: logoutUrl });\n    } else {\n      window.location.assign(logoutUrl);\n    }\n  }\n\n  public async getAccessToken() {\n    if (!this._getTokenPromise) {\n      this._getTokenPromise = this.getAccessTokenInternal();\n    }\n    try {\n      return await this._getTokenPromise;\n    } finally {\n      this._getTokenPromise = null;\n    }\n  }\n\n  public async getServicePrincipalAccessToken() {\n    if (!this._getServicePrincipalTokenPromise) {\n      this._getServicePrincipalTokenPromise =\n        this.getServicePrincipalAccessTokenInternal();\n    }\n    try {\n      return await this._getServicePrincipalTokenPromise;\n    } finally {\n      this._getServicePrincipalTokenPromise = null;\n    }\n  }\n\n  public async loginServicePrincipal() {\n    const sp = await this._store.getServicePrincipal();\n    if (sp) {\n      const scope = this.prepareScope(false, this.config.servicePrincipalRequestedScopes);\n      const res = await this.tokenClient.getByClientCredentials(\n        sp.id,\n        sp.secret,\n        scope\n      );\n      await this._store.setToken(res, this._servicePrincipalTokenId);\n      return res;\n    } else {\n      throw Error('Service principal is not registered!');\n    }\n  }\n\n  public async loginAsServicePrincipal() {\n    const token = await this._store.getToken(this._servicePrincipalTokenId);\n    if (!token) {\n      await this.loginServicePrincipal();\n    }\n    this._store.setDefaultIdentityId(this._servicePrincipalTokenId);\n  }\n\n  public async getOtp(type: OtpType, expiresIn = -1) {\n    let url = this.config.getServerUrl(`/otp/create?type=${type}`);\n    if (expiresIn > 0) {\n      url += `&expiresIn=${expiresIn}`;\n    }\n    return lastValueFrom(this.http.get<OtpResponse>(url));\n  }\n\n  public async getOtpStatus(id: string) {\n    const url = this.config.getServerUrl(`/otp/status/${id}`);\n    return lastValueFrom(this.http.get<OtpStatus>(url));\n  }\n\n  public getOtpUrl(redirectUrl: string, password: string) {\n    const encoded = encodeURIComponent(redirectUrl);\n    const url = `/otp/auth?otpValue=${password}&returnUrl=${encoded}`;\n    return this.config.getServerUrl(url);\n  }\n\n  public async startServicePrincipalRegistration() {\n    const sp = await this._store.getServicePrincipal();\n    return await this.tokenClient.getRegistrationCode(sp?.id);\n  }\n\n  public async completeServicePrincipalRegistration(deviceCode: DeviceCode) {\n    const tokenRes = await this.waitForDeviceToken(deviceCode);\n    const regRes = await this.tokenClient.registerServicePrincipal(\n      tokenRes.accessToken\n    );\n\n    await this._store.setServicePrincipal({\n      id: regRes.clientId,\n      secret: regRes.clientSecret,\n      expiresAt: regRes.secretExpirationDate,\n    });\n  }\n\n  public removeServicePrincipalRegistration() {\n    return this._store.removeServicePrincipal();\n  }\n\n  public async getServicePrincipalRegistrationStatus() {\n    const sp = await this._store.getServicePrincipal();\n    return new ServicePrincipalRegistrationStatus(sp);\n  }\n\n  public async startDeviceCodeLogin() {\n    const scope = this.prepareScope(true, this.config.requestedScopes);\n    return await this.tokenClient.getDeviceCode(scope);\n  }\n\n  public async completeDeviceCodeLogin(deviceCode: DeviceCode) {\n    const res = await this.waitForDeviceToken(deviceCode);\n    await this._store.setToken(res);\n  }\n\n  private async waitForDeviceToken(deviceCode: DeviceCode) {\n    let res: TokenResponse | null = null;\n    do {\n      if (deviceCode.isExpired()) {\n        throw Error('Device code is expired!');\n      }\n\n      try {\n        res = await this.tokenClient.getByDeviceCode(deviceCode.deviceCode);\n      } catch (error) {\n        if (\n          error instanceof AppAuthError &&\n          error.message === 'authorization_pending'\n        ) {\n          await this.delay(2000);\n        } else {\n          throw error;\n        }\n      }\n    } while (!res);\n    return res;\n  }\n\n  private prepareAuthorizationRequest(): AuthorizationRequest {\n    const redirectUri = this.config.redirectUrl;\n\n    const params = {\n      response_mode: 'fragment',\n      prompt: 'consent',\n      access_type: 'offline',\n      auth_provider_hint: this.config.authProviderHint,\n    };\n\n    return new AuthorizationRequest(\n      {\n        client_id: this.config.clientId,\n        redirect_uri: redirectUri,\n        response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,\n        scope: this.prepareScope(true, this.config.requestedScopes),\n        extras: params as StringMap,\n      },\n      this._crypto,\n      true\n    );\n  }\n\n  private async getServicePrincipalAccessTokenInternal() {\n    let token = await this._store.getToken(this._servicePrincipalTokenId);\n    if (!token?.isValid()) {\n      token = await this.loginServicePrincipal();\n    }\n    return token?.accessToken;\n  }\n\n  private async getAccessTokenInternal() {\n    let token = await this._store.getToken();\n    if (token && !token.isValid()) {\n      token = await this.loginWithRefreshToken(token);\n    }\n    return token?.accessToken ?? null;\n  }\n\n  private async loginWithRefreshToken(token: TokenResponse) {\n    if (!this._refreshTokenPromise) {\n      this._refreshTokenPromise = this.loginWithRefreshTokenInternal(token);\n    }\n    try {\n      return await this._refreshTokenPromise;\n    } finally {\n      this._refreshTokenPromise = null;\n    }\n  }\n\n  private async loginWithRefreshTokenInternal(token: TokenResponse) {\n    if (token?.refreshToken) {\n      try {\n        const res = await this.tokenClient.getByRefreshToken(\n          token.refreshToken\n        );\n        await this._store.setToken(res);\n        return res;\n      } catch (err) {\n        console.warn(\n          'Nucleus.Identity: Failed to login with refresh token.',\n          err\n        );\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        if ((err as any).message === 'invalid_grant') {\n          await this.logout();\n        }\n      }\n    } else {\n      console.warn('Nucleus.Identity: There is no refresh token available.');\n    }\n    return null;\n  }\n\n  private getCodeHash(url: string) {\n    const arr = url.split('#');\n    if (arr.length > 1) {\n      const hash = arr[1];\n      if (hash.startsWith('code=')) {\n        return hash;\n      }\n    }\n    return null;\n  }\n\n  private handleLaunchCodeHash() {\n    if (this.appService.isNative && this.appService.launchUrl) {\n      const hash = this.getCodeHash(this.appService.launchUrl);\n      if (hash) {\n        console.log(\n          'Nucleus.Identity: Got authorization code from launchUrl, will assign it to hash.'\n        );\n        window.location.hash = '#' + hash;\n      }\n    }\n  }\n\n  private prepareScope(offlineAccess: boolean, aditionalScope?: string) {\n    let scope = 'openid';\n    if (offlineAccess) {\n      scope += ' offline_access';\n    }\n    if (aditionalScope) {\n      scope += ' ' + aditionalScope;\n    }\n    return scope;\n  }\n\n  private delay(miliseconds: number) {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve();\n      }, miliseconds);\n    });\n  }\n}\n"]}
|