@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.
- 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/session/esolve-session.service.mjs +89 -89
- 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 +304 -315
- 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/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
package/lib/auth/index.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
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';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { esolveAuthInterceptor } from './esolve-auth.interceptor';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
import { EsolveAuthGetResponse, EsolveAuthResult } from '
|
|
2
|
+
import { EsolveAuthGetResponse, EsolveAuthResult } from '../types';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class EsolveAuthService {
|
|
5
5
|
private readonly config;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
import { EsolveCaptchaOptions } from '
|
|
3
|
-
import { EsolveOtpAction } from '
|
|
4
|
-
import { EsolveOtp, EsolveOtpValidation } from '
|
|
2
|
+
import { EsolveCaptchaOptions } from '../../captcha';
|
|
3
|
+
import { EsolveOtpAction } from '../types';
|
|
4
|
+
import { EsolveOtp, EsolveOtpValidation } from '../models';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class EsolveOtpService {
|
|
7
7
|
private readonly config;
|
|
@@ -1,25 +1,29 @@
|
|
|
1
1
|
import { EsolveConnectConfig } from './esolve-connect-config.interface';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class EsolveConfigService implements EsolveConnectConfig {
|
|
4
|
+
private readonly config;
|
|
5
|
+
wsid: string;
|
|
4
6
|
api_url: string;
|
|
5
7
|
site_url: string;
|
|
6
|
-
|
|
8
|
+
native: boolean;
|
|
9
|
+
device_designation: string;
|
|
7
10
|
title_prefix: string;
|
|
8
11
|
title_suffix: string;
|
|
9
12
|
title_separator: string;
|
|
10
13
|
default_seo_title: string;
|
|
11
14
|
default_seo_description: string;
|
|
12
15
|
default_seo_keywords: string;
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
ftg_cdn?: string;
|
|
21
|
-
error_image_path?: string;
|
|
16
|
+
session_cookie_key: string;
|
|
17
|
+
coupon_cookie_key: string;
|
|
18
|
+
voucher_cookie_key: string;
|
|
19
|
+
legacy_cdn: string | undefined;
|
|
20
|
+
cdn: string | undefined;
|
|
21
|
+
ftg_cdn: string | undefined;
|
|
22
|
+
error_image_path: string | undefined;
|
|
22
23
|
constructor();
|
|
24
|
+
updateWsid(wsid: string): void;
|
|
25
|
+
udpateCdn(cdn?: string, ftg_cdn?: string): void;
|
|
26
|
+
udpateLegacyCdn(cdn?: string): void;
|
|
23
27
|
static ɵfac: i0.ɵɵFactoryDeclaration<EsolveConfigService, never>;
|
|
24
28
|
static ɵprov: i0.ɵɵInjectableDeclaration<EsolveConfigService>;
|
|
25
29
|
}
|
|
@@ -39,17 +39,17 @@ export interface EsolveConnectConfig {
|
|
|
39
39
|
*/
|
|
40
40
|
default_seo_keywords?: string;
|
|
41
41
|
/**
|
|
42
|
-
* Key for user session
|
|
42
|
+
* Key for user session cookie storage (Default is `_ng_eslv_token`)
|
|
43
43
|
*/
|
|
44
|
-
|
|
44
|
+
session_cookie_key?: string;
|
|
45
45
|
/**
|
|
46
|
-
* Key for coupon
|
|
46
|
+
* Key for coupon cookie storage (Default is `_ng_eslv_coupons`)
|
|
47
47
|
*/
|
|
48
|
-
|
|
48
|
+
coupon_cookie_key?: string;
|
|
49
49
|
/**
|
|
50
|
-
* Key for voucher
|
|
50
|
+
* Key for voucher cookie storage (Default is `_ng_eslv_vouchers`)
|
|
51
51
|
*/
|
|
52
|
-
|
|
52
|
+
voucher_cookie_key?: string;
|
|
53
53
|
/**
|
|
54
54
|
* Indicates whether the implementation is a native app or a website. If it is a native
|
|
55
55
|
* app, the `device_designation` is required for native app features to be enabled
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { provideNgEsolveConnect } from './ng-esolve-connect.provider';
|
|
@@ -5,6 +5,16 @@ export declare class EsolveSessionService {
|
|
|
5
5
|
private readonly is_browser;
|
|
6
6
|
private readonly config;
|
|
7
7
|
private readonly cookieService;
|
|
8
|
+
private readonly storage_key;
|
|
9
|
+
protected readonly token: import("@angular/core").WritableSignal<string>;
|
|
10
|
+
protected readonly user_id: import("@angular/core").WritableSignal<number>;
|
|
11
|
+
protected readonly access_level: import("@angular/core").WritableSignal<number>;
|
|
12
|
+
protected readonly location_id: import("@angular/core").WritableSignal<number>;
|
|
13
|
+
protected readonly addresses_id: import("@angular/core").WritableSignal<number>;
|
|
14
|
+
protected readonly shipping_id: import("@angular/core").WritableSignal<number>;
|
|
15
|
+
protected readonly clients_id: import("@angular/core").WritableSignal<number>;
|
|
16
|
+
protected readonly state_hash: import("@angular/core").Signal<string>;
|
|
17
|
+
protected readonly session: import("@angular/core").Signal<EsolveSession>;
|
|
8
18
|
private token$;
|
|
9
19
|
private user_id$;
|
|
10
20
|
private access_level$;
|
|
@@ -12,9 +22,7 @@ export declare class EsolveSessionService {
|
|
|
12
22
|
private addresses_id$;
|
|
13
23
|
private shipping_id$;
|
|
14
24
|
private clients_id$;
|
|
15
|
-
private
|
|
16
|
-
private _session;
|
|
17
|
-
private storage_key;
|
|
25
|
+
private session$;
|
|
18
26
|
private timer_start;
|
|
19
27
|
private timer_stop;
|
|
20
28
|
private expire;
|
|
@@ -53,8 +61,7 @@ export declare class EsolveSessionService {
|
|
|
53
61
|
getCachedSession(): string | null;
|
|
54
62
|
reset(): void;
|
|
55
63
|
handleSession(session: EsolveSession, expiry_date_unix: number, grace_unix: number): void;
|
|
56
|
-
handleUpdateSession(
|
|
57
|
-
private initSession;
|
|
64
|
+
handleUpdateSession(options: EsolveSessionUpdateOptions): void;
|
|
58
65
|
private setStorageKey;
|
|
59
66
|
private getCache;
|
|
60
67
|
private setCache;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
+
import { EsolveCookieOptions } from './esolve-cookie-options.interface';
|
|
1
2
|
import * as i0 from "@angular/core";
|
|
2
3
|
export declare class EsolveCookieService {
|
|
3
4
|
private readonly cookieService;
|
|
4
5
|
check(name: string): boolean;
|
|
5
6
|
get(name: string): string;
|
|
6
|
-
set(name: string, value: string,
|
|
7
|
-
delete(name: string,
|
|
7
|
+
set(name: string, value: string, options?: EsolveCookieOptions): void;
|
|
8
|
+
delete(name: string, options?: Omit<EsolveCookieOptions, 'expires'>): void;
|
|
8
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<EsolveCookieService, never>;
|
|
9
10
|
static ɵprov: i0.ɵɵInjectableDeclaration<EsolveCookieService>;
|
|
10
11
|
}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { EsolveCookieOptions } from './esolve-cookie-options.interface';
|
|
2
|
+
export { EsolveCookieService } from './esolve-cookie.service';
|
package/package.json
CHANGED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { Injectable, inject } from '@angular/core';
|
|
2
|
-
import { EsolveSessionService } from '../session';
|
|
3
|
-
import { EsolveConfigService } from '../core';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export class EsolveAuthInterceptorService {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.config = inject(EsolveConfigService);
|
|
8
|
-
this.session = inject(EsolveSessionService);
|
|
9
|
-
}
|
|
10
|
-
intercept(req, next) {
|
|
11
|
-
if (req.url.startsWith(`${this.config.api_url}/`)) {
|
|
12
|
-
const service_identifier = req.url.replace(`${this.config.api_url}/`, '');
|
|
13
|
-
const modified_url = req.url;
|
|
14
|
-
let params = req.params;
|
|
15
|
-
let headers = req.headers;
|
|
16
|
-
if (this.session.isValid()) {
|
|
17
|
-
if (service_identifier !== 'get-access-token.php') {
|
|
18
|
-
headers = headers.set('Authorization', `Bearer ${this.session.getToken()}`);
|
|
19
|
-
}
|
|
20
|
-
const state_hash = this.session.getStateHash();
|
|
21
|
-
headers = headers.set('X-Esolve-State-Hash', state_hash);
|
|
22
|
-
}
|
|
23
|
-
params = params.set('ws_id', this.config.wsid);
|
|
24
|
-
if (this.config.native && this.config.device_designation) {
|
|
25
|
-
headers = headers.set('X-Device-Designation', this.config.device_designation);
|
|
26
|
-
}
|
|
27
|
-
const modified_req = req.clone({
|
|
28
|
-
url: modified_url,
|
|
29
|
-
params,
|
|
30
|
-
headers,
|
|
31
|
-
});
|
|
32
|
-
return next.handle(modified_req);
|
|
33
|
-
}
|
|
34
|
-
return next.handle(req);
|
|
35
|
-
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthInterceptorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
37
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthInterceptorService }); }
|
|
38
|
-
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthInterceptorService, decorators: [{
|
|
40
|
-
type: Injectable
|
|
41
|
-
}] });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWF1dGgtaW50ZXJjZXB0b3Iuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmctZXNvbHZlLWNvbm5lY3Qvc3JjL2xpYi9hdXRoL2Vzb2x2ZS1hdXRoLWludGVyY2VwdG9yLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFVbkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFNBQVMsQ0FBQzs7QUFHOUMsTUFBTSxPQUFPLDRCQUE0QjtJQUR6QztRQUVxQixXQUFNLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFDckMsWUFBTyxHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0tBZ0QzRDtJQTlDVSxTQUFTLENBQ1osR0FBcUIsRUFDckIsSUFBaUI7UUFFakIsSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2hELE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQ3RDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEdBQUcsRUFDekIsRUFBRSxDQUNMLENBQUM7WUFFRixNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDO1lBQzdCLElBQUksTUFBTSxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUM7WUFDeEIsSUFBSSxPQUFPLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQztZQUUxQixJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztnQkFDekIsSUFBSSxrQkFBa0IsS0FBSyxzQkFBc0IsRUFBRSxDQUFDO29CQUNoRCxPQUFPLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FDakIsZUFBZSxFQUNmLFVBQVUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUN0QyxDQUFDO2dCQUNOLENBQUM7Z0JBRUQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQztnQkFDL0MsT0FBTyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDN0QsQ0FBQztZQUVELE1BQU0sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRS9DLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO2dCQUN2RCxPQUFPLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FDakIsc0JBQXNCLEVBQ3RCLElBQUksQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQ2pDLENBQUM7WUFDTixDQUFDO1lBRUQsTUFBTSxZQUFZLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztnQkFDM0IsR0FBRyxFQUFFLFlBQVk7Z0JBQ2pCLE1BQU07Z0JBQ04sT0FBTzthQUNWLENBQUMsQ0FBQztZQUVILE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNyQyxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVCLENBQUM7OEdBakRRLDRCQUE0QjtrSEFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICAgIEh0dHBJbnRlcmNlcHRvcixcbiAgICBIdHRwUmVxdWVzdCxcbiAgICBIdHRwSGFuZGxlcixcbiAgICBIdHRwRXZlbnQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcblxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBFc29sdmVTZXNzaW9uU2VydmljZSB9IGZyb20gJy4uL3Nlc3Npb24nO1xuaW1wb3J0IHsgRXNvbHZlQ29uZmlnU2VydmljZSB9IGZyb20gJy4uL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRXNvbHZlQXV0aEludGVyY2VwdG9yU2VydmljZSBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWcgPSBpbmplY3QoRXNvbHZlQ29uZmlnU2VydmljZSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBzZXNzaW9uID0gaW5qZWN0KEVzb2x2ZVNlc3Npb25TZXJ2aWNlKTtcblxuICAgIHB1YmxpYyBpbnRlcmNlcHQoXG4gICAgICAgIHJlcTogSHR0cFJlcXVlc3Q8YW55PixcbiAgICAgICAgbmV4dDogSHR0cEhhbmRsZXIsXG4gICAgKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xuICAgICAgICBpZiAocmVxLnVybC5zdGFydHNXaXRoKGAke3RoaXMuY29uZmlnLmFwaV91cmx9L2ApKSB7XG4gICAgICAgICAgICBjb25zdCBzZXJ2aWNlX2lkZW50aWZpZXIgPSByZXEudXJsLnJlcGxhY2UoXG4gICAgICAgICAgICAgICAgYCR7dGhpcy5jb25maWcuYXBpX3VybH0vYCxcbiAgICAgICAgICAgICAgICAnJyxcbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgIGNvbnN0IG1vZGlmaWVkX3VybCA9IHJlcS51cmw7XG4gICAgICAgICAgICBsZXQgcGFyYW1zID0gcmVxLnBhcmFtcztcbiAgICAgICAgICAgIGxldCBoZWFkZXJzID0gcmVxLmhlYWRlcnM7XG5cbiAgICAgICAgICAgIGlmICh0aGlzLnNlc3Npb24uaXNWYWxpZCgpKSB7XG4gICAgICAgICAgICAgICAgaWYgKHNlcnZpY2VfaWRlbnRpZmllciAhPT0gJ2dldC1hY2Nlc3MtdG9rZW4ucGhwJykge1xuICAgICAgICAgICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoXG4gICAgICAgICAgICAgICAgICAgICAgICAnQXV0aG9yaXphdGlvbicsXG4gICAgICAgICAgICAgICAgICAgICAgICBgQmVhcmVyICR7dGhpcy5zZXNzaW9uLmdldFRva2VuKCl9YCxcbiAgICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBjb25zdCBzdGF0ZV9oYXNoID0gdGhpcy5zZXNzaW9uLmdldFN0YXRlSGFzaCgpO1xuICAgICAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldCgnWC1Fc29sdmUtU3RhdGUtSGFzaCcsIHN0YXRlX2hhc2gpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBwYXJhbXMgPSBwYXJhbXMuc2V0KCd3c19pZCcsIHRoaXMuY29uZmlnLndzaWQpO1xuXG4gICAgICAgICAgICBpZiAodGhpcy5jb25maWcubmF0aXZlICYmIHRoaXMuY29uZmlnLmRldmljZV9kZXNpZ25hdGlvbikge1xuICAgICAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldChcbiAgICAgICAgICAgICAgICAgICAgJ1gtRGV2aWNlLURlc2lnbmF0aW9uJyxcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jb25maWcuZGV2aWNlX2Rlc2lnbmF0aW9uLFxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvbnN0IG1vZGlmaWVkX3JlcSA9IHJlcS5jbG9uZSh7XG4gICAgICAgICAgICAgICAgdXJsOiBtb2RpZmllZF91cmwsXG4gICAgICAgICAgICAgICAgcGFyYW1zLFxuICAgICAgICAgICAgICAgIGhlYWRlcnMsXG4gICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKG1vZGlmaWVkX3JlcSk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,286 +0,0 @@
|
|
|
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
|
-
if (email !== '') {
|
|
37
|
-
params = params.set('email', email);
|
|
38
|
-
}
|
|
39
|
-
if (password !== '') {
|
|
40
|
-
params = params.set('password', password);
|
|
41
|
-
}
|
|
42
|
-
return this.http
|
|
43
|
-
.get(`${this.config.api_url}/get-access-token.php`, {
|
|
44
|
-
params,
|
|
45
|
-
headers: new HttpHeaders({
|
|
46
|
-
'Accept-Language': '*',
|
|
47
|
-
}),
|
|
48
|
-
})
|
|
49
|
-
.pipe(tap((response) => {
|
|
50
|
-
if (response.type === 'error' ||
|
|
51
|
-
response.type === 'exception') {
|
|
52
|
-
throw response;
|
|
53
|
-
}
|
|
54
|
-
}), catchError(this.handleError), tap((response) => {
|
|
55
|
-
this.handleAuthentication(response.additional_data);
|
|
56
|
-
}));
|
|
57
|
-
}
|
|
58
|
-
getAnonymousSession() {
|
|
59
|
-
return this.getAccessToken('', '', true);
|
|
60
|
-
}
|
|
61
|
-
async autoLogin() {
|
|
62
|
-
let result = await this.restore();
|
|
63
|
-
try {
|
|
64
|
-
if (!result) {
|
|
65
|
-
const response = await firstValueFrom(this.getAnonymousSession());
|
|
66
|
-
result = response.additional_data;
|
|
67
|
-
}
|
|
68
|
-
this.handleAuthentication(result);
|
|
69
|
-
}
|
|
70
|
-
catch (error) {
|
|
71
|
-
console.error(error);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
login(email, password) {
|
|
75
|
-
const body = {
|
|
76
|
-
login: {
|
|
77
|
-
email,
|
|
78
|
-
password,
|
|
79
|
-
},
|
|
80
|
-
};
|
|
81
|
-
return this.http
|
|
82
|
-
.post(`${this.config.api_url}/set-login.php`, body, {
|
|
83
|
-
headers: {
|
|
84
|
-
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;',
|
|
85
|
-
},
|
|
86
|
-
responseType: 'json',
|
|
87
|
-
observe: 'body',
|
|
88
|
-
})
|
|
89
|
-
.pipe(map((response) => {
|
|
90
|
-
if (response.responses === undefined ||
|
|
91
|
-
response.responses.length <= 0) {
|
|
92
|
-
throw response;
|
|
93
|
-
}
|
|
94
|
-
const login_response = response.responses[0];
|
|
95
|
-
const result = response.additional_data;
|
|
96
|
-
if (login_response.status.state !== 'success' &&
|
|
97
|
-
login_response.status.state !== 'warning') {
|
|
98
|
-
throw login_response;
|
|
99
|
-
}
|
|
100
|
-
for (const response_log of login_response.log) {
|
|
101
|
-
if (response_log.type === 'success' &&
|
|
102
|
-
response_log.message_code === 'login_success') {
|
|
103
|
-
const user_id = +login_response.esolve_id;
|
|
104
|
-
if (Array.isArray(result)) {
|
|
105
|
-
throw new Error('Invalid login');
|
|
106
|
-
}
|
|
107
|
-
this.handleAuthentication({
|
|
108
|
-
key: result.key,
|
|
109
|
-
user_id: result.user_id,
|
|
110
|
-
access_level: result.access_level,
|
|
111
|
-
location_id: result.location_id,
|
|
112
|
-
addresses_id: result.addresses_id,
|
|
113
|
-
shipping_id: result.shipping_id,
|
|
114
|
-
expires: result.expires,
|
|
115
|
-
expiry_time: result.expiry_time,
|
|
116
|
-
grace_period: result.grace_period,
|
|
117
|
-
clients_id: result.clients_id,
|
|
118
|
-
});
|
|
119
|
-
return user_id;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
throw login_response;
|
|
123
|
-
}), catchError((errorRes) => {
|
|
124
|
-
return this.errorHandler.handleHttpPostError('set-login', errorRes);
|
|
125
|
-
}));
|
|
126
|
-
}
|
|
127
|
-
async logout() {
|
|
128
|
-
this.session.stopTimer();
|
|
129
|
-
const response = await firstValueFrom(this.http
|
|
130
|
-
.post(`${this.config.api_url}/set-logout.php`, {}, {
|
|
131
|
-
headers: {
|
|
132
|
-
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;',
|
|
133
|
-
},
|
|
134
|
-
responseType: 'json',
|
|
135
|
-
observe: 'body',
|
|
136
|
-
})
|
|
137
|
-
.pipe(map((response) => {
|
|
138
|
-
if (response.responses === undefined ||
|
|
139
|
-
response.responses.length <= 0) {
|
|
140
|
-
throw response;
|
|
141
|
-
}
|
|
142
|
-
const logout_response = response.responses[0];
|
|
143
|
-
const result = response.additional_data;
|
|
144
|
-
if (logout_response.status.state !== 'success' &&
|
|
145
|
-
logout_response.status.state !== 'warning') {
|
|
146
|
-
throw logout_response;
|
|
147
|
-
}
|
|
148
|
-
for (const response_log of logout_response.log) {
|
|
149
|
-
if (response_log.type === 'success' &&
|
|
150
|
-
response_log.message_code === 'logout_success') {
|
|
151
|
-
if (Array.isArray(result)) {
|
|
152
|
-
throw new Error('Invalid logout');
|
|
153
|
-
}
|
|
154
|
-
this.handleAuthentication({
|
|
155
|
-
key: result.key,
|
|
156
|
-
user_id: result.user_id,
|
|
157
|
-
access_level: result.access_level,
|
|
158
|
-
location_id: result.location_id,
|
|
159
|
-
addresses_id: result.addresses_id,
|
|
160
|
-
shipping_id: result.shipping_id,
|
|
161
|
-
expires: result.expires,
|
|
162
|
-
expiry_time: result.expiry_time,
|
|
163
|
-
grace_period: result.grace_period,
|
|
164
|
-
clients_id: result.clients_id,
|
|
165
|
-
});
|
|
166
|
-
return result;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
throw logout_response;
|
|
170
|
-
}), catchError((errorRes) => {
|
|
171
|
-
return this.errorHandler.handleHttpPostError('set-logout', errorRes);
|
|
172
|
-
})));
|
|
173
|
-
return response;
|
|
174
|
-
}
|
|
175
|
-
async validateCachedTokens() {
|
|
176
|
-
let valid = false;
|
|
177
|
-
try {
|
|
178
|
-
const session = this.session.getCachedSession();
|
|
179
|
-
if (!session) {
|
|
180
|
-
throw new Error('Invalid session');
|
|
181
|
-
}
|
|
182
|
-
const result = await this.checkAccessToken(session);
|
|
183
|
-
if (!result.key) {
|
|
184
|
-
throw new Error('Invalid key');
|
|
185
|
-
}
|
|
186
|
-
valid = true;
|
|
187
|
-
}
|
|
188
|
-
catch (error) {
|
|
189
|
-
console.error(error);
|
|
190
|
-
this.session.reset();
|
|
191
|
-
}
|
|
192
|
-
return valid;
|
|
193
|
-
}
|
|
194
|
-
async checkAccessToken(token = this.session.getToken()) {
|
|
195
|
-
if (token === '') {
|
|
196
|
-
throw new Error('Invalid Token');
|
|
197
|
-
}
|
|
198
|
-
const response = await firstValueFrom(this.http.get(`${this.config.api_url}/get-access-token.php`, {
|
|
199
|
-
headers: new HttpHeaders({
|
|
200
|
-
'Accept-Language': '*',
|
|
201
|
-
Authorization: `Bearer ${token}`,
|
|
202
|
-
}),
|
|
203
|
-
}));
|
|
204
|
-
if (response.type === 'error' || response.type === 'exception') {
|
|
205
|
-
throw response;
|
|
206
|
-
}
|
|
207
|
-
const additional_data = response.additional_data;
|
|
208
|
-
if (!additional_data.key_okay) {
|
|
209
|
-
throw response;
|
|
210
|
-
}
|
|
211
|
-
if (additional_data.key) {
|
|
212
|
-
token = additional_data.key;
|
|
213
|
-
}
|
|
214
|
-
const result = {
|
|
215
|
-
key: token,
|
|
216
|
-
expires: +additional_data.expires,
|
|
217
|
-
expiry_time: +additional_data.expiry_time,
|
|
218
|
-
grace_period: +additional_data.grace_period,
|
|
219
|
-
location_id: +additional_data.location_id,
|
|
220
|
-
user_id: +additional_data.user_id,
|
|
221
|
-
access_level: +additional_data.access_level,
|
|
222
|
-
addresses_id: +additional_data.addresses_id,
|
|
223
|
-
shipping_id: +additional_data.shipping_id,
|
|
224
|
-
clients_id: +additional_data.clients_id,
|
|
225
|
-
};
|
|
226
|
-
return result;
|
|
227
|
-
}
|
|
228
|
-
async restore() {
|
|
229
|
-
try {
|
|
230
|
-
const token = this.session.getCachedSession();
|
|
231
|
-
if (!token) {
|
|
232
|
-
throw new Error('Invalid token');
|
|
233
|
-
}
|
|
234
|
-
const result = await this.checkAccessToken(token);
|
|
235
|
-
return result;
|
|
236
|
-
}
|
|
237
|
-
catch (error) {
|
|
238
|
-
console.error(error);
|
|
239
|
-
this.session.reset();
|
|
240
|
-
}
|
|
241
|
-
return null;
|
|
242
|
-
}
|
|
243
|
-
// Handlers
|
|
244
|
-
handleExternalAuthentication(result) {
|
|
245
|
-
this.handleAuthentication(result);
|
|
246
|
-
}
|
|
247
|
-
handleAuthentication(result) {
|
|
248
|
-
if (!result.key) {
|
|
249
|
-
return;
|
|
250
|
-
}
|
|
251
|
-
this.session.handleSession({
|
|
252
|
-
token: result.key,
|
|
253
|
-
user_id: +result.user_id,
|
|
254
|
-
access_level: +result.access_level,
|
|
255
|
-
location_id: +result.location_id,
|
|
256
|
-
addresses_id: +result.addresses_id,
|
|
257
|
-
shipping_id: +result.shipping_id,
|
|
258
|
-
clients_id: +result.clients_id,
|
|
259
|
-
}, +result.expiry_time, +result.grace_period);
|
|
260
|
-
}
|
|
261
|
-
handleError(errorRes) {
|
|
262
|
-
const error = {
|
|
263
|
-
message: 'An unknown error occurred',
|
|
264
|
-
data: {},
|
|
265
|
-
};
|
|
266
|
-
if (!errorRes.type || !errorRes.service_type || !errorRes.message) {
|
|
267
|
-
return throwError(() => error);
|
|
268
|
-
}
|
|
269
|
-
if (errorRes.message.trim() !== '') {
|
|
270
|
-
error.message = errorRes.message;
|
|
271
|
-
}
|
|
272
|
-
if (errorRes.additional_data) {
|
|
273
|
-
error.data = errorRes.additional_data;
|
|
274
|
-
}
|
|
275
|
-
return throwError(() => error);
|
|
276
|
-
}
|
|
277
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
278
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, providedIn: 'root' }); }
|
|
279
|
-
}
|
|
280
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: EsolveAuthService, decorators: [{
|
|
281
|
-
type: Injectable,
|
|
282
|
-
args: [{
|
|
283
|
-
providedIn: 'root',
|
|
284
|
-
}]
|
|
285
|
-
}], ctorParameters: () => [] });
|
|
286
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-auth.service.js","sourceRoot":"","sources":["../../../../../../libs/ng-esolve-connect/src/lib/auth/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        }\n\n        if (email !== '') {\n            params = params.set('email', email);\n        }\n\n        if (password !== '') {\n            params = params.set('password', password);\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');\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"]}
|