@kolektor/nucleus-identity 0.0.12-pre.7931 → 0.1.0-pre.124
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 +7 -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
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { AuthorizationNotifier } from '@openid/appauth';
|
|
2
|
-
export class NucleusAuthorizationNotifier extends AuthorizationNotifier {
|
|
3
|
-
constructor() {
|
|
4
|
-
super();
|
|
5
|
-
this.setAuthorizationListener((request, response, error) => {
|
|
6
|
-
console.log('Authorization request complete ', request, response, error);
|
|
7
|
-
this.response = response;
|
|
8
|
-
this.request = request;
|
|
9
|
-
this.error = error;
|
|
10
|
-
});
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGV1cy1hdXRob3JpemF0aW9uLW5vdGlmaWVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnVjbGV1cy1pZGVudGl0eS9zcmMvbGliL3V0aWxzL251Y2xldXMtYXV0aG9yaXphdGlvbi1ub3RpZmllci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUl4RCxNQUFNLE9BQU8sNEJBQTZCLFNBQVEscUJBQXFCO0lBS25FO1FBQ0ksS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxPQUFPLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQ3ZELE9BQU8sQ0FBQyxHQUFHLENBQUMsaUNBQWlDLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUN6RSxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztZQUN6QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztZQUN2QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF1dGhvcml6YXRpb25Ob3RpZmllciB9IGZyb20gJ0BvcGVuaWQvYXBwYXV0aCc7XHJcbmltcG9ydCB7IEF1dGhvcml6YXRpb25SZXNwb25zZSwgQXV0aG9yaXphdGlvbkVycm9yIH0gZnJvbSAnQG9wZW5pZC9hcHBhdXRoJztcclxuaW1wb3J0IHsgQXV0aG9yaXphdGlvblJlcXVlc3QgfSBmcm9tICdAb3BlbmlkL2FwcGF1dGgnO1xyXG5cclxuZXhwb3J0IGNsYXNzIE51Y2xldXNBdXRob3JpemF0aW9uTm90aWZpZXIgZXh0ZW5kcyBBdXRob3JpemF0aW9uTm90aWZpZXIge1xyXG4gICAgcmVzcG9uc2U6IEF1dGhvcml6YXRpb25SZXNwb25zZTtcclxuICAgIHJlcXVlc3Q6IEF1dGhvcml6YXRpb25SZXF1ZXN0O1xyXG4gICAgZXJyb3I6IEF1dGhvcml6YXRpb25FcnJvcjtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcigpICB7XHJcbiAgICAgICAgc3VwZXIoKTtcclxuICAgICAgICB0aGlzLnNldEF1dGhvcml6YXRpb25MaXN0ZW5lcigocmVxdWVzdCwgcmVzcG9uc2UsIGVycm9yKSA9PiB7XHJcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKCdBdXRob3JpemF0aW9uIHJlcXVlc3QgY29tcGxldGUgJywgcmVxdWVzdCwgcmVzcG9uc2UsIGVycm9yKTtcclxuICAgICAgICAgICAgdGhpcy5yZXNwb25zZSA9IHJlc3BvbnNlO1xyXG4gICAgICAgICAgICB0aGlzLnJlcXVlc3QgPSByZXF1ZXN0O1xyXG4gICAgICAgICAgICB0aGlzLmVycm9yID0gZXJyb3I7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { AppAuthError } from '@openid/appauth';
|
|
2
|
-
import * as base64 from 'base64-js';
|
|
3
|
-
const CHARSET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
|
4
|
-
export class NucleusCrypto {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.browserCrypto = window.crypto || window.msCrypto;
|
|
7
|
-
}
|
|
8
|
-
generateRandom(size) {
|
|
9
|
-
const buffer = new Uint8Array(size);
|
|
10
|
-
if (this.browserCrypto) {
|
|
11
|
-
this.browserCrypto.getRandomValues(buffer);
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
// fall back to Math.random() if nothing else is available
|
|
15
|
-
for (let i = 0; i < size; i += 1) {
|
|
16
|
-
buffer[i] = Math.random();
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
return this.bufferToString(buffer);
|
|
20
|
-
}
|
|
21
|
-
deriveChallenge(code) {
|
|
22
|
-
if (code.length < 43 || code.length > 128) {
|
|
23
|
-
return Promise.reject(new AppAuthError('Invalid code length.'));
|
|
24
|
-
}
|
|
25
|
-
if (!this.browserCrypto.subtle) {
|
|
26
|
-
return Promise.reject(new AppAuthError('window.crypto.subtle is unavailable.'));
|
|
27
|
-
}
|
|
28
|
-
const ecode = this.textEncodeLite(code);
|
|
29
|
-
const op = this.browserCrypto.subtle.digest('SHA-256', ecode);
|
|
30
|
-
return new Promise((resolve, reject) => {
|
|
31
|
-
// if operation contains algorithm it means it is not a promise which means it is CryptoOperation from IE.
|
|
32
|
-
// We just return result as promise
|
|
33
|
-
if (op.algorithm) {
|
|
34
|
-
console.log('we have a CryptoOperation');
|
|
35
|
-
op.addEventListener('complete', () => {
|
|
36
|
-
resolve(this.urlSafe(op.result));
|
|
37
|
-
});
|
|
38
|
-
op.addEventListener('error', () => {
|
|
39
|
-
reject(op.result);
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
else { // the result is promise
|
|
43
|
-
op.then(buffer => resolve(this.urlSafe(buffer)), error => reject(error));
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
urlSafe(buffer) {
|
|
48
|
-
const encoded = base64.fromByteArray(new Uint8Array(buffer));
|
|
49
|
-
return encoded.replace(/\+/g, '-').replace(/\//g, '_').replace(/=/g, '');
|
|
50
|
-
}
|
|
51
|
-
textEncodeLite(str) {
|
|
52
|
-
const buf = new ArrayBuffer(str.length);
|
|
53
|
-
const bufView = new Uint8Array(buf);
|
|
54
|
-
for (let i = 0; i < str.length; i++) {
|
|
55
|
-
bufView[i] = str.charCodeAt(i);
|
|
56
|
-
}
|
|
57
|
-
return bufView;
|
|
58
|
-
}
|
|
59
|
-
bufferToString(buffer) {
|
|
60
|
-
const state = [];
|
|
61
|
-
for (let i = 0; i < buffer.byteLength; i += 1) {
|
|
62
|
-
const index = buffer[i] % CHARSET.length;
|
|
63
|
-
state.push(CHARSET[index]);
|
|
64
|
-
}
|
|
65
|
-
return state.join('');
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGV1cy1jcnlwdG8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udWNsZXVzLWlkZW50aXR5L3NyYy9saWIvdXRpbHMvbnVjbGV1cy1jcnlwdG8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sS0FBSyxNQUFNLE1BQU0sV0FBVyxDQUFDO0FBRXBDLE1BQU0sT0FBTyxHQUFHLGdFQUFnRSxDQUFDO0FBRWpGLE1BQU0sT0FBTyxhQUFhO0lBQTFCO1FBQ1Usa0JBQWEsR0FBRyxNQUFNLENBQUMsTUFBTSxJQUFLLE1BQWMsQ0FBQyxRQUFRLENBQUM7SUFtRXBFLENBQUM7SUFqRUMsY0FBYyxDQUFDLElBQVk7UUFDekIsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDcEMsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzVDO2FBQU07WUFDTCwwREFBMEQ7WUFDMUQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNoQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO2FBQzNCO1NBQ0Y7UUFDRCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELGVBQWUsQ0FBQyxJQUFZO1FBQzFCLElBQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxFQUFFLElBQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7WUFDekMsT0FBTyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksWUFBWSxDQUFDLHNCQUFzQixDQUFDLENBQUMsQ0FBQztTQUNqRTtRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRTtZQUM5QixPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxZQUFZLENBQUMsc0NBQXNDLENBQUMsQ0FBQyxDQUFDO1NBQ2pGO1FBRUQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN4QyxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzlELE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsMEdBQTBHO1lBQzFHLG1DQUFtQztZQUNuQyxJQUFJLEVBQUUsQ0FBQyxTQUFTLEVBQUU7Z0JBQ2hCLE9BQU8sQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUMsQ0FBQztnQkFDekMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxHQUFHLEVBQUU7b0JBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO2dCQUNuQyxDQUFDLENBQUMsQ0FBQztnQkFFSCxFQUFFLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRTtvQkFDaEMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFDcEIsQ0FBQyxDQUFDLENBQUM7YUFDSjtpQkFBTSxFQUFFLHdCQUF3QjtnQkFDL0IsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQzthQUMxRTtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUdPLE9BQU8sQ0FBQyxNQUFrQjtRQUNoQyxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDN0QsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQztJQUVPLGNBQWMsQ0FBQyxHQUFXO1FBQ2hDLE1BQU0sR0FBRyxHQUFHLElBQUksV0FBVyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4QyxNQUFNLE9BQU8sR0FBRyxJQUFJLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUVwQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUNuQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUNoQztRQUNELE9BQU8sT0FBTyxDQUFDO0lBQ2pCLENBQUM7SUFFTyxjQUFjLENBQUMsTUFBa0I7UUFDdkMsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ2pCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDN0MsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDekMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztTQUM1QjtRQUNELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUN4QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJdCBhbHNvIHN1cHBvcnRzIElFIHdpdGggd2luZG93Lm1zQ3J5cHRvICEhISEhIVxyXG5pbXBvcnQgeyBDcnlwdG8gfSBmcm9tICdAb3BlbmlkL2FwcGF1dGgnO1xyXG5pbXBvcnQgeyBBcHBBdXRoRXJyb3IgfSBmcm9tICdAb3BlbmlkL2FwcGF1dGgnO1xyXG5pbXBvcnQgKiBhcyBiYXNlNjQgZnJvbSAnYmFzZTY0LWpzJztcclxuXHJcbmNvbnN0IENIQVJTRVQgPSAnQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODknO1xyXG5cclxuZXhwb3J0IGNsYXNzIE51Y2xldXNDcnlwdG8gaW1wbGVtZW50cyBDcnlwdG8ge1xyXG4gIHByaXZhdGUgYnJvd3NlckNyeXB0byA9IHdpbmRvdy5jcnlwdG8gfHwgKHdpbmRvdyBhcyBhbnkpLm1zQ3J5cHRvO1xyXG5cclxuICBnZW5lcmF0ZVJhbmRvbShzaXplOiBudW1iZXIpIHtcclxuICAgIGNvbnN0IGJ1ZmZlciA9IG5ldyBVaW50OEFycmF5KHNpemUpO1xyXG4gICAgaWYgKHRoaXMuYnJvd3NlckNyeXB0bykge1xyXG4gICAgICB0aGlzLmJyb3dzZXJDcnlwdG8uZ2V0UmFuZG9tVmFsdWVzKGJ1ZmZlcik7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICAvLyBmYWxsIGJhY2sgdG8gTWF0aC5yYW5kb20oKSBpZiBub3RoaW5nIGVsc2UgaXMgYXZhaWxhYmxlXHJcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2l6ZTsgaSArPSAxKSB7XHJcbiAgICAgICAgYnVmZmVyW2ldID0gTWF0aC5yYW5kb20oKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXMuYnVmZmVyVG9TdHJpbmcoYnVmZmVyKTtcclxuICB9XHJcblxyXG4gIGRlcml2ZUNoYWxsZW5nZShjb2RlOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xyXG4gICAgaWYgKGNvZGUubGVuZ3RoIDwgNDMgfHwgY29kZS5sZW5ndGggPiAxMjgpIHtcclxuICAgICAgcmV0dXJuIFByb21pc2UucmVqZWN0KG5ldyBBcHBBdXRoRXJyb3IoJ0ludmFsaWQgY29kZSBsZW5ndGguJykpO1xyXG4gICAgfVxyXG4gICAgaWYgKCF0aGlzLmJyb3dzZXJDcnlwdG8uc3VidGxlKSB7XHJcbiAgICAgIHJldHVybiBQcm9taXNlLnJlamVjdChuZXcgQXBwQXV0aEVycm9yKCd3aW5kb3cuY3J5cHRvLnN1YnRsZSBpcyB1bmF2YWlsYWJsZS4nKSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgZWNvZGUgPSB0aGlzLnRleHRFbmNvZGVMaXRlKGNvZGUpO1xyXG4gICAgY29uc3Qgb3AgPSB0aGlzLmJyb3dzZXJDcnlwdG8uc3VidGxlLmRpZ2VzdCgnU0hBLTI1NicsIGVjb2RlKTtcclxuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XHJcbiAgICAgIC8vIGlmIG9wZXJhdGlvbiBjb250YWlucyBhbGdvcml0aG0gaXQgbWVhbnMgaXQgaXMgbm90IGEgcHJvbWlzZSB3aGljaCBtZWFucyBpdCBpcyBDcnlwdG9PcGVyYXRpb24gZnJvbSBJRS5cclxuICAgICAgLy8gV2UganVzdCByZXR1cm4gcmVzdWx0IGFzIHByb21pc2VcclxuICAgICAgaWYgKG9wLmFsZ29yaXRobSkge1xyXG4gICAgICAgIGNvbnNvbGUubG9nKCd3ZSBoYXZlIGEgQ3J5cHRvT3BlcmF0aW9uJyk7XHJcbiAgICAgICAgb3AuYWRkRXZlbnRMaXN0ZW5lcignY29tcGxldGUnLCAoKSA9PiB7XHJcbiAgICAgICAgICByZXNvbHZlKHRoaXMudXJsU2FmZShvcC5yZXN1bHQpKTtcclxuICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgb3AuYWRkRXZlbnRMaXN0ZW5lcignZXJyb3InLCAoKSA9PiB7XHJcbiAgICAgICAgICByZWplY3Qob3AucmVzdWx0KTtcclxuICAgICAgICB9KTtcclxuICAgICAgfSBlbHNlIHsgLy8gdGhlIHJlc3VsdCBpcyBwcm9taXNlXHJcbiAgICAgICAgb3AudGhlbihidWZmZXIgPT4gcmVzb2x2ZSh0aGlzLnVybFNhZmUoYnVmZmVyKSksIGVycm9yID0+IHJlamVjdChlcnJvcikpO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG5cclxuICBwcml2YXRlIHVybFNhZmUoYnVmZmVyOiBVaW50OEFycmF5KTogc3RyaW5nIHtcclxuICAgIGNvbnN0IGVuY29kZWQgPSBiYXNlNjQuZnJvbUJ5dGVBcnJheShuZXcgVWludDhBcnJheShidWZmZXIpKTtcclxuICAgIHJldHVybiBlbmNvZGVkLnJlcGxhY2UoL1xcKy9nLCAnLScpLnJlcGxhY2UoL1xcLy9nLCAnXycpLnJlcGxhY2UoLz0vZywgJycpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSB0ZXh0RW5jb2RlTGl0ZShzdHI6IHN0cmluZykge1xyXG4gICAgY29uc3QgYnVmID0gbmV3IEFycmF5QnVmZmVyKHN0ci5sZW5ndGgpO1xyXG4gICAgY29uc3QgYnVmVmlldyA9IG5ldyBVaW50OEFycmF5KGJ1Zik7XHJcblxyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBzdHIubGVuZ3RoOyBpKyspIHtcclxuICAgICAgYnVmVmlld1tpXSA9IHN0ci5jaGFyQ29kZUF0KGkpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGJ1ZlZpZXc7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGJ1ZmZlclRvU3RyaW5nKGJ1ZmZlcjogVWludDhBcnJheSkge1xyXG4gICAgY29uc3Qgc3RhdGUgPSBbXTtcclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYnVmZmVyLmJ5dGVMZW5ndGg7IGkgKz0gMSkge1xyXG4gICAgICBjb25zdCBpbmRleCA9IGJ1ZmZlcltpXSAlIENIQVJTRVQubGVuZ3RoO1xyXG4gICAgICBzdGF0ZS5wdXNoKENIQVJTRVRbaW5kZXhdKTtcclxuICAgIH1cclxuICAgIHJldHVybiBzdGF0ZS5qb2luKCcnKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { NucleusAppService } from '@kolektor/nucleus-common';
|
|
3
|
-
import { NucleusIdentityConfig } from '../nucleus-identity-config';
|
|
4
|
-
import { AngularRequestor } from './angular-requestor';
|
|
5
|
-
import { NucleusAuthorizationServiceConfiguration } from './authorization-service-configuration';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "./angular-requestor";
|
|
8
|
-
import * as i2 from "../nucleus-identity-config";
|
|
9
|
-
import * as i3 from "@kolektor/nucleus-common";
|
|
10
|
-
export class OidcConfigurationService {
|
|
11
|
-
constructor(requestor, config, appService) {
|
|
12
|
-
this.requestor = requestor;
|
|
13
|
-
this.config = config;
|
|
14
|
-
this.appService = appService;
|
|
15
|
-
this._configuration = null;
|
|
16
|
-
}
|
|
17
|
-
async getConfiguration() {
|
|
18
|
-
await this.assureConfiguration();
|
|
19
|
-
return this._configuration;
|
|
20
|
-
}
|
|
21
|
-
get clientId() {
|
|
22
|
-
return this.config.clientId;
|
|
23
|
-
}
|
|
24
|
-
get requestedScopes() {
|
|
25
|
-
return this.config.requestedScopes;
|
|
26
|
-
}
|
|
27
|
-
get servicePrincipalRequestedScopes() {
|
|
28
|
-
return this.config.servicePrincipalRequestedScopes;
|
|
29
|
-
}
|
|
30
|
-
get authProviderHint() {
|
|
31
|
-
return this.config.authProviderHint;
|
|
32
|
-
}
|
|
33
|
-
get redirectUrl() {
|
|
34
|
-
let uri = window.location.href;
|
|
35
|
-
const platform = this.appService.platform;
|
|
36
|
-
if (platform === 'android' && this.config.androidRedirectUri) {
|
|
37
|
-
uri = this.config.androidRedirectUri;
|
|
38
|
-
}
|
|
39
|
-
else if (platform === 'ios' && this.config.iOSRedirectUri) {
|
|
40
|
-
uri = this.config.iOSRedirectUri;
|
|
41
|
-
}
|
|
42
|
-
else if (this.config.redirectUri) {
|
|
43
|
-
uri = this.config.redirectUri;
|
|
44
|
-
}
|
|
45
|
-
return this.NormalizeRedirectUri(uri);
|
|
46
|
-
}
|
|
47
|
-
getServerUrl(relativeUri = null) {
|
|
48
|
-
let authority = this.config.authority;
|
|
49
|
-
if (!authority || authority === 'origin') {
|
|
50
|
-
authority = window.origin;
|
|
51
|
-
}
|
|
52
|
-
let url = new URL(authority);
|
|
53
|
-
if (relativeUri) {
|
|
54
|
-
url = new URL(relativeUri, url);
|
|
55
|
-
}
|
|
56
|
-
return url.href;
|
|
57
|
-
}
|
|
58
|
-
NormalizeRedirectUri(uri) {
|
|
59
|
-
const i = uri.indexOf('#');
|
|
60
|
-
if (i > 0) {
|
|
61
|
-
uri = uri.substring(0, i);
|
|
62
|
-
}
|
|
63
|
-
return uri;
|
|
64
|
-
}
|
|
65
|
-
async assureConfiguration() {
|
|
66
|
-
if (this._configuration != null) {
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
let authority = this.getServerUrl();
|
|
70
|
-
if (authority[authority.length - 1] === '/') {
|
|
71
|
-
authority = authority.slice(0, -1);
|
|
72
|
-
}
|
|
73
|
-
try {
|
|
74
|
-
this._configuration = await NucleusAuthorizationServiceConfiguration.fetchFromIssuer(authority, this.requestor);
|
|
75
|
-
}
|
|
76
|
-
catch (e) {
|
|
77
|
-
console.error('Nucleus.Identity: Cannot load OIDC configuration: ' + e.message);
|
|
78
|
-
throw e;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
OidcConfigurationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: OidcConfigurationService, deps: [{ token: i1.AngularRequestor }, { token: i2.NucleusIdentityConfig }, { token: i3.NucleusAppService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
83
|
-
OidcConfigurationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: OidcConfigurationService, providedIn: 'root' });
|
|
84
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: OidcConfigurationService, decorators: [{
|
|
85
|
-
type: Injectable,
|
|
86
|
-
args: [{
|
|
87
|
-
providedIn: 'root'
|
|
88
|
-
}]
|
|
89
|
-
}], ctorParameters: function () { return [{ type: i1.AngularRequestor }, { type: i2.NucleusIdentityConfig }, { type: i3.NucleusAppService }]; } });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2lkYy1jb25maWd1cmF0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udWNsZXVzLWlkZW50aXR5L3NyYy9saWIvdXRpbHMvb2lkYy1jb25maWd1cmF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsd0NBQXdDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7Ozs7QUFLakcsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxZQUNVLFNBQTJCLEVBQzNCLE1BQTZCLEVBQzdCLFVBQTZCO1FBRjdCLGNBQVMsR0FBVCxTQUFTLENBQWtCO1FBQzNCLFdBQU0sR0FBTixNQUFNLENBQXVCO1FBQzdCLGVBQVUsR0FBVixVQUFVLENBQW1CO1FBSS9CLG1CQUFjLEdBQTZDLElBQUksQ0FBQztJQUZ4RSxDQUFDO0lBSU0sS0FBSyxDQUFDLGdCQUFnQjtRQUN6QixNQUFNLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUMvQixDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQVcsZUFBZTtRQUN4QixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxJQUFXLCtCQUErQjtRQUN4QyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsK0JBQStCLENBQUM7SUFDckQsQ0FBQztJQUVELElBQVcsZ0JBQWdCO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQztJQUN0QyxDQUFDO0lBRUQsSUFBVyxXQUFXO1FBQ3BCLElBQUksR0FBRyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQy9CLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDO1FBQzFDLElBQUksUUFBUSxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixFQUFFO1lBQzVELEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixDQUFDO1NBQ3RDO2FBQU0sSUFBSSxRQUFRLEtBQUssS0FBSyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxFQUFFO1lBQzNELEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQztTQUNsQzthQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUU7WUFDbEMsR0FBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDO1NBQy9CO1FBQ0QsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVNLFlBQVksQ0FBQyxjQUFzQixJQUFJO1FBQzVDLElBQUksU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxTQUFTLElBQUksU0FBUyxLQUFLLFFBQVEsRUFBRTtZQUN4QyxTQUFTLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztTQUMzQjtRQUVELElBQUksR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRTdCLElBQUksV0FBVyxFQUFFO1lBQ2YsR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLFdBQVcsRUFBRSxHQUFHLENBQUMsQ0FBQztTQUNqQztRQUVELE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQztJQUNsQixDQUFDO0lBRU8sb0JBQW9CLENBQUMsR0FBVztRQUN0QyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzNCLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNULEdBQUcsR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUMzQjtRQUNELE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztJQUVPLEtBQUssQ0FBQyxtQkFBbUI7UUFDL0IsSUFBSSxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksRUFBRTtZQUMvQixPQUFPO1NBQ1I7UUFDRCxJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDcEMsSUFBSSxTQUFTLENBQUMsU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsS0FBSyxHQUFHLEVBQUU7WUFDM0MsU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDcEM7UUFDRCxJQUFJO1lBQ0YsSUFBSSxDQUFDLGNBQWMsR0FBRyxNQUFNLHdDQUF3QyxDQUFDLGVBQWUsQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ2pIO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixPQUFPLENBQUMsS0FBSyxDQUFDLG9EQUFvRCxHQUFJLENBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMzRixNQUFNLENBQUMsQ0FBQztTQUNUO0lBQ0gsQ0FBQzs7cUhBakZVLHdCQUF3Qjt5SEFBeEIsd0JBQXdCLGNBRnZCLE1BQU07MkZBRVAsd0JBQXdCO2tCQUhwQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTnVjbGV1c0FwcFNlcnZpY2UgfSBmcm9tICdAa29sZWt0b3IvbnVjbGV1cy1jb21tb24nO1xyXG5pbXBvcnQgeyBOdWNsZXVzSWRlbnRpdHlDb25maWcgfSBmcm9tICcuLi9udWNsZXVzLWlkZW50aXR5LWNvbmZpZyc7XHJcbmltcG9ydCB7IEFuZ3VsYXJSZXF1ZXN0b3IgfSBmcm9tICcuL2FuZ3VsYXItcmVxdWVzdG9yJztcclxuaW1wb3J0IHsgTnVjbGV1c0F1dGhvcml6YXRpb25TZXJ2aWNlQ29uZmlndXJhdGlvbiB9IGZyb20gJy4vYXV0aG9yaXphdGlvbi1zZXJ2aWNlLWNvbmZpZ3VyYXRpb24nO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgT2lkY0NvbmZpZ3VyYXRpb25TZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVxdWVzdG9yOiBBbmd1bGFyUmVxdWVzdG9yLFxyXG4gICAgcHJpdmF0ZSBjb25maWc6IE51Y2xldXNJZGVudGl0eUNvbmZpZyxcclxuICAgIHByaXZhdGUgYXBwU2VydmljZTogTnVjbGV1c0FwcFNlcnZpY2UsXHJcbiAgKSB7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9jb25maWd1cmF0aW9uOiBOdWNsZXVzQXV0aG9yaXphdGlvblNlcnZpY2VDb25maWd1cmF0aW9uID0gbnVsbDtcclxuXHJcbiAgcHVibGljIGFzeW5jIGdldENvbmZpZ3VyYXRpb24oKSB7XHJcbiAgICAgIGF3YWl0IHRoaXMuYXNzdXJlQ29uZmlndXJhdGlvbigpO1xyXG4gICAgICByZXR1cm4gdGhpcy5fY29uZmlndXJhdGlvbjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgY2xpZW50SWQoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5jb25maWcuY2xpZW50SWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHJlcXVlc3RlZFNjb3BlcygpIHtcclxuICAgIHJldHVybiB0aGlzLmNvbmZpZy5yZXF1ZXN0ZWRTY29wZXM7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHNlcnZpY2VQcmluY2lwYWxSZXF1ZXN0ZWRTY29wZXMoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5jb25maWcuc2VydmljZVByaW5jaXBhbFJlcXVlc3RlZFNjb3BlcztcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgYXV0aFByb3ZpZGVySGludCgpIHtcclxuICAgIHJldHVybiB0aGlzLmNvbmZpZy5hdXRoUHJvdmlkZXJIaW50O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCByZWRpcmVjdFVybCgpIHtcclxuICAgIGxldCB1cmkgPSB3aW5kb3cubG9jYXRpb24uaHJlZjtcclxuICAgIGNvbnN0IHBsYXRmb3JtID0gdGhpcy5hcHBTZXJ2aWNlLnBsYXRmb3JtO1xyXG4gICAgaWYgKHBsYXRmb3JtID09PSAnYW5kcm9pZCcgJiYgdGhpcy5jb25maWcuYW5kcm9pZFJlZGlyZWN0VXJpKSB7XHJcbiAgICAgIHVyaSA9IHRoaXMuY29uZmlnLmFuZHJvaWRSZWRpcmVjdFVyaTtcclxuICAgIH0gZWxzZSBpZiAocGxhdGZvcm0gPT09ICdpb3MnICYmIHRoaXMuY29uZmlnLmlPU1JlZGlyZWN0VXJpKSB7XHJcbiAgICAgIHVyaSA9IHRoaXMuY29uZmlnLmlPU1JlZGlyZWN0VXJpO1xyXG4gICAgfSBlbHNlIGlmICh0aGlzLmNvbmZpZy5yZWRpcmVjdFVyaSkge1xyXG4gICAgICB1cmkgPSB0aGlzLmNvbmZpZy5yZWRpcmVjdFVyaTtcclxuICAgIH1cclxuICAgIHJldHVybiB0aGlzLk5vcm1hbGl6ZVJlZGlyZWN0VXJpKHVyaSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0U2VydmVyVXJsKHJlbGF0aXZlVXJpOiBzdHJpbmcgPSBudWxsKSB7XHJcbiAgICBsZXQgYXV0aG9yaXR5ID0gdGhpcy5jb25maWcuYXV0aG9yaXR5O1xyXG4gICAgaWYgKCFhdXRob3JpdHkgfHwgYXV0aG9yaXR5ID09PSAnb3JpZ2luJykge1xyXG4gICAgICBhdXRob3JpdHkgPSB3aW5kb3cub3JpZ2luO1xyXG4gICAgfVxyXG5cclxuICAgIGxldCB1cmwgPSBuZXcgVVJMKGF1dGhvcml0eSk7XHJcblxyXG4gICAgaWYgKHJlbGF0aXZlVXJpKSB7XHJcbiAgICAgIHVybCA9IG5ldyBVUkwocmVsYXRpdmVVcmksIHVybCk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHVybC5ocmVmO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBOb3JtYWxpemVSZWRpcmVjdFVyaSh1cmk6IHN0cmluZykge1xyXG4gICAgY29uc3QgaSA9IHVyaS5pbmRleE9mKCcjJyk7XHJcbiAgICBpZiAoaSA+IDApIHtcclxuICAgICAgdXJpID0gdXJpLnN1YnN0cmluZygwLCBpKTtcclxuICAgIH1cclxuICAgIHJldHVybiB1cmk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFzeW5jIGFzc3VyZUNvbmZpZ3VyYXRpb24oKSB7XHJcbiAgICBpZiAodGhpcy5fY29uZmlndXJhdGlvbiAhPSBudWxsKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuICAgIGxldCBhdXRob3JpdHkgPSB0aGlzLmdldFNlcnZlclVybCgpO1xyXG4gICAgaWYgKGF1dGhvcml0eVthdXRob3JpdHkubGVuZ3RoIC0gMV0gPT09ICcvJykge1xyXG4gICAgICBhdXRob3JpdHkgPSBhdXRob3JpdHkuc2xpY2UoMCwgLTEpO1xyXG4gICAgfVxyXG4gICAgdHJ5IHtcclxuICAgICAgdGhpcy5fY29uZmlndXJhdGlvbiA9IGF3YWl0IE51Y2xldXNBdXRob3JpemF0aW9uU2VydmljZUNvbmZpZ3VyYXRpb24uZmV0Y2hGcm9tSXNzdWVyKGF1dGhvcml0eSwgdGhpcy5yZXF1ZXN0b3IpO1xyXG4gICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICBjb25zb2xlLmVycm9yKCdOdWNsZXVzLklkZW50aXR5OiBDYW5ub3QgbG9hZCBPSURDIGNvbmZpZ3VyYXRpb246ICcgKyAoZSBhcyBFcnJvcikubWVzc2FnZSk7XHJcbiAgICAgIHRocm93IGU7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
import 'capacitor-secure-storage-plugin';
|
|
2
|
-
import { TokenResponse } from '@openid/appauth';
|
|
3
|
-
import { Identity } from '../models/identity';
|
|
4
|
-
import { SecureStoragePlugin } from 'capacitor-secure-storage-plugin';
|
|
5
|
-
export class SecretsStore {
|
|
6
|
-
constructor(clientId) {
|
|
7
|
-
this._tokens = {};
|
|
8
|
-
this._identities = {};
|
|
9
|
-
// this specify which identity id is used by default, when If id is not specified in getToken or getIdentity
|
|
10
|
-
this._defaultIdentityId = null;
|
|
11
|
-
this._defaultIdentityIdStorageKey = null;
|
|
12
|
-
this._tokenStorageKeyPrefix = `Nucleus.Identity.${clientId}`; // do not change this or login with existing tokens will fail
|
|
13
|
-
this._servicePrincipalKey = `${this._tokenStorageKeyPrefix}.SvcP`;
|
|
14
|
-
this._defaultIdentityIdStorageKey = `${this._tokenStorageKeyPrefix}.IdId`;
|
|
15
|
-
this._defaultIdentityId = localStorage.getItem(this._defaultIdentityIdStorageKey);
|
|
16
|
-
}
|
|
17
|
-
get defaultIdentityId() {
|
|
18
|
-
return this._defaultIdentityId;
|
|
19
|
-
}
|
|
20
|
-
removeServicePrincipal() {
|
|
21
|
-
this._servicePrincipal = null;
|
|
22
|
-
return this.clear(this._servicePrincipalKey);
|
|
23
|
-
}
|
|
24
|
-
async setServicePrincipal(servicePrincipal) {
|
|
25
|
-
this._servicePrincipal = servicePrincipal;
|
|
26
|
-
await this.save(this._servicePrincipalKey, servicePrincipal);
|
|
27
|
-
}
|
|
28
|
-
async getServicePrincipal() {
|
|
29
|
-
if (!this._servicePrincipal) {
|
|
30
|
-
this._servicePrincipal = await this.load(this._servicePrincipalKey);
|
|
31
|
-
}
|
|
32
|
-
return this._servicePrincipal;
|
|
33
|
-
}
|
|
34
|
-
setToken(token, id = null) {
|
|
35
|
-
return this.setTokenInternal(token, true, id);
|
|
36
|
-
}
|
|
37
|
-
getIdentity(id = null) {
|
|
38
|
-
const key = this.getTokenKey(id);
|
|
39
|
-
return this._identities[key];
|
|
40
|
-
}
|
|
41
|
-
setDefaultIdentityId(id) {
|
|
42
|
-
this._defaultIdentityId = id;
|
|
43
|
-
if (this._defaultIdentityId) {
|
|
44
|
-
localStorage.setItem(this._defaultIdentityIdStorageKey, this._defaultIdentityId);
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
localStorage.removeItem(this._defaultIdentityIdStorageKey);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
async getToken(id = null) {
|
|
51
|
-
const key = this.getTokenKey(id);
|
|
52
|
-
// if token is not there or it is invalid we check storage again before returning
|
|
53
|
-
if (!this._tokens[key] || !this._tokens[key].isValid()) {
|
|
54
|
-
await this.reloadTokenFromStorage(id);
|
|
55
|
-
}
|
|
56
|
-
return this._tokens[key];
|
|
57
|
-
}
|
|
58
|
-
removeToken(id = null) {
|
|
59
|
-
const key = this.getTokenKey(id);
|
|
60
|
-
delete this._tokens[key];
|
|
61
|
-
delete this._identities[key];
|
|
62
|
-
return this.clear(key);
|
|
63
|
-
}
|
|
64
|
-
async reloadTokenFromStorage(id) {
|
|
65
|
-
const key = this.getTokenKey(id);
|
|
66
|
-
const storedToken = await this.load(key);
|
|
67
|
-
if (storedToken) {
|
|
68
|
-
const res = new TokenResponse(storedToken);
|
|
69
|
-
if (res?.accessToken || res?.idToken) {
|
|
70
|
-
await this.setTokenInternal(res, false, id);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return null;
|
|
74
|
-
}
|
|
75
|
-
async setTokenInternal(token, save, id = null) {
|
|
76
|
-
const key = this.getTokenKey(id);
|
|
77
|
-
if (token == null) {
|
|
78
|
-
await this.removeToken(id);
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
this._tokens[key] = token;
|
|
82
|
-
this._identities[key] = Identity.createFromResponse(token);
|
|
83
|
-
if (save) {
|
|
84
|
-
try {
|
|
85
|
-
await this.save(key, token.toJson());
|
|
86
|
-
}
|
|
87
|
-
catch (e) {
|
|
88
|
-
console.warn('Nucleus.Identity: Could not save to SecureStorage.');
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
getTokenKey(id = null) {
|
|
94
|
-
if (!id) {
|
|
95
|
-
id = this._defaultIdentityId;
|
|
96
|
-
}
|
|
97
|
-
return id ? `${this._tokenStorageKeyPrefix}.${id}` : this._tokenStorageKeyPrefix;
|
|
98
|
-
}
|
|
99
|
-
clear(key) {
|
|
100
|
-
return SecureStoragePlugin.remove({ key });
|
|
101
|
-
}
|
|
102
|
-
save(key, value) {
|
|
103
|
-
return SecureStoragePlugin.set({ key, value: JSON.stringify(value) });
|
|
104
|
-
}
|
|
105
|
-
async load(key) {
|
|
106
|
-
try {
|
|
107
|
-
const x = await SecureStoragePlugin.get({ key });
|
|
108
|
-
if (x?.value) {
|
|
109
|
-
return JSON.parse(x.value);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
return null;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
catch {
|
|
116
|
-
return null;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"secrets-store.js","sourceRoot":"","sources":["../../../../../projects/nucleus-identity/src/lib/utils/secrets-store.ts"],"names":[],"mappings":"AAAA,OAAO,iCAAiC,CAAC;AACzC,OAAO,EAAE,aAAa,EAAqB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAEtE,MAAM,OAAO,YAAY;IACvB,YAAY,QAAgB;QAOpB,YAAO,GAAoC,EAAE,CAAC;QAC9C,gBAAW,GAA+B,EAAE,CAAC;QAGrD,4GAA4G;QACpG,uBAAkB,GAAW,IAAI,CAAC;QAClC,iCAA4B,GAAW,IAAI,CAAC;QAZlD,IAAI,CAAC,sBAAsB,GAAG,oBAAoB,QAAQ,EAAE,CAAC,CAAC,6DAA6D;QAC3H,IAAI,CAAC,oBAAoB,GAAG,GAAG,IAAI,CAAC,sBAAsB,OAAO,CAAC;QAClE,IAAI,CAAC,4BAA4B,GAAG,GAAG,IAAI,CAAC,sBAAsB,OAAO,CAAC;QAC1E,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IACpF,CAAC;IAUD,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAEM,sBAAsB;QAC3B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IAC/C,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAAC,gBAAkC;QACjE,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;QAC1C,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,gBAAgB,CAAC,CAAC;IAC/D,CAAC;IAEM,KAAK,CAAC,mBAAmB;QAC9B,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,IAAI,CAAC,iBAAiB,GAAG,MAAM,IAAI,CAAC,IAAI,CAAmB,IAAI,CAAC,oBAAoB,CAAC,CAAC;SACvF;QACD,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAEM,QAAQ,CAAC,KAAoB,EAAE,KAAa,IAAI;QACrD,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;IAChD,CAAC;IAEM,WAAW,CAAC,KAAa,IAAI;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACjC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAEM,oBAAoB,CAAC,EAAU;QACpC,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,4BAA4B,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;SAClF;aAAM;YACL,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;SAC5D;IACH,CAAC;IAEM,KAAK,CAAC,QAAQ,CAAC,KAAa,IAAI;QACrC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAEjC,iFAAiF;QACjF,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACtD,MAAM,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;SACvC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;IAEM,WAAW,CAAC,KAAa,IAAI;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACjC,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC7B,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IAEO,KAAK,CAAC,sBAAsB,CAAC,EAAU;QAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACjC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,IAAI,CAAoB,GAAG,CAAC,CAAC;QAC5D,IAAI,WAAW,EAAE;YACf,MAAM,GAAG,GAAG,IAAI,aAAa,CAAC,WAAW,CAAC,CAAC;YAC3C,IAAI,GAAG,EAAE,WAAW,IAAI,GAAG,EAAE,OAAO,EAAE;gBACpC,MAAM,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;aAC7C;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAAC,KAAoB,EAAE,IAAa,EAAE,KAAa,IAAI;QACnF,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACjC,IAAI,KAAK,IAAI,IAAI,EAAE;YACjB,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC3D,IAAI,IAAI,EAAE;gBACR,IAAI;oBACF,MAAM,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;iBACtC;gBAAC,OAAO,CAAC,EAAE;oBACV,OAAO,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;iBACpE;aACF;SACF;IACH,CAAC;IAEO,WAAW,CAAC,KAAa,IAAI;QACnC,IAAI,CAAC,EAAE,EAAE;YACP,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC;SAC9B;QACD,OAAO,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,sBAAsB,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC;IACnF,CAAC;IAEO,KAAK,CAAC,GAAW;QACvB,OAAO,mBAAmB,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7C,CAAC;IAEO,IAAI,CAAI,GAAW,EAAE,KAAQ;QACnC,OAAO,mBAAmB,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACxE,CAAC;IAEO,KAAK,CAAC,IAAI,CAAI,GAAW;QAC/B,IAAI;YACF,MAAM,CAAC,GAAG,MAAM,mBAAmB,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YACjD,IAAI,CAAC,EAAE,KAAK,EAAE;gBACZ,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAM,CAAC;aACjC;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;SACF;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;CAEF","sourcesContent":["import 'capacitor-secure-storage-plugin';\r\nimport { TokenResponse, TokenResponseJson } from '@openid/appauth';\r\nimport { Identity } from '../models/identity';\r\nimport { ServicePrincipal } from '../models/service-principal';\r\nimport { SecureStoragePlugin } from 'capacitor-secure-storage-plugin';\r\n\r\nexport class SecretsStore {\r\n  constructor(clientId: string) {\r\n    this._tokenStorageKeyPrefix = `Nucleus.Identity.${clientId}`; // do not change this or login with existing tokens will fail\r\n    this._servicePrincipalKey = `${this._tokenStorageKeyPrefix}.SvcP`;\r\n    this._defaultIdentityIdStorageKey = `${this._tokenStorageKeyPrefix}.IdId`;\r\n    this._defaultIdentityId = localStorage.getItem(this._defaultIdentityIdStorageKey);\r\n  }\r\n  private _tokenStorageKeyPrefix: string;\r\n  private _tokens: { [id: string]: TokenResponse } = {};\r\n  private _identities: { [id: string]: Identity } = {};\r\n  private _servicePrincipalKey;\r\n  private _servicePrincipal: ServicePrincipal;\r\n  // this specify which identity id is used by default, when If id is not specified in getToken or getIdentity\r\n  private _defaultIdentityId: string = null;\r\n  private _defaultIdentityIdStorageKey: string = null;\r\n\r\n  public get defaultIdentityId() {\r\n    return this._defaultIdentityId;\r\n  }\r\n\r\n  public removeServicePrincipal() {\r\n    this._servicePrincipal = null;\r\n    return this.clear(this._servicePrincipalKey);\r\n  }\r\n\r\n  public async setServicePrincipal(servicePrincipal: ServicePrincipal) {\r\n    this._servicePrincipal = servicePrincipal;\r\n    await this.save(this._servicePrincipalKey, servicePrincipal);\r\n  }\r\n\r\n  public async getServicePrincipal() {\r\n    if (!this._servicePrincipal) {\r\n      this._servicePrincipal = await this.load<ServicePrincipal>(this._servicePrincipalKey);\r\n    }\r\n    return this._servicePrincipal;\r\n  }\r\n\r\n  public setToken(token: TokenResponse, id: string = null) {\r\n    return this.setTokenInternal(token, true, id);\r\n  }\r\n\r\n  public getIdentity(id: string = null) {\r\n    const key = this.getTokenKey(id);\r\n    return this._identities[key];\r\n  }\r\n\r\n  public setDefaultIdentityId(id: string) {\r\n    this._defaultIdentityId = id;\r\n    if (this._defaultIdentityId) {\r\n      localStorage.setItem(this._defaultIdentityIdStorageKey, this._defaultIdentityId);\r\n    } else {\r\n      localStorage.removeItem(this._defaultIdentityIdStorageKey);\r\n    }\r\n  }\r\n\r\n  public async getToken(id: string = null) {\r\n    const key = this.getTokenKey(id);\r\n\r\n    // if token is not there or it is invalid we check storage again before returning\r\n    if (!this._tokens[key] || !this._tokens[key].isValid()) {\r\n      await this.reloadTokenFromStorage(id);\r\n    }\r\n    return this._tokens[key];\r\n  }\r\n\r\n  public removeToken(id: string = null) {\r\n    const key = this.getTokenKey(id);\r\n    delete this._tokens[key];\r\n    delete this._identities[key];\r\n    return this.clear(key);\r\n  }\r\n\r\n  private async reloadTokenFromStorage(id: string) {\r\n    const key = this.getTokenKey(id);\r\n    const storedToken = await this.load<TokenResponseJson>(key);\r\n    if (storedToken) {\r\n      const res = new TokenResponse(storedToken);\r\n      if (res?.accessToken || res?.idToken) {\r\n        await this.setTokenInternal(res, false, id);\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  private async setTokenInternal(token: TokenResponse, save: boolean, id: string = null) {\r\n    const key = this.getTokenKey(id);\r\n    if (token == null) {\r\n      await this.removeToken(id);\r\n    } else {\r\n      this._tokens[key] = token;\r\n      this._identities[key] = Identity.createFromResponse(token);\r\n      if (save) {\r\n        try {\r\n          await this.save(key, token.toJson());\r\n        } catch (e) {\r\n          console.warn('Nucleus.Identity: Could not save to SecureStorage.');\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private getTokenKey(id: string = null) {\r\n    if (!id) {\r\n      id = this._defaultIdentityId;\r\n    }\r\n    return id ? `${this._tokenStorageKeyPrefix}.${id}` : this._tokenStorageKeyPrefix;\r\n  }\r\n\r\n  private clear(key: string) {\r\n    return SecureStoragePlugin.remove({ key });\r\n  }\r\n\r\n  private save<T>(key: string, value: T): Promise<{ value: boolean }> {\r\n    return SecureStoragePlugin.set({ key, value: JSON.stringify(value) });\r\n  }\r\n\r\n  private async load<T>(key: string) {\r\n    try {\r\n      const x = await SecureStoragePlugin.get({ key });\r\n      if (x?.value) {\r\n        return JSON.parse(x.value) as T;\r\n      } else {\r\n        return null;\r\n      }\r\n    } catch {\r\n      return null;\r\n    }\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
import { AppAuthError, BaseTokenRequestHandler, BasicQueryStringUtils, GRANT_TYPE_AUTHORIZATION_CODE, GRANT_TYPE_REFRESH_TOKEN, TokenRequest } from '@openid/appauth';
|
|
2
|
-
import { OidcConfigurationService } from './oidc-configuration.service';
|
|
3
|
-
import { AngularRequestor } from './angular-requestor';
|
|
4
|
-
import { Injectable } from '@angular/core';
|
|
5
|
-
import { DeviceCode } from '../models/device-code';
|
|
6
|
-
import { ClientRegistrationResponse } from '../models/client-registration';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "./angular-requestor";
|
|
9
|
-
import * as i2 from "./oidc-configuration.service";
|
|
10
|
-
export class TokenClient {
|
|
11
|
-
constructor(requestor, config) {
|
|
12
|
-
this.requestor = requestor;
|
|
13
|
-
this.config = config;
|
|
14
|
-
this._tokenHandler = new BaseTokenRequestHandler(requestor);
|
|
15
|
-
this._utils = new BasicQueryStringUtils();
|
|
16
|
-
}
|
|
17
|
-
async getByAuthorizationCode(redirectUrl, code, codeVerifier) {
|
|
18
|
-
const config = await this.config.getConfiguration();
|
|
19
|
-
const redirectUri = redirectUrl;
|
|
20
|
-
const req = new TokenRequest({
|
|
21
|
-
client_id: this.config.clientId,
|
|
22
|
-
redirect_uri: redirectUri,
|
|
23
|
-
grant_type: GRANT_TYPE_AUTHORIZATION_CODE,
|
|
24
|
-
code,
|
|
25
|
-
extras: { code_verifier: codeVerifier }
|
|
26
|
-
});
|
|
27
|
-
return await this._tokenHandler.performTokenRequest(config, req);
|
|
28
|
-
}
|
|
29
|
-
async getByRefreshToken(refreshToken) {
|
|
30
|
-
const config = await this.config.getConfiguration();
|
|
31
|
-
const redirectUri = this.config.redirectUrl;
|
|
32
|
-
const req = new TokenRequest({
|
|
33
|
-
client_id: this.config.clientId,
|
|
34
|
-
redirect_uri: redirectUri,
|
|
35
|
-
grant_type: GRANT_TYPE_REFRESH_TOKEN,
|
|
36
|
-
refresh_token: refreshToken
|
|
37
|
-
});
|
|
38
|
-
return await this._tokenHandler.performTokenRequest(config, req);
|
|
39
|
-
}
|
|
40
|
-
async getByClientCredentials(clientId, clientSecret, scope) {
|
|
41
|
-
const config = await this.config.getConfiguration();
|
|
42
|
-
const req = new TokenRequest({
|
|
43
|
-
client_id: clientId,
|
|
44
|
-
redirect_uri: null,
|
|
45
|
-
grant_type: 'client_credentials',
|
|
46
|
-
extras: {
|
|
47
|
-
client_secret: clientSecret,
|
|
48
|
-
scope,
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
return await this._tokenHandler.performTokenRequest(config, req);
|
|
52
|
-
}
|
|
53
|
-
async getBySecret(provider, secret, assertionToken, scope) {
|
|
54
|
-
const config = await this.config.getConfiguration();
|
|
55
|
-
const req = new TokenRequest({
|
|
56
|
-
client_id: this.config.clientId,
|
|
57
|
-
redirect_uri: null,
|
|
58
|
-
grant_type: 'urn:kolektor:nucleus:secret',
|
|
59
|
-
extras: {
|
|
60
|
-
secret_provider: provider,
|
|
61
|
-
secret_value: secret,
|
|
62
|
-
client_assertion_type: 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer',
|
|
63
|
-
client_assertion: assertionToken,
|
|
64
|
-
scope,
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
return await this._tokenHandler.performTokenRequest(config, req);
|
|
68
|
-
}
|
|
69
|
-
async getByDeviceCode(deviceCode) {
|
|
70
|
-
const config = await this.config.getConfiguration();
|
|
71
|
-
const req = new TokenRequest({
|
|
72
|
-
client_id: this.config.clientId,
|
|
73
|
-
redirect_uri: null,
|
|
74
|
-
grant_type: 'urn:ietf:params:oauth:grant-type:device_code',
|
|
75
|
-
extras: {
|
|
76
|
-
device_code: deviceCode
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
return await this._tokenHandler.performTokenRequest(config, req);
|
|
80
|
-
}
|
|
81
|
-
async registerServicePrincipal(token) {
|
|
82
|
-
const config = await this.config.getConfiguration();
|
|
83
|
-
const response = await this.requestor.xhr({
|
|
84
|
-
url: config.registrationEndpoint,
|
|
85
|
-
method: 'POST',
|
|
86
|
-
dataType: 'json',
|
|
87
|
-
headers: {
|
|
88
|
-
'Content-Type': 'application/json',
|
|
89
|
-
Authorization: `Bearer ${token}`
|
|
90
|
-
}
|
|
91
|
-
// data: this._utils.stringify(map)
|
|
92
|
-
});
|
|
93
|
-
if (response.error === undefined) {
|
|
94
|
-
return new ClientRegistrationResponse(response);
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
throw new AppAuthError(response.error);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
async getRegistrationCode(existingServicePrincipalId = null) {
|
|
101
|
-
const params = {
|
|
102
|
-
custom_action: 'sp_register',
|
|
103
|
-
service_principal_id: existingServicePrincipalId
|
|
104
|
-
};
|
|
105
|
-
return this.getDeviceCodeInternal(params);
|
|
106
|
-
}
|
|
107
|
-
async getDeviceCode(scope) {
|
|
108
|
-
const params = {
|
|
109
|
-
scope,
|
|
110
|
-
};
|
|
111
|
-
return this.getDeviceCodeInternal(params);
|
|
112
|
-
}
|
|
113
|
-
async getDeviceCodeInternal(params) {
|
|
114
|
-
const config = await this.config.getConfiguration();
|
|
115
|
-
params['client_id'] = this.config.clientId;
|
|
116
|
-
const map = params;
|
|
117
|
-
const response = await this.requestor.xhr({
|
|
118
|
-
url: config.deviceAuthorizationEndpoint,
|
|
119
|
-
method: 'POST',
|
|
120
|
-
dataType: 'json',
|
|
121
|
-
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
|
122
|
-
data: this._utils.stringify(map)
|
|
123
|
-
});
|
|
124
|
-
if (response.error === undefined) {
|
|
125
|
-
return new DeviceCode(response);
|
|
126
|
-
}
|
|
127
|
-
else {
|
|
128
|
-
throw new AppAuthError(response.error);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
TokenClient.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TokenClient, deps: [{ token: i1.AngularRequestor }, { token: i2.OidcConfigurationService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
133
|
-
TokenClient.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TokenClient, providedIn: 'root' });
|
|
134
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TokenClient, decorators: [{
|
|
135
|
-
type: Injectable,
|
|
136
|
-
args: [{
|
|
137
|
-
providedIn: 'root'
|
|
138
|
-
}]
|
|
139
|
-
}], ctorParameters: function () { return [{ type: i1.AngularRequestor }, { type: i2.OidcConfigurationService }]; } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token-client.js","sourceRoot":"","sources":["../../../../../projects/nucleus-identity/src/lib/utils/token-client.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AppAuthError,\r\n  BaseTokenRequestHandler,\r\n  BasicQueryStringUtils,\r\n  GRANT_TYPE_AUTHORIZATION_CODE,\r\n  GRANT_TYPE_REFRESH_TOKEN,\r\n  QueryStringUtils,\r\n  StringMap,\r\n  TokenErrorJson,\r\n  TokenRequest,\r\n  TokenRequestHandler} from '@openid/appauth';\r\nimport { OidcConfigurationService } from './oidc-configuration.service';\r\nimport { AngularRequestor } from './angular-requestor';\r\nimport { Injectable } from '@angular/core';\r\nimport { DeviceCode, DeviceCodeJson } from '../models/device-code';\r\nimport { ClientRegistrationResponse, ClientRegistrationResponseJson } from '../models/client-registration';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class TokenClient  {\r\n  constructor(\r\n    private requestor: AngularRequestor,\r\n    private config: OidcConfigurationService\r\n  ) {\r\n    this._tokenHandler = new BaseTokenRequestHandler(requestor);\r\n    this._utils = new BasicQueryStringUtils();\r\n  }\r\n\r\n  private _tokenHandler: TokenRequestHandler;\r\n  private _utils: QueryStringUtils;\r\n\r\n  public async getByAuthorizationCode(redirectUrl: string, code: string, codeVerifier: string) {\r\n    const config = await this.config.getConfiguration();\r\n    const redirectUri = redirectUrl;\r\n    const req = new TokenRequest({\r\n      client_id: this.config.clientId,\r\n      redirect_uri: redirectUri,\r\n      grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\r\n      code,\r\n      extras: { code_verifier: codeVerifier }\r\n    });\r\n    return await this._tokenHandler.performTokenRequest(config, req);\r\n  }\r\n\r\n  public async getByRefreshToken(refreshToken: string) {\r\n    const config = await this.config.getConfiguration();\r\n    const redirectUri = this.config.redirectUrl;\r\n    const req = new TokenRequest({\r\n      client_id: this.config.clientId,\r\n      redirect_uri: redirectUri,\r\n      grant_type: GRANT_TYPE_REFRESH_TOKEN,\r\n      refresh_token: refreshToken\r\n    });\r\n    return await this._tokenHandler.performTokenRequest(config, req);\r\n  }\r\n\r\n  public async getByClientCredentials(clientId: string, clientSecret: string, scope: string) {\r\n    const config = await this.config.getConfiguration();\r\n    const req = new TokenRequest({\r\n      client_id: clientId,\r\n      redirect_uri: null,\r\n      grant_type: 'client_credentials',\r\n      extras: {\r\n        client_secret: clientSecret,\r\n        scope,\r\n      }\r\n    });\r\n    return await this._tokenHandler.performTokenRequest(config, req);\r\n  }\r\n\r\n  public async getBySecret(provider: string, secret: string, assertionToken: string, scope: string) {\r\n    const config = await this.config.getConfiguration();\r\n    const req = new TokenRequest({\r\n      client_id: this.config.clientId,\r\n      redirect_uri: null,\r\n      grant_type: 'urn:kolektor:nucleus:secret',\r\n      extras: {\r\n        secret_provider: provider,\r\n        secret_value: secret,\r\n        client_assertion_type: 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer',\r\n        client_assertion: assertionToken,\r\n        scope,\r\n      }\r\n    });\r\n\r\n    return await this._tokenHandler.performTokenRequest(config, req);\r\n  }\r\n\r\n  public async getByDeviceCode(deviceCode: string) {\r\n    const config =  await this.config.getConfiguration();\r\n    const req = new TokenRequest({\r\n      client_id: this.config.clientId,\r\n      redirect_uri: null,\r\n      grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\r\n      extras: {\r\n        device_code: deviceCode\r\n      }\r\n    });\r\n    return await this._tokenHandler.performTokenRequest(config, req);\r\n  }\r\n\r\n  public async registerServicePrincipal(token: string) {\r\n    const config =  await this.config.getConfiguration();\r\n\r\n    const response = await this.requestor.xhr<ClientRegistrationResponseJson | TokenErrorJson>({\r\n      url: config.registrationEndpoint,\r\n      method: 'POST',\r\n      dataType: 'json',\r\n      headers: {\r\n        'Content-Type': 'application/json',\r\n        Authorization: `Bearer ${token}`\r\n      }\r\n      // data: this._utils.stringify(map)\r\n    });\r\n\r\n    if ((response as TokenErrorJson).error === undefined) {\r\n      return new ClientRegistrationResponse(response as ClientRegistrationResponseJson);\r\n    } else {\r\n      throw new AppAuthError((response as TokenErrorJson).error);\r\n    }\r\n  }\r\n\r\n  public async getRegistrationCode(existingServicePrincipalId: string = null) {\r\n    const params = {\r\n      custom_action: 'sp_register',\r\n      service_principal_id: existingServicePrincipalId\r\n    };\r\n    return this.getDeviceCodeInternal(params);\r\n  }\r\n\r\n  public async getDeviceCode(scope: string) {\r\n    const params = {\r\n      scope,\r\n    };\r\n    return this.getDeviceCodeInternal(params);\r\n  }\r\n\r\n  private async getDeviceCodeInternal(params: StringMap) {\r\n    const config =  await this.config.getConfiguration();\r\n\r\n    params['client_id'] = this.config.clientId;\r\n    const map: StringMap = params;\r\n\r\n    const response = await this.requestor.xhr<DeviceCodeJson | TokenErrorJson>({\r\n      url: config.deviceAuthorizationEndpoint,\r\n      method: 'POST',\r\n      dataType: 'json',\r\n      headers: {'Content-Type': 'application/x-www-form-urlencoded'},\r\n      data: this._utils.stringify(map)\r\n    });\r\n\r\n    if ((response as TokenErrorJson).error === undefined) {\r\n      return new DeviceCode(response as DeviceCodeJson);\r\n    } else {\r\n      throw new AppAuthError((response as TokenErrorJson).error);\r\n    }\r\n  }\r\n\r\n\r\n}\r\n"]}
|
package/esm2020/public-api.mjs
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of nucleus-identity
|
|
3
|
-
*/
|
|
4
|
-
export * from './lib/nucleus-identity.module';
|
|
5
|
-
export * from './lib/nucleus-identity.service';
|
|
6
|
-
export * from './lib/nucleus-identity-config';
|
|
7
|
-
export { OtpResponse, OtpStatus, OtpType } from './lib/models/otp';
|
|
8
|
-
export { DeviceCode } from './lib/models/device-code';
|
|
9
|
-
export { Identity } from './lib/models/identity';
|
|
10
|
-
export { ServicePrincipalRegistrationStatus } from './lib/models/service-principal';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL251Y2xldXMtaWRlbnRpdHkvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ2pELE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLGdDQUFnQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG51Y2xldXMtaWRlbnRpdHlcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9udWNsZXVzLWlkZW50aXR5Lm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL251Y2xldXMtaWRlbnRpdHkuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL251Y2xldXMtaWRlbnRpdHktY29uZmlnJztcclxuZXhwb3J0IHsgT3RwUmVzcG9uc2UsIE90cFN0YXR1cywgT3RwVHlwZSB9IGZyb20gJy4vbGliL21vZGVscy9vdHAnO1xyXG5leHBvcnQgeyBEZXZpY2VDb2RlIH0gZnJvbSAnLi9saWIvbW9kZWxzL2RldmljZS1jb2RlJztcclxuZXhwb3J0IHsgSWRlbnRpdHkgfSBmcm9tICcuL2xpYi9tb2RlbHMvaWRlbnRpdHknO1xyXG5leHBvcnQgeyBTZXJ2aWNlUHJpbmNpcGFsUmVnaXN0cmF0aW9uU3RhdHVzIH0gZnJvbSAnLi9saWIvbW9kZWxzL3NlcnZpY2UtcHJpbmNpcGFsJztcclxuIl19
|