@sambath999/localize-token 12.4.11 → 12.4.13
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/bundles/sambath999-localize-token.umd.js +400 -1125
- package/bundles/sambath999-localize-token.umd.js.map +1 -1
- package/{localize-logindlg/localize-logindlg.component.d.ts → components/localize-token-login-dialog.component.d.ts} +14 -17
- package/esm2015/components/localize-token-login-dialog.component.js +395 -0
- package/esm2015/models/localize-token-models.js +2 -0
- package/esm2015/models/localize-token.module.js +26 -0
- package/esm2015/public-api.js +6 -15
- package/esm2015/sambath999-localize-token.js +1 -1
- package/esm2015/services/localize-token-configure.service.js +32 -0
- package/esm2015/services/localize-token-dialog.service.js +64 -0
- package/fesm2015/sambath999-localize-token.js +64 -906
- package/fesm2015/sambath999-localize-token.js.map +1 -1
- package/{localize-logindlg/localize-logindlg.service.d.ts → models/localize-token-models.d.ts} +1 -10
- package/package.json +2 -2
- package/public-api.d.ts +5 -13
- package/sambath999-localize-token.metadata.json +1 -1
- package/services/localize-token-configure.service.d.ts +9 -0
- package/services/localize-token-dialog.service.d.ts +10 -0
- package/README.md +0 -57
- package/esm2015/localize-api-token/localize-api-token.module.js +0 -21
- package/esm2015/localize-api-token/localize-api-token.service.js +0 -34
- package/esm2015/localize-logindlg/localize-logindlg.component.js +0 -423
- package/esm2015/localize-logindlg/localize-logindlg.module.js +0 -28
- package/esm2015/localize-logindlg/localize-logindlg.service.js +0 -64
- package/esm2015/localize-token/helpers/interfaces.js +0 -19
- package/esm2015/localize-token/helpers/localize.api.assets.js +0 -20
- package/esm2015/localize-token/helpers/loccalize.api.helper.js +0 -267
- package/esm2015/localize-token/localize.api.service.js +0 -242
- package/esm2015/localize-token/localize.token.js +0 -60
- package/esm2015/localize-token/localize.token.module.js +0 -14
- package/esm2015/localize-token/localize.token.service.js +0 -94
- package/esm2015/localize-token/localize.token.storage.js +0 -107
- package/localize-api-token/localize-api-token.module.d.ts +0 -2
- package/localize-api-token/localize-api-token.service.d.ts +0 -12
- package/localize-logindlg/localize-logindlg.module.d.ts +0 -2
- package/localize-token/helpers/interfaces.d.ts +0 -89
- package/localize-token/helpers/localize.api.assets.d.ts +0 -5
- package/localize-token/helpers/loccalize.api.helper.d.ts +0 -32
- package/localize-token/localize.api.service.d.ts +0 -55
- package/localize-token/localize.token.d.ts +0 -55
- package/localize-token/localize.token.service.d.ts +0 -36
- package/localize-token/localize.token.storage.d.ts +0 -61
- /package/{localize-token/localize.token.module.d.ts → models/localize-token.module.d.ts} +0 -0
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { LocalizeTokenStorage } from "./localize.token.storage";
|
|
3
|
-
export class LocalizeToken {
|
|
4
|
-
}
|
|
5
|
-
LocalizeToken.storage = new LocalizeTokenStorage();
|
|
6
|
-
LocalizeToken.httpHeaders = {
|
|
7
|
-
AUTHORIZATION: 'Authorization',
|
|
8
|
-
X_TENANT: 'X-Tenant',
|
|
9
|
-
X_REFRESH_TOKEN: 'X-RefreshToken',
|
|
10
|
-
CONTENT_TYPE: 'Content-Type',
|
|
11
|
-
X_CLIENT: 'X-Client',
|
|
12
|
-
X_SECRET: 'X-Secret'
|
|
13
|
-
};
|
|
14
|
-
/**
|
|
15
|
-
* Waits for a specified amount of time.
|
|
16
|
-
* @param milliseconds - The milliseconds to wait.
|
|
17
|
-
* @param when - The condition to wait for. Default is true.
|
|
18
|
-
* @returns - Promise<void>
|
|
19
|
-
*/
|
|
20
|
-
export function waitFor(milliseconds, when = true) {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
if (!when)
|
|
23
|
-
return;
|
|
24
|
-
yield new Promise(resolve => setTimeout(resolve, milliseconds));
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Waits until the condition is met.
|
|
29
|
-
* @param when - The condition to wait for.
|
|
30
|
-
* @param intervalNumber - The interval number in milliseconds to check the condition. Default is 50.
|
|
31
|
-
*/
|
|
32
|
-
export function waitUntil(when, intervalNumber = 50) {
|
|
33
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
-
function isConditionMet() {
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
const cond = when();
|
|
37
|
-
const result = cond instanceof Promise
|
|
38
|
-
? yield cond
|
|
39
|
-
: cond;
|
|
40
|
-
return result;
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
if (yield isConditionMet())
|
|
44
|
-
return;
|
|
45
|
-
yield new Promise(resolve => {
|
|
46
|
-
const interval = setInterval(() => __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
if (yield isConditionMet()) {
|
|
48
|
-
clearInterval(interval);
|
|
49
|
-
resolve(true);
|
|
50
|
-
}
|
|
51
|
-
}), intervalNumber);
|
|
52
|
-
});
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
export function extractMainDomain(subdomain) {
|
|
56
|
-
subdomain !== null && subdomain !== void 0 ? subdomain : (subdomain = window.location.hostname);
|
|
57
|
-
const parts = subdomain.split('.');
|
|
58
|
-
return parts.length > 2 ? parts.slice(-2).join('.') : subdomain;
|
|
59
|
-
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemUudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9BTkdVTEFSL0xJQlJBUklFUy9sb2NhbGl6ZS50b2tlbi4xMi4xLjAvZGV2L3NyYy9sb2NhbGl6ZS10b2tlbi9sb2NhbGl6ZS50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFnQ2hFLE1BQU0sT0FBTyxhQUFhOztBQUVSLHFCQUFPLEdBQUcsSUFBSSxvQkFBb0IsRUFBRSxDQUFDO0FBRXJDLHlCQUFXLEdBQUc7SUFDNUIsYUFBYSxFQUFFLGVBQWU7SUFDOUIsUUFBUSxFQUFFLFVBQVU7SUFDcEIsZUFBZSxFQUFFLGdCQUFnQjtJQUNqQyxZQUFZLEVBQUUsY0FBYztJQUM1QixRQUFRLEVBQUUsVUFBVTtJQUNwQixRQUFRLEVBQUUsVUFBVTtDQUNyQixDQUFBO0FBSUg7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQWdCLE9BQU8sQ0FBQyxZQUFvQixFQUFFLE9BQWdCLElBQUk7O1FBQ3RFLElBQUksQ0FBQyxJQUFJO1lBQUUsT0FBTztRQUNsQixNQUFNLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7Q0FBQTtBQUVEOzs7O0dBSUc7QUFDSCxNQUFNLFVBQWdCLFNBQVMsQ0FBQyxJQUFlLEVBQUUsaUJBQXlCLEVBQUU7O1FBRTFFLFNBQWUsY0FBYzs7Z0JBQzNCLE1BQU0sSUFBSSxHQUFHLElBQUksRUFBRSxDQUFDO2dCQUNwQixNQUFNLE1BQU0sR0FBRyxJQUFJLFlBQVksT0FBTztvQkFDcEMsQ0FBQyxDQUFDLE1BQU0sSUFBSTtvQkFDWixDQUFDLENBQUMsSUFBSSxDQUFDO2dCQUNULE9BQU8sTUFBTSxDQUFDO1lBQ2hCLENBQUM7U0FBQTtRQUVELElBQUksTUFBTSxjQUFjLEVBQUU7WUFBRSxPQUFPO1FBRW5DLE1BQU0sSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDMUIsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUFDLEdBQVMsRUFBRTtnQkFDdEMsSUFBSSxNQUFNLGNBQWMsRUFBRSxFQUFFO29CQUMxQixhQUFhLENBQUMsUUFBUSxDQUFDLENBQUM7b0JBQ3hCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztpQkFDZjtZQUNILENBQUMsQ0FBQSxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUFBO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLFNBQWtCO0lBQ2xELFNBQVMsYUFBVCxTQUFTLGNBQVQsU0FBUyxJQUFULFNBQVMsR0FBSyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBQztJQUN2QyxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25DLE9BQU8sS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztBQUNsRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRU1ldGhvZCB9IGZyb20gXCIuL2hlbHBlcnMvaW50ZXJmYWNlc1wiO1xyXG5pbXBvcnQgeyBMb2NhbGl6ZVRva2VuU3RvcmFnZSB9IGZyb20gXCIuL2xvY2FsaXplLnRva2VuLnN0b3JhZ2VcIjtcclxuXHJcbmludGVyZmFjZSBJTG9jYWxpemVUb2tlblRva2VucyB7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG4gIHJlcXVlc3RVcmw/OiBzdHJpbmc7XHJcbiAgbWV0aG9kPzogRU1ldGhvZDtcclxuICBib2R5Pzoge307XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVRoaXJkUGFydHlDb25maWcge1xyXG4gIGlzVGhpcmRQYXJ0eU1vZGU6IGJvb2xlYW47XHJcbiAgY2xpZW50SWQ6IHN0cmluZztcclxuICBjbGllbnRTZWNyZXQ6IHN0cmluZztcclxuICByZWZyZXNoVG9rZW46IElMb2NhbGl6ZVRva2VuVG9rZW5zO1xyXG4gIGxhc3RVbmF1dGhvcml6ZWRVcmw/OiBzdHJpbmcgfCBudWxsO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElMb2NhbGl6ZVRva2VuQ29uZmlnIHtcclxuICAvKipcclxuICAgKiBUaGUgbWFpbiBkb21haW4gb2YgdGhlIGFwcGxpY2F0aW9uIHRvIHNldCB0aGUgY29va2llcyB0byBiZSBhdmFpbGFibGUgZm9yIGNyb3NzIGFwcGxpY2F0aW9uIHdpdGggc3ViZG9tYWlucy5cclxuICAgKiBcclxuICAgKiBEZWZhdWx0IGlzIGxvY2F0aW9uLmhvc3RuYW1lIChjdXJyZW50IGRvbWFpbikgYW5kIGF1dG9tYXRpY2FsbHkgc2V0IGV4dHJhY3RlZCBtYWluIGRvbWFpbiBpZiBpdCBpcyBzdWJkb21haW4uXHJcbiAgICovXHJcbiAgbWFpbkRvbWFpbj86IHN0cmluZztcclxuICBpc1Byb2R1Y3Rpb246IGJvb2xlYW47XHJcbiAgYXV0aFRva2VuPzogSUxvY2FsaXplVG9rZW5Ub2tlbnM7XHJcbiAgcmVmcmVzaFRva2VuPzogSUxvY2FsaXplVG9rZW5Ub2tlbnM7XHJcbiAgdGVuYW50VG9rZW4/OiBJTG9jYWxpemVUb2tlblRva2VucztcclxuICByZXF1aXJlZFRlbmFudD86IGJvb2xlYW47XHJcbiAgdGhpcmRQYXJ0eUNvbmZpZz86IElUaGlyZFBhcnR5Q29uZmlnO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgTG9jYWxpemVUb2tlbiB7XHJcblxyXG4gIHN0YXRpYyByZWFkb25seSBzdG9yYWdlID0gbmV3IExvY2FsaXplVG9rZW5TdG9yYWdlKCk7XHJcblxyXG4gIHN0YXRpYyByZWFkb25seSBodHRwSGVhZGVycyA9IHtcclxuICAgIEFVVEhPUklaQVRJT046ICdBdXRob3JpemF0aW9uJyxcclxuICAgIFhfVEVOQU5UOiAnWC1UZW5hbnQnLFxyXG4gICAgWF9SRUZSRVNIX1RPS0VOOiAnWC1SZWZyZXNoVG9rZW4nLFxyXG4gICAgQ09OVEVOVF9UWVBFOiAnQ29udGVudC1UeXBlJyxcclxuICAgIFhfQ0xJRU5UOiAnWC1DbGllbnQnLFxyXG4gICAgWF9TRUNSRVQ6ICdYLVNlY3JldCdcclxuICB9XHJcbn1cclxuXHJcblxyXG4vKipcclxuICogIFdhaXRzIGZvciBhIHNwZWNpZmllZCBhbW91bnQgb2YgdGltZS5cclxuICogQHBhcmFtIG1pbGxpc2Vjb25kcyAgLSBUaGUgbWlsbGlzZWNvbmRzIHRvIHdhaXQuXHJcbiAqIEBwYXJhbSB3aGVuICAtIFRoZSBjb25kaXRpb24gdG8gd2FpdCBmb3IuIERlZmF1bHQgaXMgdHJ1ZS5cclxuICogQHJldHVybnMgIC0gUHJvbWlzZTx2b2lkPlxyXG4gKi9cclxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHdhaXRGb3IobWlsbGlzZWNvbmRzOiBudW1iZXIsIHdoZW46IGJvb2xlYW4gPSB0cnVlKSB7XHJcbiAgaWYgKCF3aGVuKSByZXR1cm47XHJcbiAgYXdhaXQgbmV3IFByb21pc2UocmVzb2x2ZSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIG1pbGxpc2Vjb25kcykpO1xyXG59XHJcblxyXG4vKipcclxuICogIFdhaXRzIHVudGlsIHRoZSBjb25kaXRpb24gaXMgbWV0LlxyXG4gKiBAcGFyYW0gd2hlbiAgLSBUaGUgY29uZGl0aW9uIHRvIHdhaXQgZm9yLlxyXG4gKiBAcGFyYW0gaW50ZXJ2YWxOdW1iZXIgIC0gVGhlIGludGVydmFsIG51bWJlciBpbiBtaWxsaXNlY29uZHMgdG8gY2hlY2sgdGhlIGNvbmRpdGlvbi4gRGVmYXVsdCBpcyA1MC5cclxuICovXHJcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB3YWl0VW50aWwod2hlbjogKCkgPT4gYW55LCBpbnRlcnZhbE51bWJlcjogbnVtYmVyID0gNTApIHtcclxuXHJcbiAgYXN5bmMgZnVuY3Rpb24gaXNDb25kaXRpb25NZXQoKSB7XHJcbiAgICBjb25zdCBjb25kID0gd2hlbigpO1xyXG4gICAgY29uc3QgcmVzdWx0ID0gY29uZCBpbnN0YW5jZW9mIFByb21pc2VcclxuICAgICAgPyBhd2FpdCBjb25kXHJcbiAgICAgIDogY29uZDtcclxuICAgIHJldHVybiByZXN1bHQ7XHJcbiAgfVxyXG5cclxuICBpZiAoYXdhaXQgaXNDb25kaXRpb25NZXQoKSkgcmV0dXJuO1xyXG5cclxuICBhd2FpdCBuZXcgUHJvbWlzZShyZXNvbHZlID0+IHtcclxuICAgIGNvbnN0IGludGVydmFsID0gc2V0SW50ZXJ2YWwoYXN5bmMgKCkgPT4ge1xyXG4gICAgICBpZiAoYXdhaXQgaXNDb25kaXRpb25NZXQoKSkge1xyXG4gICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgIHJlc29sdmUodHJ1ZSk7XHJcbiAgICAgIH1cclxuICAgIH0sIGludGVydmFsTnVtYmVyKTtcclxuICB9KTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGV4dHJhY3RNYWluRG9tYWluKHN1YmRvbWFpbj86IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgc3ViZG9tYWluID8/PSB3aW5kb3cubG9jYXRpb24uaG9zdG5hbWU7XHJcbiAgY29uc3QgcGFydHMgPSBzdWJkb21haW4uc3BsaXQoJy4nKTtcclxuICByZXR1cm4gcGFydHMubGVuZ3RoID4gMiA/IHBhcnRzLnNsaWNlKC0yKS5qb2luKCcuJykgOiBzdWJkb21haW47XHJcbn0iXX0=
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { LocalizeTokenService } from './localize.token.service';
|
|
3
|
-
import { LocalizeApiService } from './localize.api.service';
|
|
4
|
-
export class LocalizeTokenModule {
|
|
5
|
-
}
|
|
6
|
-
LocalizeTokenModule.decorators = [
|
|
7
|
-
{ type: NgModule, args: [{
|
|
8
|
-
providers: [
|
|
9
|
-
LocalizeTokenService,
|
|
10
|
-
LocalizeApiService
|
|
11
|
-
]
|
|
12
|
-
},] }
|
|
13
|
-
];
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemUudG9rZW4ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vQU5HVUxBUi9MSUJSQVJJRVMvbG9jYWxpemUudG9rZW4uMTIuMS4wL2Rldi9zcmMvbG9jYWxpemUtdG9rZW4vbG9jYWxpemUudG9rZW4ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFRNUQsTUFBTSxPQUFPLG1CQUFtQjs7O1lBTi9CLFFBQVEsU0FBQztnQkFDTixTQUFTLEVBQUU7b0JBQ1Asb0JBQW9CO29CQUNwQixrQkFBa0I7aUJBQ3JCO2FBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBMb2NhbGl6ZVRva2VuU2VydmljZSB9IGZyb20gJy4vbG9jYWxpemUudG9rZW4uc2VydmljZSc7XHJcbmltcG9ydCB7IExvY2FsaXplQXBpU2VydmljZSB9IGZyb20gJy4vbG9jYWxpemUuYXBpLnNlcnZpY2UnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIExvY2FsaXplVG9rZW5TZXJ2aWNlLFxyXG4gICAgICAgIExvY2FsaXplQXBpU2VydmljZVxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTG9jYWxpemVUb2tlbk1vZHVsZSB7IH0iXX0=
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as jwt_decode from 'jwt-decode';
|
|
3
|
-
import { BehaviorSubject } from 'rxjs';
|
|
4
|
-
import { extractMainDomain, LocalizeToken } from './localize.token';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class LocalizeTokenService {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.configSubject = new BehaviorSubject({});
|
|
9
|
-
this.isRevokingTokenSubject = new BehaviorSubject(false);
|
|
10
|
-
this.defaultConfig = {
|
|
11
|
-
mainDomain: extractMainDomain(),
|
|
12
|
-
authToken: {
|
|
13
|
-
name: 'auth-token',
|
|
14
|
-
},
|
|
15
|
-
refreshToken: {
|
|
16
|
-
name: 'refresh-token',
|
|
17
|
-
requestUrl: '/api/token/revoke'
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
this.isInitialized = false;
|
|
21
|
-
this.decodeToken = (token) => jwt_decode.jwtDecode(token);
|
|
22
|
-
}
|
|
23
|
-
get config() {
|
|
24
|
-
this.throwIfNotInitialized();
|
|
25
|
-
return this.configSubject.value;
|
|
26
|
-
}
|
|
27
|
-
init(config) {
|
|
28
|
-
console.log('LocalizeTokenService is initialized.');
|
|
29
|
-
this.configSubject.next(Object.assign(Object.assign({}, this.defaultConfig), config));
|
|
30
|
-
this.isInitialized = true;
|
|
31
|
-
}
|
|
32
|
-
ngOnDestroy() {
|
|
33
|
-
// this.configSubject.complete();
|
|
34
|
-
// this.isRevokingTokenSubject.complete();
|
|
35
|
-
}
|
|
36
|
-
get authToken() { return this.storageGet(); }
|
|
37
|
-
set authToken(value) {
|
|
38
|
-
var _a;
|
|
39
|
-
value
|
|
40
|
-
? this.storageSet(value)
|
|
41
|
-
: LocalizeToken.storage.delete((_a = this.config.authToken) === null || _a === void 0 ? void 0 : _a.name);
|
|
42
|
-
}
|
|
43
|
-
get tenantToken() { var _a; return LocalizeToken.storage.get(((_a = this.config.tenantToken) === null || _a === void 0 ? void 0 : _a.name) || ''); }
|
|
44
|
-
get refreshToken() { var _a; return LocalizeToken.storage.get(((_a = this.config.refreshToken) === null || _a === void 0 ? void 0 : _a.name) || ''); }
|
|
45
|
-
get accessToken() { var _a; return (_a = this.authToken) === null || _a === void 0 ? void 0 : _a.token; }
|
|
46
|
-
set accessToken(value) {
|
|
47
|
-
value && (this.authToken = { token: value, revoke: false });
|
|
48
|
-
}
|
|
49
|
-
get isRevokingToken() { return this.isRevokingTokenSubject.value; /* this.authToken?.revoke ?? false */ }
|
|
50
|
-
set isRevokingToken(value) {
|
|
51
|
-
this.isRevokingTokenSubject.next(value);
|
|
52
|
-
this.authToken && (this.authToken = Object.assign(Object.assign({}, this.authToken), { revoke: value }));
|
|
53
|
-
}
|
|
54
|
-
get clientId() { var _a; return LocalizeToken.storage.get(((_a = this.config.thirdPartyConfig) === null || _a === void 0 ? void 0 : _a.clientId) || ''); }
|
|
55
|
-
get clientSecret() { var _a; return LocalizeToken.storage.get(((_a = this.config.thirdPartyConfig) === null || _a === void 0 ? void 0 : _a.clientSecret) || ''); }
|
|
56
|
-
storageGet() {
|
|
57
|
-
var _a;
|
|
58
|
-
try {
|
|
59
|
-
const encoded = LocalizeToken.storage.get(((_a = this.config.authToken) === null || _a === void 0 ? void 0 : _a.name) || '');
|
|
60
|
-
const decoded = atob(encoded || '');
|
|
61
|
-
return JSON.parse(decoded);
|
|
62
|
-
}
|
|
63
|
-
catch (_b) {
|
|
64
|
-
return undefined;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
storageSet(value) {
|
|
68
|
-
var _a;
|
|
69
|
-
const base64 = btoa(JSON.stringify(value));
|
|
70
|
-
LocalizeToken.storage.set(((_a = this.config.authToken) === null || _a === void 0 ? void 0 : _a.name) || '', base64);
|
|
71
|
-
}
|
|
72
|
-
tokensValid() {
|
|
73
|
-
var _a, _b;
|
|
74
|
-
if (!((_a = this.refreshToken) === null || _a === void 0 ? void 0 : _a.length))
|
|
75
|
-
return false;
|
|
76
|
-
if (this.config.requiredTenant && !((_b = this.tenantToken) === null || _b === void 0 ? void 0 : _b.length))
|
|
77
|
-
return false;
|
|
78
|
-
return true;
|
|
79
|
-
}
|
|
80
|
-
get decodeRefreshToken() {
|
|
81
|
-
const token = this.refreshToken;
|
|
82
|
-
return !token ? null : this.decodeToken(token);
|
|
83
|
-
}
|
|
84
|
-
throwIfNotInitialized() {
|
|
85
|
-
if (!this.isInitialized) {
|
|
86
|
-
throw new Error('LocalizeTokenService is not initialized. Call init() method before using it.');
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
LocalizeTokenService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LocalizeTokenService_Factory() { return new LocalizeTokenService(); }, token: LocalizeTokenService, providedIn: "root" });
|
|
91
|
-
LocalizeTokenService.decorators = [
|
|
92
|
-
{ type: Injectable, args: [{ providedIn: 'root' },] }
|
|
93
|
-
];
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"localize.token.service.js","sourceRoot":"","sources":["../../../../../../../ANGULAR/LIBRARIES/localize.token.12.1.0/dev/src/localize-token/localize.token.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\r\nimport * as jwt_decode from 'jwt-decode';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { extractMainDomain, ILocalizeTokenConfig, LocalizeToken } from './localize.token';\r\nexport interface JwtPayload extends jwt_decode.JwtPayload {\r\n    // Define the structure of your JWT payload here\r\n    email: string;\r\n    sub: string;\r\n    name: string;\r\n    iat: number;\r\n    exp: number;\r\n    // Add other fields as needed\r\n}\r\n\r\ninterface IAuthToken {\r\n    token: string;\r\n    revoke: boolean;\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class LocalizeTokenService implements OnDestroy {\r\n    private readonly configSubject = new BehaviorSubject<Partial<ILocalizeTokenConfig>>({});\r\n    readonly isRevokingTokenSubject = new BehaviorSubject<boolean>(false);\r\n    private readonly defaultConfig: Partial<ILocalizeTokenConfig> = {\r\n        mainDomain: extractMainDomain(),\r\n        authToken: {\r\n            name: 'auth-token',\r\n        },\r\n        refreshToken: {\r\n            name: 'refresh-token',\r\n            requestUrl: '/api/token/revoke'\r\n        }\r\n    }\r\n\r\n    get config(): ILocalizeTokenConfig {\r\n        this.throwIfNotInitialized();\r\n        return this.configSubject.value as ILocalizeTokenConfig;\r\n    }\r\n\r\n    private isInitialized = false;\r\n\r\n    init(config: ILocalizeTokenConfig) {\r\n        console.log('LocalizeTokenService is initialized.');\r\n        this.configSubject.next({ ...this.defaultConfig, ...config });\r\n        this.isInitialized = true;\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        // this.configSubject.complete();\r\n        // this.isRevokingTokenSubject.complete();\r\n    }\r\n\r\n    private get authToken() { return this.storageGet() }\r\n    private set authToken(value: IAuthToken | undefined) {\r\n        value\r\n            ? this.storageSet(value)\r\n            : LocalizeToken.storage.delete(this.config.authToken?.name!);\r\n    }\r\n\r\n    get tenantToken() { return LocalizeToken.storage.get(this.config.tenantToken?.name || '') }\r\n\r\n    get refreshToken() { return LocalizeToken.storage.get(this.config.refreshToken?.name || '') }\r\n    get accessToken() { return this.authToken?.token }\r\n\r\n    set accessToken(value: string | undefined) {\r\n        value && (this.authToken = { token: value, revoke: false })\r\n    }\r\n\r\n    get isRevokingToken() { return this.isRevokingTokenSubject.value /* this.authToken?.revoke ?? false */ }\r\n\r\n    set isRevokingToken(value: boolean) {\r\n        this.isRevokingTokenSubject.next(value);\r\n        this.authToken && (this.authToken = { ...this.authToken, revoke: value })\r\n    }\r\n    get clientId() { return LocalizeToken.storage.get(this.config.thirdPartyConfig?.clientId || '') }\r\n    get clientSecret() { return LocalizeToken.storage.get(this.config.thirdPartyConfig?.clientSecret || '') }\r\n    private storageGet() {\r\n        try {\r\n            const encoded = LocalizeToken.storage.get(this.config.authToken?.name || '');\r\n            const decoded = atob(encoded || '');\r\n            return JSON.parse(decoded) as IAuthToken;\r\n        } catch {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    private storageSet(value: IAuthToken) {\r\n        const base64 = btoa(JSON.stringify(value));\r\n        LocalizeToken.storage.set(this.config.authToken?.name || '', base64);\r\n    }\r\n\r\n    tokensValid(): boolean | undefined {\r\n        if (!this.refreshToken?.length) return false;\r\n        if (this.config.requiredTenant && !this.tenantToken?.length) return false;\r\n        return true;\r\n    }\r\n\r\n    decodeToken = (token: string) => jwt_decode.jwtDecode<JwtPayload>(token);\r\n    get decodeRefreshToken() {\r\n        const token = this.refreshToken;\r\n        return !token ? null : this.decodeToken(token);\r\n    }\r\n\r\n    private throwIfNotInitialized() {\r\n        if (!this.isInitialized) {\r\n            throw new Error('LocalizeTokenService is not initialized. Call init() method before using it.');\r\n        }\r\n    }\r\n\r\n}\r\n"]}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { extractMainDomain } from "./localize.token";
|
|
2
|
-
/**
|
|
3
|
-
* Assembly of @package ng2-cookies @see https://www.npmjs.com/package/ng2-cookies
|
|
4
|
-
*
|
|
5
|
-
* Reassembled by
|
|
6
|
-
* @author sambath999
|
|
7
|
-
* @date_29_09_2021
|
|
8
|
-
* Updated from raw parameters to
|
|
9
|
-
* @param {ICookieOptions} options and added another newer cookie flag
|
|
10
|
-
* @param {string} samesite
|
|
11
|
-
* @param {constant} SameSiteTypes, @param {string} strict "strict", @param {string} lax "lax", @param {string} none "none"
|
|
12
|
-
*
|
|
13
|
-
* @enum
|
|
14
|
-
*/
|
|
15
|
-
export class LocalizeTokenStorage {
|
|
16
|
-
constructor(_defaultOptions) {
|
|
17
|
-
this.defaultOptions = _defaultOptions !== null && _defaultOptions !== void 0 ? _defaultOptions : this.getDefaultOptions;
|
|
18
|
-
}
|
|
19
|
-
get getDefaultOptions() {
|
|
20
|
-
const mainDomain = extractMainDomain(window.location.hostname);
|
|
21
|
-
return {
|
|
22
|
-
path: '/',
|
|
23
|
-
domain: mainDomain,
|
|
24
|
-
secure: true,
|
|
25
|
-
// samesite: SameSiteType.strict,
|
|
26
|
-
expires: 1
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Checks the existence of a single cookie by it's name
|
|
31
|
-
*
|
|
32
|
-
* @param {string} name Identification of the cookie
|
|
33
|
-
* @returns existence of the cookie
|
|
34
|
-
*/
|
|
35
|
-
check(name) {
|
|
36
|
-
if (typeof document === "undefined")
|
|
37
|
-
return false;
|
|
38
|
-
name = encodeURIComponent(name);
|
|
39
|
-
const regexp = new RegExp('(?:^' + name + '|;\\s*' + name + ')=(.*?)(?:;|$)', 'g');
|
|
40
|
-
return regexp.test(document.cookie);
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Retrieves a single cookie by it's name
|
|
44
|
-
*
|
|
45
|
-
* @param {string} name Identification of the Cookie
|
|
46
|
-
* @returns The Cookie's value
|
|
47
|
-
*/
|
|
48
|
-
get(name) {
|
|
49
|
-
if (!this.check(name))
|
|
50
|
-
return undefined;
|
|
51
|
-
name = encodeURIComponent(name);
|
|
52
|
-
const regexp = new RegExp('(?:^' + name + '|;\\s*' + name + ')=(.*?)(?:;|$)', 'g');
|
|
53
|
-
const result = regexp.exec(document.cookie);
|
|
54
|
-
return result ? decodeURIComponent(result[1]) : undefined;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Retrieves a a list of all cookie avaiable
|
|
58
|
-
*
|
|
59
|
-
* @returns Object with all Cookies
|
|
60
|
-
*/
|
|
61
|
-
getAll() {
|
|
62
|
-
const cookies = {};
|
|
63
|
-
if (document.cookie) {
|
|
64
|
-
const split = document.cookie.split(';');
|
|
65
|
-
for (const s of split) {
|
|
66
|
-
const currCookie = s.split('=');
|
|
67
|
-
currCookie[0] = currCookie[0].trim();
|
|
68
|
-
cookies[decodeURIComponent(currCookie[0])] = decodeURIComponent(currCookie[1]);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return cookies;
|
|
72
|
-
}
|
|
73
|
-
set(name, value, options) {
|
|
74
|
-
options !== null && options !== void 0 ? options : (options = this.defaultOptions);
|
|
75
|
-
const { expires, path, domain, secure, samesite } = Object.assign(Object.assign({}, this.defaultOptions), options);
|
|
76
|
-
let cookieStr = `${encodeURIComponent(name)}=${encodeURIComponent(value)};`;
|
|
77
|
-
if (expires) {
|
|
78
|
-
const dtExpires = typeof expires === 'number' ? new Date(Date.now() + expires * 864e5) : expires;
|
|
79
|
-
cookieStr += `expires=${dtExpires.toUTCString()};`;
|
|
80
|
-
}
|
|
81
|
-
cookieStr += path ? `path=${path};` : '';
|
|
82
|
-
cookieStr += domain ? `domain=${domain};` : '';
|
|
83
|
-
cookieStr += secure ? 'secure;' : '';
|
|
84
|
-
cookieStr += samesite ? `samesite=${samesite};` : '';
|
|
85
|
-
document.cookie = cookieStr;
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Removes specified Cookie
|
|
89
|
-
*
|
|
90
|
-
* @param {string} name Cookie's identification
|
|
91
|
-
* @param {string} path Path relative to the domain where the cookie should be avaiable. Default /
|
|
92
|
-
* @param {string} domain Domain where the cookie should be avaiable. Default current domain
|
|
93
|
-
*/
|
|
94
|
-
delete(name, path = '/', domain = window.location.hostname) {
|
|
95
|
-
this.set(name, '', { path, domain, expires: -1 });
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Delete all cookie avaiable
|
|
99
|
-
*/
|
|
100
|
-
deleteAll(path, domain) {
|
|
101
|
-
const cookies = this.getAll();
|
|
102
|
-
for (const cookieName of Object.keys(cookies)) {
|
|
103
|
-
this.delete(cookieName, path, domain);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"localize.token.storage.js","sourceRoot":"","sources":["../../../../../../../ANGULAR/LIBRARIES/localize.token.12.1.0/dev/src/localize-token/localize.token.storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { extractMainDomain } from \"./localize.token\";\r\n\r\nexport interface ICookieOptions {\r\n  /**\r\n   * Cookie expiration date in days from now. If not provided the cookie is a session cookie\r\n   */\r\n  expires?: number | Date;\r\n  path?: string;\r\n  domain?: string;\r\n  secure?: boolean;\r\n  samesite?: \"strict\" | \"lax\" | \"none\";\r\n}\r\n\r\n/**\r\n* Assembly of @package ng2-cookies @see https://www.npmjs.com/package/ng2-cookies\r\n*\r\n* Reassembled by\r\n* @author sambath999\r\n* @date_29_09_2021\r\n* Updated from raw parameters to\r\n* @param {ICookieOptions} options and added another newer cookie flag\r\n* @param {string} samesite\r\n* @param {constant} SameSiteTypes, @param {string} strict \"strict\", @param {string} lax \"lax\", @param {string} none \"none\"\r\n*\r\n* @enum\r\n*/\r\nexport class LocalizeTokenStorage {\r\n\r\n  private get getDefaultOptions(): ICookieOptions {\r\n    const mainDomain = extractMainDomain(window.location.hostname);\r\n    return {\r\n      path: '/',\r\n      domain: mainDomain,\r\n      secure: true,\r\n      // samesite: SameSiteType.strict,\r\n      expires: 1\r\n    }\r\n  }\r\n\r\n  private readonly defaultOptions: ICookieOptions;\r\n  constructor(_defaultOptions?: ICookieOptions) {\r\n    this.defaultOptions = _defaultOptions ?? this.getDefaultOptions;\r\n  }\r\n\r\n  /**\r\n   * Checks the existence of a single cookie by it's name\r\n   *\r\n   * @param  {string} name Identification of the cookie\r\n   * @returns existence of the cookie\r\n   */\r\n  check(name: string): boolean {\r\n    if (typeof document === \"undefined\") return false;\r\n    name = encodeURIComponent(name);\r\n    const regexp = new RegExp('(?:^' + name + '|;\\\\s*' + name + ')=(.*?)(?:;|$)', 'g');\r\n    return regexp.test(document.cookie);\r\n  }\r\n\r\n  /**\r\n   * Retrieves a single cookie by it's name\r\n   *\r\n   * @param  {string} name Identification of the Cookie\r\n   * @returns The Cookie's value\r\n   */\r\n  get(name: string): string | undefined {\r\n    if (!this.check(name)) return undefined;\r\n\r\n    name = encodeURIComponent(name);\r\n    const regexp = new RegExp('(?:^' + name + '|;\\\\s*' + name + ')=(.*?)(?:;|$)', 'g');\r\n    const result = regexp.exec(document.cookie);\r\n    return result ? decodeURIComponent(result[1]) : undefined;\r\n  }\r\n\r\n  /**\r\n   * Retrieves a a list of all cookie avaiable\r\n   *\r\n   * @returns Object with all Cookies\r\n   */\r\n  getAll(): any {\r\n    const cookies: any = {};\r\n    if (document.cookie) {\r\n      const split = document.cookie.split(';');\r\n      for (const s of split) {\r\n        const currCookie = s.split('=');\r\n        currCookie[0] = currCookie[0].trim();\r\n        cookies[decodeURIComponent(currCookie[0])] = decodeURIComponent(currCookie[1]);\r\n      }\r\n    }\r\n\r\n    return cookies;\r\n  }\r\n\r\n  set(name: string, value: string, options?: ICookieOptions) {\r\n    options ??= this.defaultOptions;\r\n    const { expires, path, domain, secure, samesite } = { ...this.defaultOptions, ...options };\r\n    let cookieStr = `${encodeURIComponent(name)}=${encodeURIComponent(value)};`;\r\n\r\n    if (expires) {\r\n      const dtExpires = typeof expires === 'number' ? new Date(Date.now() + expires * 864e5) : expires;\r\n      cookieStr += `expires=${dtExpires.toUTCString()};`;\r\n    }\r\n\r\n    cookieStr += path ? `path=${path};` : '';\r\n    cookieStr += domain ? `domain=${domain};` : '';\r\n    cookieStr += secure ? 'secure;' : '';\r\n    cookieStr += samesite ? `samesite=${samesite};` : '';\r\n\r\n    document.cookie = cookieStr;\r\n  }\r\n\r\n  /**\r\n   * Removes specified Cookie\r\n   *\r\n   * @param  {string} name Cookie's identification\r\n   * @param  {string} path Path relative to the domain where the cookie should be avaiable. Default /\r\n   * @param  {string} domain Domain where the cookie should be avaiable. Default current domain\r\n   */\r\n  delete(name: string, path: string = '/', domain: string = window.location.hostname): void {\r\n    this.set(name, '', { path, domain, expires: -1 });\r\n  }\r\n\r\n  /**\r\n   * Delete all cookie avaiable\r\n   */\r\n  deleteAll(path?: string, domain?: string): void {\r\n    const cookies = this.getAll();\r\n\r\n    for (const cookieName of Object.keys(cookies)) {\r\n      this.delete(cookieName, path, domain);\r\n    }\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { LocalizeLogindlgService } from '../localize-logindlg/localize-logindlg.service';
|
|
2
|
-
import { ILocalizeApiConfigs } from '../localize-token/helpers/interfaces';
|
|
3
|
-
import { LocalizeApiService } from '../localize-token/localize.api.service';
|
|
4
|
-
import { ILocalizeTokenConfig } from '../localize-token/localize.token';
|
|
5
|
-
import { LocalizeTokenService } from '../localize-token/localize.token.service';
|
|
6
|
-
export declare class LocalizeApiTokenService {
|
|
7
|
-
readonly api: LocalizeApiService;
|
|
8
|
-
readonly token: LocalizeTokenService;
|
|
9
|
-
readonly loginDialog: LocalizeLogindlgService;
|
|
10
|
-
constructor(tokenService: LocalizeTokenService, apiService: LocalizeApiService, loginDialogService: LocalizeLogindlgService);
|
|
11
|
-
initialize(tokenConfig: ILocalizeTokenConfig, apiConfig: ILocalizeApiConfigs): void;
|
|
12
|
-
}
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import { HttpErrorResponse } from "@angular/common/http";
|
|
2
|
-
/**
|
|
3
|
-
* Http method options
|
|
4
|
-
*/
|
|
5
|
-
export declare enum EMethod {
|
|
6
|
-
POST = "post",
|
|
7
|
-
GET = "get",
|
|
8
|
-
PUT = "put",
|
|
9
|
-
DELETE = "delete",
|
|
10
|
-
PATCH = "patch"
|
|
11
|
-
}
|
|
12
|
-
export interface IOnConnectionError {
|
|
13
|
-
/**
|
|
14
|
-
* Callback function to execute when a connection error occurs.
|
|
15
|
-
* This function should return a Promise or any value.
|
|
16
|
-
*/
|
|
17
|
-
callback?: (error: HttpErrorResponse) => Promise<void> | any;
|
|
18
|
-
/**
|
|
19
|
-
* If true, the request will block the screen with overlay on connection errors.
|
|
20
|
-
* Default is false.
|
|
21
|
-
*/
|
|
22
|
-
blockScreen?: boolean;
|
|
23
|
-
/** Optional z-index for the block screen overlay.
|
|
24
|
-
* Default is 10000.
|
|
25
|
-
*/
|
|
26
|
-
blockScreenZIndex?: number;
|
|
27
|
-
/**
|
|
28
|
-
* Optional message to display when a connection error occurs.
|
|
29
|
-
*/
|
|
30
|
-
message?: string;
|
|
31
|
-
suggestionMessage?: string;
|
|
32
|
-
}
|
|
33
|
-
interface IRetryOptions {
|
|
34
|
-
/**
|
|
35
|
-
* Maximum number of retries for a failed request.
|
|
36
|
-
* Default is 100.
|
|
37
|
-
*/
|
|
38
|
-
maxRetries?: number;
|
|
39
|
-
/**
|
|
40
|
-
* Delay in milliseconds before retrying a failed request.
|
|
41
|
-
* Default is 500ms.
|
|
42
|
-
*/
|
|
43
|
-
delay?: number;
|
|
44
|
-
/**
|
|
45
|
-
* Function to determine if a request should be retried based on the error.
|
|
46
|
-
* If not provided, the default function will retry for network errors and server errors (status 500-599).
|
|
47
|
-
* @param error - The error object from the failed request.
|
|
48
|
-
* @returns true if the request should be retried, false otherwise.
|
|
49
|
-
*/
|
|
50
|
-
retryFunction?: (error: HttpErrorResponse) => Promise<boolean> | any;
|
|
51
|
-
/**
|
|
52
|
-
* Function to execute when a connection error occurs.
|
|
53
|
-
* This function should return a Promise or any value.
|
|
54
|
-
*/
|
|
55
|
-
onConnectionError?: IOnConnectionError;
|
|
56
|
-
}
|
|
57
|
-
export interface ILocalizeApiConfigs {
|
|
58
|
-
onPrepareRequest?: () => Promise<void> | any;
|
|
59
|
-
onAutoLogout?: () => Promise<void> | any;
|
|
60
|
-
onRevokeUnauthorized?: () => Promise<void> | any;
|
|
61
|
-
onResponseBodyInvalid?: (body: any) => void;
|
|
62
|
-
onException?: (error: any) => void;
|
|
63
|
-
waitEachRequest?: {
|
|
64
|
-
milliseconds: number;
|
|
65
|
-
};
|
|
66
|
-
enableRequestCancellation?: boolean;
|
|
67
|
-
/**
|
|
68
|
-
* Config for retrying failed requests.
|
|
69
|
-
* If not provided, the default retry options will be used.
|
|
70
|
-
*/
|
|
71
|
-
retryOptions?: IRetryOptions;
|
|
72
|
-
}
|
|
73
|
-
export interface IApiOptions {
|
|
74
|
-
headers?: {
|
|
75
|
-
[key: string]: string;
|
|
76
|
-
};
|
|
77
|
-
method: EMethod;
|
|
78
|
-
requestUrl: string;
|
|
79
|
-
requestBody?: any;
|
|
80
|
-
isFormData?: boolean;
|
|
81
|
-
/**
|
|
82
|
-
* If true, the request will use the refresh token for authorization.
|
|
83
|
-
*/
|
|
84
|
-
refreshToken?: boolean;
|
|
85
|
-
}
|
|
86
|
-
export interface IHeader {
|
|
87
|
-
[key: string]: string;
|
|
88
|
-
}
|
|
89
|
-
export {};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { HttpClient, HttpErrorResponse, HttpHeaders } from "@angular/common/http";
|
|
2
|
-
import { IApiOptions, ILocalizeApiConfigs, IOnConnectionError } from "./interfaces";
|
|
3
|
-
import { Subject } from "rxjs";
|
|
4
|
-
interface IRequestInstance {
|
|
5
|
-
client: HttpClient;
|
|
6
|
-
destroy$: () => Subject<void>;
|
|
7
|
-
}
|
|
8
|
-
interface IRetryOptions {
|
|
9
|
-
maxRetries: () => number;
|
|
10
|
-
delay: number;
|
|
11
|
-
callback: () => Promise<any> | any;
|
|
12
|
-
retryUnless?: (error: any) => boolean;
|
|
13
|
-
onError?: (error: any) => Promise<void> | any;
|
|
14
|
-
connectionError?: IOnConnectionError;
|
|
15
|
-
}
|
|
16
|
-
declare class LocalizeApiHelper {
|
|
17
|
-
readonly defaultRetryOptions: Partial<IRetryOptions>;
|
|
18
|
-
performRetry<T = any>(options: IRetryOptions): Promise<T>;
|
|
19
|
-
performRequestWithRetry<T = any>(options: IApiOptions, config: ILocalizeApiConfigs, performRequest: <T = any>(options: IApiOptions) => Promise<T>): Promise<T>;
|
|
20
|
-
buildUrl(baseUrl: string, path: string): string;
|
|
21
|
-
invokeHook(callback?: () => Promise<any> | any): Promise<any>;
|
|
22
|
-
createRequest<T = any>(instance: Required<IRequestInstance>, method: string, url: string, body: any, options: {
|
|
23
|
-
headers: HttpHeaders;
|
|
24
|
-
}, onInvalidResponseBody?: (body: any) => void): import("rxjs").Observable<any>;
|
|
25
|
-
defaultRetryFunction(error: HttpErrorResponse): boolean;
|
|
26
|
-
isConnectionError(error: HttpErrorResponse): boolean;
|
|
27
|
-
onConnectionError(options: IRetryOptions, error: any): Promise<Promise<void> | any>;
|
|
28
|
-
screenBlocker(optons: IRetryOptions, error?: HttpErrorResponse, add?: boolean): HTMLStyleElement | undefined;
|
|
29
|
-
private removeBlocker;
|
|
30
|
-
}
|
|
31
|
-
export declare const ApiHelper: LocalizeApiHelper;
|
|
32
|
-
export {};
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "@angular/common/http";
|
|
2
|
-
import { OnDestroy } from "@angular/core";
|
|
3
|
-
import { BehaviorSubject } from "rxjs";
|
|
4
|
-
import { EMethod, IHeader, ILocalizeApiConfigs } from "./helpers/interfaces";
|
|
5
|
-
import { IThirdPartyConfig } from "./localize.token";
|
|
6
|
-
import { LocalizeTokenService } from "./localize.token.service";
|
|
7
|
-
export declare class LocalizeApiService implements OnDestroy {
|
|
8
|
-
readonly httpClient: HttpClient;
|
|
9
|
-
private readonly localizeTokenService;
|
|
10
|
-
private readonly destroy$;
|
|
11
|
-
private readonly configSubject;
|
|
12
|
-
readonly isRequestingSubject: BehaviorSubject<boolean>;
|
|
13
|
-
readonly isResolvingStartupSubject: BehaviorSubject<boolean>;
|
|
14
|
-
get isResolvingStartup(): boolean;
|
|
15
|
-
get needTenant(): boolean;
|
|
16
|
-
get isRequesting(): boolean;
|
|
17
|
-
get isRevokingToken(): boolean;
|
|
18
|
-
set isRevokingToken(value: boolean);
|
|
19
|
-
get accessToken(): string | undefined;
|
|
20
|
-
set accessToken(value: string | undefined);
|
|
21
|
-
get refreshToken(): string | undefined;
|
|
22
|
-
get tenantToken(): string | undefined;
|
|
23
|
-
get thirdPartyConfig(): IThirdPartyConfig | undefined;
|
|
24
|
-
private defaultConfig;
|
|
25
|
-
private get config();
|
|
26
|
-
private apiOptions;
|
|
27
|
-
constructor(httpClient: HttpClient, localizeTokenService: LocalizeTokenService);
|
|
28
|
-
/**
|
|
29
|
-
* Initialize the API service.
|
|
30
|
-
* @param apiConfigs - The API configurations.
|
|
31
|
-
*/
|
|
32
|
-
init(apiConfigs: ILocalizeApiConfigs): void;
|
|
33
|
-
cancelPendingRequests(): void;
|
|
34
|
-
ngOnDestroy(): void;
|
|
35
|
-
/**
|
|
36
|
-
* A higher-order function that returns a curried function for making API requests.
|
|
37
|
-
*
|
|
38
|
-
* @param baseUrl - The base URL of the API.
|
|
39
|
-
* @returns A curried function that can be used to make API requests.
|
|
40
|
-
*/
|
|
41
|
-
func: (baseUrl: string) => <T = any>(path: string, method?: EMethod, reqBody?: any, reqHeaders?: IHeader) => Promise<T>;
|
|
42
|
-
request<T = any>(baseUrl: string, path: string, method?: EMethod, reqBody?: any, reqHeaders?: IHeader): Promise<T>;
|
|
43
|
-
private handleOnRequestError;
|
|
44
|
-
private handleThirdPartyAuthError;
|
|
45
|
-
private performRequest;
|
|
46
|
-
private revokeToken;
|
|
47
|
-
private buildThirdPartyApiOption;
|
|
48
|
-
/** default http request options */
|
|
49
|
-
private buildHeaderOptions;
|
|
50
|
-
private buildApiOptions;
|
|
51
|
-
private toWaitForPreviousRequest;
|
|
52
|
-
private handleOnTokenRevoked;
|
|
53
|
-
private interceptRevokeToken;
|
|
54
|
-
validateConfig(): void;
|
|
55
|
-
}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { EMethod } from "./helpers/interfaces";
|
|
2
|
-
import { LocalizeTokenStorage } from "./localize.token.storage";
|
|
3
|
-
interface ILocalizeTokenTokens {
|
|
4
|
-
name: string;
|
|
5
|
-
requestUrl?: string;
|
|
6
|
-
method?: EMethod;
|
|
7
|
-
body?: {};
|
|
8
|
-
}
|
|
9
|
-
export interface IThirdPartyConfig {
|
|
10
|
-
isThirdPartyMode: boolean;
|
|
11
|
-
clientId: string;
|
|
12
|
-
clientSecret: string;
|
|
13
|
-
refreshToken: ILocalizeTokenTokens;
|
|
14
|
-
lastUnauthorizedUrl?: string | null;
|
|
15
|
-
}
|
|
16
|
-
export interface ILocalizeTokenConfig {
|
|
17
|
-
/**
|
|
18
|
-
* The main domain of the application to set the cookies to be available for cross application with subdomains.
|
|
19
|
-
*
|
|
20
|
-
* Default is location.hostname (current domain) and automatically set extracted main domain if it is subdomain.
|
|
21
|
-
*/
|
|
22
|
-
mainDomain?: string;
|
|
23
|
-
isProduction: boolean;
|
|
24
|
-
authToken?: ILocalizeTokenTokens;
|
|
25
|
-
refreshToken?: ILocalizeTokenTokens;
|
|
26
|
-
tenantToken?: ILocalizeTokenTokens;
|
|
27
|
-
requiredTenant?: boolean;
|
|
28
|
-
thirdPartyConfig?: IThirdPartyConfig;
|
|
29
|
-
}
|
|
30
|
-
export declare class LocalizeToken {
|
|
31
|
-
static readonly storage: LocalizeTokenStorage;
|
|
32
|
-
static readonly httpHeaders: {
|
|
33
|
-
AUTHORIZATION: string;
|
|
34
|
-
X_TENANT: string;
|
|
35
|
-
X_REFRESH_TOKEN: string;
|
|
36
|
-
CONTENT_TYPE: string;
|
|
37
|
-
X_CLIENT: string;
|
|
38
|
-
X_SECRET: string;
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Waits for a specified amount of time.
|
|
43
|
-
* @param milliseconds - The milliseconds to wait.
|
|
44
|
-
* @param when - The condition to wait for. Default is true.
|
|
45
|
-
* @returns - Promise<void>
|
|
46
|
-
*/
|
|
47
|
-
export declare function waitFor(milliseconds: number, when?: boolean): Promise<void>;
|
|
48
|
-
/**
|
|
49
|
-
* Waits until the condition is met.
|
|
50
|
-
* @param when - The condition to wait for.
|
|
51
|
-
* @param intervalNumber - The interval number in milliseconds to check the condition. Default is 50.
|
|
52
|
-
*/
|
|
53
|
-
export declare function waitUntil(when: () => any, intervalNumber?: number): Promise<void>;
|
|
54
|
-
export declare function extractMainDomain(subdomain?: string): string;
|
|
55
|
-
export {};
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { OnDestroy } from '@angular/core';
|
|
2
|
-
import * as jwt_decode from 'jwt-decode';
|
|
3
|
-
import { BehaviorSubject } from 'rxjs';
|
|
4
|
-
import { ILocalizeTokenConfig } from './localize.token';
|
|
5
|
-
export interface JwtPayload extends jwt_decode.JwtPayload {
|
|
6
|
-
email: string;
|
|
7
|
-
sub: string;
|
|
8
|
-
name: string;
|
|
9
|
-
iat: number;
|
|
10
|
-
exp: number;
|
|
11
|
-
}
|
|
12
|
-
export declare class LocalizeTokenService implements OnDestroy {
|
|
13
|
-
private readonly configSubject;
|
|
14
|
-
readonly isRevokingTokenSubject: BehaviorSubject<boolean>;
|
|
15
|
-
private readonly defaultConfig;
|
|
16
|
-
get config(): ILocalizeTokenConfig;
|
|
17
|
-
private isInitialized;
|
|
18
|
-
init(config: ILocalizeTokenConfig): void;
|
|
19
|
-
ngOnDestroy(): void;
|
|
20
|
-
private get authToken();
|
|
21
|
-
private set authToken(value);
|
|
22
|
-
get tenantToken(): string;
|
|
23
|
-
get refreshToken(): string;
|
|
24
|
-
get accessToken(): string | undefined;
|
|
25
|
-
set accessToken(value: string | undefined);
|
|
26
|
-
get isRevokingToken(): boolean;
|
|
27
|
-
set isRevokingToken(value: boolean);
|
|
28
|
-
get clientId(): string;
|
|
29
|
-
get clientSecret(): string;
|
|
30
|
-
private storageGet;
|
|
31
|
-
private storageSet;
|
|
32
|
-
tokensValid(): boolean | undefined;
|
|
33
|
-
decodeToken: (token: string) => JwtPayload;
|
|
34
|
-
get decodeRefreshToken(): JwtPayload;
|
|
35
|
-
private throwIfNotInitialized;
|
|
36
|
-
}
|