@esolve/ng-esolve-connect 0.109.0 → 0.110.0

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.
Files changed (39) hide show
  1. package/esm2022/lib/auth/index.mjs +3 -4
  2. package/esm2022/lib/auth/interceptors/esolve-auth.interceptor.mjs +32 -0
  3. package/esm2022/lib/auth/interceptors/index.mjs +2 -0
  4. package/esm2022/lib/auth/providers/esolve-eurus-auto-login.provider.mjs +2 -2
  5. package/esm2022/lib/auth/services/esolve-auth.service.mjs +288 -0
  6. package/esm2022/lib/auth/services/esolve-otp.service.mjs +77 -0
  7. package/esm2022/lib/auth/services/index.mjs +3 -0
  8. package/esm2022/lib/core/esolve-config.service.mjs +37 -40
  9. package/esm2022/lib/core/esolve-connect-config.interface.mjs +1 -1
  10. package/esm2022/lib/core/providers/index.mjs +2 -2
  11. package/esm2022/lib/core/providers/ng-esolve-connect.provider.mjs +19 -0
  12. package/esm2022/lib/coupons/esolve-coupons.service.mjs +8 -6
  13. package/esm2022/lib/session/esolve-session.service.mjs +89 -89
  14. package/esm2022/lib/shared/cookie/esolve-cookie-options.interface.mjs +2 -0
  15. package/esm2022/lib/shared/cookie/esolve-cookie.service.mjs +5 -5
  16. package/esm2022/lib/shared/cookie/index.mjs +2 -2
  17. package/esm2022/lib/vouchers/esolve-vouchers.service.mjs +8 -6
  18. package/fesm2022/esolve-ng-esolve-connect.mjs +304 -315
  19. package/fesm2022/esolve-ng-esolve-connect.mjs.map +1 -1
  20. package/lib/auth/index.d.ts +2 -3
  21. package/lib/auth/interceptors/esolve-auth.interceptor.d.ts +2 -0
  22. package/lib/auth/interceptors/index.d.ts +1 -0
  23. package/lib/auth/{esolve-auth.service.d.ts → services/esolve-auth.service.d.ts} +1 -1
  24. package/lib/auth/{esolve-otp.service.d.ts → services/esolve-otp.service.d.ts} +3 -3
  25. package/lib/auth/services/index.d.ts +2 -0
  26. package/lib/core/esolve-config.service.d.ts +14 -10
  27. package/lib/core/esolve-connect-config.interface.d.ts +6 -6
  28. package/lib/core/providers/index.d.ts +1 -1
  29. package/lib/session/esolve-session.service.d.ts +12 -5
  30. package/lib/shared/cookie/esolve-cookie-options.interface.d.ts +7 -0
  31. package/lib/shared/cookie/esolve-cookie.service.d.ts +3 -2
  32. package/lib/shared/cookie/index.d.ts +2 -1
  33. package/package.json +1 -1
  34. package/esm2022/lib/auth/esolve-auth-interceptor.service.mjs +0 -42
  35. package/esm2022/lib/auth/esolve-auth.service.mjs +0 -286
  36. package/esm2022/lib/auth/esolve-otp.service.mjs +0 -77
  37. package/esm2022/lib/core/providers/provide-ng-esolve-connect.function.mjs +0 -24
  38. package/lib/auth/esolve-auth-interceptor.service.d.ts +0 -10
  39. /package/lib/core/providers/{provide-ng-esolve-connect.function.d.ts → ng-esolve-connect.provider.d.ts} +0 -0
@@ -1,8 +1,7 @@
1
- export * from './esolve-auth.service';
2
- export * from './esolve-auth-interceptor.service';
3
- export * from './esolve-otp.service';
1
+ export * from './services';
4
2
  export * from './models';
5
3
  export * from './types';
4
+ export * from './interceptors';
6
5
  export * from './interfaces';
7
6
  export * from './providers';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZXNvbHZlLWF1dGguc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2Vzb2x2ZS1hdXRoLWludGVyY2VwdG9yLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9lc29sdmUtb3RwLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm92aWRlcnMnO1xuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL21vZGVscyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJjZXB0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3Byb3ZpZGVycyc7XG4iXX0=
