@esolve/ng-esolve-connect 0.5.0 → 0.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/esolve-ng-esolve-connect.umd.js +528 -465
- package/bundles/esolve-ng-esolve-connect.umd.js.map +1 -1
- package/esm2015/lib/auth/esolve-account.service.js +55 -7
- package/esm2015/lib/auth/esolve-auth-interceptor.service.js +3 -3
- package/esm2015/lib/auth/esolve-auth.service.js +21 -58
- package/esm2015/lib/auth/esolve-registration-data.js +2 -0
- package/esm2015/lib/auth/esolve-registration-post-response-item.js +2 -0
- package/esm2015/lib/auth/esolve-registration-result.js +9 -0
- package/esm2015/lib/auth/esolve-session.service.js +4 -10
- package/esm2015/lib/cart/esolve-cart-item-record.js +1 -1
- package/esm2015/lib/cart/esolve-cart-item-response.js +2 -0
- package/esm2015/lib/cart/esolve-cart.service.js +8 -53
- package/esm2015/lib/esolve-connect.config.js +8 -1
- package/esm2015/lib/shared/error-handler/esolve-error-handler.service.js +58 -0
- package/esm2015/lib/shared/error-handler/esolve-http-error.js +8 -0
- package/esm2015/lib/stock/esolve-stock-item.js +13 -3
- package/esm2015/lib/stock/esolve-stock-record.js +1 -1
- package/esm2015/lib/stock/esolve-stock.service.js +2 -2
- package/esm2015/public-api.js +6 -1
- package/fesm2015/esolve-ng-esolve-connect.js +257 -214
- package/fesm2015/esolve-ng-esolve-connect.js.map +1 -1
- package/lib/auth/esolve-account.service.d.ts +8 -1
- package/lib/auth/esolve-auth.service.d.ts +3 -1
- package/lib/auth/esolve-registration-data.d.ts +12 -0
- package/lib/auth/esolve-registration-post-response-item.d.ts +6 -0
- package/lib/auth/esolve-registration-result.d.ts +7 -0
- package/lib/auth/esolve-session.service.d.ts +1 -2
- package/lib/cart/esolve-cart-item-record.d.ts +0 -5
- package/lib/cart/esolve-cart-item-response.d.ts +5 -0
- package/lib/cart/esolve-cart.service.d.ts +4 -2
- package/lib/shared/error-handler/esolve-error-handler.service.d.ts +11 -0
- package/lib/shared/error-handler/esolve-http-error.d.ts +6 -0
- package/lib/stock/esolve-stock-item.d.ts +17 -1
- package/lib/stock/esolve-stock-record.d.ts +7 -1
- package/package.json +1 -1
- package/public-api.d.ts +5 -0
|
@@ -4,13 +4,23 @@ import { iif, throwError } from 'rxjs';
|
|
|
4
4
|
import { catchError, map } from 'rxjs/operators';
|
|
5
5
|
import { ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';
|
|
6
6
|
import { EsolveAddress } from './esolve-address';
|
|
7
|
+
import { EsolveRegistrationResult } from './esolve-registration-result';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/common/http";
|
|
10
|
+
import * as i2 from "./esolve-session.service";
|
|
11
|
+
import * as i3 from "../shared/error-handler/esolve-error-handler.service";
|
|
9
12
|
export class EsolveAccountService {
|
|
10
|
-
constructor(config, http) {
|
|
13
|
+
constructor(config, http, sessionService, errorHandler) {
|
|
11
14
|
this.config = config;
|
|
12
15
|
this.http = http;
|
|
16
|
+
this.sessionService = sessionService;
|
|
17
|
+
this.errorHandler = errorHandler;
|
|
13
18
|
this._user_id = 0;
|
|
19
|
+
this.sessionService.session.subscribe((session) => {
|
|
20
|
+
if (session.key !== '') {
|
|
21
|
+
this.user_id = session.id;
|
|
22
|
+
}
|
|
23
|
+
});
|
|
14
24
|
}
|
|
15
25
|
get user_id() {
|
|
16
26
|
return this._user_id;
|
|
@@ -22,15 +32,15 @@ export class EsolveAccountService {
|
|
|
22
32
|
}
|
|
23
33
|
}
|
|
24
34
|
processUserAddress(records) {
|
|
25
|
-
const
|
|
35
|
+
const user_addresses = [];
|
|
26
36
|
if (records && (this._user_id > 0)) {
|
|
27
37
|
for (const record of records) {
|
|
28
38
|
if (+record.userid === this._user_id) {
|
|
29
|
-
|
|
39
|
+
user_addresses.push(new EsolveAddress(+record.id, record.recipient, record.address_type, record.pobox, record.place_name, record.street_number, record.street, record.suburb, record.city, record.province, record.country, record.postal_code, +record.latitude, +record.longitude));
|
|
30
40
|
}
|
|
31
41
|
}
|
|
32
42
|
}
|
|
33
|
-
return
|
|
43
|
+
return user_addresses;
|
|
34
44
|
}
|
|
35
45
|
getAddress() {
|
|
36
46
|
let params = new HttpParams();
|
|
@@ -45,8 +55,46 @@ export class EsolveAccountService {
|
|
|
45
55
|
return throwError(err);
|
|
46
56
|
})), throwError('Log in is required'));
|
|
47
57
|
}
|
|
58
|
+
register(user_registration) {
|
|
59
|
+
const body = {
|
|
60
|
+
user: user_registration
|
|
61
|
+
};
|
|
62
|
+
return this.http.post(`${this.config.api_url}/service/set-registration.php`, body, {
|
|
63
|
+
headers: {
|
|
64
|
+
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'
|
|
65
|
+
},
|
|
66
|
+
params: {
|
|
67
|
+
ws_id: this.config.wsid
|
|
68
|
+
},
|
|
69
|
+
responseType: 'json',
|
|
70
|
+
observe: 'body'
|
|
71
|
+
}).pipe(map(response => {
|
|
72
|
+
if ((response.responses === undefined) ||
|
|
73
|
+
(response.responses.length <= 0)) {
|
|
74
|
+
throw response;
|
|
75
|
+
}
|
|
76
|
+
const registration_response = response.responses[0];
|
|
77
|
+
if ((registration_response.status.state !== 'success') &&
|
|
78
|
+
(registration_response.status.state !== 'warning')) {
|
|
79
|
+
throw registration_response;
|
|
80
|
+
}
|
|
81
|
+
for (const response_log of registration_response.log) {
|
|
82
|
+
if ((response_log.type === 'success') && (response_log.message_code === 'registration_success')) {
|
|
83
|
+
let user_id = 0;
|
|
84
|
+
if (registration_response.auto_login) {
|
|
85
|
+
user_id = registration_response.esolve_id;
|
|
86
|
+
this.sessionService.handleUpdateSession(user_id);
|
|
87
|
+
}
|
|
88
|
+
return new EsolveRegistrationResult(user_id, registration_response.guest, registration_response.authentication_required, registration_response.auto_login);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
throw registration_response;
|
|
92
|
+
}), catchError((errorRes) => {
|
|
93
|
+
return this.errorHandler.handleHttpError('set-registration', errorRes);
|
|
94
|
+
}));
|
|
95
|
+
}
|
|
48
96
|
}
|
|
49
|
-
EsolveAccountService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAccountService, deps: [{ token: ESOLVE_CONNECT_CONFIG }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
97
|
+
EsolveAccountService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAccountService, deps: [{ token: ESOLVE_CONNECT_CONFIG }, { token: i1.HttpClient }, { token: i2.EsolveSessionService }, { token: i3.EsolveErrorHandlerService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
50
98
|
EsolveAccountService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAccountService, providedIn: 'root' });
|
|
51
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAccountService, decorators: [{
|
|
52
100
|
type: Injectable,
|
|
@@ -56,5 +104,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImpor
|
|
|
56
104
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
57
105
|
type: Inject,
|
|
58
106
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
59
|
-
}] }, { type: i1.HttpClient }]; } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWFjY291bnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9lc29sdmUtYWNjb3VudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUU5RCxPQUFPLEVBQUUsR0FBRyxFQUFjLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWpELE9BQU8sRUFBdUIscUJBQXFCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUV0RixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQU1qRCxNQUFNLE9BQU8sb0JBQW9CO0lBZTdCLFlBQzJDLE1BQTJCLEVBQzFELElBQWdCO1FBRGUsV0FBTSxHQUFOLE1BQU0sQ0FBcUI7UUFDMUQsU0FBSSxHQUFKLElBQUksQ0FBWTtRQWhCcEIsYUFBUSxHQUFHLENBQUMsQ0FBQztJQWlCakIsQ0FBQztJQWZMLElBQVcsT0FBTztRQUNkLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBVyxPQUFPLENBQUMsS0FBYTtRQUM1QixLQUFLLEdBQUcsQ0FBQyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVsQyxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssS0FBSyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1NBQ3pCO0lBQ0wsQ0FBQztJQU9PLGtCQUFrQixDQUFDLE9BQThCO1FBQ3JELE1BQU0sYUFBYSxHQUFvQixFQUFFLENBQUM7UUFFMUMsSUFBSSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxFQUFFO1lBQ2hDLEtBQUssTUFBTSxNQUFNLElBQUksT0FBTyxFQUFFO2dCQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsUUFBUSxFQUFFO29CQUNsQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksYUFBYSxDQUNoQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQ1YsTUFBTSxDQUFDLFNBQVMsRUFDaEIsTUFBTSxDQUFDLFlBQVksRUFDbkIsTUFBTSxDQUFDLEtBQUssRUFDWixNQUFNLENBQUMsVUFBVSxFQUNqQixNQUFNLENBQUMsYUFBYSxFQUNwQixNQUFNLENBQUMsTUFBTSxFQUNiLE1BQU0sQ0FBQyxNQUFNLEVBQ2IsTUFBTSxDQUFDLElBQUksRUFDWCxNQUFNLENBQUMsUUFBUSxFQUNmLE1BQU0sQ0FBQyxPQUFPLEVBQ2QsTUFBTSxDQUFDLFdBQVcsRUFDbEIsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUNoQixDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQ3BCLENBQUMsQ0FBQztpQkFDTjthQUNKO1NBQ0o7UUFFRCxPQUFPLGFBQWEsQ0FBQztJQUN6QixDQUFDO0lBRU0sVUFBVTtRQUNiLElBQUksTUFBTSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDOUIsTUFBTSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0MsTUFBTSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUV4RCxPQUFPLEdBQUcsQ0FDTixHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLEVBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNULEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLDRCQUE0QixFQUNsRCxFQUFFLE1BQU0sRUFBRSxDQUNiLENBQUMsSUFBSSxDQUNGLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNYLElBQUksUUFBUSxDQUFDLE9BQU8sS0FBSyxTQUFTLEVBQUU7Z0JBQ2hDLE1BQU0sUUFBUSxDQUFDO2FBQ2xCO1lBRUQsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3JELENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ2YsT0FBTyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQ0wsRUFDRCxVQUFVLENBQUMsb0JBQW9CLENBQUMsQ0FDbkMsQ0FBQztJQUNOLENBQUM7O2lIQXpFUSxvQkFBb0Isa0JBZ0JqQixxQkFBcUI7cUhBaEJ4QixvQkFBb0IsY0FGbkIsTUFBTTsyRkFFUCxvQkFBb0I7a0JBSGhDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFpQlEsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cFBhcmFtcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuXHJcbmltcG9ydCB7IGlpZiwgT2JzZXJ2YWJsZSwgdGhyb3dFcnJvciB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yLCBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG5pbXBvcnQgeyBFc29sdmVDb25uZWN0Q29uZmlnLCBFU09MVkVfQ09OTkVDVF9DT05GSUcgfSBmcm9tICcuLi9lc29sdmUtY29ubmVjdC5jb25maWcnO1xyXG5pbXBvcnQgeyBFc29sdmVHZXRSZXNwb25zZSB9IGZyb20gJy4uL3NoYXJlZC9lc29sdmUtcmVzcG9uc2UnO1xyXG5pbXBvcnQgeyBFc29sdmVBZGRyZXNzIH0gZnJvbSAnLi9lc29sdmUtYWRkcmVzcyc7XHJcbmltcG9ydCB7IEVzb2x2ZUFkZHJlc3NSZWNvcmQgfSBmcm9tICcuL2Vzb2x2ZS1hZGRyZXNzLXJlY29yZCc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFc29sdmVBY2NvdW50U2VydmljZSB7XHJcbiAgICBwcml2YXRlIF91c2VyX2lkID0gMDtcclxuXHJcbiAgICBwdWJsaWMgZ2V0IHVzZXJfaWQoKTogbnVtYmVyIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXNlcl9pZDtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgc2V0IHVzZXJfaWQodmFsdWU6IG51bWJlcikge1xyXG4gICAgICAgIHZhbHVlID0gKCh2YWx1ZSA+IDApID8gdmFsdWUgOiAwKTtcclxuXHJcbiAgICAgICAgaWYgKHRoaXMuX3VzZXJfaWQgIT09IHZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX3VzZXJfaWQgPSB2YWx1ZTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgQEluamVjdChFU09MVkVfQ09OTkVDVF9DT05GSUcpIHByaXZhdGUgY29uZmlnOiBFc29sdmVDb25uZWN0Q29uZmlnLFxyXG4gICAgICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudFxyXG4gICAgKSB7IH1cclxuXHJcbiAgICBwcml2YXRlIHByb2Nlc3NVc2VyQWRkcmVzcyhyZWNvcmRzOiBFc29sdmVBZGRyZXNzUmVjb3JkW10pOiBFc29sdmVBZGRyZXNzW10ge1xyXG4gICAgICAgIGNvbnN0IHVzZXJfYWRkZXNzZXM6IEVzb2x2ZUFkZHJlc3NbXSA9IFtdO1xyXG5cclxuICAgICAgICBpZiAocmVjb3JkcyAmJiAodGhpcy5fdXNlcl9pZCA+IDApKSB7XHJcbiAgICAgICAgICAgIGZvciAoY29uc3QgcmVjb3JkIG9mIHJlY29yZHMpIHtcclxuICAgICAgICAgICAgICAgIGlmICgrcmVjb3JkLnVzZXJpZCA9PT0gdGhpcy5fdXNlcl9pZCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHVzZXJfYWRkZXNzZXMucHVzaChuZXcgRXNvbHZlQWRkcmVzcyhcclxuICAgICAgICAgICAgICAgICAgICAgICAgK3JlY29yZC5pZCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVjb3JkLnJlY2lwaWVudCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVjb3JkLmFkZHJlc3NfdHlwZSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVjb3JkLnBvYm94LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICByZWNvcmQucGxhY2VfbmFtZSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVjb3JkLnN0cmVldF9udW1iZXIsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlY29yZC5zdHJlZXQsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlY29yZC5zdWJ1cmIsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlY29yZC5jaXR5LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICByZWNvcmQucHJvdmluY2UsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlY29yZC5jb3VudHJ5LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICByZWNvcmQucG9zdGFsX2NvZGUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICtyZWNvcmQubGF0aXR1ZGUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICtyZWNvcmQubG9uZ2l0dWRlXHJcbiAgICAgICAgICAgICAgICAgICAgKSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiB1c2VyX2FkZGVzc2VzO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBnZXRBZGRyZXNzKCk6IE9ic2VydmFibGU8RXNvbHZlQWRkcmVzc1tdPiB7XHJcbiAgICAgICAgbGV0IHBhcmFtcyA9IG5ldyBIdHRwUGFyYW1zKCk7XHJcbiAgICAgICAgcGFyYW1zID0gcGFyYW1zLnNldCgnd3NfaWQnLCB0aGlzLmNvbmZpZy53c2lkKTtcclxuICAgICAgICBwYXJhbXMgPSBwYXJhbXMuc2V0KCd1c2VyX2lkJywgdGhpcy51c2VyX2lkLnRvU3RyaW5nKCkpO1xyXG5cclxuICAgICAgICByZXR1cm4gaWlmKFxyXG4gICAgICAgICAgICAoKSA9PiAodGhpcy51c2VyX2lkID4gMCksXHJcbiAgICAgICAgICAgIHRoaXMuaHR0cC5nZXQ8RXNvbHZlR2V0UmVzcG9uc2U8RXNvbHZlQWRkcmVzc1JlY29yZFtdPj4oXHJcbiAgICAgICAgICAgICAgICBgJHt0aGlzLmNvbmZpZy5hcGlfdXJsfS9zZXJ2aWNlL2dldC1hZGRyZXNzZXMucGhwYCxcclxuICAgICAgICAgICAgICAgIHsgcGFyYW1zIH1cclxuICAgICAgICAgICAgKS5waXBlKFxyXG4gICAgICAgICAgICAgICAgbWFwKHJlc3BvbnNlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBpZiAocmVzcG9uc2UucmVjb3JkcyA9PT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHRocm93IHJlc3BvbnNlO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuXHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMucHJvY2Vzc1VzZXJBZGRyZXNzKHJlc3BvbnNlLnJlY29yZHMpO1xyXG4gICAgICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gdGhyb3dFcnJvcihlcnIpO1xyXG4gICAgICAgICAgICAgICAgfSlcclxuICAgICAgICAgICAgKSxcclxuICAgICAgICAgICAgdGhyb3dFcnJvcignTG9nIGluIGlzIHJlcXVpcmVkJylcclxuICAgICAgICApO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
107
|
+
}] }, { type: i1.HttpClient }, { type: i2.EsolveSessionService }, { type: i3.EsolveErrorHandlerService }]; } });
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-account.service.js","sourceRoot":"","sources":["../../../../../projects/ng-esolve-connect/src/lib/auth/esolve-account.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { HttpClient, HttpErrorResponse, HttpParams } from '@angular/common/http';\r\n\r\nimport { iif, Observable, throwError } from 'rxjs';\r\nimport { catchError, map } from 'rxjs/operators';\r\n\r\nimport { EsolveConnectConfig, ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';\r\nimport { EsolveAddress } from './esolve-address';\r\nimport { EsolveAddressRecord } from './esolve-address-record';\r\nimport { EsolveRegistrationData } from './esolve-registration-data';\r\nimport { EsolveSessionService } from './esolve-session.service';\r\nimport { EsolveRegistrationResult } from './esolve-registration-result';\r\nimport { EsolveRegistrationPostResponseItem } from './esolve-registration-post-response-item';\r\nimport { EsolveGetResponse, EsolveSetResponse } from '../shared/esolve-response';\r\nimport { EsolveErrorHandlerService } from '../shared/error-handler/esolve-error-handler.service';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class EsolveAccountService {\r\n    private _user_id = 0;\r\n\r\n    public get user_id(): number {\r\n        return this._user_id;\r\n    }\r\n\r\n    public set user_id(value: number) {\r\n        value = ((value > 0) ? value : 0);\r\n\r\n        if (this._user_id !== value) {\r\n            this._user_id = value;\r\n        }\r\n    }\r\n\r\n    constructor(\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig,\r\n        private http: HttpClient,\r\n        private sessionService: EsolveSessionService,\r\n        private errorHandler: EsolveErrorHandlerService\r\n    ) {\r\n        this.sessionService.session.subscribe((session) => {\r\n            if (session.key !== '') {\r\n                this.user_id = session.id;\r\n            }\r\n        });\r\n    }\r\n\r\n    private processUserAddress(records: EsolveAddressRecord[]): EsolveAddress[] {\r\n        const user_addresses: EsolveAddress[] = [];\r\n\r\n        if (records && (this._user_id > 0)) {\r\n            for (const record of records) {\r\n                if (+record.userid === this._user_id) {\r\n                    user_addresses.push(new EsolveAddress(\r\n                        +record.id,\r\n                        record.recipient,\r\n                        record.address_type,\r\n                        record.pobox,\r\n                        record.place_name,\r\n                        record.street_number,\r\n                        record.street,\r\n                        record.suburb,\r\n                        record.city,\r\n                        record.province,\r\n                        record.country,\r\n                        record.postal_code,\r\n                        +record.latitude,\r\n                        +record.longitude\r\n                    ));\r\n                }\r\n            }\r\n        }\r\n\r\n        return user_addresses;\r\n    }\r\n\r\n    public getAddress(): Observable<EsolveAddress[]> {\r\n        let params = new HttpParams();\r\n        params = params.set('ws_id', this.config.wsid);\r\n        params = params.set('user_id', this.user_id.toString());\r\n\r\n        return iif(\r\n            () => (this.user_id > 0),\r\n            this.http.get<EsolveGetResponse<EsolveAddressRecord[]>>(\r\n                `${this.config.api_url}/service/get-addresses.php`,\r\n                { params }\r\n            ).pipe(\r\n                map(response => {\r\n                    if (response.records === undefined) {\r\n                        throw response;\r\n                    }\r\n\r\n                    return this.processUserAddress(response.records);\r\n                }),\r\n                catchError((err) => {\r\n                    return throwError(err);\r\n                })\r\n            ),\r\n            throwError('Log in is required')\r\n        );\r\n    }\r\n\r\n    public register(user_registration: EsolveRegistrationData): Observable<EsolveRegistrationResult> {\r\n        const body = {\r\n            user: user_registration\r\n        };\r\n\r\n        return this.http.post<EsolveSetResponse<EsolveRegistrationPostResponseItem>>(\r\n            `${this.config.api_url}/service/set-registration.php`,\r\n            body,\r\n            {\r\n                headers: {\r\n                    'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'\r\n                },\r\n                params: {\r\n                    ws_id: this.config.wsid\r\n                },\r\n                responseType: 'json',\r\n                observe: 'body'\r\n            }\r\n        ).pipe(\r\n            map(response => {\r\n                if (\r\n                    (response.responses === undefined) ||\r\n                    (response.responses.length <= 0)\r\n                ) {\r\n                    throw response;\r\n                }\r\n\r\n                const registration_response = response.responses[0];\r\n\r\n                if (\r\n                    (registration_response.status.state !== 'success') &&\r\n                    (registration_response.status.state !== 'warning')\r\n                ) {\r\n                    throw registration_response;\r\n                }\r\n\r\n                for (const response_log of registration_response.log) {\r\n                    if ((response_log.type === 'success') && (response_log.message_code === 'registration_success')) {\r\n                        let user_id = 0;\r\n\r\n                        if (registration_response.auto_login) {\r\n                            user_id = registration_response.esolve_id as number;\r\n\r\n                            this.sessionService.handleUpdateSession(user_id);\r\n                        }\r\n\r\n                        return new EsolveRegistrationResult(\r\n                            user_id,\r\n                            registration_response.guest,\r\n                            registration_response.authentication_required,\r\n                            registration_response.auto_login\r\n                        );\r\n                    }\r\n                }\r\n\r\n                throw registration_response;\r\n            }),\r\n            catchError((errorRes: HttpErrorResponse | any) => {\r\n                return this.errorHandler.handleHttpError('set-registration', errorRes);\r\n            })\r\n        );\r\n\r\n    }\r\n}\r\n"]}
|
|
@@ -11,7 +11,7 @@ export class EsolveAuthInterceptorService {
|
|
|
11
11
|
intercept(req, next) {
|
|
12
12
|
if (req.url.startsWith(`${this.config.api_url}/service/`)) {
|
|
13
13
|
const service_identifier = req.url.replace(`${this.config.api_url}/service/`, '');
|
|
14
|
-
const
|
|
14
|
+
const old_params_keys = req.params.keys();
|
|
15
15
|
const modified_url = req.url;
|
|
16
16
|
let params = new HttpParams();
|
|
17
17
|
const session = this.session.currentSession;
|
|
@@ -20,7 +20,7 @@ export class EsolveAuthInterceptorService {
|
|
|
20
20
|
params = params.set('key', session.key);
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
|
|
23
|
+
old_params_keys.forEach(key => {
|
|
24
24
|
params = params.set(key, req.params.get(key) || '');
|
|
25
25
|
});
|
|
26
26
|
const modified_req = req.clone({
|
|
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImpor
|
|
|
40
40
|
type: Inject,
|
|
41
41
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
42
42
|
}] }, { type: i1.EsolveSessionService }]; } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWF1dGgtaW50ZXJjZXB0b3Iuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvYXV0aC9lc29sdmUtYXV0aC1pbnRlcmNlcHRvci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFJSCxVQUFVLEVBRWIsTUFBTSxzQkFBc0IsQ0FBQztBQUk5QixPQUFPLEVBQXVCLHFCQUFxQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7OztBQUl0RixNQUFNLE9BQU8sNEJBQTRCO0lBQ3JDLFlBQzJDLE1BQTJCLEVBQzFELE9BQTZCO1FBREUsV0FBTSxHQUFOLE1BQU0sQ0FBcUI7UUFDMUQsWUFBTyxHQUFQLE9BQU8sQ0FBc0I7SUFDckMsQ0FBQztJQUVMLFNBQVMsQ0FBQyxHQUFxQixFQUFFLElBQWlCO1FBQzlDLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sV0FBVyxDQUFDLEVBQUU7WUFDdkQsTUFBTSxrQkFBa0IsR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxXQUFXLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFFbEYsTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUMxQyxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDO1lBQzdCLElBQUksTUFBTSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7WUFFOUIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUM7WUFFNUMsSUFBSSxPQUFPLENBQUMsS0FBSyxFQUFFO2dCQUNmLElBQUksa0JBQWtCLEtBQUssc0JBQXNCLEVBQUU7b0JBQy9DLE1BQU0sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQzNDO2FBQ0o7WUFFRCxlQUFlLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUMxQixNQUFNLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7WUFDeEQsQ0FBQyxDQUFDLENBQUM7WUFFSCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO2dCQUMzQixHQUFHLEVBQUUsWUFBWTtnQkFDakIsTUFBTTthQUNULENBQUMsQ0FBQztZQUVILE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUNwQztRQUVELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM1QixDQUFDOzt5SEFuQ1EsNEJBQTRCLGtCQUV6QixxQkFBcUI7NkhBRnhCLDRCQUE0QjsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVOzswQkFHRixNQUFNOzJCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gICAgSHR0cEludGVyY2VwdG9yLFxyXG4gICAgSHR0cFJlcXVlc3QsXHJcbiAgICBIdHRwSGFuZGxlcixcclxuICAgIEh0dHBQYXJhbXMsXHJcbiAgICBIdHRwRXZlbnRcclxufSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcblxyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5pbXBvcnQgeyBFc29sdmVDb25uZWN0Q29uZmlnLCBFU09MVkVfQ09OTkVDVF9DT05GSUcgfSBmcm9tICcuLi9lc29sdmUtY29ubmVjdC5jb25maWcnO1xyXG5pbXBvcnQgeyBFc29sdmVTZXNzaW9uU2VydmljZSB9IGZyb20gJy4vZXNvbHZlLXNlc3Npb24uc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBFc29sdmVBdXRoSW50ZXJjZXB0b3JTZXJ2aWNlIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIEBJbmplY3QoRVNPTFZFX0NPTk5FQ1RfQ09ORklHKSBwcml2YXRlIGNvbmZpZzogRXNvbHZlQ29ubmVjdENvbmZpZyxcclxuICAgICAgICBwcml2YXRlIHNlc3Npb246IEVzb2x2ZVNlc3Npb25TZXJ2aWNlXHJcbiAgICApIHsgfVxyXG5cclxuICAgIGludGVyY2VwdChyZXE6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgICAgIGlmIChyZXEudXJsLnN0YXJ0c1dpdGgoYCR7dGhpcy5jb25maWcuYXBpX3VybH0vc2VydmljZS9gKSkge1xyXG4gICAgICAgICAgICBjb25zdCBzZXJ2aWNlX2lkZW50aWZpZXIgPSByZXEudXJsLnJlcGxhY2UoYCR7dGhpcy5jb25maWcuYXBpX3VybH0vc2VydmljZS9gLCAnJyk7XHJcblxyXG4gICAgICAgICAgICBjb25zdCBvbGRfcGFyYW1zX2tleXMgPSByZXEucGFyYW1zLmtleXMoKTtcclxuICAgICAgICAgICAgY29uc3QgbW9kaWZpZWRfdXJsID0gcmVxLnVybDtcclxuICAgICAgICAgICAgbGV0IHBhcmFtcyA9IG5ldyBIdHRwUGFyYW1zKCk7XHJcblxyXG4gICAgICAgICAgICBjb25zdCBzZXNzaW9uID0gdGhpcy5zZXNzaW9uLmN1cnJlbnRTZXNzaW9uO1xyXG5cclxuICAgICAgICAgICAgaWYgKHNlc3Npb24udmFsaWQpIHtcclxuICAgICAgICAgICAgICAgIGlmIChzZXJ2aWNlX2lkZW50aWZpZXIgIT09ICdnZXQtYWNjZXNzLXRva2VuLnBocCcpIHtcclxuICAgICAgICAgICAgICAgICAgICBwYXJhbXMgPSBwYXJhbXMuc2V0KCdrZXknLCBzZXNzaW9uLmtleSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuXHJcbiAgICAgICAgICAgIG9sZF9wYXJhbXNfa2V5cy5mb3JFYWNoKGtleSA9PiB7XHJcbiAgICAgICAgICAgICAgICBwYXJhbXMgPSBwYXJhbXMuc2V0KGtleSwgcmVxLnBhcmFtcy5nZXQoa2V5KSB8fCAnJyk7XHJcbiAgICAgICAgICAgIH0pO1xyXG5cclxuICAgICAgICAgICAgY29uc3QgbW9kaWZpZWRfcmVxID0gcmVxLmNsb25lKHtcclxuICAgICAgICAgICAgICAgIHVybDogbW9kaWZpZWRfdXJsLFxyXG4gICAgICAgICAgICAgICAgcGFyYW1zXHJcbiAgICAgICAgICAgIH0pO1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKG1vZGlmaWVkX3JlcSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
import { Inject, Injectable } from '@angular/core';
|
|
2
|
-
import { HttpParams,
|
|
2
|
+
import { HttpParams, HttpHeaders } from '@angular/common/http';
|
|
3
3
|
import { throwError } from 'rxjs';
|
|
4
4
|
import { tap, catchError, map } from 'rxjs/operators';
|
|
5
5
|
import { ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/common/http";
|
|
8
8
|
import * as i2 from "./esolve-session.service";
|
|
9
|
+
import * as i3 from "../shared/error-handler/esolve-error-handler.service";
|
|
9
10
|
export class EsolveAuthService {
|
|
10
|
-
constructor(config, http, session) {
|
|
11
|
+
constructor(config, http, session, errorHandler) {
|
|
11
12
|
this.config = config;
|
|
12
13
|
this.http = http;
|
|
13
14
|
this.session = session;
|
|
15
|
+
this.errorHandler = errorHandler;
|
|
14
16
|
}
|
|
15
17
|
checkAccessToken(session) {
|
|
16
18
|
var _a;
|
|
@@ -28,7 +30,9 @@ export class EsolveAuthService {
|
|
|
28
30
|
'Accept-Language': '*'
|
|
29
31
|
})
|
|
30
32
|
}).pipe(map(responseData => {
|
|
31
|
-
if ((responseData.type === 'error') ||
|
|
33
|
+
if ((responseData.type === 'error') ||
|
|
34
|
+
(responseData.type === 'exception') ||
|
|
35
|
+
(!responseData.additional_data.key_okay)) {
|
|
32
36
|
throw responseData;
|
|
33
37
|
}
|
|
34
38
|
responseData.additional_data.key = token;
|
|
@@ -53,7 +57,8 @@ export class EsolveAuthService {
|
|
|
53
57
|
'Accept-Language': '*'
|
|
54
58
|
})
|
|
55
59
|
}).pipe(tap(responseData => {
|
|
56
|
-
if ((responseData.type === 'error') ||
|
|
60
|
+
if ((responseData.type === 'error') ||
|
|
61
|
+
(responseData.type === 'exception')) {
|
|
57
62
|
throw responseData;
|
|
58
63
|
}
|
|
59
64
|
}), catchError(this.handleError), tap(responseData => {
|
|
@@ -84,11 +89,13 @@ export class EsolveAuthService {
|
|
|
84
89
|
responseType: 'json',
|
|
85
90
|
observe: 'body'
|
|
86
91
|
}).pipe(map(response => {
|
|
87
|
-
if ((response.responses === undefined) ||
|
|
92
|
+
if ((response.responses === undefined) ||
|
|
93
|
+
(response.responses.length <= 0)) {
|
|
88
94
|
throw response;
|
|
89
95
|
}
|
|
90
96
|
const login_response = response.responses[0];
|
|
91
|
-
if ((login_response.status.state !== 'success') &&
|
|
97
|
+
if ((login_response.status.state !== 'success') &&
|
|
98
|
+
(login_response.status.state !== 'warning')) {
|
|
92
99
|
throw login_response;
|
|
93
100
|
}
|
|
94
101
|
for (const response_log of login_response.log) {
|
|
@@ -99,54 +106,7 @@ export class EsolveAuthService {
|
|
|
99
106
|
}
|
|
100
107
|
throw login_response;
|
|
101
108
|
}), catchError((errorRes) => {
|
|
102
|
-
|
|
103
|
-
const exception_type = exception.additional_data.exception_type;
|
|
104
|
-
const error = {
|
|
105
|
-
type: 'exception',
|
|
106
|
-
message: exception.message || '',
|
|
107
|
-
error_code: exception_type || 'unknown'
|
|
108
|
-
};
|
|
109
|
-
return error;
|
|
110
|
-
};
|
|
111
|
-
const parseLoginErrors = (login_response) => {
|
|
112
|
-
const error = {
|
|
113
|
-
type: 'error',
|
|
114
|
-
message: 'Unknown error has occured',
|
|
115
|
-
error_code: 'unknown'
|
|
116
|
-
};
|
|
117
|
-
if ((login_response.status.state === 'none') && (login_response.log.length > 0)) {
|
|
118
|
-
error.error_code = 'no_response';
|
|
119
|
-
error.message = 'Response was provided';
|
|
120
|
-
}
|
|
121
|
-
else if (login_response.status.state === 'error') {
|
|
122
|
-
const login_error_log = login_response.log[0];
|
|
123
|
-
error.error_code = login_error_log.message_code;
|
|
124
|
-
error.message = login_error_log.message;
|
|
125
|
-
}
|
|
126
|
-
return error;
|
|
127
|
-
};
|
|
128
|
-
if (errorRes instanceof HttpErrorResponse) {
|
|
129
|
-
if (errorRes.status === 500) {
|
|
130
|
-
const server_error = errorRes.error;
|
|
131
|
-
if ((server_error.service_type === 'set-login') ||
|
|
132
|
-
(server_error.type !== undefined) ||
|
|
133
|
-
(server_error.message !== undefined) ||
|
|
134
|
-
(server_error.additional_data !== undefined)) {
|
|
135
|
-
return throwError(parseException(server_error));
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
else {
|
|
140
|
-
if (errorRes.type !== undefined) {
|
|
141
|
-
if (errorRes.type === 'exception') {
|
|
142
|
-
return throwError(parseException(errorRes));
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
else if (errorRes.transaction_type === 'Login') {
|
|
146
|
-
return throwError(parseLoginErrors(errorRes));
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return throwError(errorRes);
|
|
109
|
+
return this.errorHandler.handleHttpError('set-login', errorRes);
|
|
150
110
|
}));
|
|
151
111
|
}
|
|
152
112
|
logout() {
|
|
@@ -155,6 +115,7 @@ export class EsolveAuthService {
|
|
|
155
115
|
console.log(error);
|
|
156
116
|
});
|
|
157
117
|
}
|
|
118
|
+
// Handlers
|
|
158
119
|
handleExpiration() {
|
|
159
120
|
return (session) => {
|
|
160
121
|
this.checkAccessToken(session).then((response) => {
|
|
@@ -174,7 +135,9 @@ export class EsolveAuthService {
|
|
|
174
135
|
message: 'An unknown error occurred',
|
|
175
136
|
data: {}
|
|
176
137
|
};
|
|
177
|
-
if ((!errorRes.type) ||
|
|
138
|
+
if ((!errorRes.type) ||
|
|
139
|
+
(!errorRes.service_type) ||
|
|
140
|
+
(!errorRes.message)) {
|
|
178
141
|
return throwError(error);
|
|
179
142
|
}
|
|
180
143
|
if (errorRes.message.trim() !== '') {
|
|
@@ -186,7 +149,7 @@ export class EsolveAuthService {
|
|
|
186
149
|
return throwError(error);
|
|
187
150
|
}
|
|
188
151
|
}
|
|
189
|
-
EsolveAuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAuthService, deps: [{ token: ESOLVE_CONNECT_CONFIG }, { token: i1.HttpClient }, { token: i2.EsolveSessionService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
152
|
+
EsolveAuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAuthService, deps: [{ token: ESOLVE_CONNECT_CONFIG }, { token: i1.HttpClient }, { token: i2.EsolveSessionService }, { token: i3.EsolveErrorHandlerService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
190
153
|
EsolveAuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAuthService, providedIn: 'root' });
|
|
191
154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveAuthService, decorators: [{
|
|
192
155
|
type: Injectable,
|
|
@@ -196,5 +159,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImpor
|
|
|
196
159
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
197
160
|
type: Inject,
|
|
198
161
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
199
|
-
}] }, { type: i1.HttpClient }, { type: i2.EsolveSessionService }]; } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-auth.service.js","sourceRoot":"","sources":["../../../../../projects/ng-esolve-connect/src/lib/auth/esolve-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport {\r\n    HttpClient,\r\n    HttpParams,\r\n    HttpErrorResponse,\r\n    HttpHeaders\r\n} from '@angular/common/http';\r\n\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { tap, catchError, map } from 'rxjs/operators';\r\n\r\nimport { EsolveConnectConfig, ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';\r\nimport { EsolveSetResponse, EsolvePostResponseItem } from '../shared/esolve-response';\r\nimport { EsolveSessionService } from './esolve-session.service';\r\nimport { EsolveSession } from './esolve-session';\r\n\r\ninterface EsolveAuthResponseData {\r\n    service_type: string;\r\n    type: string;\r\n    message: string;\r\n    additional_data: {\r\n        expires: number,\r\n        expiry_time: number,\r\n        user_id: number,\r\n        key?: string,\r\n        key_okay?: boolean,\r\n    };\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class EsolveAuthService {\r\n    constructor(\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig,\r\n        private http: HttpClient,\r\n        private session: EsolveSessionService\r\n    ) { }\r\n\r\n    private checkAccessToken(session?: EsolveSession): Promise<EsolveAuthResponseData> {\r\n        session = session || this.session.currentSession;\r\n\r\n        const token = session?.key ?? '';\r\n\r\n        const params = new HttpParams({\r\n            fromObject: {\r\n                key: token,\r\n                ws_id: this.config.wsid\r\n            }\r\n        });\r\n\r\n        return this.http.get<EsolveAuthResponseData>(\r\n            `${this.config.api_url}/service/get-access-token.php`,\r\n            {\r\n                params,\r\n                headers: new HttpHeaders({\r\n                    'Accept-Language': '*'\r\n                })\r\n            }\r\n        ).pipe(\r\n            map(responseData => {\r\n                if ((responseData.type === 'error') || (responseData.type === 'exception') || (!responseData.additional_data.key_okay)) {\r\n                    throw responseData;\r\n                }\r\n\r\n                responseData.additional_data.key = token;\r\n\r\n                return responseData;\r\n            })\r\n        ).toPromise();\r\n    }\r\n\r\n    getAccessToken(email: string, password: string, anonymous: boolean = false): Observable<EsolveAuthResponseData> {\r\n        let params = new HttpParams();\r\n\r\n        if (anonymous) {\r\n            params = params.set('anonymous', '1');\r\n        }\r\n\r\n        if (email !== '') {\r\n            params = params.set('email', email);\r\n        }\r\n\r\n        if (password !== '') {\r\n            params = params.set('password', password);\r\n        }\r\n\r\n        params = params.set('ws_id', this.config.wsid);\r\n\r\n        return this.http.get<EsolveAuthResponseData>(\r\n            `${this.config.api_url}/service/get-access-token.php`,\r\n            {\r\n                params,\r\n                headers: new HttpHeaders({\r\n                    'Accept-Language': '*'\r\n                })\r\n            }\r\n        ).pipe(\r\n            tap(responseData => {\r\n                if ((responseData.type === 'error') || (responseData.type === 'exception')) {\r\n                    throw responseData;\r\n                }\r\n            }),\r\n            catchError(this.handleError),\r\n            tap(responseData => {\r\n                this.handleAuthentication(responseData);\r\n            })\r\n        );\r\n    }\r\n\r\n    autoLogin(): void {\r\n        this.session.restore(\r\n            this.handleExpiration(),\r\n            () => {\r\n                this.getAccessToken('', '', true).toPromise().then(\r\n                    _ => { },\r\n                    error => {\r\n                        console.log(error);\r\n                    }\r\n                );\r\n            }\r\n        );\r\n    }\r\n\r\n    login(email: string, password: string): Observable<number> {\r\n        const body = {\r\n            login: {\r\n                email,\r\n                password\r\n            }\r\n        };\r\n\r\n        return this.http.post<EsolveSetResponse<EsolvePostResponseItem>>(\r\n            `${this.config.api_url}/service/set-login.php`,\r\n            body,\r\n            {\r\n                headers: {\r\n                    'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'\r\n                },\r\n                params: {\r\n                    ws_id: this.config.wsid\r\n                },\r\n                responseType: 'json',\r\n                observe: 'body'\r\n            }\r\n        ).pipe(\r\n            map(response => {\r\n                if ((response.responses === undefined) || (response.responses.length <= 0)) {\r\n                    throw response;\r\n                }\r\n\r\n                const login_response = response.responses[0];\r\n\r\n                if ((login_response.status.state !== 'success') && (login_response.status.state !== 'warning')) {\r\n                    throw login_response;\r\n                }\r\n\r\n                for (const response_log of login_response.log) {\r\n                    if ((response_log.type === 'success') && (response_log.message_code === 'login_success')) {\r\n                        this.session.handleUpdateSession(login_response.esolve_id as number);\r\n\r\n                        return login_response.esolve_id as number;\r\n                    }\r\n                }\r\n\r\n                throw login_response;\r\n            }),\r\n            catchError((errorRes) => {\r\n                const parseException = (exception: EsolveSetResponse) => {\r\n                    const exception_type = exception.additional_data.exception_type;\r\n                    const error = {\r\n                        type: 'exception',\r\n                        message: exception.message || '',\r\n                        error_code: exception_type || 'unknown'\r\n                    };\r\n\r\n                    return error;\r\n                };\r\n\r\n                const parseLoginErrors = (login_response: EsolvePostResponseItem) => {\r\n                    const error = {\r\n                        type: 'error',\r\n                        message: 'Unknown error has occured',\r\n                        error_code: 'unknown'\r\n                    };\r\n\r\n                    if ((login_response.status.state === 'none') && (login_response.log.length > 0)) {\r\n                        error.error_code = 'no_response';\r\n                        error.message = 'Response was provided';\r\n                    } else if (login_response.status.state === 'error') {\r\n                        const login_error_log = login_response.log[0];\r\n\r\n                        error.error_code = login_error_log.message_code;\r\n                        error.message = login_error_log.message;\r\n                    }\r\n\r\n                    return error;\r\n                };\r\n\r\n                if (errorRes instanceof HttpErrorResponse) {\r\n                    if (errorRes.status === 500) {\r\n                        const server_error = errorRes.error;\r\n\r\n                        if (\r\n                            (server_error.service_type === 'set-login') ||\r\n                            (server_error.type !== undefined) ||\r\n                            (server_error.message !== undefined) ||\r\n                            (server_error.additional_data !== undefined)\r\n                        ) {\r\n                            return throwError(parseException(server_error));\r\n                        }\r\n                    }\r\n                } else {\r\n                    if (errorRes.type !== undefined) {\r\n                        if (errorRes.type === 'exception') {\r\n                            return throwError(parseException(errorRes));\r\n                        }\r\n                    } else if (errorRes.transaction_type === 'Login') {\r\n                        return throwError(parseLoginErrors(errorRes));\r\n                    }\r\n                }\r\n\r\n                return throwError(errorRes);\r\n            })\r\n        );\r\n    }\r\n\r\n    logout(): void {\r\n        this.session.clearTimer();\r\n        this.getAccessToken('', '', true).toPromise().then(\r\n            _ => { },\r\n            error => {\r\n                console.log(error);\r\n            }\r\n        );\r\n    }\r\n\r\n    private handleExpiration(): (session?: EsolveSession) => void {\r\n        return (session?: EsolveSession) => {\r\n            this.checkAccessToken(session).then(\r\n                (response) => {\r\n                    this.handleAuthentication(response);\r\n                },\r\n                () => {\r\n                    this.logout();\r\n                }\r\n            );\r\n        };\r\n    }\r\n\r\n    private handleAuthentication(responseData: EsolveAuthResponseData): void {\r\n        if (responseData.additional_data.key) {\r\n            this.session.handleSession(\r\n                responseData.additional_data.user_id,\r\n                responseData.additional_data.key,\r\n                +responseData.additional_data.expiry_time,\r\n                +responseData.additional_data.expires,\r\n                this.handleExpiration()\r\n            );\r\n        }\r\n    }\r\n\r\n    private handleError(errorRes: EsolveAuthResponseData): Observable<never> {\r\n        const error = {\r\n            message: 'An unknown error occurred',\r\n            data: {}\r\n        };\r\n\r\n        if ((!errorRes.type) || (!errorRes.service_type) || (!errorRes.message)) {\r\n            return throwError(error);\r\n        }\r\n\r\n        if (errorRes.message.trim() !== '') {\r\n            error.message = errorRes.message;\r\n        }\r\n\r\n        if (errorRes.additional_data) {\r\n            error.data = errorRes.additional_data;\r\n        }\r\n\r\n        return throwError(error);\r\n    }\r\n}\r\n"]}
|
|
162
|
+
}] }, { type: i1.HttpClient }, { type: i2.EsolveSessionService }, { type: i3.EsolveErrorHandlerService }]; } });
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-auth.service.js","sourceRoot":"","sources":["../../../../../projects/ng-esolve-connect/src/lib/auth/esolve-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport {\r\n    HttpClient,\r\n    HttpParams,\r\n    HttpErrorResponse,\r\n    HttpHeaders\r\n} from '@angular/common/http';\r\n\r\nimport { Observable, throwError } from 'rxjs';\r\nimport { tap, catchError, map } from 'rxjs/operators';\r\n\r\nimport { EsolveConnectConfig, ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';\r\nimport { EsolveSetResponse, EsolvePostResponseItem } from '../shared/esolve-response';\r\nimport { EsolveSessionService } from './esolve-session.service';\r\nimport { EsolveSession } from './esolve-session';\r\nimport { EsolveErrorHandlerService } from '../shared/error-handler/esolve-error-handler.service';\r\n\r\ninterface EsolveAuthResponseData {\r\n    service_type: string;\r\n    type: string;\r\n    message: string;\r\n    additional_data: {\r\n        expires: number,\r\n        expiry_time: number,\r\n        user_id: number,\r\n        key?: string,\r\n        key_okay?: boolean,\r\n    };\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class EsolveAuthService {\r\n    constructor(\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig,\r\n        private http: HttpClient,\r\n        private session: EsolveSessionService,\r\n        private errorHandler: EsolveErrorHandlerService\r\n    ) { }\r\n\r\n    private checkAccessToken(session?: EsolveSession): Promise<EsolveAuthResponseData> {\r\n        session = session || this.session.currentSession;\r\n\r\n        const token = session?.key ?? '';\r\n\r\n        const params = new HttpParams({\r\n            fromObject: {\r\n                key: token,\r\n                ws_id: this.config.wsid\r\n            }\r\n        });\r\n\r\n        return this.http.get<EsolveAuthResponseData>(\r\n            `${this.config.api_url}/service/get-access-token.php`,\r\n            {\r\n                params,\r\n                headers: new HttpHeaders({\r\n                    'Accept-Language': '*'\r\n                })\r\n            }\r\n        ).pipe(\r\n            map(responseData => {\r\n                if (\r\n                    (responseData.type === 'error') ||\r\n                    (responseData.type === 'exception') ||\r\n                    (!responseData.additional_data.key_okay)\r\n                ) {\r\n                    throw responseData;\r\n                }\r\n\r\n                responseData.additional_data.key = token;\r\n\r\n                return responseData;\r\n            })\r\n        ).toPromise();\r\n    }\r\n\r\n    public getAccessToken(\r\n        email: string,\r\n        password: string,\r\n        anonymous: boolean = false\r\n    ): Observable<EsolveAuthResponseData> {\r\n        let params = new HttpParams();\r\n\r\n        if (anonymous) {\r\n            params = params.set('anonymous', '1');\r\n        }\r\n\r\n        if (email !== '') {\r\n            params = params.set('email', email);\r\n        }\r\n\r\n        if (password !== '') {\r\n            params = params.set('password', password);\r\n        }\r\n\r\n        params = params.set('ws_id', this.config.wsid);\r\n\r\n        return this.http.get<EsolveAuthResponseData>(\r\n            `${this.config.api_url}/service/get-access-token.php`,\r\n            {\r\n                params,\r\n                headers: new HttpHeaders({\r\n                    'Accept-Language': '*'\r\n                })\r\n            }\r\n        ).pipe(\r\n            tap(responseData => {\r\n                if (\r\n                    (responseData.type === 'error') ||\r\n                    (responseData.type === 'exception')\r\n                ) {\r\n                    throw responseData;\r\n                }\r\n            }),\r\n            catchError(this.handleError),\r\n            tap(responseData => {\r\n                this.handleAuthentication(responseData);\r\n            })\r\n        );\r\n    }\r\n\r\n    public autoLogin(): void {\r\n        this.session.restore(\r\n            this.handleExpiration(),\r\n            () => {\r\n                this.getAccessToken('', '', true).toPromise().then(\r\n                    _ => { },\r\n                    error => {\r\n                        console.log(error);\r\n                    }\r\n                );\r\n            }\r\n        );\r\n    }\r\n\r\n    public login(email: string, password: string): Observable<number> {\r\n        const body = {\r\n            login: {\r\n                email,\r\n                password\r\n            }\r\n        };\r\n\r\n        return this.http.post<EsolveSetResponse<EsolvePostResponseItem>>(\r\n            `${this.config.api_url}/service/set-login.php`,\r\n            body,\r\n            {\r\n                headers: {\r\n                    'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'\r\n                },\r\n                params: {\r\n                    ws_id: this.config.wsid\r\n                },\r\n                responseType: 'json',\r\n                observe: 'body'\r\n            }\r\n        ).pipe(\r\n            map(response => {\r\n                if (\r\n                    (response.responses === undefined) ||\r\n                    (response.responses.length <= 0)\r\n                ) {\r\n                    throw response;\r\n                }\r\n\r\n                const login_response = response.responses[0];\r\n\r\n                if (\r\n                    (login_response.status.state !== 'success') &&\r\n                    (login_response.status.state !== 'warning')\r\n                ) {\r\n                    throw login_response;\r\n                }\r\n\r\n                for (const response_log of login_response.log) {\r\n                    if ((response_log.type === 'success') && (response_log.message_code === 'login_success')) {\r\n                        this.session.handleUpdateSession(login_response.esolve_id as number);\r\n\r\n                        return login_response.esolve_id as number;\r\n                    }\r\n                }\r\n\r\n                throw login_response;\r\n            }),\r\n            catchError((errorRes: HttpErrorResponse | any) => {\r\n                return this.errorHandler.handleHttpError('set-login', errorRes);\r\n            })\r\n        );\r\n    }\r\n\r\n    public logout(): void {\r\n        this.session.clearTimer();\r\n        this.getAccessToken('', '', true).toPromise().then(\r\n            _ => { },\r\n            error => {\r\n                console.log(error);\r\n            }\r\n        );\r\n    }\r\n\r\n    // Handlers\r\n    private handleExpiration(): (session?: EsolveSession) => void {\r\n        return (session?: EsolveSession) => {\r\n            this.checkAccessToken(session).then(\r\n                (response) => {\r\n                    this.handleAuthentication(response);\r\n                },\r\n                () => {\r\n                    this.logout();\r\n                }\r\n            );\r\n        };\r\n    }\r\n\r\n    private handleAuthentication(responseData: EsolveAuthResponseData): void {\r\n        if (responseData.additional_data.key) {\r\n            this.session.handleSession(\r\n                responseData.additional_data.user_id,\r\n                responseData.additional_data.key,\r\n                +responseData.additional_data.expiry_time,\r\n                +responseData.additional_data.expires,\r\n                this.handleExpiration()\r\n            );\r\n        }\r\n    }\r\n\r\n    private handleError(errorRes: EsolveAuthResponseData): Observable<never> {\r\n        const error = {\r\n            message: 'An unknown error occurred',\r\n            data: {}\r\n        };\r\n\r\n        if (\r\n            (!errorRes.type) ||\r\n            (!errorRes.service_type) ||\r\n            (!errorRes.message)\r\n        ) {\r\n            return throwError(error);\r\n        }\r\n\r\n        if (errorRes.message.trim() !== '') {\r\n            error.message = errorRes.message;\r\n        }\r\n\r\n        if (errorRes.additional_data) {\r\n            error.data = errorRes.additional_data;\r\n        }\r\n\r\n        return throwError(error);\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLXJlZ2lzdHJhdGlvbi1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZXNvbHZlLWNvbm5lY3Qvc3JjL2xpYi9hdXRoL2Vzb2x2ZS1yZWdpc3RyYXRpb24tZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFc29sdmVSZWdpc3RyYXRpb25EYXRhIHtcclxuICAgIGVtYWlsOiBzdHJpbmc7XHJcbiAgICBwYXNzd29yZDogc3RyaW5nO1xyXG4gICAgY29uZmlybV9wYXNzd29yZD86IHN0cmluZztcclxuICAgIHRpdGxlPzogc3RyaW5nO1xyXG4gICAgZmlyc3RuYW1lPzogc3RyaW5nO1xyXG4gICAgc3VybmFtZT86IHN0cmluZztcclxuICAgIGxveWFsdHludW1iZXI/OiBzdHJpbmc7XHJcbiAgICBpZG51bWJlcj86IHN0cmluZztcclxuICAgIHRlbG51bWJlcj86IHN0cmluZztcclxuICAgIGNlbGxudW1iZXI/OiBzdHJpbmc7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLXJlZ2lzdHJhdGlvbi1wb3N0LXJlc3BvbnNlLWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2F1dGgvZXNvbHZlLXJlZ2lzdHJhdGlvbi1wb3N0LXJlc3BvbnNlLWl0ZW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVzb2x2ZVBvc3RSZXNwb25zZUl0ZW0gfSBmcm9tICcuLi9zaGFyZWQvZXNvbHZlLXJlc3BvbnNlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRXNvbHZlUmVnaXN0cmF0aW9uUG9zdFJlc3BvbnNlSXRlbSBleHRlbmRzIEVzb2x2ZVBvc3RSZXNwb25zZUl0ZW0ge1xyXG4gICAgZ3Vlc3Q6IGJvb2xlYW47XHJcbiAgICBhdXRoZW50aWNhdGlvbl9yZXF1aXJlZDogYm9vbGVhbjtcclxuICAgIGF1dG9fbG9naW46IGJvb2xlYW47XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export class EsolveRegistrationResult {
|
|
2
|
+
constructor(user_id, guest, authentication_required, auto_login) {
|
|
3
|
+
this.user_id = user_id;
|
|
4
|
+
this.guest = guest;
|
|
5
|
+
this.authentication_required = authentication_required;
|
|
6
|
+
this.auto_login = auto_login;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLXJlZ2lzdHJhdGlvbi1yZXN1bHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2F1dGgvZXNvbHZlLXJlZ2lzdHJhdGlvbi1yZXN1bHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLHdCQUF3QjtJQUNqQyxZQUNXLE9BQWUsRUFDZixLQUFjLEVBQ2QsdUJBQWdDLEVBQ2hDLFVBQW1CO1FBSG5CLFlBQU8sR0FBUCxPQUFPLENBQVE7UUFDZixVQUFLLEdBQUwsS0FBSyxDQUFTO1FBQ2QsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUFTO1FBQ2hDLGVBQVUsR0FBVixVQUFVLENBQVM7SUFDMUIsQ0FBQztDQUNSIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIEVzb2x2ZVJlZ2lzdHJhdGlvblJlc3VsdCB7XHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwdWJsaWMgdXNlcl9pZDogbnVtYmVyLFxyXG4gICAgICAgIHB1YmxpYyBndWVzdDogYm9vbGVhbixcclxuICAgICAgICBwdWJsaWMgYXV0aGVudGljYXRpb25fcmVxdWlyZWQ6IGJvb2xlYW4sXHJcbiAgICAgICAgcHVibGljIGF1dG9fbG9naW46IGJvb2xlYW5cclxuICAgICkgeyB9XHJcbn1cclxuIl19
|
|
@@ -3,19 +3,13 @@ import { BehaviorSubject } from 'rxjs';
|
|
|
3
3
|
import { ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';
|
|
4
4
|
import { EsolveSession } from './esolve-session';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "./esolve-account.service";
|
|
7
6
|
export class EsolveSessionService {
|
|
8
|
-
constructor(config
|
|
7
|
+
constructor(config) {
|
|
9
8
|
this.config = config;
|
|
10
9
|
this.storage_key = 'ngEslvUserSession';
|
|
11
10
|
this.setStorageKey();
|
|
12
11
|
this._session = new BehaviorSubject(new EsolveSession(0, ''));
|
|
13
12
|
this.session = this._session.asObservable();
|
|
14
|
-
this._session.subscribe((session) => {
|
|
15
|
-
if (session.key !== '') {
|
|
16
|
-
account.user_id = session.id;
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
13
|
}
|
|
20
14
|
get currentSession() {
|
|
21
15
|
return this._session.value;
|
|
@@ -71,7 +65,7 @@ export class EsolveSessionService {
|
|
|
71
65
|
}
|
|
72
66
|
}
|
|
73
67
|
}
|
|
74
|
-
EsolveSessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveSessionService, deps: [{ token: ESOLVE_CONNECT_CONFIG }
|
|
68
|
+
EsolveSessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveSessionService, deps: [{ token: ESOLVE_CONNECT_CONFIG }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
75
69
|
EsolveSessionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveSessionService, providedIn: 'root' });
|
|
76
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: EsolveSessionService, decorators: [{
|
|
77
71
|
type: Injectable,
|
|
@@ -81,5 +75,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImpor
|
|
|
81
75
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
82
76
|
type: Inject,
|
|
83
77
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
84
|
-
}] }
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
}] }]; } });
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-session.service.js","sourceRoot":"","sources":["../../../../../projects/ng-esolve-connect/src/lib/auth/esolve-session.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\n\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\n\r\nimport { EsolveConnectConfig, ESOLVE_CONNECT_CONFIG } from '../esolve-connect.config';\r\nimport { EsolveStoredSession } from './esolve-stored-session';\r\nimport { EsolveSession } from './esolve-session';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class EsolveSessionService {\r\n    private key_expiration_timer: any;\r\n    private storage_key = 'ngEslvUserSession';\r\n\r\n    private _session: BehaviorSubject<EsolveSession>;\r\n    public session: Observable<EsolveSession>;\r\n\r\n    public get currentSession(): EsolveSession {\r\n        return this._session.value;\r\n    }\r\n\r\n    constructor(\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig\r\n    ) {\r\n        this.setStorageKey();\r\n        this._session = new BehaviorSubject<EsolveSession>(new EsolveSession(0, ''));\r\n        this.session = this._session.asObservable();\r\n    }\r\n\r\n    private setStorageKey(): void {\r\n        if (\r\n            (typeof this.config.user_session_storage_key === 'string') &&\r\n            (this.config.user_session_storage_key !== '')\r\n        ) {\r\n            this.storage_key = this.config.user_session_storage_key;\r\n        }\r\n    }\r\n\r\n    private startTimer(callback: () => void, duration: number): void {\r\n        this.key_expiration_timer = setTimeout(callback, duration);\r\n    }\r\n\r\n    public clearTimer(): void {\r\n        if (this.key_expiration_timer) {\r\n            clearTimeout(this.key_expiration_timer);\r\n        }\r\n    }\r\n\r\n    public restore(\r\n        expirationCallback: (session?: EsolveSession) => void,\r\n        invalidSessionCallback: () => void\r\n    ): void {\r\n        if (!this.currentSession.valid) {\r\n            const stored_session_json = localStorage.getItem(this.storage_key);\r\n            const stored_session: EsolveStoredSession = (stored_session_json ? JSON.parse(stored_session_json) : null);\r\n\r\n            if (!stored_session) {\r\n                invalidSessionCallback();\r\n                return;\r\n            }\r\n\r\n            const expiration_date = new Date(stored_session._key_expiration_date);\r\n\r\n            const loaded_session = new EsolveSession(\r\n                stored_session.id,\r\n                stored_session._key,\r\n                expiration_date\r\n            );\r\n\r\n            if (!loaded_session.expired) {\r\n                this._session.next(loaded_session);\r\n                const expiration_duration = expiration_date.getTime() - new Date().getTime();\r\n                this.startTimer(expirationCallback, expiration_duration);\r\n            } else {\r\n                expirationCallback(loaded_session);\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleSession(\r\n        user_id: number,\r\n        key: string,\r\n        expiry_time: number,\r\n        expires: number,\r\n        expirationCallback: () => void\r\n    ): void {\r\n        const expiration_date = new Date(expiry_time * 1000);\r\n        const session = new EsolveSession(user_id, key, expiration_date);\r\n\r\n        localStorage.setItem(this.storage_key, JSON.stringify(session));\r\n        this._session.next(session);\r\n        this.startTimer(expirationCallback, expires * 1000);\r\n    }\r\n\r\n    public handleUpdateSession(user_id: number, callback?: () => void): void {\r\n        const current_session = this.currentSession;\r\n        current_session.updateUser(user_id);\r\n\r\n        localStorage.setItem(this.storage_key, JSON.stringify(current_session));\r\n        this._session.next(current_session);\r\n\r\n        if (typeof callback === 'function') {\r\n            callback();\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWNhcnQtaXRlbS1yZWNvcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lc29sdmUtY29ubmVjdC9zcmMvbGliL2NhcnQvZXNvbHZlLWNhcnQtaXRlbS1yZWNvcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRXNvbHZlQ2FydEl0ZW1SZWNvcmQge1xyXG4gICAgaWQ6IG51bWJlcjtcclxuICAgIGNvZGU6IHN0cmluZztcclxuICAgIGV4dGVybmFsX3N5c3RlbV9jb2RlOiBzdHJpbmc7XHJcbiAgICBuYW1lOiBzdHJpbmc7XHJcbiAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xyXG4gICAgcXR5OiBudW1iZXI7XHJcbiAgICBwcmljZTogbnVtYmVyO1xyXG4gICAgcHJpY2VfZGVzY3JpcHRpb246IHN0cmluZztcclxuICAgIHByaWNlX2luY2w6IG51bWJlcjtcclxuICAgIGRpc2NvdW50X3ByaWNlOiBudW1iZXI7XHJcbiAgICBkaXNjb3VudF9wcmljZV9pbmNsOiBudW1iZXI7XHJcbiAgICBkaXNjb3VudF90b3RhbDogbnVtYmVyO1xyXG4gICAgdmF0X3RvdGFsOiBudW1iZXI7XHJcbiAgICBsaW5lX3RvdGFsOiBudW1iZXI7XHJcbiAgICBsaW5lX3RvdGFsX2luY2w6IG51bWJlcjtcclxuICAgIGRpc2NvdW50OiBudW1iZXI7XHJcbiAgICBkaXNjb3VudF9pbnRlcnZhbDogbnVtYmVyO1xyXG4gICAgdmF0X3JhdGU6IG51bWJlcjtcclxuICAgIGRlbGl2ZXJ5X2NhdGVnb3J5OiBzdHJpbmc7XHJcbiAgICB0eXBlOiBzdHJpbmc7XHJcbiAgICBtdXN0X2NvbGxlY3Q6IGJvb2xlYW47XHJcbiAgICByZXF1ZXN0ZWRfYXNzZW1ibHk6IGJvb2xlYW47XHJcbiAgICBhbGxvd19xdW90ZXM6IGJvb2xlYW47XHJcbiAgICBhbGxvd19vcmRlcnM6IGJvb2xlYW47XHJcbiAgICBzZWZfbmFtZTogc3RyaW5nO1xyXG4gICAgbWluaW11bV9vbmhhbmQ6IG51bWJlcjtcclxuICAgIGdyb3VwOiBzdHJpbmc7XHJcbiAgICBsaW1pdF9wZXJfdHJhbnNhY3Rpb246IG51bWJlcjtcclxuICAgIG9uaGFuZDogbnVtYmVyO1xyXG4gICAgY2FydF9xdWVzdGlvbl9pZGVudGlmaWVyOiBzdHJpbmc7XHJcbiAgICBpdGVtc19pbl9wYWNrOiBudW1iZXI7XHJcbiAgICBpc19hY3RpdmU6IGJvb2xlYW47XHJcbiAgICBkaXNwbGF5X29ubHk6IGJvb2xlYW47XHJcbiAgICBpZ25vcmVfb25oYW5kX2NoZWNrOiBib29sZWFuO1xyXG4gICAgc3ViY2F0ZWdvcnlfbWluX2xldmVsOiBudW1iZXI7XHJcbiAgICBpbWFnZV9uYW1lOiBzdHJpbmc7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNvbHZlLWNhcnQtaXRlbS1yZXNwb25zZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVzb2x2ZS1jb25uZWN0L3NyYy9saWIvY2FydC9lc29sdmUtY2FydC1pdGVtLXJlc3BvbnNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFc29sdmVQb3N0UmVzcG9uc2VJdGVtIH0gZnJvbSAnLi4vc2hhcmVkL2Vzb2x2ZS1yZXNwb25zZSc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEVzb2x2ZUNhcnRJdGVtUmVzcG9uc2UgZXh0ZW5kcyBFc29sdmVQb3N0UmVzcG9uc2VJdGVtIHtcclxuICAgIGVzb2x2ZV9pZDogbnVtYmVyO1xyXG4gICAgY3VycmVudF9xdHk6IG51bWJlcjtcclxufVxyXG4iXX0=
|