@esolve/ng-esolve-connect 0.29.5 → 0.29.6
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/esm2020/lib/auth/esolve-auth.service.mjs +26 -2
- package/esm2020/lib/session/esolve-session.service.mjs +30 -1
- package/fesm2015/esolve-ng-esolve-connect.mjs +62 -6
- package/fesm2015/esolve-ng-esolve-connect.mjs.map +1 -1
- package/fesm2020/esolve-ng-esolve-connect.mjs +54 -2
- package/fesm2020/esolve-ng-esolve-connect.mjs.map +1 -1
- package/lib/auth/esolve-auth.service.d.ts +3 -1
- package/lib/session/esolve-session.service.d.ts +3 -0
- package/package.json +1 -1
|
@@ -19,6 +19,11 @@ export class EsolveAuthService {
|
|
|
19
19
|
this.errorHandler = errorHandler;
|
|
20
20
|
this.cookieService = cookieService;
|
|
21
21
|
}
|
|
22
|
+
static preValidate(auth) {
|
|
23
|
+
return () => {
|
|
24
|
+
return auth.validateCachedTokens();
|
|
25
|
+
};
|
|
26
|
+
}
|
|
22
27
|
getAccessToken(email, password, anonymous = false) {
|
|
23
28
|
let params = new HttpParams();
|
|
24
29
|
if (anonymous) {
|
|
@@ -46,7 +51,8 @@ export class EsolveAuthService {
|
|
|
46
51
|
this.handleAuthentication(responseData.additional_data);
|
|
47
52
|
}));
|
|
48
53
|
}
|
|
49
|
-
autoLogin() {
|
|
54
|
+
async autoLogin() {
|
|
55
|
+
await this.validateCachedTokens();
|
|
50
56
|
this.session.restore(this.handleExpiration(), () => {
|
|
51
57
|
firstValueFrom(this.getAccessToken('', '', true)).then(() => {
|
|
52
58
|
// empty
|
|
@@ -107,6 +113,24 @@ export class EsolveAuthService {
|
|
|
107
113
|
}
|
|
108
114
|
throw new Error('Invalid response');
|
|
109
115
|
}
|
|
116
|
+
async validateCachedTokens() {
|
|
117
|
+
let valid = false;
|
|
118
|
+
try {
|
|
119
|
+
const session = this.session.getCachedSession();
|
|
120
|
+
if (!session) {
|
|
121
|
+
throw null;
|
|
122
|
+
}
|
|
123
|
+
const result = await firstValueFrom(this.checkAccessToken(session));
|
|
124
|
+
if (!result.key) {
|
|
125
|
+
throw null;
|
|
126
|
+
}
|
|
127
|
+
valid = true;
|
|
128
|
+
}
|
|
129
|
+
catch (error) {
|
|
130
|
+
this.session.resetSessionCache();
|
|
131
|
+
}
|
|
132
|
+
return valid;
|
|
133
|
+
}
|
|
110
134
|
checkAccessToken(session) {
|
|
111
135
|
session = session || this.session.currentSession;
|
|
112
136
|
const token = session?.key ?? '';
|
|
@@ -182,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
182
206
|
type: Inject,
|
|
183
207
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
184
208
|
}] }, { type: i1.HttpClient }, { type: i2.EsolveSessionService }, { type: i3.EsolveErrorHandlerService }, { type: i4.EsolveCookieService }]; } });
|
|
185
|
-
//# 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';\r\nimport {\r\n    HttpClient,\r\n    HttpParams,\r\n    HttpErrorResponse,\r\n    HttpHeaders,\r\n} from '@angular/common/http';\r\n\r\nimport { firstValueFrom, Observable, throwError } from 'rxjs';\r\nimport { tap, catchError, map } from 'rxjs/operators';\r\n\r\nimport { EsolveConnectConfig } from '../esolve-connect.config';\r\nimport { ESOLVE_CONNECT_CONFIG } from '../esolve-connect-config.constant';\r\nimport { EsolveCookieService } from '../shared/cookie/esolve-cookie.service';\r\nimport { EsolveErrorHandlerService } from '../shared/errors/esolve-error-handler.service';\r\nimport { EsolveSetResponse } from '../shared/response';\r\n\r\nimport { EsolveSession } from '../session/esolve-session.model';\r\nimport { EsolveSessionService } from '../session/esolve-session.service';\r\n\r\nimport { EsolveLoginPostResponseItem } from './esolve-login-post-response-item.interface';\r\nimport { EsolveAuthGetResponse } from './esolve-auth-get-response.interface';\r\nimport { EsolveAuthCheckResponse } from './esolve-auth-check-response.interface';\r\nimport { EsolveAuthResult } from './esolve-auth-result.type';\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        private cookieService: EsolveCookieService,\r\n    ) { }\r\n\r\n    public getAccessToken(\r\n        email: string,\r\n        password: string,\r\n        anonymous: boolean = false,\r\n    ): Observable<EsolveAuthGetResponse> {\r\n        let params = new HttpParams();\r\n\r\n        if (anonymous) {\r\n            params = params.set('anonymous', true);\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        return this.http\r\n            .get<EsolveAuthGetResponse>(\r\n                `${this.config.api_url}/get-access-token.php`,\r\n                {\r\n                    params,\r\n                    headers: new HttpHeaders({\r\n                        'Accept-Language': '*',\r\n                    }),\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.additional_data);\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                firstValueFrom(this.getAccessToken('', '', true)).then(\r\n                    () => {\r\n                        // empty\r\n                    },\r\n                    (error) => {\r\n                        console.error(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\r\n            .post<EsolveSetResponse<EsolveLoginPostResponseItem>>(\r\n                `${this.config.api_url}/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                    responseType: 'json',\r\n                    observe: 'body',\r\n                },\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 (\r\n                            (response_log.type === 'success') &&\r\n                            (response_log.message_code === 'login_success')\r\n                        ) {\r\n                            const session_data = login_response.session_data;\r\n                            const user_id = +login_response.esolve_id;\r\n                            const location_id = +session_data.location_id;\r\n\r\n                            this.session.handleUpdateSession({\r\n                                user_id: user_id,\r\n                                location_id: location_id,\r\n                            });\r\n\r\n                            return user_id;\r\n                        }\r\n                    }\r\n\r\n                    throw login_response;\r\n                }),\r\n                catchError((errorRes: HttpErrorResponse | any) => {\r\n                    return this.errorHandler.handleHttpPostError('set-login', errorRes);\r\n                }),\r\n            );\r\n    }\r\n\r\n    public async logout(): Promise<EsolveAuthGetResponse> {\r\n        this.session.clearTimer();\r\n        this.cookieService.delete('_ws_id');\r\n\r\n        const response = await firstValueFrom(this.getAccessToken('', '', true));\r\n\r\n        if (response) {\r\n            return response;\r\n        }\r\n\r\n        throw new Error('Invalid response');\r\n    }\r\n\r\n    private checkAccessToken(session?: EsolveSession): Observable<EsolveAuthResult> {\r\n        session = session || this.session.currentSession;\r\n\r\n        const token = session?.key ?? '';\r\n\r\n        return this.http\r\n            .get<EsolveAuthCheckResponse>(\r\n                `${this.config.api_url}/get-access-token.php`,\r\n                {\r\n                    params: { key: token },\r\n                    headers: new HttpHeaders({\r\n                        'Accept-Language': '*',\r\n                    }),\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                    const additional_data = responseData.additional_data;\r\n\r\n                    const result: EsolveAuthResult = {\r\n                        key: token,\r\n                        expires: additional_data.expires,\r\n                        expiry_time: additional_data.expiry_time,\r\n                        location_id: additional_data.location_id,\r\n                        user_id: additional_data.user_id,\r\n                    };\r\n\r\n                    return result;\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            firstValueFrom(this.checkAccessToken(session)).then(\r\n                (response) => {\r\n                    if (response) {\r\n                        this.handleAuthentication(response);\r\n                    }\r\n                },\r\n                () => {\r\n                    this.logout();\r\n                },\r\n            );\r\n        };\r\n    }\r\n\r\n    private handleAuthentication(result: EsolveAuthResult): void {\r\n        if (!result.key) {\r\n            return;\r\n        }\r\n\r\n        this.session.handleSession(\r\n            +result.user_id,\r\n            +result.location_id,\r\n            result.key,\r\n            +result.expiry_time,\r\n            +result.expires,\r\n            this.handleExpiration(),\r\n        );\r\n    }\r\n\r\n    private handleError(\r\n        errorRes: EsolveAuthGetResponse | EsolveAuthCheckResponse,\r\n    ): 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"]}
|
|
209
|
+
//# 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":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EACH,UAAU,EACV,UAAU,EAEV,WAAW,GACd,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,cAAc,EAAc,UAAU,EAAE,MAAM,MAAM,CAAC;AAC9D,OAAO,EAAE,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAGtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,yBAAyB,EAAE,MAAM,+CAA+C,CAAC;AAI1F,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;;;;;;AAUzE,MAAM,OAAO,iBAAiB;IAC1B,YAC2C,MAA2B,EAC1D,IAAgB,EAChB,OAA6B,EAC7B,YAAuC,EACvC,aAAkC;QAJH,WAAM,GAAN,MAAM,CAAqB;QAC1D,SAAI,GAAJ,IAAI,CAAY;QAChB,YAAO,GAAP,OAAO,CAAsB;QAC7B,iBAAY,GAAZ,YAAY,CAA2B;QACvC,kBAAa,GAAb,aAAa,CAAqB;IAC3C,CAAC;IAEG,MAAM,CAAC,WAAW,CAAC,IAAuB;QAC7C,OAAO,GAAG,EAAE;YACR,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACvC,CAAC,CAAC;IACN,CAAC;IAEM,cAAc,CACjB,KAAa,EACb,QAAgB,EAChB,YAAqB,KAAK;QAE1B,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAE9B,IAAI,SAAS,EAAE;YACX,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SAC1C;QAED,IAAI,KAAK,KAAK,EAAE,EAAE;YACd,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;SACvC;QAED,IAAI,QAAQ,KAAK,EAAE,EAAE;YACjB,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;SAC7C;QAED,OAAO,IAAI,CAAC,IAAI;aACX,GAAG,CACA,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,uBAAuB,EAC7C;YACI,MAAM;YACN,OAAO,EAAE,IAAI,WAAW,CAAC;gBACrB,iBAAiB,EAAE,GAAG;aACzB,CAAC;SACL,CACJ;aACA,IAAI,CACD,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE;YACjB,IACI,CAAC,YAAY,CAAC,IAAI,KAAK,OAAO,CAAC;gBAC/B,CAAC,YAAY,CAAC,IAAI,KAAK,WAAW,CAAC,EACrC;gBACE,MAAM,YAAY,CAAC;aACtB;QACL,CAAC,CAAC,EACF,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,EAC5B,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE;YACjB,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;QAC5D,CAAC,CAAC,CACL,CAAC;IACV,CAAC;IAEM,KAAK,CAAC,SAAS;QAClB,MAAM,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAElC,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,IAAI,CAAC,gBAAgB,EAAE,EACvB,GAAG,EAAE;YACD,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAClD,GAAG,EAAE;gBACD,QAAQ;YACZ,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;gBACN,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC,CACJ,CAAC;QACN,CAAC,CACJ,CAAC;IACN,CAAC;IAEM,KAAK,CAAC,KAAa,EAAE,QAAgB;QACxC,MAAM,IAAI,GAAG;YACT,KAAK,EAAE;gBACH,KAAK;gBACL,QAAQ;aACX;SACJ,CAAC;QAEF,OAAO,IAAI,CAAC,IAAI;aACX,IAAI,CACD,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,gBAAgB,EACtC,IAAI,EACJ;YACI,OAAO,EAAE;gBACL,cAAc,EAAE,kDAAkD;aACrE;YACD,YAAY,EAAE,MAAM;YACpB,OAAO,EAAE,MAAM;SAClB,CACJ;aACA,IAAI,CACD,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACb,IACI,CAAC,QAAQ,CAAC,SAAS,KAAK,SAAS,CAAC;gBAClC,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,CAAC,EAClC;gBACE,MAAM,QAAQ,CAAC;aAClB;YAED,MAAM,cAAc,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAE7C,IACI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC;gBAC3C,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,EAC7C;gBACE,MAAM,cAAc,CAAC;aACxB;YAED,KAAK,MAAM,YAAY,IAAI,cAAc,CAAC,GAAG,EAAE;gBAC3C,IACI,CAAC,YAAY,CAAC,IAAI,KAAK,SAAS,CAAC;oBACjC,CAAC,YAAY,CAAC,YAAY,KAAK,eAAe,CAAC,EACjD;oBACE,MAAM,YAAY,GAAG,cAAc,CAAC,YAAY,CAAC;oBACjD,MAAM,OAAO,GAAG,CAAC,cAAc,CAAC,SAAS,CAAC;oBAC1C,MAAM,WAAW,GAAG,CAAC,YAAY,CAAC,WAAW,CAAC;oBAE9C,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC;wBAC7B,OAAO,EAAE,OAAO;wBAChB,WAAW,EAAE,WAAW;qBAC3B,CAAC,CAAC;oBAEH,OAAO,OAAO,CAAC;iBAClB;aACJ;YAED,MAAM,cAAc,CAAC;QACzB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,QAAiC,EAAE,EAAE;YAC7C,OAAO,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QACxE,CAAC,CAAC,CACL,CAAC;IACV,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEpC,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC;QAEzE,IAAI,QAAQ,EAAE;YACV,OAAO,QAAQ,CAAC;SACnB;QAED,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;IACxC,CAAC;IAEM,KAAK,CAAC,oBAAoB;QAC7B,IAAI,KAAK,GAAG,KAAK,CAAC;QAElB,IAAI;YACA,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAEhD,IAAI,CAAC,OAAO,EAAE;gBACV,MAAM,IAAI,CAAC;aACd;YAED,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;YAEpE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;gBACb,MAAM,IAAI,CAAC;aACd;YAED,KAAK,GAAG,IAAI,CAAC;SAChB;QAAC,OAAO,KAAK,EAAE;YACZ,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;SACpC;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,gBAAgB,CAAC,OAAuB;QAC5C,OAAO,GAAG,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;QAEjD,MAAM,KAAK,GAAG,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;QAEjC,OAAO,IAAI,CAAC,IAAI;aACX,GAAG,CACA,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,uBAAuB,EAC7C;YACI,MAAM,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE;YACtB,OAAO,EAAE,IAAI,WAAW,CAAC;gBACrB,iBAAiB,EAAE,GAAG;aACzB,CAAC;SACL,CACJ;aACA,IAAI,CACD,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE;YACjB,IACI,CAAC,YAAY,CAAC,IAAI,KAAK,OAAO,CAAC;gBAC/B,CAAC,YAAY,CAAC,IAAI,KAAK,WAAW,CAAC;gBACnC,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC,QAAQ,CAAC,EAC1C;gBACE,MAAM,YAAY,CAAC;aACtB;YAED,MAAM,eAAe,GAAG,YAAY,CAAC,eAAe,CAAC;YAErD,MAAM,MAAM,GAAqB;gBAC7B,GAAG,EAAE,KAAK;gBACV,OAAO,EAAE,eAAe,CAAC,OAAO;gBAChC,WAAW,EAAE,eAAe,CAAC,WAAW;gBACxC,WAAW,EAAE,eAAe,CAAC,WAAW;gBACxC,OAAO,EAAE,eAAe,CAAC,OAAO;aACnC,CAAC;YAEF,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CACL,CAAC;IACV,CAAC;IAED,WAAW;IACH,gBAAgB;QACpB,OAAO,CAAC,OAAuB,EAAE,EAAE;YAC/B,cAAc,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAC/C,CAAC,QAAQ,EAAE,EAAE;gBACT,IAAI,QAAQ,EAAE;oBACV,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;iBACvC;YACL,CAAC,EACD,GAAG,EAAE;gBACD,IAAI,CAAC,MAAM,EAAE,CAAC;YAClB,CAAC,CACJ,CAAC;QACN,CAAC,CAAC;IACN,CAAC;IAEO,oBAAoB,CAAC,MAAwB;QACjD,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACb,OAAO;SACV;QAED,IAAI,CAAC,OAAO,CAAC,aAAa,CACtB,CAAC,MAAM,CAAC,OAAO,EACf,CAAC,MAAM,CAAC,WAAW,EACnB,MAAM,CAAC,GAAG,EACV,CAAC,MAAM,CAAC,WAAW,EACnB,CAAC,MAAM,CAAC,OAAO,EACf,IAAI,CAAC,gBAAgB,EAAE,CAC1B,CAAC;IACN,CAAC;IAEO,WAAW,CACf,QAAyD;QAEzD,MAAM,KAAK,GAAG;YACV,OAAO,EAAE,2BAA2B;YACpC,IAAI,EAAE,EAAE;SACX,CAAC;QAEF,IACI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;YAChB,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC;YACxB,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,EACrB;YACE,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;SAClC;QAED,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAChC,KAAK,CAAC,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;SACpC;QAED,IAAI,QAAQ,CAAC,eAAe,EAAE;YAC1B,KAAK,CAAC,IAAI,GAAG,QAAQ,CAAC,eAAe,CAAC;SACzC;QAED,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;;8GAnRQ,iBAAiB,kBAEd,qBAAqB;kHAFxB,iBAAiB,cAFd,MAAM;2FAET,iBAAiB;kBAH7B,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB;;0BAGQ,MAAM;2BAAC,qBAAqB","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 { firstValueFrom, Observable, throwError } from 'rxjs';\r\nimport { tap, catchError, map } from 'rxjs/operators';\r\n\r\nimport { EsolveConnectConfig } from '../esolve-connect.config';\r\nimport { ESOLVE_CONNECT_CONFIG } from '../esolve-connect-config.constant';\r\nimport { EsolveCookieService } from '../shared/cookie/esolve-cookie.service';\r\nimport { EsolveErrorHandlerService } from '../shared/errors/esolve-error-handler.service';\r\nimport { EsolveSetResponse } from '../shared/response';\r\n\r\nimport { EsolveSession } from '../session/esolve-session.model';\r\nimport { EsolveSessionService } from '../session/esolve-session.service';\r\n\r\nimport { EsolveLoginPostResponseItem } from './esolve-login-post-response-item.interface';\r\nimport { EsolveAuthGetResponse } from './esolve-auth-get-response.interface';\r\nimport { EsolveAuthCheckResponse } from './esolve-auth-check-response.interface';\r\nimport { EsolveAuthResult } from './esolve-auth-result.type';\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        private cookieService: EsolveCookieService,\r\n    ) {}\r\n\r\n    public static preValidate(auth: EsolveAuthService) {\r\n        return () => {\r\n            return auth.validateCachedTokens();\r\n        };\r\n    }\r\n\r\n    public getAccessToken(\r\n        email: string,\r\n        password: string,\r\n        anonymous: boolean = false,\r\n    ): Observable<EsolveAuthGetResponse> {\r\n        let params = new HttpParams();\r\n\r\n        if (anonymous) {\r\n            params = params.set('anonymous', true);\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        return this.http\r\n            .get<EsolveAuthGetResponse>(\r\n                `${this.config.api_url}/get-access-token.php`,\r\n                {\r\n                    params,\r\n                    headers: new HttpHeaders({\r\n                        'Accept-Language': '*',\r\n                    }),\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.additional_data);\r\n                }),\r\n            );\r\n    }\r\n\r\n    public async autoLogin(): Promise<void> {\r\n        await this.validateCachedTokens();\r\n\r\n        this.session.restore(\r\n            this.handleExpiration(),\r\n            () => {\r\n                firstValueFrom(this.getAccessToken('', '', true)).then(\r\n                    () => {\r\n                        // empty\r\n                    },\r\n                    (error) => {\r\n                        console.error(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\r\n            .post<EsolveSetResponse<EsolveLoginPostResponseItem>>(\r\n                `${this.config.api_url}/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                    responseType: 'json',\r\n                    observe: 'body',\r\n                },\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 (\r\n                            (response_log.type === 'success') &&\r\n                            (response_log.message_code === 'login_success')\r\n                        ) {\r\n                            const session_data = login_response.session_data;\r\n                            const user_id = +login_response.esolve_id;\r\n                            const location_id = +session_data.location_id;\r\n\r\n                            this.session.handleUpdateSession({\r\n                                user_id: user_id,\r\n                                location_id: location_id,\r\n                            });\r\n\r\n                            return user_id;\r\n                        }\r\n                    }\r\n\r\n                    throw login_response;\r\n                }),\r\n                catchError((errorRes: HttpErrorResponse | any) => {\r\n                    return this.errorHandler.handleHttpPostError('set-login', errorRes);\r\n                }),\r\n            );\r\n    }\r\n\r\n    public async logout(): Promise<EsolveAuthGetResponse> {\r\n        this.session.clearTimer();\r\n        this.cookieService.delete('_ws_id');\r\n\r\n        const response = await firstValueFrom(this.getAccessToken('', '', true));\r\n\r\n        if (response) {\r\n            return response;\r\n        }\r\n\r\n        throw new Error('Invalid response');\r\n    }\r\n\r\n    public async validateCachedTokens(): Promise<boolean> {\r\n        let valid = false;\r\n\r\n        try {\r\n            const session = this.session.getCachedSession();\r\n\r\n            if (!session) {\r\n                throw null;\r\n            }\r\n\r\n            const result = await firstValueFrom(this.checkAccessToken(session));\r\n\r\n            if (!result.key) {\r\n                throw null;\r\n            }\r\n\r\n            valid = true;\r\n        } catch (error) {\r\n            this.session.resetSessionCache();\r\n        }\r\n\r\n        return valid;\r\n    }\r\n\r\n    private checkAccessToken(session?: EsolveSession): Observable<EsolveAuthResult> {\r\n        session = session || this.session.currentSession;\r\n\r\n        const token = session?.key ?? '';\r\n\r\n        return this.http\r\n            .get<EsolveAuthCheckResponse>(\r\n                `${this.config.api_url}/get-access-token.php`,\r\n                {\r\n                    params: { key: token },\r\n                    headers: new HttpHeaders({\r\n                        'Accept-Language': '*',\r\n                    }),\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                    const additional_data = responseData.additional_data;\r\n\r\n                    const result: EsolveAuthResult = {\r\n                        key: token,\r\n                        expires: additional_data.expires,\r\n                        expiry_time: additional_data.expiry_time,\r\n                        location_id: additional_data.location_id,\r\n                        user_id: additional_data.user_id,\r\n                    };\r\n\r\n                    return result;\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            firstValueFrom(this.checkAccessToken(session)).then(\r\n                (response) => {\r\n                    if (response) {\r\n                        this.handleAuthentication(response);\r\n                    }\r\n                },\r\n                () => {\r\n                    this.logout();\r\n                },\r\n            );\r\n        };\r\n    }\r\n\r\n    private handleAuthentication(result: EsolveAuthResult): void {\r\n        if (!result.key) {\r\n            return;\r\n        }\r\n\r\n        this.session.handleSession(\r\n            +result.user_id,\r\n            +result.location_id,\r\n            result.key,\r\n            +result.expiry_time,\r\n            +result.expires,\r\n            this.handleExpiration(),\r\n        );\r\n    }\r\n\r\n    private handleError(\r\n        errorRes: EsolveAuthGetResponse | EsolveAuthCheckResponse,\r\n    ): 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"]}
|
|
@@ -25,6 +25,26 @@ export class EsolveSessionService {
|
|
|
25
25
|
clearTimeout(this.key_expiration_timer);
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
+
getCachedSession() {
|
|
29
|
+
let json_data = this.cookieService.get(this.storage_key);
|
|
30
|
+
if (json_data === '') {
|
|
31
|
+
const local_store_data = this.getBackup();
|
|
32
|
+
if (local_store_data) {
|
|
33
|
+
json_data = local_store_data;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
const stored_session = (json_data ? JSON.parse(json_data) : null);
|
|
37
|
+
if (!stored_session) {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
const expiration_date = new Date(stored_session.expiration_date);
|
|
41
|
+
const loaded_session = new EsolveSession(stored_session.id, stored_session.location_id, stored_session.key, expiration_date);
|
|
42
|
+
return loaded_session;
|
|
43
|
+
}
|
|
44
|
+
resetSessionCache() {
|
|
45
|
+
this.cookieService.delete(this.storage_key, '/');
|
|
46
|
+
this.removeBackup();
|
|
47
|
+
}
|
|
28
48
|
restore(expirationCallback, invalidSessionCallback) {
|
|
29
49
|
if (this.currentSession.valid) {
|
|
30
50
|
return;
|
|
@@ -106,6 +126,15 @@ export class EsolveSessionService {
|
|
|
106
126
|
}
|
|
107
127
|
localStorage.setItem(this.storage_key, data);
|
|
108
128
|
}
|
|
129
|
+
removeBackup() {
|
|
130
|
+
if (!this.is_browser) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
if (!localStorage) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
localStorage.removeItem(this.storage_key);
|
|
137
|
+
}
|
|
109
138
|
}
|
|
110
139
|
EsolveSessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: EsolveSessionService, deps: [{ token: PLATFORM_ID }, { token: ESOLVE_CONNECT_CONFIG }, { token: i1.EsolveCookieService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
111
140
|
EsolveSessionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: EsolveSessionService, providedIn: 'root' });
|
|
@@ -121,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
121
150
|
type: Inject,
|
|
122
151
|
args: [ESOLVE_CONNECT_CONFIG]
|
|
123
152
|
}] }, { type: i1.EsolveCookieService }]; } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-session.service.js","sourceRoot":"","sources":["../../../../../../libs/ng-esolve-connect/src/lib/session/esolve-session.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID } from '@angular/core';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\n\r\nimport { EsolveCookieService } from '../shared/cookie/esolve-cookie.service';\r\nimport { EsolveConnectConfig } from '../esolve-connect.config';\r\nimport { ESOLVE_CONNECT_CONFIG } from '../esolve-connect-config.constant';\r\nimport { EsolveStoredSession } from './esolve-stored-session.interface';\r\nimport { EsolveSession } from './esolve-session.model';\r\n\r\n// TODO: Rewrite session manager to use a pure rxjs solution.\r\n\r\ninterface SessionUpdateOptions {\r\n    user_id?: number;\r\n    location_id?: number;\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class EsolveSessionService {\r\n    public session: Observable<EsolveSession>;\r\n\r\n    private _session: BehaviorSubject<EsolveSession>;\r\n    private key_expiration_timer: any;\r\n    private storage_key = 'ngEslvUserSession';\r\n    private is_browser: boolean;\r\n\r\n    public get currentSession(): EsolveSession {\r\n        return this._session.value;\r\n    }\r\n\r\n    constructor(\r\n        @Inject(PLATFORM_ID) private platformId: object,\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig,\r\n        private cookieService: EsolveCookieService,\r\n    ) {\r\n        this.setStorageKey();\r\n        this._session = new BehaviorSubject<EsolveSession>(new EsolveSession());\r\n        this.session = this._session.asObservable();\r\n        this.is_browser = isPlatformBrowser(this.platformId);\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            return;\r\n        }\r\n\r\n        let json_data = this.cookieService.get(this.storage_key);\r\n\r\n        if (json_data === '') {\r\n            const local_store_data = this.getBackup();\r\n\r\n            if (local_store_data) {\r\n                json_data = local_store_data;\r\n            }\r\n        }\r\n\r\n        const stored_session: EsolveStoredSession | null = (json_data ? JSON.parse(json_data) : null);\r\n\r\n        if (!stored_session) {\r\n            invalidSessionCallback();\r\n\r\n            return;\r\n        }\r\n\r\n        const expiration_date = new Date(stored_session.expiration_date);\r\n\r\n        const loaded_session = new EsolveSession(\r\n            stored_session.id,\r\n            stored_session.location_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    public handleSession(\r\n        user_id: number,\r\n        location_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(\r\n            user_id,\r\n            location_id,\r\n            key,\r\n            expiration_date,\r\n        );\r\n\r\n        const json_data = JSON.stringify(session);\r\n\r\n        this.cookieService.set(\r\n            this.storage_key,\r\n            json_data,\r\n            expiration_date,\r\n            '/',\r\n        );\r\n\r\n        this.setBackup(json_data);\r\n\r\n        this._session.next(session);\r\n        this.startTimer(expirationCallback, expires * 1000);\r\n    }\r\n\r\n    public handleUpdateSession(\r\n        {\r\n            user_id,\r\n            location_id,\r\n        }: SessionUpdateOptions,\r\n        callback?: () => void,\r\n    ): void {\r\n        const current_session = this.currentSession;\r\n\r\n        if (typeof user_id !== 'undefined') {\r\n            current_session.updateUser(user_id);\r\n        }\r\n\r\n        if (typeof location_id !== 'undefined') {\r\n            current_session.updateLocation(location_id);\r\n        }\r\n\r\n        const json_data = JSON.stringify(current_session);\r\n\r\n        this.cookieService.set(\r\n            this.storage_key,\r\n            json_data,\r\n            current_session.expiration_date,\r\n            '/',\r\n        );\r\n\r\n        this.setBackup(json_data);\r\n\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    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        if (this.is_browser) {\r\n            this.key_expiration_timer = setTimeout(callback, duration);\r\n        }\r\n    }\r\n\r\n    private getBackup(): string | null {\r\n        if (!this.is_browser) {\r\n            return null;\r\n        }\r\n\r\n        if (!localStorage) {\r\n            return null;\r\n        }\r\n\r\n        return localStorage.getItem(this.storage_key);\r\n    }\r\n\r\n    private setBackup(data: string): void {\r\n        if (!this.is_browser) {\r\n            return;\r\n        }\r\n\r\n        if (!localStorage) {\r\n            return;\r\n        }\r\n\r\n        localStorage.setItem(this.storage_key, data);\r\n    }\r\n}\r\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esolve-session.service.js","sourceRoot":"","sources":["../../../../../../libs/ng-esolve-connect/src/lib/session/esolve-session.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID } from '@angular/core';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\n\r\nimport { EsolveCookieService } from '../shared/cookie/esolve-cookie.service';\r\nimport { EsolveConnectConfig } from '../esolve-connect.config';\r\nimport { ESOLVE_CONNECT_CONFIG } from '../esolve-connect-config.constant';\r\nimport { EsolveStoredSession } from './esolve-stored-session.interface';\r\nimport { EsolveSession } from './esolve-session.model';\r\n\r\n// TODO: Rewrite session manager to use a pure rxjs solution.\r\n\r\ninterface SessionUpdateOptions {\r\n    user_id?: number;\r\n    location_id?: number;\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class EsolveSessionService {\r\n    public session: Observable<EsolveSession>;\r\n\r\n    private _session: BehaviorSubject<EsolveSession>;\r\n    private key_expiration_timer: any;\r\n    private storage_key = 'ngEslvUserSession';\r\n    private is_browser: boolean;\r\n\r\n    public get currentSession(): EsolveSession {\r\n        return this._session.value;\r\n    }\r\n\r\n    constructor(\r\n        @Inject(PLATFORM_ID) private platformId: object,\r\n        @Inject(ESOLVE_CONNECT_CONFIG) private config: EsolveConnectConfig,\r\n        private cookieService: EsolveCookieService,\r\n    ) {\r\n        this.setStorageKey();\r\n        this._session = new BehaviorSubject<EsolveSession>(new EsolveSession());\r\n        this.session = this._session.asObservable();\r\n        this.is_browser = isPlatformBrowser(this.platformId);\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 getCachedSession(): EsolveSession | null {\r\n        let json_data = this.cookieService.get(this.storage_key);\r\n\r\n        if (json_data === '') {\r\n            const local_store_data = this.getBackup();\r\n\r\n            if (local_store_data) {\r\n                json_data = local_store_data;\r\n            }\r\n        }\r\n\r\n        const stored_session: EsolveStoredSession | null = (json_data ? JSON.parse(json_data) : null);\r\n\r\n        if (!stored_session) {\r\n            return null;\r\n        }\r\n\r\n        const expiration_date = new Date(stored_session.expiration_date);\r\n\r\n        const loaded_session = new EsolveSession(\r\n            stored_session.id,\r\n            stored_session.location_id,\r\n            stored_session.key,\r\n            expiration_date,\r\n        );\r\n\r\n        return loaded_session;\r\n    }\r\n\r\n    public resetSessionCache(): void {\r\n        this.cookieService.delete(this.storage_key, '/');\r\n\r\n        this.removeBackup();\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            return;\r\n        }\r\n\r\n        let json_data = this.cookieService.get(this.storage_key);\r\n\r\n        if (json_data === '') {\r\n            const local_store_data = this.getBackup();\r\n\r\n            if (local_store_data) {\r\n                json_data = local_store_data;\r\n            }\r\n        }\r\n\r\n        const stored_session: EsolveStoredSession | null = (json_data ? JSON.parse(json_data) : null);\r\n\r\n        if (!stored_session) {\r\n            invalidSessionCallback();\r\n\r\n            return;\r\n        }\r\n\r\n        const expiration_date = new Date(stored_session.expiration_date);\r\n\r\n        const loaded_session = new EsolveSession(\r\n            stored_session.id,\r\n            stored_session.location_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    public handleSession(\r\n        user_id: number,\r\n        location_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(\r\n            user_id,\r\n            location_id,\r\n            key,\r\n            expiration_date,\r\n        );\r\n\r\n        const json_data = JSON.stringify(session);\r\n\r\n        this.cookieService.set(\r\n            this.storage_key,\r\n            json_data,\r\n            expiration_date,\r\n            '/',\r\n        );\r\n\r\n        this.setBackup(json_data);\r\n\r\n        this._session.next(session);\r\n        this.startTimer(expirationCallback, expires * 1000);\r\n    }\r\n\r\n    public handleUpdateSession(\r\n        {\r\n            user_id,\r\n            location_id,\r\n        }: SessionUpdateOptions,\r\n        callback?: () => void,\r\n    ): void {\r\n        const current_session = this.currentSession;\r\n\r\n        if (typeof user_id !== 'undefined') {\r\n            current_session.updateUser(user_id);\r\n        }\r\n\r\n        if (typeof location_id !== 'undefined') {\r\n            current_session.updateLocation(location_id);\r\n        }\r\n\r\n        const json_data = JSON.stringify(current_session);\r\n\r\n        this.cookieService.set(\r\n            this.storage_key,\r\n            json_data,\r\n            current_session.expiration_date,\r\n            '/',\r\n        );\r\n\r\n        this.setBackup(json_data);\r\n\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    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        if (this.is_browser) {\r\n            this.key_expiration_timer = setTimeout(callback, duration);\r\n        }\r\n    }\r\n\r\n    private getBackup(): string | null {\r\n        if (!this.is_browser) {\r\n            return null;\r\n        }\r\n\r\n        if (!localStorage) {\r\n            return null;\r\n        }\r\n\r\n        return localStorage.getItem(this.storage_key);\r\n    }\r\n\r\n    private setBackup(data: string): void {\r\n        if (!this.is_browser) {\r\n            return;\r\n        }\r\n\r\n        if (!localStorage) {\r\n            return;\r\n        }\r\n\r\n        localStorage.setItem(this.storage_key, data);\r\n    }\r\n\r\n    private removeBackup(): void {\r\n        if (!this.is_browser) {\r\n            return;\r\n        }\r\n\r\n        if (!localStorage) {\r\n            return;\r\n        }\r\n\r\n        localStorage.removeItem(this.storage_key);\r\n    }\r\n}\r\n"]}
|
|
@@ -168,6 +168,26 @@ class EsolveSessionService {
|
|
|
168
168
|
clearTimeout(this.key_expiration_timer);
|
|
169
169
|
}
|
|
170
170
|
}
|
|
171
|
+
getCachedSession() {
|
|
172
|
+
let json_data = this.cookieService.get(this.storage_key);
|
|
173
|
+
if (json_data === '') {
|
|
174
|
+
const local_store_data = this.getBackup();
|
|
175
|
+
if (local_store_data) {
|
|
176
|
+
json_data = local_store_data;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
const stored_session = (json_data ? JSON.parse(json_data) : null);
|
|
180
|
+
if (!stored_session) {
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
const expiration_date = new Date(stored_session.expiration_date);
|
|
184
|
+
const loaded_session = new EsolveSession(stored_session.id, stored_session.location_id, stored_session.key, expiration_date);
|
|
185
|
+
return loaded_session;
|
|
186
|
+
}
|
|
187
|
+
resetSessionCache() {
|
|
188
|
+
this.cookieService.delete(this.storage_key, '/');
|
|
189
|
+
this.removeBackup();
|
|
190
|
+
}
|
|
171
191
|
restore(expirationCallback, invalidSessionCallback) {
|
|
172
192
|
if (this.currentSession.valid) {
|
|
173
193
|
return;
|
|
@@ -249,6 +269,15 @@ class EsolveSessionService {
|
|
|
249
269
|
}
|
|
250
270
|
localStorage.setItem(this.storage_key, data);
|
|
251
271
|
}
|
|
272
|
+
removeBackup() {
|
|
273
|
+
if (!this.is_browser) {
|
|
274
|
+
return;
|
|
275
|
+
}
|
|
276
|
+
if (!localStorage) {
|
|
277
|
+
return;
|
|
278
|
+
}
|
|
279
|
+
localStorage.removeItem(this.storage_key);
|
|
280
|
+
}
|
|
252
281
|
}
|
|
253
282
|
EsolveSessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: EsolveSessionService, deps: [{ token: PLATFORM_ID }, { token: ESOLVE_CONNECT_CONFIG }, { token: EsolveCookieService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
254
283
|
EsolveSessionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: EsolveSessionService, providedIn: 'root' });
|
|
@@ -1712,6 +1741,11 @@ class EsolveAuthService {
|
|
|
1712
1741
|
this.errorHandler = errorHandler;
|
|
1713
1742
|
this.cookieService = cookieService;
|
|
1714
1743
|
}
|
|
1744
|
+
static preValidate(auth) {
|
|
1745
|
+
return () => {
|
|
1746
|
+
return auth.validateCachedTokens();
|
|
1747
|
+
};
|
|
1748
|
+
}
|
|
1715
1749
|
getAccessToken(email, password, anonymous = false) {
|
|
1716
1750
|
let params = new HttpParams();
|
|
1717
1751
|
if (anonymous) {
|
|
@@ -1740,11 +1774,14 @@ class EsolveAuthService {
|
|
|
1740
1774
|
}));
|
|
1741
1775
|
}
|
|
1742
1776
|
autoLogin() {
|
|
1743
|
-
|
|
1744
|
-
|
|
1745
|
-
|
|
1746
|
-
|
|
1747
|
-
|
|
1777
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
1778
|
+
yield this.validateCachedTokens();
|
|
1779
|
+
this.session.restore(this.handleExpiration(), () => {
|
|
1780
|
+
firstValueFrom(this.getAccessToken('', '', true)).then(() => {
|
|
1781
|
+
// empty
|
|
1782
|
+
}, (error) => {
|
|
1783
|
+
console.error(error);
|
|
1784
|
+
});
|
|
1748
1785
|
});
|
|
1749
1786
|
});
|
|
1750
1787
|
}
|
|
@@ -1802,6 +1839,26 @@ class EsolveAuthService {
|
|
|
1802
1839
|
throw new Error('Invalid response');
|
|
1803
1840
|
});
|
|
1804
1841
|
}
|
|
1842
|
+
validateCachedTokens() {
|
|
1843
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
1844
|
+
let valid = false;
|
|
1845
|
+
try {
|
|
1846
|
+
const session = this.session.getCachedSession();
|
|
1847
|
+
if (!session) {
|
|
1848
|
+
throw null;
|
|
1849
|
+
}
|
|
1850
|
+
const result = yield firstValueFrom(this.checkAccessToken(session));
|
|
1851
|
+
if (!result.key) {
|
|
1852
|
+
throw null;
|
|
1853
|
+
}
|
|
1854
|
+
valid = true;
|
|
1855
|
+
}
|
|
1856
|
+
catch (error) {
|
|
1857
|
+
this.session.resetSessionCache();
|
|
1858
|
+
}
|
|
1859
|
+
return valid;
|
|
1860
|
+
});
|
|
1861
|
+
}
|
|
1805
1862
|
checkAccessToken(session) {
|
|
1806
1863
|
var _a;
|
|
1807
1864
|
session = session || this.session.currentSession;
|
|
@@ -5723,4 +5780,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
5723
5780
|
|
|
5724
5781
|
export { ESOLVE_CONNECT_CONFIG, EsolveAccountConfirmationResult, EsolveAccountService, EsolveAdditionalStockImage, EsolveAddress, EsolveAddressResult, EsolveAsset, EsolveAssetsService, EsolveAuthService, EsolveBankingDetails, EsolveBanner, EsolveBannerImage, EsolveBannerImageHotspot, EsolveBannerService, EsolveCartItem, EsolveCartService, EsolveCartStockItem, EsolveCartTotals, EsolveCategoryTreeItem, EsolveCategoryTreeService, EsolveChangePasswordResult, EsolveCheckoutResult, EsolveColour, EsolveCookieService, EsolveCoupon, EsolveCouponsService, EsolveDependantItem, EsolveEmptyCartResult, EsolveEmptyWishlistResult, EsolveEnquiryResult, EsolveEnquiryService, EsolveErrorHandlerService, EsolveFilterFactory, EsolveGeocodeAddressResult, EsolveGeocodeCoordsResult, EsolveGeocodeResult, EsolveGeocoderService, EsolveHttpError, EsolveLinkedAsset, EsolveLinkedStockItem, EsolveList, EsolveLocation, EsolveLocationAddress, EsolveLocationContactInfo, EsolveLocationGEO, EsolveLocationPOBoxAddress, EsolveLocationTradingDay, EsolveLocationTradingTimes, EsolveLocationsService, EsolveManufacturer, EsolveManufacturersService, EsolveMediaStockItem, EsolveMenuItem, EsolveMenuService, EsolveMultipleSelectFilter, EsolveNewsArticle, EsolveNewsArticleAuthor, EsolveNewsArticleList, EsolveNewsGroup, EsolveNewsService, EsolvePaymentMethod, EsolvePaymentResult, EsolvePaymentService, EsolveRange, EsolveRangeFilter, EsolveRangesService, EsolveRecipeStockItem, EsolveRegistrationResult, EsolveResetPasswordResult, EsolveResponseHandlerService, EsolveResponseResult, EsolveResult, EsolveSeoInfo, EsolveSeoService, EsolveSession, EsolveSessionService, EsolveShippingCost, EsolveShippingMethod, EsolveShippingService, EsolveShippingTotals, EsolveSingleSelectFilter, EsolveSpecial, EsolveSpecialDates, EsolveSpecialImage, EsolveSpecialImageCollection, EsolveSpecialsService, EsolveStatement, EsolveStatementAgeing, EsolveStatementBalances, EsolveStatementTransaction, EsolveStockBadge, EsolveStockGroup, EsolveStockGroupItem, EsolveStockImage, EsolveStockImageCollection, EsolveStockItem, EsolveStockItemBase, EsolveStockItemList, EsolveStockLeadTimes, EsolveStockPrice, EsolveStockService, EsolveSupplier, EsolveSuppliersService, EsolveTag, EsolveTagsService, EsolveTopic, EsolveTopicService, EsolveTransaction, EsolveTransactionAddress, EsolveTransactionAnalyticsData, EsolveTransactionClient, EsolveTransactionItem, EsolveTransactionItemPrice, EsolveTransactionList, EsolveTransactionLocation, EsolveTransactionPaymentMethod, EsolveTransactionShippingMethod, EsolveTransactionUser, EsolveUserAccount, EsolveUserAccountBusiness, EsolveUserAccountContact, EsolveUserAccountResult, EsolveUserClientAccount, EsolveUserClientAccountBalances, EsolveVaultItem, EsolveVaultItemResult, EsolveWishlistItem, EsolveWishlistService, NgEsolveConnectModule };
|
|
5725
5782
|
//# sourceMappingURL=esolve-ng-esolve-connect.mjs.map
|
|
5726
|
-
//# sourceMappingURL=esolve-ng-esolve-connect.mjs.map
|