@@ -0,0 +1,32 @@
1
+ import { inject } from '@angular/core';
2
+ import { EsolveSessionService } from '../../session';
3
+ import { EsolveConfigService } from '../../core';
4
+ export const esolveAuthInterceptor = (req, next) => {
5
+ const config = inject(EsolveConfigService);
6
+ const session = inject(EsolveSessionService);
7
+ if (req.url.startsWith(`${config.api_url}/`)) {
8
+ const service_identifier = req.url.replace(`${config.api_url}/`, '');
9
+ const modified_url = req.url;
10
+ let params = req.params;
11
+ let headers = req.headers;
12
+ if (session.isValid()) {
13
+ if (service_identifier !== 'get-access-token.php') {
14
+ headers = headers.set('Authorization', `Bearer ${session.getToken()}`);
15
+ }
16
+ const state_hash = session.getStateHash();
17
+ headers = headers.set('X-Esolve-State-Hash', state_hash);
18
+ }
19
+ params = params.set('ws_id', config.wsid);
20
+ if (config.native && config.device_designation) {
21
+ headers = headers.set('X-Device-Designation', config.device_designation);
22
+ }
23
+ const modified_req = req.clone({
24
+ url: modified_url,
25
+ params,
26
+ headers,
27
+ });
28
+ return next(modified_req);
29
+ }
30
+ return next(req);
31
+ };
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWF1dGguaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9pbnRlcmNlcHRvcnMvZXNvbHZlLWF1dGguaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRWpELE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFzQixDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRTtJQUNsRSxNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUMzQyxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUU3QyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEdBQUcsTUFBTSxDQUFDLE9BQU8sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUMzQyxNQUFNLGtCQUFrQixHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsTUFBTSxDQUFDLE9BQU8sR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRXJFLE1BQU0sWUFBWSxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUM7UUFDN0IsSUFBSSxNQUFNLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQztRQUN4QixJQUFJLE9BQU8sR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDO1FBRTFCLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUM7WUFDcEIsSUFBSSxrQkFBa0IsS0FBSyxzQkFBc0IsRUFBRSxDQUFDO2dCQUNoRCxPQUFPLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FDakIsZUFBZSxFQUNmLFVBQVUsT0FBTyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQ2pDLENBQUM7WUFDTixDQUFDO1lBRUQsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQzFDLE9BQU8sR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLHFCQUFxQixFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzdELENBQUM7UUFFRCxNQUFNLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRTFDLElBQUksTUFBTSxDQUFDLE1BQU0sSUFBSSxNQUFNLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUM3QyxPQUFPLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FDakIsc0JBQXNCLEVBQ3RCLE1BQU0sQ0FBQyxrQkFBa0IsQ0FDNUIsQ0FBQztRQUNOLENBQUM7UUFFRCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO1lBQzNCLEdBQUcsRUFBRSxZQUFZO1lBQ2pCLE1BQU07WUFDTixPQUFPO1NBQ1YsQ0FBQyxDQUFDO1FBRUgsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3JCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBJbnRlcmNlcHRvckZuIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEVzb2x2ZVNlc3Npb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2Vzc2lvbic7XG5pbXBvcnQgeyBFc29sdmVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5cbmV4cG9ydCBjb25zdCBlc29sdmVBdXRoSW50ZXJjZXB0b3I6IEh0dHBJbnRlcmNlcHRvckZuID0gKHJlcSwgbmV4dCkgPT4ge1xuICAgIGNvbnN0IGNvbmZpZyA9IGluamVjdChFc29sdmVDb25maWdTZXJ2aWNlKTtcbiAgICBjb25zdCBzZXNzaW9uID0gaW5qZWN0KEVzb2x2ZVNlc3Npb25TZXJ2aWNlKTtcblxuICAgIGlmIChyZXEudXJsLnN0YXJ0c1dpdGgoYCR7Y29uZmlnLmFwaV91cmx9L2ApKSB7XG4gICAgICAgIGNvbnN0IHNlcnZpY2VfaWRlbnRpZmllciA9IHJlcS51cmwucmVwbGFjZShgJHtjb25maWcuYXBpX3VybH0vYCwgJycpO1xuXG4gICAgICAgIGNvbnN0IG1vZGlmaWVkX3VybCA9IHJlcS51cmw7XG4gICAgICAgIGxldCBwYXJhbXMgPSByZXEucGFyYW1zO1xuICAgICAgICBsZXQgaGVhZGVycyA9IHJlcS5oZWFkZXJzO1xuXG4gICAgICAgIGlmIChzZXNzaW9uLmlzVmFsaWQoKSkge1xuICAgICAgICAgICAgaWYgKHNlcnZpY2VfaWRlbnRpZmllciAhPT0gJ2dldC1hY2Nlc3MtdG9rZW4ucGhwJykge1xuICAgICAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldChcbiAgICAgICAgICAgICAgICAgICAgJ0F1dGhvcml6YXRpb24nLFxuICAgICAgICAgICAgICAgICAgICBgQmVhcmVyICR7c2Vzc2lvbi5nZXRUb2tlbigpfWAsXG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3Qgc3RhdGVfaGFzaCA9IHNlc3Npb24uZ2V0U3RhdGVIYXNoKCk7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ1gtRXNvbHZlLVN0YXRlLUhhc2gnLCBzdGF0ZV9oYXNoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHBhcmFtcyA9IHBhcmFtcy5zZXQoJ3dzX2lkJywgY29uZmlnLndzaWQpO1xuXG4gICAgICAgIGlmIChjb25maWcubmF0aXZlICYmIGNvbmZpZy5kZXZpY2VfZGVzaWduYXRpb24pIHtcbiAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldChcbiAgICAgICAgICAgICAgICAnWC1EZXZpY2UtRGVzaWduYXRpb24nLFxuICAgICAgICAgICAgICAgIGNvbmZpZy5kZXZpY2VfZGVzaWduYXRpb24sXG4gICAgICAgICAgICApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgbW9kaWZpZWRfcmVxID0gcmVxLmNsb25lKHtcbiAgICAgICAgICAgIHVybDogbW9kaWZpZWRfdXJsLFxuICAgICAgICAgICAgcGFyYW1zLFxuICAgICAgICAgICAgaGVhZGVycyxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmV0dXJuIG5leHQobW9kaWZpZWRfcmVxKTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV4dChyZXEpO1xufTtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export { esolveAuthInterceptor } from './esolve-auth.interceptor';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9pbnRlcmNlcHRvcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBlc29sdmVBdXRoSW50ZXJjZXB0b3IgfSBmcm9tICcuL2Vzb2x2ZS1hdXRoLmludGVyY2VwdG9yJztcbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { APP_INITIALIZER } from '@angular/core';
2
- import { EsolveAuthService } from '../esolve-auth.service';
2
+ import { EsolveAuthService } from '../services';
3
3
  export const ESOLVE_EURUS_AUTO_LOGIN = {
4
4
  provide: APP_INITIALIZER,
5
5
  multi: true,
@@ -9,4 +9,4 @@ export const ESOLVE_EURUS_AUTO_LOGIN = {
9
9
  return true;
10
10
  },
11
11
  };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWV1cnVzLWF1dG8tbG9naW4ucHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9wcm92aWRlcnMvZXNvbHZlLWV1cnVzLWF1dG8tbG9naW4ucHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUUxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUUzRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBYTtJQUM3QyxPQUFPLEVBQUUsZUFBZTtJQUN4QixLQUFLLEVBQUUsSUFBSTtJQUNYLElBQUksRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3pCLFVBQVUsRUFBRSxDQUFDLElBQXVCLEVBQUUsRUFBRSxDQUFDLEtBQUssSUFBSSxFQUFFO1FBQ2hELE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBRXZCLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVBQX0lOSVRJQUxJWkVSLCBQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBFc29sdmVBdXRoU2VydmljZSB9IGZyb20gJy4uL2Vzb2x2ZS1hdXRoLnNlcnZpY2UnO1xuXG5leHBvcnQgY29uc3QgRVNPTFZFX0VVUlVTX0FVVE9fTE9HSU46IFByb3ZpZGVyID0ge1xuICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcbiAgICBtdWx0aTogdHJ1ZSxcbiAgICBkZXBzOiBbRXNvbHZlQXV0aFNlcnZpY2VdLFxuICAgIHVzZUZhY3Rvcnk6IChhdXRoOiBFc29sdmVBdXRoU2VydmljZSkgPT4gYXN5bmMgKCkgPT4ge1xuICAgICAgICBhd2FpdCBhdXRoLmF1dG9Mb2dpbigpO1xuXG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0sXG59O1xuIl19
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWV1cnVzLWF1dG8tbG9naW4ucHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9wcm92aWRlcnMvZXNvbHZlLWV1cnVzLWF1dG8tbG9naW4ucHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUUxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFaEQsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQWE7SUFDN0MsT0FBTyxFQUFFLGVBQWU7SUFDeEIsS0FBSyxFQUFFLElBQUk7SUFDWCxJQUFJLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztJQUN6QixVQUFVLEVBQUUsQ0FBQyxJQUF1QixFQUFFLEVBQUUsQ0FBQyxLQUFLLElBQUksRUFBRTtRQUNoRCxNQUFNLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUV2QixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFQUF9JTklUSUFMSVpFUiwgUHJvdmlkZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRXNvbHZlQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XG5cbmV4cG9ydCBjb25zdCBFU09MVkVfRVVSVVNfQVVUT19MT0dJTjogUHJvdmlkZXIgPSB7XG4gICAgcHJvdmlkZTogQVBQX0lOSVRJQUxJWkVSLFxuICAgIG11bHRpOiB0cnVlLFxuICAgIGRlcHM6IFtFc29sdmVBdXRoU2VydmljZV0sXG4gICAgdXNlRmFjdG9yeTogKGF1dGg6IEVzb2x2ZUF1dGhTZXJ2aWNlKSA9PiBhc3luYyAoKSA9PiB7XG4gICAgICAgIGF3YWl0IGF1dGguYXV0b0xvZ2luKCk7XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSxcbn07XG4iXX0=
@@ -0,0 +1,288 @@
1
+ import { inject, Injectable } from '@angular/core';
2
+ import { HttpClient, HttpParams, HttpHeaders, } from '@angular/common/http';
3
+ import { catchError, firstValueFrom, map, of, switchMap, tap, throwError, } from 'rxjs';
4
+ import { EsolveConfigService } from '../../core';
5
+ import { EsolveErrorHandlerService } from '../../shared';
6
+ import { EsolveSessionService } from '../../session';
7
+ import * as i0 from "@angular/core";
8
+ export class EsolveAuthService {
9
+ constructor() {
10
+ this.config = inject(EsolveConfigService);
11
+ this.http = inject(HttpClient);
12
+ this.session = inject(EsolveSessionService);
13
+ this.errorHandler = inject(EsolveErrorHandlerService);
14
+ this.session
15
+ .onSessionEnd()
16
+ .pipe(switchMap(() => this.checkAccessToken()), catchError(() => of(null)))
17
+ .subscribe((result) => {
18
+ if (result) {
19
+ this.handleAuthentication(result);
20
+ }
21
+ else {
22
+ this.session.expireSession();
23
+ }
24
+ });
25
+ this.session.onExpire().subscribe(() => {
26
+ this.logout().catch(() => {
27
+ // Deal with error gracefully
28
+ });
29
+ });
30
+ }
31
+ getAccessToken(email, password, anonymous = false) {
32
+ let params = new HttpParams();
33
+ if (anonymous) {
34
+ params = params.set('anonymous', true);
35
+ }
36
+ else {
37
+ if (email !== '') {
38
+ params = params.set('email', email);
39
+ }
40
+ if (password !== '') {
41
+ params = params.set('password', password);
42
+ }
43
+ }
44
+ return this.http
45
+ .get(`${this.config.api_url}/get-access-token.php`, {
46
+ params,
47
+ headers: new HttpHeaders({
48
+ 'Accept-Language': '*',
49
+ }),
50
+ })
51
+ .pipe(tap((response) => {
52
+ if (response.type === 'error' ||
53
+ response.type === 'exception') {
54
+ throw response;
55
+ }
56
+ }), catchError(this.handleError), tap((response) => {
57
+ this.handleAuthentication(response.additional_data);
58
+ }));
59
+ }
60
+ getAnonymousSession() {
61
+ return this.getAccessToken('', '', true);
62
+ }
63
+ async autoLogin() {
64
+ let result = await this.restore();
65
+ try {
66
+ if (!result) {
67
+ const response = await firstValueFrom(this.getAnonymousSession());
68
+ result = response.additional_data;
69
+ }
70
+ this.handleAuthentication(result);
71
+ }
72
+ catch (error) {
73
+ console.error(error);
74
+ }
75
+ }
76
+ login(email, password) {
77
+ const body = {
78
+ login: {
79
+ email,
80
+ password,
81
+ },
82
+ };
83
+ return this.http
84
+ .post(`${this.config.api_url}/set-login.php`, body, {
85
+ headers: {
86
+ 'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;',
87
+ },
88
+ responseType: 'json',
89
+ observe: 'body',
90
+ })
91
+ .pipe(map((response) => {
92
+ if (response.responses === undefined ||
93
+ response.responses.length <= 0) {
94
+ throw response;
95
+ }
96
+ const login_response = response.responses[0];
97
+ const result = response.additional_data;
98
+ if (login_response.status.state !== 'success' &&
99
+ login_response.status.state !== 'warning') {
100
+ throw login_response;
101
+ }
102
+ for (const response_log of login_response.log) {
103
+ if (response_log.type === 'success' &&
104
+ response_log.message_code === 'login_success') {
105
+ const user_id = +login_response.esolve_id;
106
+ if (Array.isArray(result)) {
107
+ throw new Error('Invalid login');
108
+ }
109
+ this.handleAuthentication({
110
+ key: result.key,
111
+ user_id: result.user_id,
112
+ access_level: result.access_level,
113
+ location_id: result.location_id,
114
+ addresses_id: result.addresses_id,
115
+ shipping_id: result.shipping_id,
116
+ expires: result.expires,
117
+ expiry_time: result.expiry_time,
118
+ grace_period: result.grace_period,
119
+ clients_id: result.clients_id,
120
+ });
121
+ return user_id;
122
+ }
123
+ }
124
+ throw login_response;
125
+ }), catchError((errorRes) => {
126
+ return this.errorHandler.handleHttpPostError('set-login', errorRes);
127
+ }));
128
+ }
129
+ async logout() {
130
+ this.session.stopTimer();
131
+ const response = await firstValueFrom(this.http
132
+ .post(`${this.config.api_url}/set-logout.php`, {}, {
133
+ headers: {
134
+ 'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;',
135
+ },
136
+ responseType: 'json',
137
+ observe: 'body',
138
+ })
139
+ .pipe(map((response) => {
140
+ if (response.responses === undefined ||
141
+ response.responses.length <= 0) {
142
+ throw response;
143
+ }
144
+ const logout_response = response.responses[0];
145
+ const result = response.additional_data;
146
+ if (logout_response.status.state !== 'success' &&
147
+ logout_response.status.state !== 'warning') {
148
+ throw logout_response;
149
+ }
150
+ for (const response_log of logout_response.log) {
151
+ if (response_log.type === 'success' &&
152
+ response_log.message_code === 'logout_success') {
153
+ if (Array.isArray(result)) {
154
+ throw new Error('Invalid logout');
155
+ }
156
+ this.handleAuthentication({
157
+ key: result.key,
158
+ user_id: result.user_id,
159
+ access_level: result.access_level,
160
+ location_id: result.location_id,
161
+ addresses_id: result.addresses_id,
162
+ shipping_id: result.shipping_id,
163
+ expires: result.expires,
164
+ expiry_time: result.expiry_time,
165
+ grace_period: result.grace_period,
166
+ clients_id: result.clients_id,
167
+ });
168
+ return result;
169
+ }
170
+ }
171
+ throw logout_response;
172
+ }), catchError((errorRes) => {
173
+ return this.errorHandler.handleHttpPostError('set-logout', errorRes);
174
+ })));
175
+ return response;
176
+ }
177
+ async validateCachedTokens() {
178
+ let valid = false;
179
+ try {
180
+ const session = this.session.getCachedSession();
181
+ if (!session) {
182
+ throw new Error('Invalid session');
183
+ }
184
+ const result = await this.checkAccessToken(session);
185
+ if (!result.key) {
186
+ throw new Error('Invalid key');
187
+ }
188
+ valid = true;
189
+ }
190
+ catch (error) {
191
+ console.error(error);
192
+ this.session.reset();
193
+ }
194
+ return valid;
195
+ }
196
+ async checkAccessToken(token = this.session.getToken()) {
197
+ if (token === '') {
198
+ throw new Error('Invalid Token');
199
+ }
200
+ const response = await firstValueFrom(this.http.get(`${this.config.api_url}/get-access-token.php`, {
201
+ headers: new HttpHeaders({
202
+ 'Accept-Language': '*',
203
+ Authorization: `Bearer ${token}`,
204
+ }),
205
+ }));
206
+ if (response.type === 'error' || response.type === 'exception') {
207
+ throw response;
208
+ }
209
+ const additional_data = response.additional_data;
210
+ if (!additional_data.key_okay) {
211
+ throw response;
212
+ }
213
+ if (additional_data.key) {
214
+ token = additional_data.key;
215
+ }
216
+ const result = {
217
+ key: token,
218
+ expires: +additional_data.expires,
219
+ expiry_time: +additional_data.expiry_time,
220
+ grace_period: +additional_data.grace_period,
221
+ location_id: +additional_data.location_id,
222
+ user_id: +additional_data.user_id,
223
+ access_level: +additional_data.access_level,
224
+ addresses_id: +additional_data.addresses_id,
225
+ shipping_id: +additional_data.shipping_id,
226
+ clients_id: +additional_data.clients_id,
227
+ };
228
+ return result;
229
+ }
230
+ async restore() {
231
+ try {
232
+ const token = this.session.getCachedSession();
233
+ if (!token) {
234
+ throw new Error('Invalid token. Resetting session');
235
+ }
236
+ const result = await this.checkAccessToken(token);
237
+ return result;
238
+ }
239
+ catch (error) {
240
+ console.error(error);
241
+ this.session.reset();
242
+ }
243
+ return null;
244
+ }
245
+ // Handlers
246
+ handleExternalAuthentication(result) {
247
+ this.handleAuthentication(result);
248
+ }
249
+ handleAuthentication(result) {
250
+ if (!result.key) {
251
+ return;
252
+ }
253
+ this.session.handleSession({
254
+ token: result.key,
255
+ user_id: +result.user_id,
256
+ access_level: +result.access_level,
257
+ location_id: +result.location_id,
258
+ addresses_id: +result.addresses_id,
259
+ shipping_id: +result.shipping_id,
260
+ clients_id: +result.clients_id,
261
+ }, +result.expiry_time, +result.grace_period);
262
+ }
263
+ handleError(errorRes) {
264
+ const error = {
265
+ message: 'An unknown error occurred',
266
+ data: {},
267
+ };
268
+ if (!errorRes.type || !errorRes.service_type || !errorRes.message) {
269
+ return throwError(() => error);
270
+ }
271
+ if (errorRes.message.trim() !== '') {
272
+ error.message = errorRes.message;
273
+ }
274
+ if (errorRes.additional_data) {
275
+ error.data = errorRes.additional_data;
276
+ }
277
+ return throwError(() => error);
278
+ }
279
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
280
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, providedIn: 'root' }); }
281
+ }
282
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, decorators: [{
283
+ type: Injectable,
284
+ args: [{
285
+ providedIn: 'root',
286
+ }]
287
+ }], ctorParameters: () => [] });
288
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-auth.service.js","sourceRoot":"","sources":["../../../../../../../libs/ng-esolve-connect/src/lib/auth/services/esolve-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport {\n    HttpClient,\n    HttpParams,\n    HttpErrorResponse,\n    HttpHeaders,\n} from '@angular/common/http';\n\nimport {\n    catchError,\n    firstValueFrom,\n    map,\n    Observable,\n    of,\n    switchMap,\n    tap,\n    throwError,\n} from 'rxjs';\n\nimport { EsolveConfigService } from '../../core';\nimport { EsolveErrorHandlerService } from '../../shared';\n\nimport { EsolveSessionService } from '../../session';\n\nimport {\n    EsolveAuthGetResponse,\n    EsolveAuthCheckResponse,\n    EsolveAuthResult,\n    EsolveLoginResponse,\n    EsolveLogoutResponse,\n} from '../types';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class EsolveAuthService {\n    private readonly config = inject(EsolveConfigService);\n    private readonly http = inject(HttpClient);\n    private readonly session = inject(EsolveSessionService);\n    private readonly errorHandler = inject(EsolveErrorHandlerService);\n\n    constructor() {\n        this.session\n            .onSessionEnd()\n            .pipe(\n                switchMap(() => this.checkAccessToken()),\n                catchError(() => of(null)),\n            )\n            .subscribe((result) => {\n                if (result) {\n                    this.handleAuthentication(result);\n                } else {\n                    this.session.expireSession();\n                }\n            });\n\n        this.session.onExpire().subscribe(() => {\n            this.logout().catch(() => {\n                // Deal with error gracefully\n            });\n        });\n    }\n\n    public getAccessToken(\n        email: string,\n        password: string,\n        anonymous = false,\n    ): Observable<EsolveAuthGetResponse> {\n        let params = new HttpParams();\n\n        if (anonymous) {\n            params = params.set('anonymous', true);\n        } else {\n            if (email !== '') {\n                params = params.set('email', email);\n            }\n\n            if (password !== '') {\n                params = params.set('password', password);\n            }\n        }\n\n        return this.http\n            .get<EsolveAuthGetResponse>(\n                `${this.config.api_url}/get-access-token.php`,\n                {\n                    params,\n                    headers: new HttpHeaders({\n                        'Accept-Language': '*',\n                    }),\n                },\n            )\n            .pipe(\n                tap((response) => {\n                    if (\n                        response.type === 'error' ||\n                        response.type === 'exception'\n                    ) {\n                        throw response;\n                    }\n                }),\n                catchError(this.handleError),\n                tap((response) => {\n                    this.handleAuthentication(response.additional_data);\n                }),\n            );\n    }\n\n    public getAnonymousSession(): Observable<EsolveAuthGetResponse> {\n        return this.getAccessToken('', '', true);\n    }\n\n    public async autoLogin(): Promise<void> {\n        let result = await this.restore();\n\n        try {\n            if (!result) {\n                const response = await firstValueFrom(\n                    this.getAnonymousSession(),\n                );\n\n                result = response.additional_data;\n            }\n\n            this.handleAuthentication(result);\n        } catch (error) {\n            console.error(error);\n        }\n    }\n\n    public login(email: string, password: string): Observable<number> {\n        const body = {\n            login: {\n                email,\n                password,\n            },\n        };\n\n        return this.http\n            .post<EsolveLoginResponse>(\n                `${this.config.api_url}/set-login.php`,\n                body,\n                {\n                    headers: {\n                        'Content-Type':\n                            'application/x-www-form-urlencoded;charset=utf-8;',\n                    },\n                    responseType: 'json',\n                    observe: 'body',\n                },\n            )\n            .pipe(\n                map((response) => {\n                    if (\n                        response.responses === undefined ||\n                        response.responses.length <= 0\n                    ) {\n                        throw response;\n                    }\n\n                    const login_response = response.responses[0];\n                    const result = response.additional_data;\n\n                    if (\n                        login_response.status.state !== 'success' &&\n                        login_response.status.state !== 'warning'\n                    ) {\n                        throw login_response;\n                    }\n\n                    for (const response_log of login_response.log) {\n                        if (\n                            response_log.type === 'success' &&\n                            response_log.message_code === 'login_success'\n                        ) {\n                            const user_id = +login_response.esolve_id;\n\n                            if (Array.isArray(result)) {\n                                throw new Error('Invalid login');\n                            }\n\n                            this.handleAuthentication({\n                                key: result.key,\n                                user_id: result.user_id,\n                                access_level: result.access_level,\n                                location_id: result.location_id,\n                                addresses_id: result.addresses_id,\n                                shipping_id: result.shipping_id,\n                                expires: result.expires,\n                                expiry_time: result.expiry_time,\n                                grace_period: result.grace_period,\n                                clients_id: result.clients_id,\n                            });\n\n                            return user_id;\n                        }\n                    }\n\n                    throw login_response;\n                }),\n                catchError((errorRes: HttpErrorResponse) => {\n                    return this.errorHandler.handleHttpPostError(\n                        'set-login',\n                        errorRes,\n                    );\n                }),\n            );\n    }\n\n    public async logout() {\n        this.session.stopTimer();\n\n        const response = await firstValueFrom<EsolveAuthResult>(\n            this.http\n                .post<EsolveLogoutResponse>(\n                    `${this.config.api_url}/set-logout.php`,\n                    {},\n                    {\n                        headers: {\n                            'Content-Type':\n                                'application/x-www-form-urlencoded;charset=utf-8;',\n                        },\n                        responseType: 'json',\n                        observe: 'body',\n                    },\n                )\n                .pipe(\n                    map((response) => {\n                        if (\n                            response.responses === undefined ||\n                            response.responses.length <= 0\n                        ) {\n                            throw response;\n                        }\n\n                        const logout_response = response.responses[0];\n                        const result = response.additional_data;\n\n                        if (\n                            logout_response.status.state !== 'success' &&\n                            logout_response.status.state !== 'warning'\n                        ) {\n                            throw logout_response;\n                        }\n\n                        for (const response_log of logout_response.log) {\n                            if (\n                                response_log.type === 'success' &&\n                                response_log.message_code === 'logout_success'\n                            ) {\n                                if (Array.isArray(result)) {\n                                    throw new Error('Invalid logout');\n                                }\n\n                                this.handleAuthentication({\n                                    key: result.key,\n                                    user_id: result.user_id,\n                                    access_level: result.access_level,\n                                    location_id: result.location_id,\n                                    addresses_id: result.addresses_id,\n                                    shipping_id: result.shipping_id,\n                                    expires: result.expires,\n                                    expiry_time: result.expiry_time,\n                                    grace_period: result.grace_period,\n                                    clients_id: result.clients_id,\n                                });\n\n                                return result;\n                            }\n                        }\n\n                        throw logout_response;\n                    }),\n                    catchError((errorRes: HttpErrorResponse) => {\n                        return this.errorHandler.handleHttpPostError(\n                            'set-logout',\n                            errorRes,\n                        );\n                    }),\n                ),\n        );\n\n        return response;\n    }\n\n    public async validateCachedTokens(): Promise<boolean> {\n        let valid = false;\n\n        try {\n            const session = this.session.getCachedSession();\n\n            if (!session) {\n                throw new Error('Invalid session');\n            }\n\n            const result = await this.checkAccessToken(session);\n\n            if (!result.key) {\n                throw new Error('Invalid key');\n            }\n\n            valid = true;\n        } catch (error) {\n            console.error(error);\n\n            this.session.reset();\n        }\n\n        return valid;\n    }\n\n    private async checkAccessToken(\n        token = this.session.getToken(),\n    ): Promise<EsolveAuthResult> {\n        if (token === '') {\n            throw new Error('Invalid Token');\n        }\n\n        const response = await firstValueFrom(\n            this.http.get<EsolveAuthCheckResponse>(\n                `${this.config.api_url}/get-access-token.php`,\n                {\n                    headers: new HttpHeaders({\n                        'Accept-Language': '*',\n                        Authorization: `Bearer ${token}`,\n                    }),\n                },\n            ),\n        );\n\n        if (response.type === 'error' || response.type === 'exception') {\n            throw response;\n        }\n\n        const additional_data = response.additional_data;\n\n        if (!additional_data.key_okay) {\n            throw response;\n        }\n\n        if (additional_data.key) {\n            token = additional_data.key;\n        }\n\n        const result: EsolveAuthResult = {\n            key: token,\n            expires: +additional_data.expires,\n            expiry_time: +additional_data.expiry_time,\n            grace_period: +additional_data.grace_period,\n            location_id: +additional_data.location_id,\n            user_id: +additional_data.user_id,\n            access_level: +additional_data.access_level,\n            addresses_id: +additional_data.addresses_id,\n            shipping_id: +additional_data.shipping_id,\n            clients_id: +additional_data.clients_id,\n        };\n\n        return result;\n    }\n\n    private async restore(): Promise<EsolveAuthResult | null> {\n        try {\n            const token = this.session.getCachedSession();\n\n            if (!token) {\n                throw new Error('Invalid token. Resetting session');\n            }\n\n            const result = await this.checkAccessToken(token);\n\n            return result;\n        } catch (error) {\n            console.error(error);\n\n            this.session.reset();\n        }\n\n        return null;\n    }\n\n    // Handlers\n\n    public handleExternalAuthentication(result: EsolveAuthResult): void {\n        this.handleAuthentication(result);\n    }\n\n    private handleAuthentication(result: EsolveAuthResult): void {\n        if (!result.key) {\n            return;\n        }\n\n        this.session.handleSession(\n            {\n                token: result.key,\n                user_id: +result.user_id,\n                access_level: +result.access_level,\n                location_id: +result.location_id,\n                addresses_id: +result.addresses_id,\n                shipping_id: +result.shipping_id,\n                clients_id: +result.clients_id,\n            },\n            +result.expiry_time,\n            +result.grace_period,\n        );\n    }\n\n    private handleError(\n        errorRes: EsolveAuthGetResponse | EsolveAuthCheckResponse,\n    ): Observable<never> {\n        const error = {\n            message: 'An unknown error occurred',\n            data: {},\n        };\n\n        if (!errorRes.type || !errorRes.service_type || !errorRes.message) {\n            return throwError(() => error);\n        }\n\n        if (errorRes.message.trim() !== '') {\n            error.message = errorRes.message;\n        }\n\n        if (errorRes.additional_data) {\n            error.data = errorRes.additional_data;\n        }\n\n        return throwError(() => error);\n    }\n}\n"]}
@@ -0,0 +1,77 @@
1
+ import { inject, Injectable } from '@angular/core';
2
+ import { HttpClient, HttpParams } from '@angular/common/http';
3
+ import { throwError } from 'rxjs';
4
+ import { map } from 'rxjs/operators';
5
+ import { EsolveConfigService } from '../../core';
6
+ import { EsolveOtp, EsolveOtpValidation } from '../models';
7
+ import { EsolveAuthService } from './esolve-auth.service';
8
+ import * as i0 from "@angular/core";
9
+ export class EsolveOtpService {
10
+ constructor() {
11
+ this.config = inject(EsolveConfigService);
12
+ this.http = inject(HttpClient);
13
+ this.auth = inject(EsolveAuthService);
14
+ }
15
+ getOtp(recipient_number, captcha_options) {
16
+ let params = new HttpParams();
17
+ if (recipient_number) {
18
+ params = params.set('recipient_number', recipient_number);
19
+ }
20
+ if (captcha_options) {
21
+ params = params.set('captcha_key', captcha_options.captcha_key);
22
+ params = params.set('captcha_code', captcha_options.captcha_code);
23
+ }
24
+ try {
25
+ return this.http
26
+ .get(`${this.config.api_url}/get-otp.php`, { params })
27
+ .pipe(map((response) => {
28
+ if (response.records === undefined ||
29
+ Array.isArray(response.records)) {
30
+ throw response;
31
+ }
32
+ return new EsolveOtp(response.records);
33
+ }));
34
+ }
35
+ catch (error) {
36
+ return throwError(() => error);
37
+ }
38
+ }
39
+ getValidateOtp(otp_key, otp_code, otp_action = '', email = '', cellnumber = '') {
40
+ try {
41
+ return this.http
42
+ .get(`${this.config.api_url}/get-otp-validation.php`, {
43
+ params: {
44
+ otp_key,
45
+ otp_code,
46
+ otp_action,
47
+ email,
48
+ cellnumber,
49
+ },
50
+ })
51
+ .pipe(map((response) => {
52
+ if (response.records === undefined ||
53
+ Array.isArray(response.records)) {
54
+ throw response;
55
+ }
56
+ const additional_data = response.additional_data;
57
+ if (!Array.isArray(additional_data) &&
58
+ additional_data.key) {
59
+ this.auth.handleExternalAuthentication(additional_data);
60
+ }
61
+ return new EsolveOtpValidation(response.records);
62
+ }));
63
+ }
64
+ catch (error) {
65
+ return throwError(() => error);
66
+ }
67
+ }
68
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveOtpService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
69
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveOtpService, providedIn: 'root' }); }
70
+ }
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveOtpService, decorators: [{
72
+ type: Injectable,
73
+ args: [{
74
+ providedIn: 'root',
75
+ }]
76
+ }] });
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-otp.service.js","sourceRoot":"","sources":["../../../../../../../libs/ng-esolve-connect/src/lib/auth/services/esolve-otp.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { HttpClient, HttpParams } from '@angular/common/http';\n\nimport { Observable, throwError } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { EsolveConfigService } from '../../core';\nimport { EsolveGetResponse } from '../../shared';\nimport { EsolveCaptchaOptions } from '../../captcha';\n\nimport { EsolveOtpAction, EsolveValidateOtpResponse } from '../types';\nimport { EsolveOtpRecord } from '../interfaces';\nimport { EsolveOtp, EsolveOtpValidation } from '../models';\n\nimport { EsolveAuthService } from './esolve-auth.service';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class EsolveOtpService {\n    private readonly config = inject(EsolveConfigService);\n    private readonly http = inject(HttpClient);\n    private readonly auth = inject(EsolveAuthService);\n\n    public getOtp(\n        recipient_number?: string,\n        captcha_options?: EsolveCaptchaOptions,\n    ): Observable<EsolveOtp> {\n        let params = new HttpParams();\n\n        if (recipient_number) {\n            params = params.set('recipient_number', recipient_number);\n        }\n\n        if (captcha_options) {\n            params = params.set('captcha_key', captcha_options.captcha_key);\n            params = params.set('captcha_code', captcha_options.captcha_code);\n        }\n\n        try {\n            return this.http\n                .get<\n                    EsolveGetResponse<EsolveOtpRecord>\n                >(`${this.config.api_url}/get-otp.php`, { params })\n                .pipe(\n                    map((response) => {\n                        if (\n                            response.records === undefined ||\n                            Array.isArray(response.records)\n                        ) {\n                            throw response;\n                        }\n\n                        return new EsolveOtp(response.records);\n                    }),\n                );\n        } catch (error) {\n            return throwError(() => error);\n        }\n    }\n\n    public getValidateOtp(\n        otp_key: string,\n        otp_code: string,\n        otp_action: EsolveOtpAction = '',\n        email = '',\n        cellnumber = '',\n    ): Observable<EsolveOtpValidation> {\n        try {\n            return this.http\n                .get<EsolveValidateOtpResponse>(\n                    `${this.config.api_url}/get-otp-validation.php`,\n                    {\n                        params: {\n                            otp_key,\n                            otp_code,\n                            otp_action,\n                            email,\n                            cellnumber,\n                        },\n                    },\n                )\n                .pipe(\n                    map((response) => {\n                        if (\n                            response.records === undefined ||\n                            Array.isArray(response.records)\n                        ) {\n                            throw response;\n                        }\n\n                        const additional_data = response.additional_data;\n\n                        if (\n                            !Array.isArray(additional_data) &&\n                            additional_data.key\n                        ) {\n                            this.auth.handleExternalAuthentication(\n                                additional_data,\n                            );\n                        }\n\n                        return new EsolveOtpValidation(response.records);\n                    }),\n                );\n        } catch (error) {\n            return throwError(() => error);\n        }\n    }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ export { EsolveAuthService } from './esolve-auth.service';
2
+ export { EsolveOtpService } from './esolve-otp.service';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9zZXJ2aWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEVzb2x2ZUF1dGhTZXJ2aWNlIH0gZnJvbSAnLi9lc29sdmUtYXV0aC5zZXJ2aWNlJztcbmV4cG9ydCB7IEVzb2x2ZU90cFNlcnZpY2UgfSBmcm9tICcuL2Vzb2x2ZS1vdHAuc2VydmljZSc7XG4iXX0=
@@ -3,48 +3,45 @@ import { ESOLVE_CONNECT_CONFIG } from './esolve-connect-config.token';
3
3
  import * as i0 from "@angular/core";
4
4
  export class EsolveConfigService {
5
5
  constructor() {
6
- this.api_url = '';
7
- this.site_url = '';
8
- this.wsid = '';
9
- this.title_separator = '|';
10
- this.session_storage_key = '_ng_eslv_token';
11
- this.coupon_storage_key = '_ng_eslv_coupons';
12
- this.voucher_storage_key = '_ng_eslv_vouchers';
13
- this.device_designation = 'web';
14
- const config = inject(ESOLVE_CONNECT_CONFIG);
15
- if (config.api_url === '' || config.wsid === '') {
6
+ this.config = inject(ESOLVE_CONNECT_CONFIG);
7
+ this.wsid = this.config.wsid;
8
+ this.api_url = this.config.api_url;
9
+ this.site_url = this.config.site_url;
10
+ // Device specific
11
+ this.native = this.config.native ?? false;
12
+ this.device_designation = this.config.device_designation ?? 'web';
13
+ // SEO configuration
14
+ this.title_prefix = this.config.title_prefix ?? '';
15
+ this.title_suffix = this.config.title_suffix ?? '';
16
+ this.title_separator = this.config.title_separator ?? '|';
17
+ this.default_seo_title = this.config.default_seo_title ?? '';
18
+ this.default_seo_description = this.config.default_seo_description ?? '';
19
+ this.default_seo_keywords = this.config.default_seo_keywords ?? '';
20
+ // Storage keys
21
+ this.session_cookie_key = this.config.session_cookie_key ?? '_ng_eslv_token';
22
+ this.coupon_cookie_key = this.config.coupon_cookie_key ?? '_ng_eslv_coupons';
23
+ this.voucher_cookie_key = this.config.voucher_cookie_key ?? '_ng_eslv_vouchers';
24
+ // CDN settings
25
+ this.legacy_cdn = this.config.legacy_cdn;
26
+ this.cdn = this.config.cdn;
27
+ this.ftg_cdn = this.config.ftg_cdn;
28
+ this.error_image_path = this.config.error_image_path;
29
+ if (this.api_url === '' || this.wsid === '') {
16
30
  throw new Error('Invalid eSolve Eurus config');
17
31
  }
18
- this.api_url = config.api_url;
19
- this.site_url = config.site_url;
20
- this.wsid = config.wsid;
21
- this.title_prefix = config.title_prefix ?? '';
22
- this.title_suffix = config.title_suffix ?? '';
23
- this.default_seo_title = config.default_seo_title ?? '';
24
- this.default_seo_description = config.default_seo_description ?? '';
25
- this.default_seo_keywords = config.default_seo_keywords ?? '';
26
- this.native = config.native ?? false;
27
- if (config.session_storage_key) {
28
- this.session_storage_key = config.session_storage_key;
29
- }
30
- if (config.title_separator) {
31
- this.title_separator = config.title_separator;
32
- }
33
- if (config.coupon_storage_key) {
34
- this.coupon_storage_key = config.coupon_storage_key;
35
- }
36
- if (config.voucher_storage_key) {
37
- this.voucher_storage_key = config.voucher_storage_key;
38
- }
39
- if (this.native && config.device_designation) {
40
- this.device_designation = config.device_designation;
41
- }
42
- this.legacy_cdn = config.legacy_cdn;
43
- this.cdn = config.cdn;
44
- if (config.ftg_cdn) {
45
- this.ftg_cdn = config.ftg_cdn;
32
+ }
33
+ updateWsid(wsid) {
34
+ if (wsid === '') {
35
+ throw new Error('Invalid WSID');
46
36
  }
47
- this.error_image_path = config.error_image_path;
37
+ this.wsid = wsid;
38
+ }
39
+ udpateCdn(cdn, ftg_cdn) {
40
+ this.cdn = cdn;
41
+ this.ftg_cdn = ftg_cdn;
42
+ }
43
+ udpateLegacyCdn(cdn) {
44
+ this.legacy_cdn = cdn;
48
45
  }
49
46
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
50
47
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveConfigService, providedIn: 'root' }); }
@@ -55,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
55
52
  providedIn: 'root',
56
53
  }]
