@esolve/ng-esolve-connect 0.109.0 → 0.110.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/esm2022/lib/auth/index.mjs +3 -4
  2. package/esm2022/lib/auth/interceptors/esolve-auth.interceptor.mjs +32 -0
  3. package/esm2022/lib/auth/interceptors/index.mjs +2 -0
  4. package/esm2022/lib/auth/providers/esolve-eurus-auto-login.provider.mjs +2 -2
  5. package/esm2022/lib/auth/services/esolve-auth.service.mjs +288 -0
  6. package/esm2022/lib/auth/services/esolve-otp.service.mjs +77 -0
  7. package/esm2022/lib/auth/services/index.mjs +3 -0
  8. package/esm2022/lib/core/esolve-config.service.mjs +37 -40
  9. package/esm2022/lib/core/esolve-connect-config.interface.mjs +1 -1
  10. package/esm2022/lib/core/providers/index.mjs +2 -2
  11. package/esm2022/lib/core/providers/ng-esolve-connect.provider.mjs +19 -0
  12. package/esm2022/lib/coupons/esolve-coupons.service.mjs +8 -6
  13. package/esm2022/lib/session/esolve-session.service.mjs +89 -89
  14. package/esm2022/lib/shared/cookie/esolve-cookie-options.interface.mjs +2 -0
  15. package/esm2022/lib/shared/cookie/esolve-cookie.service.mjs +5 -5
  16. package/esm2022/lib/shared/cookie/index.mjs +2 -2
  17. package/esm2022/lib/vouchers/esolve-vouchers.service.mjs +8 -6
  18. package/fesm2022/esolve-ng-esolve-connect.mjs +304 -315
  19. package/fesm2022/esolve-ng-esolve-connect.mjs.map +1 -1
  20. package/lib/auth/index.d.ts +2 -3
  21. package/lib/auth/interceptors/esolve-auth.interceptor.d.ts +2 -0
  22. package/lib/auth/interceptors/index.d.ts +1 -0
  23. package/lib/auth/{esolve-auth.service.d.ts → services/esolve-auth.service.d.ts} +1 -1
  24. package/lib/auth/{esolve-otp.service.d.ts → services/esolve-otp.service.d.ts} +3 -3
  25. package/lib/auth/services/index.d.ts +2 -0
  26. package/lib/core/esolve-config.service.d.ts +14 -10
  27. package/lib/core/esolve-connect-config.interface.d.ts +6 -6
  28. package/lib/core/providers/index.d.ts +1 -1
  29. package/lib/session/esolve-session.service.d.ts +12 -5
  30. package/lib/shared/cookie/esolve-cookie-options.interface.d.ts +7 -0
  31. package/lib/shared/cookie/esolve-cookie.service.d.ts +3 -2
  32. package/lib/shared/cookie/index.d.ts +2 -1
  33. package/package.json +1 -1
  34. package/esm2022/lib/auth/esolve-auth-interceptor.service.mjs +0 -42
  35. package/esm2022/lib/auth/esolve-auth.service.mjs +0 -286
  36. package/esm2022/lib/auth/esolve-otp.service.mjs +0 -77
  37. package/esm2022/lib/core/providers/provide-ng-esolve-connect.function.mjs +0 -24
  38. package/lib/auth/esolve-auth-interceptor.service.d.ts +0 -10
  39. /package/lib/core/providers/{provide-ng-esolve-connect.function.d.ts → ng-esolve-connect.provider.d.ts} +0 -0
@@ -1,7 +1,6 @@
1
- export * from './esolve-auth.service';
2
- export * from './esolve-auth-interceptor.service';
3
- export * from './esolve-otp.service';
1
+ export * from './services';
4
2
  export * from './models';
5
3
  export * from './types';
4
+ export * from './interceptors';
6
5
  export * from './interfaces';
7
6
  export * from './providers';
@@ -0,0 +1,2 @@
1
+ import { HttpInterceptorFn } from '@angular/common/http';
2
+ export declare const esolveAuthInterceptor: HttpInterceptorFn;
@@ -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 './types';
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 '../captcha';
3
- import { EsolveOtpAction } from './types';
4
- import { EsolveOtp, EsolveOtpValidation } from './models';
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;
@@ -0,0 +1,2 @@
1
+ export { EsolveAuthService } from './esolve-auth.service';
2
+ export { EsolveOtpService } from './esolve-otp.service';
@@ -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
- wsid: string;
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
- native: boolean;
14
- session_storage_key: string;
15
- coupon_storage_key: string;
16
- voucher_storage_key: string;
17
- device_designation: string;
18
- legacy_cdn?: string;
19
- cdn?: string;
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 local storage (Default is `_ng_eslv_token`)
42
+ * Key for user session cookie storage (Default is `_ng_eslv_token`)
43
43
  */
44
- session_storage_key?: string;
44
+ session_cookie_key?: string;
45
45
  /**
46
- * Key for coupon local storage (Default is `_ng_eslv_coupons`)
46
+ * Key for coupon cookie storage (Default is `_ng_eslv_coupons`)
47
47
  */
48
- coupon_storage_key?: string;
48
+ coupon_cookie_key?: string;
49
49
  /**
50
- * Key for voucher local storage (Default is `_ng_eslv_vouchers`)
50
+ * Key for voucher cookie storage (Default is `_ng_eslv_vouchers`)
51
51
  */
52
- voucher_storage_key?: string;
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 * from './provide-ng-esolve-connect.function';
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 state_hash;
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({ user_id, location_id, addresses_id, shipping_id, clients_id, token, }: EsolveSessionUpdateOptions): void;
57
- private initSession;
64
+ handleUpdateSession(options: EsolveSessionUpdateOptions): void;
58
65
  private setStorageKey;
59
66
  private getCache;
60
67
  private setCache;
@@ -0,0 +1,7 @@
1
+ export interface EsolveCookieOptions {
2
+ expires?: Date;
3
+ path?: string;
4
+ domain?: string;
5
+ secure?: boolean;
6
+ sameSite?: 'Lax' | 'None' | 'Strict';
7
+ }
@@ -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, expires?: Date, path?: string, domain?: string, secure?: boolean): void;
7
- delete(name: string, path?: string, domain?: string, secure?: boolean): void;
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 * from './esolve-cookie.service';
1
+ export { EsolveCookieOptions } from './esolve-cookie-options.interface';
2
+ export { EsolveCookieService } from './esolve-cookie.service';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@esolve/ng-esolve-connect",
3
- "version": "0.109.0",
3
+ "version": "0.110.0",
4
4
  "homepage": "https://www.esolve.co.za/",
5
5
  "description": "An Angular library that speaks to an eSolve instance's API",
6
6
  "peerDependencies": {
@@ -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"]}