@esolve/ng-esolve-connect 0.109.1 → 0.111.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.
- package/esm2022/lib/auth/index.mjs +3 -4
- package/esm2022/lib/auth/interceptors/esolve-auth.interceptor.mjs +32 -0
- package/esm2022/lib/auth/interceptors/index.mjs +2 -0
- package/esm2022/lib/auth/providers/esolve-eurus-auto-login.provider.mjs +2 -2
- package/esm2022/lib/auth/services/esolve-auth.service.mjs +288 -0
- package/esm2022/lib/auth/services/esolve-otp.service.mjs +77 -0
- package/esm2022/lib/auth/services/index.mjs +3 -0
- package/esm2022/lib/core/esolve-config.service.mjs +37 -40
- package/esm2022/lib/core/esolve-connect-config.interface.mjs +1 -1
- package/esm2022/lib/core/providers/index.mjs +2 -2
- package/esm2022/lib/core/providers/ng-esolve-connect.provider.mjs +19 -0
- package/esm2022/lib/coupons/esolve-coupons.service.mjs +8 -6
- package/esm2022/lib/device/esolve-device.service.mjs +4 -1
- package/esm2022/lib/device/index.mjs +2 -1
- package/esm2022/lib/device/interfaces/esolve-device.interface.mjs +1 -1
- package/esm2022/lib/device/interfaces/esolve-user-device-options.interface.mjs +1 -1
- package/esm2022/lib/device/types/esolve-device-type.type.mjs +2 -0
- package/esm2022/lib/device/types/index.mjs +2 -0
- package/esm2022/lib/locations/classes/esolve-location.model.mjs +39 -1
- package/esm2022/lib/locations/interfaces/esolve-location-record.interface.mjs +1 -1
- package/esm2022/lib/locations/types/esolve-location-image-size.type.mjs +2 -0
- package/esm2022/lib/locations/types/index.mjs +2 -1
- package/esm2022/lib/session/esolve-session.service.mjs +86 -88
- package/esm2022/lib/shared/cookie/esolve-cookie-options.interface.mjs +2 -0
- package/esm2022/lib/shared/cookie/esolve-cookie.service.mjs +5 -5
- package/esm2022/lib/shared/cookie/index.mjs +2 -2
- package/esm2022/lib/vouchers/esolve-vouchers.service.mjs +8 -6
- package/fesm2022/esolve-ng-esolve-connect.mjs +342 -314
- package/fesm2022/esolve-ng-esolve-connect.mjs.map +1 -1
- package/lib/auth/index.d.ts +2 -3
- package/lib/auth/interceptors/esolve-auth.interceptor.d.ts +2 -0
- package/lib/auth/interceptors/index.d.ts +1 -0
- package/lib/auth/{esolve-auth.service.d.ts → services/esolve-auth.service.d.ts} +1 -1
- package/lib/auth/{esolve-otp.service.d.ts → services/esolve-otp.service.d.ts} +3 -3
- package/lib/auth/services/index.d.ts +2 -0
- package/lib/core/esolve-config.service.d.ts +14 -10
- package/lib/core/esolve-connect-config.interface.d.ts +6 -6
- package/lib/core/providers/index.d.ts +1 -1
- package/lib/device/index.d.ts +1 -0
- package/lib/device/interfaces/esolve-device.interface.d.ts +2 -0
- package/lib/device/interfaces/esolve-user-device-options.interface.d.ts +2 -0
- package/lib/device/types/esolve-device-type.type.d.ts +1 -0
- package/lib/device/types/index.d.ts +1 -0
- package/lib/locations/classes/esolve-location.model.d.ts +22 -0
- package/lib/locations/interfaces/esolve-location-record.interface.d.ts +2 -0
- package/lib/locations/types/esolve-location-image-size.type.d.ts +1 -0
- package/lib/locations/types/index.d.ts +1 -0
- package/lib/session/esolve-session.service.d.ts +12 -5
- package/lib/shared/cookie/esolve-cookie-options.interface.d.ts +7 -0
- package/lib/shared/cookie/esolve-cookie.service.d.ts +3 -2
- package/lib/shared/cookie/index.d.ts +2 -1
- package/package.json +1 -1
- package/esm2022/lib/auth/esolve-auth-interceptor.service.mjs +0 -42
- package/esm2022/lib/auth/esolve-auth.service.mjs +0 -286
- package/esm2022/lib/auth/esolve-otp.service.mjs +0 -77
- package/esm2022/lib/core/providers/provide-ng-esolve-connect.function.mjs +0 -24
- package/lib/auth/esolve-auth-interceptor.service.d.ts +0 -10
- /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 './
|
|
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,
|
|
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 '../
|
|
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,
|
|
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.
|
|
7
|
-
this.
|
|
8
|
-
this.
|
|
9
|
-
this.
|
|
10
|
-
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
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
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
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.
|
|
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,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2NvcmUvZXNvbHZlLWNvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtCQUErQixDQUFDOztBQUt0RSxNQUFNLE9BQU8sbUJBQW1CO0lBaUM1QjtRQWhDaUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBRWpELFNBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztRQUN4QixZQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDOUIsYUFBUSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDO1FBRXZDLGtCQUFrQjtRQUNYLFdBQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUM7UUFDckMsdUJBQWtCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsSUFBSSxLQUFLLENBQUM7UUFFcEUsb0JBQW9CO1FBQ2IsaUJBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUM7UUFDOUMsaUJBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUM7UUFDOUMsb0JBQWUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGVBQWUsSUFBSSxHQUFHLENBQUM7UUFDckQsc0JBQWlCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7UUFDeEQsNEJBQXVCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBdUIsSUFBSSxFQUFFLENBQUM7UUFDcEUseUJBQW9CLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsSUFBSSxFQUFFLENBQUM7UUFFckUsZUFBZTtRQUNSLHVCQUFrQixHQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixJQUFJLGdCQUFnQixDQUFDO1FBQ2hELHNCQUFpQixHQUNwQixJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixJQUFJLGtCQUFrQixDQUFDO1FBQ2pELHVCQUFrQixHQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixJQUFJLG1CQUFtQixDQUFDO1FBRTFELGVBQWU7UUFDUixlQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUM7UUFDcEMsUUFBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDO1FBQ3RCLFlBQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUM5QixxQkFBZ0IsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDO1FBR25ELElBQUksSUFBSSxDQUFDLE9BQU8sS0FBSyxFQUFFLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUMxQyxNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7UUFDbkQsQ0FBQztJQUNMLENBQUM7SUFFTSxVQUFVLENBQUMsSUFBWTtRQUMxQixJQUFJLElBQUksS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUVELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ3JCLENBQUM7SUFFTSxTQUFTLENBQUMsR0FBWSxFQUFFLE9BQWdCO1FBQzNDLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ2YsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDM0IsQ0FBQztJQUVNLGVBQWUsQ0FBQyxHQUFZO1FBQy9CLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxDQUFDO0lBQzFCLENBQUM7OEdBdERRLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmhCLE1BQU07OzJGQUVULG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRXNvbHZlQ29ubmVjdENvbmZpZyB9IGZyb20gJy4vZXNvbHZlLWNvbm5lY3QtY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBFU09MVkVfQ09OTkVDVF9DT05GSUcgfSBmcm9tICcuL2Vzb2x2ZS1jb25uZWN0LWNvbmZpZy50b2tlbic7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEVzb2x2ZUNvbmZpZ1NlcnZpY2UgaW1wbGVtZW50cyBFc29sdmVDb25uZWN0Q29uZmlnIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZyA9IGluamVjdChFU09MVkVfQ09OTkVDVF9DT05GSUcpO1xuXG4gICAgcHVibGljIHdzaWQgPSB0aGlzLmNvbmZpZy53c2lkO1xuICAgIHB1YmxpYyBhcGlfdXJsID0gdGhpcy5jb25maWcuYXBpX3VybDtcbiAgICBwdWJsaWMgc2l0ZV91cmwgPSB0aGlzLmNvbmZpZy5zaXRlX3VybDtcblxuICAgIC8vIERldmljZSBzcGVjaWZpY1xuICAgIHB1YmxpYyBuYXRpdmUgPSB0aGlzLmNvbmZpZy5uYXRpdmUgPz8gZmFsc2U7XG4gICAgcHVibGljIGRldmljZV9kZXNpZ25hdGlvbiA9IHRoaXMuY29uZmlnLmRldmljZV9kZXNpZ25hdGlvbiA/PyAnd2ViJztcblxuICAgIC8vIFNFTyBjb25maWd1cmF0aW9uXG4gICAgcHVibGljIHRpdGxlX3ByZWZpeCA9IHRoaXMuY29uZmlnLnRpdGxlX3ByZWZpeCA/PyAnJztcbiAgICBwdWJsaWMgdGl0bGVfc3VmZml4ID0gdGhpcy5jb25maWcudGl0bGVfc3VmZml4ID8/ICcnO1xuICAgIHB1YmxpYyB0aXRsZV9zZXBhcmF0b3IgPSB0aGlzLmNvbmZpZy50aXRsZV9zZXBhcmF0b3IgPz8gJ3wnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb190aXRsZSA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX3RpdGxlID8/ICcnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb19kZXNjcmlwdGlvbiA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX2Rlc2NyaXB0aW9uID8/ICcnO1xuICAgIHB1YmxpYyBkZWZhdWx0X3Nlb19rZXl3b3JkcyA9IHRoaXMuY29uZmlnLmRlZmF1bHRfc2VvX2tleXdvcmRzID8/ICcnO1xuXG4gICAgLy8gU3RvcmFnZSBrZXlzXG4gICAgcHVibGljIHNlc3Npb25fY29va2llX2tleSA9XG4gICAgICAgIHRoaXMuY29uZmlnLnNlc3Npb25fY29va2llX2tleSA/PyAnX25nX2VzbHZfdG9rZW4nO1xuICAgIHB1YmxpYyBjb3Vwb25fY29va2llX2tleSA9XG4gICAgICAgIHRoaXMuY29uZmlnLmNvdXBvbl9jb29raWVfa2V5ID8/ICdfbmdfZXNsdl9jb3Vwb25zJztcbiAgICBwdWJsaWMgdm91Y2hlcl9jb29raWVfa2V5ID1cbiAgICAgICAgdGhpcy5jb25maWcudm91Y2hlcl9jb29raWVfa2V5ID8/ICdfbmdfZXNsdl92b3VjaGVycyc7XG5cbiAgICAvLyBDRE4gc2V0dGluZ3NcbiAgICBwdWJsaWMgbGVnYWN5X2NkbiA9IHRoaXMuY29uZmlnLmxlZ2FjeV9jZG47XG4gICAgcHVibGljIGNkbiA9IHRoaXMuY29uZmlnLmNkbjtcbiAgICBwdWJsaWMgZnRnX2NkbiA9IHRoaXMuY29uZmlnLmZ0Z19jZG47XG4gICAgcHVibGljIGVycm9yX2ltYWdlX3BhdGggPSB0aGlzLmNvbmZpZy5lcnJvcl9pbWFnZV9wYXRoO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGlmICh0aGlzLmFwaV91cmwgPT09ICcnIHx8IHRoaXMud3NpZCA9PT0gJycpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBlU29sdmUgRXVydXMgY29uZmlnJyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgdXBkYXRlV3NpZCh3c2lkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgaWYgKHdzaWQgPT09ICcnKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgV1NJRCcpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy53c2lkID0gd3NpZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgdWRwYXRlQ2RuKGNkbj86IHN0cmluZywgZnRnX2Nkbj86IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmNkbiA9IGNkbjtcbiAgICAgICAgdGhpcy5mdGdfY2RuID0gZnRnX2NkbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgdWRwYXRlTGVnYWN5Q2RuKGNkbj86IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmxlZ2FjeV9jZG4gPSBjZG47XG4gICAgfVxufVxuIl19
|