57
54
  }], ctorParameters: () => [] });
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2NvcmUvZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtCQUErQixDQUFDOztBQUt0RSxNQUFNLE9BQU8sbUJBQW1CO0lBcUI1QjtRQXBCTyxZQUFPLEdBQUcsRUFBRSxDQUFDO1FBQ2IsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUNkLFNBQUksR0FBRyxFQUFFLENBQUM7UUFHVixvQkFBZSxHQUFHLEdBQUcsQ0FBQztRQUt0Qix3QkFBbUIsR0FBRyxnQkFBZ0IsQ0FBQztRQUN2Qyx1QkFBa0IsR0FBRyxrQkFBa0IsQ0FBQztRQUN4Qyx3QkFBbUIsR0FBRyxtQkFBbUIsQ0FBQztRQUMxQyx1QkFBa0IsR0FBRyxLQUFLLENBQUM7UUFROUIsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFN0MsSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLEVBQUUsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLEVBQUUsRUFBRSxDQUFDO1lBQzlDLE1BQU0sSUFBSSxLQUFLLENBQUMsNkJBQTZCLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBRUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO1FBQzlCLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNoQyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFFeEIsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFNLENBQUMsWUFBWSxJQUFJLEVBQUUsQ0FBQztRQUM5QyxJQUFJLENBQUMsWUFBWSxHQUFHLE1BQU0sQ0FBQyxZQUFZLElBQUksRUFBRSxDQUFDO1FBQzlDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxNQUFNLENBQUMsaUJBQWlCLElBQUksRUFBRSxDQUFDO1FBQ3hELElBQUksQ0FBQyx1QkFBdUIsR0FBRyxNQUFNLENBQUMsdUJBQXVCLElBQUksRUFBRSxDQUFDO1FBQ3BFLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxNQUFNLENBQUMsb0JBQW9CLElBQUksRUFBRSxDQUFDO1FBRTlELElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUM7UUFFckMsSUFBSSxNQUFNLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUM3QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDO1FBQzFELENBQUM7UUFFRCxJQUFJLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsZUFBZSxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUM7UUFDbEQsQ0FBQztRQUVELElBQUksTUFBTSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLGtCQUFrQixHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQztRQUN4RCxDQUFDO1FBRUQsSUFBSSxNQUFNLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUM3QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDO1FBQzFELENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksTUFBTSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDM0MsSUFBSSxDQUFDLGtCQUFrQixHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQztRQUN4RCxDQUFDO1FBRUQsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO1FBQ3BDLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQztRQUV0QixJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDbEMsQ0FBQztRQUVELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUM7SUFDcEQsQ0FBQzs4R0FwRVEsbUJBQW1CO2tIQUFuQixtQkFBbUIsY0FGaEIsTUFBTTs7MkZBRVQsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBFc29sdmVDb25uZWN0Q29uZmlnIH0gZnJvbSAnLi9lc29sdmUtY29ubmVjdC1jb25maWcuaW50ZXJmYWNlJztcbmltcG9ydCB7IEVTT0xWRV9DT05ORUNUX0NPTkZJRyB9IGZyb20gJy4vZXNvbHZlLWNvbm5lY3QtY29uZmlnLnRva2VuJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgRXNvbHZlQ29uZmlnU2VydmljZSBpbXBsZW1lbnRzIEVzb2x2ZUNvbm5lY3RDb25maWcge1xuICAgIHB1YmxpYyBhcGlfdXJsID0gJyc7XG4gICAgcHVibGljIHNpdGVfdXJsID0gJyc7XG4gICAgcHVibGljIHdzaWQgPSAnJztcbiAgICBwdWJsaWMgdGl0bGVfcHJlZml4OiBzdHJpbmc7XG4gICAgcHVibGljIHRpdGxlX3N1ZmZpeDogc3RyaW5nO1xuICAgIHB1YmxpYyB0aXRsZV9zZXBhcmF0b3IgPSAnfCc7XG4gICAgcHVibGljIGRlZmF1bHRfc2VvX3RpdGxlOiBzdHJpbmc7XG4gICAgcHVibGljIGRlZmF1bHRfc2VvX2Rlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgcHVibGljIGRlZmF1bHRfc2VvX2tleXdvcmRzOiBzdHJpbmc7XG4gICAgcHVibGljIG5hdGl2ZTogYm9vbGVhbjtcbiAgICBwdWJsaWMgc2Vzc2lvbl9zdG9yYWdlX2tleSA9ICdfbmdfZXNsdl90b2tlbic7XG4gICAgcHVibGljIGNvdXBvbl9zdG9yYWdlX2tleSA9ICdfbmdfZXNsdl9jb3Vwb25zJztcbiAgICBwdWJsaWMgdm91Y2hlcl9zdG9yYWdlX2tleSA9ICdfbmdfZXNsdl92b3VjaGVycyc7XG4gICAgcHVibGljIGRldmljZV9kZXNpZ25hdGlvbiA9ICd3ZWInO1xuXG4gICAgcHVibGljIGxlZ2FjeV9jZG4/OiBzdHJpbmc7XG4gICAgcHVibGljIGNkbj86IHN0cmluZztcbiAgICBwdWJsaWMgZnRnX2Nkbj86IHN0cmluZztcbiAgICBwdWJsaWMgZXJyb3JfaW1hZ2VfcGF0aD86IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBjb25zdCBjb25maWcgPSBpbmplY3QoRVNPTFZFX0NPTk5FQ1RfQ09ORklHKTtcblxuICAgICAgICBpZiAoY29uZmlnLmFwaV91cmwgPT09ICcnIHx8IGNvbmZpZy53c2lkID09PSAnJykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGVTb2x2ZSBFdXJ1cyBjb25maWcnKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuYXBpX3VybCA9IGNvbmZpZy5hcGlfdXJsO1xuICAgICAgICB0aGlzLnNpdGVfdXJsID0gY29uZmlnLnNpdGVfdXJsO1xuICAgICAgICB0aGlzLndzaWQgPSBjb25maWcud3NpZDtcblxuICAgICAgICB0aGlzLnRpdGxlX3ByZWZpeCA9IGNvbmZpZy50aXRsZV9wcmVmaXggPz8gJyc7XG4gICAgICAgIHRoaXMudGl0bGVfc3VmZml4ID0gY29uZmlnLnRpdGxlX3N1ZmZpeCA/PyAnJztcbiAgICAgICAgdGhpcy5kZWZhdWx0X3Nlb190aXRsZSA9IGNvbmZpZy5kZWZhdWx0X3Nlb190aXRsZSA/PyAnJztcbiAgICAgICAgdGhpcy5kZWZhdWx0X3Nlb19kZXNjcmlwdGlvbiA9IGNvbmZpZy5kZWZhdWx0X3Nlb19kZXNjcmlwdGlvbiA/PyAnJztcbiAgICAgICAgdGhpcy5kZWZhdWx0X3Nlb19rZXl3b3JkcyA9IGNvbmZpZy5kZWZhdWx0X3Nlb19rZXl3b3JkcyA/PyAnJztcblxuICAgICAgICB0aGlzLm5hdGl2ZSA9IGNvbmZpZy5uYXRpdmUgPz8gZmFsc2U7XG5cbiAgICAgICAgaWYgKGNvbmZpZy5zZXNzaW9uX3N0b3JhZ2Vfa2V5KSB7XG4gICAgICAgICAgICB0aGlzLnNlc3Npb25fc3RvcmFnZV9rZXkgPSBjb25maWcuc2Vzc2lvbl9zdG9yYWdlX2tleTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb25maWcudGl0bGVfc2VwYXJhdG9yKSB7XG4gICAgICAgICAgICB0aGlzLnRpdGxlX3NlcGFyYXRvciA9IGNvbmZpZy50aXRsZV9zZXBhcmF0b3I7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoY29uZmlnLmNvdXBvbl9zdG9yYWdlX2tleSkge1xuICAgICAgICAgICAgdGhpcy5jb3Vwb25fc3RvcmFnZV9rZXkgPSBjb25maWcuY291cG9uX3N0b3JhZ2Vfa2V5O1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGNvbmZpZy52b3VjaGVyX3N0b3JhZ2Vfa2V5KSB7XG4gICAgICAgICAgICB0aGlzLnZvdWNoZXJfc3RvcmFnZV9rZXkgPSBjb25maWcudm91Y2hlcl9zdG9yYWdlX2tleTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLm5hdGl2ZSAmJiBjb25maWcuZGV2aWNlX2Rlc2lnbmF0aW9uKSB7XG4gICAgICAgICAgICB0aGlzLmRldmljZV9kZXNpZ25hdGlvbiA9IGNvbmZpZy5kZXZpY2VfZGVzaWduYXRpb247XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmxlZ2FjeV9jZG4gPSBjb25maWcubGVnYWN5X2NkbjtcbiAgICAgICAgdGhpcy5jZG4gPSBjb25maWcuY2RuO1xuXG4gICAgICAgIGlmIChjb25maWcuZnRnX2Nkbikge1xuICAgICAgICAgICAgdGhpcy5mdGdfY2RuID0gY29uZmlnLmZ0Z19jZG47XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmVycm9yX2ltYWdlX3BhdGggPSBjb25maWcuZXJyb3JfaW1hZ2VfcGF0aDtcbiAgICB9XG59XG4iXX0=
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2NvcmUvZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtCQUErQixDQUFDOztBQUt0RSxNQUFNLE9BQU8sbUJBQW1CO0lBaUM1QjtRQWhDaUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBRWpELFNBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztRQUN4QixZQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDOUIsYUFBUSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDO1FBRXZDLGtCQUFrQjtRQUNYLFdBQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUM7UUFDckMsdUJBQWtCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsSUFBSSxLQUFLLENBQUM7UUFFcEUsb0JBQW9CO1FBQ2IsaUJBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUM7UUFDOUMsaUJBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUM7UUFDOUMsb0JBQWUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGVBQWUsSUFBSSxHQUFHLENBQUM7UUFDckQsc0JBQWlCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7UUFDeEQsNEJBQXVCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBdUIsSUFBSSxFQUFFLENBQUM7UUFDcEUseUJBQW9CLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsSUFBSSxFQUFFLENBQUM7UUFFckUsZUFBZTtRQUNSLHVCQUFrQixHQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixJQUFJLGdCQUFnQixDQUFDO1FBQ2hELHNCQUFpQixHQUNwQixJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixJQUFJLGtCQUFrQixDQUFDO1FBQ2pELHVCQUFrQixHQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixJQUFJLG1CQUFtQixDQUFDO1FBRTFELGVBQWU7UUFDUixlQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUM7UUFDcEMsUUFBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDO1FBQ3RCLFlBQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUM5QixxQkFBZ0IsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDO1FBR25ELElBQUksSUFBSSxDQUFDLE9BQU8sS0FBSyxFQUFFLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUMxQyxNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7UUFDbkQsQ0FBQztJQUNMLENBQUM7SUFFTSxVQUFVLENBQUMsSUFBWTtRQUMxQixJQUFJLElBQUksS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUVELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ3JCLENBQUM7SUFFTSxTQUFTLENBQUMsR0FBWSxFQUFFLE9BQWdCO1FBQzNDLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ2YsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDM0IsQ0FBQztJQUVNLGVBQWUsQ0FBQyxHQUFZO1FBQy9CLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxDQUFDO0lBQzFCLENBQUM7OEdBdERRLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmhCLE1BQU07OzJGQUVULG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRXNvbHZlQ29ubmVjdENvbmZpZyB9IGZyb20gJy4vZXNvbHZlLWNvbm5lY3QtY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBFU09MVkVfQ09OTkVDVF9DT05GSUcgfSBmcm9tICcuL2Vzb2x2ZS1jb25uZWN0LWNvbmZpZy50b2tlbic7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEVzb2x2ZUNvbmZpZ1NlcnZpY2UgaW1wbGVtZW50cyBFc29sdmVDb25uZWN0Q29uZmlnIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZyA9IGluamVjdChFU09MVkVfQ09OTkVDVF9DT05GSUcpO1xuXG4gICAgcHVibGljIHdzaWQgPSB0aGlzLmNvbmZpZy53c2lkO1xuICAgIHB1YmxpYyBhcGlfdXJsID0gdGhpcy5jb25maWcuYXBpX3VybDtcbiAgICBwdWJsaWMgc2l0ZV91cmwgPSB0aGlzLmNvbmZpZy5zaXRlX3VybDtcblxuICAgIC8vIERldmljZSBzcGVjaWZpY1xuICAgIHB1YmxpYyBuYXRpdmUgPSB0aGlzLmNvbmZpZy5uYXRpdmUgPz8gZmFsc2U7XG4gICAgcHVibGljIGRldmljZV9kZXNpZ25hdGlvbiA9IHRoaXMuY29uZmlnLmRldmljZV9kZXNpZ25hdGlvbiA/PyAnd2ViJztcblxuICAgIC8vIFNFTyBjb25maWd1cmF0aW9uXG4gICAgcHVibGljIHRpdGxlX3ByZWZpeCA9IHRoaXMuY29uZmlnLnRpdGxlX3ByZWZpeCA/PyAnJztcbiAgICBwdWJsaWMgdGl0bGVfc3VmZml4ID0gdGhpcy5jb25maWcudGl0bGVfc3VmZml4ID8/ICcnO1xuICAgIHB1YmxpYyB0aXRsZV9zZXBhcmF0b3IgPSB0aGlzLmNvbmZpZy50aXRsZV9zZXBhcmF0b3IgPz8gJ3wnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb190aXRsZSA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX3RpdGxlID8/ICcnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb19kZXNjcmlwdGlvbiA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX2Rlc2NyaXB0aW9uID8/ICcnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb19rZXl3b3JkcyA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX2tleXdvcmRzID8/ICcnO1xuXG4gICAgLy8gU3RvcmFnZSBrZXlzXG4gICAgcHVibGljIHNlc3Npb25fY29va2llX2tleSA9XG4gICAgICAgIHRoaXMuY29uZmlnLnNlc3Npb25fY29va2llX2tleSA/PyAnX25nX2VzbHZfdG9rZW4nO1xuICAgIHB1YmxpYyBjb3Vwb25fY29va2llX2tleSA9XG4gICAgICAgIHRoaXMuY29uZmlnLmNvdXBvbl9jb29raWVfa2V5ID8/ICdfbmdfZXNsdl9jb3Vwb25zJztcbiAgICBwdWJsaWMgdm91Y2hlcl9jb29raWVfa2V5ID1cbiAgICAgICAgdGhpcy5jb25maWcudm91Y2hlcl9jb29raWVfa2V5ID8/ICdfbmdfZXNsdl92b3VjaGVycyc7XG5cbiAgICAvLyBDRE4gc2V0dGluZ3NcbiAgICBwdWJsaWMgbGVnYWN5X2NkbiA9IHRoaXMuY29uZmlnLmxlZ2FjeV9jZG47XG4gICAgcHVibGljIGNkbiA9IHRoaXMuY29uZmlnLmNkbjtcbiAgICBwdWJsaWMgZnRnX2NkbiA9IHRoaXMuY29uZmlnLmZ0Z19jZG47XG4gICAgcHVibGljIGVycm9yX2ltYWdlX3BhdGggPSB0aGlzLmNvbmZpZy5lcnJvcl9pbWFnZV9wYXRoO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGlmICh0aGlzLmFwaV91cmwgPT09ICcnIHx8IHRoaXMud3NpZCA9PT0gJycpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBlU29sdmUgRXVydXMgY29uZmlnJyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgdXBkYXRlV3NpZCh3c2lkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgaWYgKHdzaWQgPT09ICcnKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgV1NJRCcpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy53c2lkID0gd3NpZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgdWRwYXRlQ2RuKGNkbj86IHN0cmluZywgZnRnX2Nkbj86IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmNkbiA9IGNkbjtcbiAgICAgICAgdGhpcy5mdGdfY2RuID0gZnRnX2NkbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgdWRwYXRlTGVnYWN5Q2RuKGNkbj86IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmxlZ2FjeV9jZG4gPSBjZG47XG4gICAgfVxufVxuIl19