ngx-histaff-alpha 1.6.3 → 1.6.5

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.
@@ -64,7 +64,7 @@ export class ResponseInterceptor {
64
64
  It is highly recommended to change the back end code. Otherwise your code might not work, or does work but NOT CORRECTLY!
65
65
  `, noneAutoClosedAlertOptions);
66
66
  }
67
- if (isDevMode() && event.url?.toLowerCase().indexOf('/api/grpc') > 0) {
67
+ if (event.url?.toLowerCase().indexOf('/api/grpc') > 0) {
68
68
  const newInnerBody = this.grpcService.convertToCamelCase(JSON.parse(event.body?.innerBody));
69
69
  return event.clone({ body: {
70
70
  ...event.body,
@@ -87,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
87
87
  providedIn: 'root'
88
88
  }]
89
89
  }], ctorParameters: () => [{ type: i1.AlertService }, { type: i2.AppConfigService }, { type: i3.ResponseService }, { type: i4.GrpcService }, { type: i5.MultiLanguageService }] });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response-interceptor.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/http-interceptors/response-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport {\r\n    HttpInterceptor, HttpHandler, HttpRequest, HttpEvent, HttpResponse\r\n} from '@angular/common/http';\r\n\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { Observable, filter, map } from 'rxjs';\r\nimport { noneAutoClosedAlertOptions } from '../constants/alertOptions';\r\nimport { AppConfigService } from '../services/app-config.service';\r\nimport { ResponseService } from '../services/response.service';\r\nimport { MultiLanguageService } from '../services/multi-language.service';\r\nimport { IFormatedResponse } from '../interfaces/IFormatedResponse';\r\nimport { GrpcService } from '../services/grpc.service';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class ResponseInterceptor implements HttpInterceptor {\r\n\r\n    constructor(\r\n        private alertService: AlertService,\r\n        private appConfigService: AppConfigService,\r\n        private responseService: ResponseService,\r\n        private grpcService: GrpcService,\r\n        private mls: MultiLanguageService) { }\r\n\r\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n\r\n\r\n\r\n        return next.handle(req).pipe(\r\n            filter(event => event instanceof HttpResponse),\r\n            map(event => {\r\n                if (event instanceof HttpResponse) {\r\n                    let body: any = null;\r\n\r\n                    if (event.ok && event.status === 200) {\r\n                        body = event.body;\r\n                        this.responseService.resolve(body);\r\n                    } else {\r\n                        if (isDevMode()) {\r\n                            this.alertService.error(JSON.stringify(event, null, 2), noneAutoClosedAlertOptions)\r\n                        }\r\n                    }\r\n\r\n                    if (isDevMode() && event.url?.indexOf(`${this.appConfigService.BASE_URL}/static/excel-templates/`)! < 0 && event.ok && event.status === 200 && (event.body.innerBody?.innerBody !== undefined)) {\r\n                        this.alertService.error(`\r\n                    Nested innerBody from ${event.url} response\r\n                    innerBody bị lồng trong phản hồi từ ${event.url}  \r\n                    `, noneAutoClosedAlertOptions)\r\n                    }\r\n                    if (isDevMode()\r\n                        && event.url?.indexOf(`${this.appConfigService.BASE_URL}/static/excel-templates/`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/GenerateTemplate`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/ExportCorePageListGridToExcel`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/ImportXlsxToDb`)! < 0\r\n                        && event.url?.indexOf(`XlsxReport/GetReport`)! < 0\r\n                        && event.url?.indexOf(`Get2C_TCTW_98`)! < 0\r\n                        && event.url?.indexOf(`Get2C_BNV_2008`)! < 0\r\n                        && event.url?.indexOf(`PrintContractInfo`)! < 0\r\n                        && event.url?.indexOf(`PrintHuWorking`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportSalary`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportTimeSheet`)! < 0\r\n                        && event.url?.indexOf(`ImportTimeSheetDaily`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportShiftSort`)! < 0\r\n                        && event.url?.indexOf(`ImportShiftSort`)! < 0\r\n                        && event.url?.indexOf(`ImportDeclareSeniority`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportBasic`)! < 0\r\n                        && event.url?.indexOf(`ImportRegisterLeave`)! < 0\r\n                        && event.url?.indexOf(`ImportRegisterOT`)! < 0\r\n                        && event.url?.indexOf(`ExportTemp`)! < 0\r\n                        && event.url?.indexOf(`ImportTemp`)! < 0\r\n                        && event.url?.indexOf(`Print`)! < 0\r\n                        && event.url?.indexOf(`FileDownload`)! < 0\r\n                        && event.ok && event.status === 200 && (event.body.innerBody === undefined || event.body.errorType === undefined || event.body.messageCode === undefined)) {\r\n                        this.alertService.error(`\r\n                    It looks like API controller with endpoint ${event.url} does not follow the rule of the App (must return Ok(FormatedResponse))\r\n                    It is highly recommended to change the back end code. Otherwise your code might not work, or does work but NOT CORRECTLY!\r\n                    `, noneAutoClosedAlertOptions)\r\n                    }\r\n\r\n                    if (isDevMode() && event.url?.toLowerCase().indexOf('/api/grpc')! > 0) {\r\n                        const newInnerBody = this.grpcService.convertToCamelCase(JSON.parse((event.body as IFormatedResponse)?.innerBody));\r\n                        return event.clone({ body: {\r\n                            ...event.body,\r\n                            innerBody: newInnerBody\r\n                        }})\r\n                    } else {\r\n                        return event;\r\n                    }\r\n                }\r\n\r\n                return event;\r\n            })\r\n        );\r\n    }\r\n}"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response-interceptor.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/http-interceptors/response-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport {\r\n    HttpInterceptor, HttpHandler, HttpRequest, HttpEvent, HttpResponse\r\n} from '@angular/common/http';\r\n\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { Observable, filter, map } from 'rxjs';\r\nimport { noneAutoClosedAlertOptions } from '../constants/alertOptions';\r\nimport { AppConfigService } from '../services/app-config.service';\r\nimport { ResponseService } from '../services/response.service';\r\nimport { MultiLanguageService } from '../services/multi-language.service';\r\nimport { IFormatedResponse } from '../interfaces/IFormatedResponse';\r\nimport { GrpcService } from '../services/grpc.service';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class ResponseInterceptor implements HttpInterceptor {\r\n\r\n    constructor(\r\n        private alertService: AlertService,\r\n        private appConfigService: AppConfigService,\r\n        private responseService: ResponseService,\r\n        private grpcService: GrpcService,\r\n        private mls: MultiLanguageService) { }\r\n\r\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n\r\n\r\n\r\n        return next.handle(req).pipe(\r\n            filter(event => event instanceof HttpResponse),\r\n            map(event => {\r\n                if (event instanceof HttpResponse) {\r\n                    let body: any = null;\r\n\r\n                    if (event.ok && event.status === 200) {\r\n                        body = event.body;\r\n                        this.responseService.resolve(body);\r\n                    } else {\r\n                        if (isDevMode()) {\r\n                            this.alertService.error(JSON.stringify(event, null, 2), noneAutoClosedAlertOptions)\r\n                        }\r\n                    }\r\n\r\n                    if (isDevMode() && event.url?.indexOf(`${this.appConfigService.BASE_URL}/static/excel-templates/`)! < 0 && event.ok && event.status === 200 && (event.body.innerBody?.innerBody !== undefined)) {\r\n                        this.alertService.error(`\r\n                    Nested innerBody from ${event.url} response\r\n                    innerBody bị lồng trong phản hồi từ ${event.url}  \r\n                    `, noneAutoClosedAlertOptions)\r\n                    }\r\n                    if (isDevMode()\r\n                        && event.url?.indexOf(`${this.appConfigService.BASE_URL}/static/excel-templates/`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/GenerateTemplate`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/ExportCorePageListGridToExcel`)! < 0\r\n                        && event.url?.indexOf(`Xlsx/ImportXlsxToDb`)! < 0\r\n                        && event.url?.indexOf(`XlsxReport/GetReport`)! < 0\r\n                        && event.url?.indexOf(`Get2C_TCTW_98`)! < 0\r\n                        && event.url?.indexOf(`Get2C_BNV_2008`)! < 0\r\n                        && event.url?.indexOf(`PrintContractInfo`)! < 0\r\n                        && event.url?.indexOf(`PrintHuWorking`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportSalary`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportTimeSheet`)! < 0\r\n                        && event.url?.indexOf(`ImportTimeSheetDaily`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportShiftSort`)! < 0\r\n                        && event.url?.indexOf(`ImportShiftSort`)! < 0\r\n                        && event.url?.indexOf(`ImportDeclareSeniority`)! < 0\r\n                        && event.url?.indexOf(`ExportTempImportBasic`)! < 0\r\n                        && event.url?.indexOf(`ImportRegisterLeave`)! < 0\r\n                        && event.url?.indexOf(`ImportRegisterOT`)! < 0\r\n                        && event.url?.indexOf(`ExportTemp`)! < 0\r\n                        && event.url?.indexOf(`ImportTemp`)! < 0\r\n                        && event.url?.indexOf(`Print`)! < 0\r\n                        && event.url?.indexOf(`FileDownload`)! < 0\r\n                        && event.ok && event.status === 200 && (event.body.innerBody === undefined || event.body.errorType === undefined || event.body.messageCode === undefined)) {\r\n                        this.alertService.error(`\r\n                    It looks like API controller with endpoint ${event.url} does not follow the rule of the App (must return Ok(FormatedResponse))\r\n                    It is highly recommended to change the back end code. Otherwise your code might not work, or does work but NOT CORRECTLY!\r\n                    `, noneAutoClosedAlertOptions)\r\n                    }\r\n\r\n                    if (event.url?.toLowerCase().indexOf('/api/grpc')! > 0) {\r\n                        const newInnerBody = this.grpcService.convertToCamelCase(JSON.parse((event.body as IFormatedResponse)?.innerBody));\r\n                        return event.clone({ body: {\r\n                            ...event.body,\r\n                            innerBody: newInnerBody\r\n                        }})\r\n                    } else {\r\n                        return event;\r\n                    }\r\n                }\r\n\r\n                return event;\r\n            })\r\n        );\r\n    }\r\n}"]}
@@ -41,14 +41,16 @@ export class TokenInterceptor {
41
41
  console.log("app.config.json excluded");
42
42
  return next.handle(req);
43
43
  }
44
+ /* WHY???
44
45
  if (req.url.includes("GenerateTemplate")) {
45
- console.log("GenerateTemplate excluded");
46
+ console.log("GenerateTemplate excluded")
46
47
  return next.handle(req);
47
48
  }
48
49
  if (req.url.includes("ExportCorePageListGridToExcel")) {
49
- console.log("ExportCorePageListGridToExcel excluded");
50
+ console.log("ExportCorePageListGridToExcel excluded")
50
51
  return next.handle(req);
51
52
  }
53
+ */
52
54
  let ok;
53
55
  // extend server response observable with logging
54
56
  return next.handle(req)
@@ -98,7 +100,7 @@ export class TokenInterceptor {
98
100
  switchMap(() => next.handle(this.addAuthenticationToken(req))));
99
101
  }
100
102
  else {
101
- console.error(response.error?.message.toUpperCase() || response);
103
+ console.error(response.error?.message?.toUpperCase() || response);
102
104
  this.refreshTokenInProgress = true;
103
105
  // Set the refreshTokenSubject to null
104
106
  // so that subsequent API calls will wait
@@ -147,4 +149,4 @@ export class TokenInterceptor {
147
149
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: TokenInterceptor, decorators: [{
148
150
  type: Injectable
149
151
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.AppInitializationService }, { type: i3.Router }] });
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token-interceptor.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/http-interceptors/token-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\nTannv: This code is based on the original blog post of Alexandru Bereghici\r\nhttps://itnext.io/angular-tutorial-implement-refresh-token-with-httpinterceptor-bfa27b966f57\r\n*/\r\n\r\nimport { filter, finalize, switchMap, tap, take } from 'rxjs/operators';\r\nimport { Injectable } from '@angular/core';\r\nimport { Observable, BehaviorSubject, throwError, catchError } from 'rxjs';\r\nimport { HttpEvent } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\n\r\nimport { AuthService } from '../services/auth.service';\r\nimport { AppInitializationService } from '../services/app-initialization.service';\r\n\r\nimport {\r\n    HttpInterceptor, HttpHandler, HttpRequest, HttpResponse\r\n} from '@angular/common/http';\r\n\r\n@Injectable()\r\nexport class TokenInterceptor implements HttpInterceptor {\r\n\r\n    addAuthenticationToken(request: HttpRequest<any>): HttpRequest<any> {\r\n        // Get access token from Local Storage\r\n        const accessToken = this.authService.getAuthorizationToken();\r\n\r\n        // If access token is null this means that user is not logged in\r\n        // And we return the original request\r\n        if (!accessToken) {\r\n            return request;\r\n        }\r\n\r\n        // We clone the request, because the original request is immutable\r\n        return request.clone({\r\n            headers: request.headers.set('Authorization', 'Bearer ' + accessToken)\r\n        });\r\n    }\r\n\r\n    private refreshTokenInProgress = false;\r\n    // Refresh Token Subject tracks the current token, \r\n    // or is null if no token is currently available (e.g. refresh pending).\r\n    private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(\r\n        null\r\n    );\r\n\r\n    constructor(\r\n        private authService: AuthService,\r\n        private appInitializationService: AppInitializationService,\r\n        private router: Router\r\n    ) {\r\n    }\r\n\r\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n        if (req.url === undefined) {\r\n            return next.handle(req);\r\n        }\r\n\r\n        if (req.url.includes(\"app.config.json\")) {\r\n            console.log(\"app.config.json excluded\")\r\n            return next.handle(req);\r\n        }\r\n        if (req.url.includes(\"GenerateTemplate\")) {\r\n            console.log(\"GenerateTemplate excluded\")\r\n            return next.handle(req);\r\n        }\r\n        if (req.url.includes(\"ExportCorePageListGridToExcel\")) {\r\n            console.log(\"ExportCorePageListGridToExcel excluded\")\r\n            return next.handle(req);\r\n        }\r\n\r\n        let ok: string;\r\n        // extend server response observable with logging\r\n        return next.handle(req)\r\n            .pipe(\r\n                tap({\r\n                    // Succeeds when there is a response; ignore other events\r\n                    next: event => (ok = event instanceof HttpResponse ? 'succeeded' : ''),\r\n                    error: () => { } // we do not implement the logic here\r\n                }),\r\n                // But here:\r\n                // Operation failed; error is an HttpErrorResponse\r\n                catchError((response: any) => {\r\n\r\n                    console.log(\"TokenInterceptor Error: \", req, response)\r\n\r\n                    // We don't want to refresh token for some requests \r\n                    // like login or refresh token itself\r\n                    // So we verify url and we throw an error if it's the case\r\n                    if (\r\n                        req.url.toUpperCase().includes('LOGIN') ||\r\n                        req.url.toUpperCase().includes('REFRESH_TOKEN') ||\r\n                        req.url.toUpperCase().includes('REFRESHTOKEN')\r\n                    ) {\r\n                        // We do another check to see if refresh token failed\r\n                        // In this case we want to logout user and to redirect it to login page\r\n\r\n                        if (\r\n                            req.url.toUpperCase().includes('REFRESH_TOKEN') ||\r\n                            req.url.toUpperCase().includes('REFRESHTOKEN')\r\n\r\n                        ) {\r\n                            this.appInitializationService.initializing$.next(false);\r\n                            this.authService.userLogout().subscribe(x => {\r\n                                if (x.ok && x.status === 200) {\r\n                                    this.authService.postLogout();\r\n                                }\r\n                            })\r\n\r\n                        }\r\n\r\n                        return throwError(() => new Error(JSON.stringify(response)));\r\n\r\n                    }\r\n\r\n                    // If error status is different than 401 \r\n                    // we want to skip refresh token\r\n                    // So we check that and throw the error if it's the case\r\n                    if (response.status !== 401) {\r\n                        return throwError(() => new Error(response.error));\r\n                    }\r\n\r\n                    if (this.refreshTokenInProgress) {\r\n                        // If refreshTokenInProgress is true, we will wait until refreshTokenSubject has a non-null value\r\n                        // – which means the new token is ready and we can retry the request again\r\n                        return this.refreshTokenSubject.pipe(\r\n                            // filter: Emit values that pass the provided condition\r\n                            filter(result => result !== null),\r\n\r\n                            take(1),\r\n                            /*\r\n                            The main difference between switchMap and other flattening operators is the cancelling effect. On each emission the previous inner observable (the result of the function you supplied) is cancelled and the new observable is subscribed. You can remember this by the phrase switch to a new observable.\r\n                            */\r\n                            switchMap(() => next.handle(this.addAuthenticationToken(req)))\r\n                        )\r\n                    } else {\r\n                        console.error(response.error?.message.toUpperCase() || response);\r\n                        this.refreshTokenInProgress = true;\r\n\r\n                        // Set the refreshTokenSubject to null \r\n                        // so that subsequent API calls will wait\r\n                        // until the new token has been retrieved\r\n                        this.refreshTokenSubject.next(null);\r\n\r\n                        // Call auth.refreshAccessToken\r\n                        // (this is an Observable that will be returned)\r\n\r\n                        const refreshTokenReq = this.authService.tryRestoreSession();\r\n\r\n                        return refreshTokenReq.pipe(\r\n                            /*\r\n                            The main difference between switchMap and other flattening operators is the cancelling effect. On each emission the previous inner observable (the result of the function you supplied) is cancelled and the new observable is subscribed. You can remember this by the phrase switch to a new observable.\r\n                            */\r\n                            switchMap((response: any) => {\r\n                                let token = '';\r\n\r\n                                if (response.ok && response.status === 200) {\r\n                                    this.authService.data$.next(response.body);\r\n                                    this.authService.authenticated$.next(true);\r\n                                    token = response.body.jwtToken;\r\n                                }\r\n\r\n                                // When the call to refreshToken completes \r\n                                // we reset the refreshTokenInProgress to false\r\n                                // for the next time the token needs to be refreshed\r\n                                this.refreshTokenInProgress = false;\r\n                                this.refreshTokenSubject.next(token);\r\n                                const newReq = this.addAuthenticationToken(req);\r\n                                return next.handle(newReq);\r\n                            }),\r\n                            catchError((err: any) => {\r\n                                this.refreshTokenInProgress = false;\r\n\r\n                                console.log(\"refreshTokenReq catchError\", err)\r\n                                debugger\r\n                                this.authService.userLogout().subscribe(x => {\r\n                                    if (x.ok && x.status === 200) {\r\n                                        this.authService.postLogout();\r\n                                    }\r\n                                })\r\n\r\n                                return throwError(() => new Error(err));\r\n                            })\r\n                        )\r\n                    }\r\n                }),\r\n                // Log when response observable either completes or errors\r\n                finalize(() => { })\r\n            );\r\n    }\r\n\r\n}"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token-interceptor.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/http-interceptors/token-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\nTannv: This code is based on the original blog post of Alexandru Bereghici\r\nhttps://itnext.io/angular-tutorial-implement-refresh-token-with-httpinterceptor-bfa27b966f57\r\n*/\r\n\r\nimport { filter, finalize, switchMap, tap, take } from 'rxjs/operators';\r\nimport { Injectable } from '@angular/core';\r\nimport { Observable, BehaviorSubject, throwError, catchError } from 'rxjs';\r\nimport { HttpEvent } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\n\r\nimport { AuthService } from '../services/auth.service';\r\nimport { AppInitializationService } from '../services/app-initialization.service';\r\n\r\nimport {\r\n    HttpInterceptor, HttpHandler, HttpRequest, HttpResponse\r\n} from '@angular/common/http';\r\n\r\n@Injectable()\r\nexport class TokenInterceptor implements HttpInterceptor {\r\n\r\n    addAuthenticationToken(request: HttpRequest<any>): HttpRequest<any> {\r\n        // Get access token from Local Storage\r\n        const accessToken = this.authService.getAuthorizationToken();\r\n\r\n        // If access token is null this means that user is not logged in\r\n        // And we return the original request\r\n        if (!accessToken) {\r\n            return request;\r\n        }\r\n\r\n        // We clone the request, because the original request is immutable\r\n        return request.clone({\r\n            headers: request.headers.set('Authorization', 'Bearer ' + accessToken)\r\n        });\r\n    }\r\n\r\n    private refreshTokenInProgress = false;\r\n    // Refresh Token Subject tracks the current token, \r\n    // or is null if no token is currently available (e.g. refresh pending).\r\n    private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(\r\n        null\r\n    );\r\n\r\n    constructor(\r\n        private authService: AuthService,\r\n        private appInitializationService: AppInitializationService,\r\n        private router: Router\r\n    ) {\r\n    }\r\n\r\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n\r\n        if (req.url === undefined) {\r\n            return next.handle(req);\r\n        }\r\n\r\n        if (req.url.includes(\"app.config.json\")) {\r\n            console.log(\"app.config.json excluded\")\r\n            return next.handle(req);\r\n        }\r\n\r\n        /* WHY???\r\n        if (req.url.includes(\"GenerateTemplate\")) {\r\n            console.log(\"GenerateTemplate excluded\")\r\n            return next.handle(req);\r\n        }\r\n        if (req.url.includes(\"ExportCorePageListGridToExcel\")) {\r\n            console.log(\"ExportCorePageListGridToExcel excluded\")\r\n            return next.handle(req);\r\n        }\r\n        */\r\n\r\n        let ok: string;\r\n        // extend server response observable with logging\r\n        return next.handle(req)\r\n            .pipe(\r\n                tap({\r\n                    // Succeeds when there is a response; ignore other events\r\n                    next: event => (ok = event instanceof HttpResponse ? 'succeeded' : ''),\r\n                    error: () => { } // we do not implement the logic here\r\n                }),\r\n                // But here:\r\n                // Operation failed; error is an HttpErrorResponse\r\n                catchError((response: any) => {\r\n\r\n                    console.log(\"TokenInterceptor Error: \", req, response)\r\n\r\n                    // We don't want to refresh token for some requests \r\n                    // like login or refresh token itself\r\n                    // So we verify url and we throw an error if it's the case\r\n                    if (\r\n                        req.url.toUpperCase().includes('LOGIN') ||\r\n                        req.url.toUpperCase().includes('REFRESH_TOKEN') ||\r\n                        req.url.toUpperCase().includes('REFRESHTOKEN')\r\n                    ) {\r\n                        // We do another check to see if refresh token failed\r\n                        // In this case we want to logout user and to redirect it to login page\r\n\r\n                        if (\r\n                            req.url.toUpperCase().includes('REFRESH_TOKEN') ||\r\n                            req.url.toUpperCase().includes('REFRESHTOKEN')\r\n\r\n                        ) {\r\n                            this.appInitializationService.initializing$.next(false);\r\n                            this.authService.userLogout().subscribe(x => {\r\n                                if (x.ok && x.status === 200) {\r\n                                    this.authService.postLogout();\r\n                                }\r\n                            })\r\n\r\n                        }\r\n\r\n                        return throwError(() => new Error(JSON.stringify(response)));\r\n\r\n                    }\r\n\r\n                    // If error status is different than 401 \r\n                    // we want to skip refresh token\r\n                    // So we check that and throw the error if it's the case\r\n                    if (response.status !== 401) {\r\n                        return throwError(() => new Error(response.error));\r\n                    }\r\n\r\n                    if (this.refreshTokenInProgress) {\r\n                        // If refreshTokenInProgress is true, we will wait until refreshTokenSubject has a non-null value\r\n                        // – which means the new token is ready and we can retry the request again\r\n                        return this.refreshTokenSubject.pipe(\r\n                            // filter: Emit values that pass the provided condition\r\n                            filter(result => result !== null),\r\n\r\n                            take(1),\r\n                            /*\r\n                            The main difference between switchMap and other flattening operators is the cancelling effect. On each emission the previous inner observable (the result of the function you supplied) is cancelled and the new observable is subscribed. You can remember this by the phrase switch to a new observable.\r\n                            */\r\n                            switchMap(() => next.handle(this.addAuthenticationToken(req)))\r\n                        )\r\n                    } else {\r\n                        console.error(response.error?.message?.toUpperCase() || response);\r\n                        this.refreshTokenInProgress = true;\r\n\r\n                        // Set the refreshTokenSubject to null \r\n                        // so that subsequent API calls will wait\r\n                        // until the new token has been retrieved\r\n                        this.refreshTokenSubject.next(null);\r\n\r\n                        // Call auth.refreshAccessToken\r\n                        // (this is an Observable that will be returned)\r\n\r\n                        const refreshTokenReq = this.authService.tryRestoreSession();\r\n\r\n                        return refreshTokenReq.pipe(\r\n                            /*\r\n                            The main difference between switchMap and other flattening operators is the cancelling effect. On each emission the previous inner observable (the result of the function you supplied) is cancelled and the new observable is subscribed. You can remember this by the phrase switch to a new observable.\r\n                            */\r\n                            switchMap((response: any) => {\r\n                                let token = '';\r\n\r\n                                if (response.ok && response.status === 200) {\r\n                                    this.authService.data$.next(response.body);\r\n                                    this.authService.authenticated$.next(true);\r\n                                    token = response.body.jwtToken;\r\n                                }\r\n\r\n                                // When the call to refreshToken completes \r\n                                // we reset the refreshTokenInProgress to false\r\n                                // for the next time the token needs to be refreshed\r\n                                this.refreshTokenInProgress = false;\r\n                                this.refreshTokenSubject.next(token);\r\n                                const newReq = this.addAuthenticationToken(req);\r\n                                return next.handle(newReq);\r\n                            }),\r\n                            catchError((err: any) => {\r\n                                this.refreshTokenInProgress = false;\r\n\r\n                                console.log(\"refreshTokenReq catchError\", err)\r\n                                debugger\r\n                                this.authService.userLogout().subscribe(x => {\r\n                                    if (x.ok && x.status === 200) {\r\n                                        this.authService.postLogout();\r\n                                    }\r\n                                })\r\n\r\n                                return throwError(() => new Error(err));\r\n                            })\r\n                        )\r\n                    }\r\n                }),\r\n                // Log when response observable either completes or errors\r\n                finalize(() => { })\r\n            );\r\n    }\r\n\r\n}"]}
@@ -2804,14 +2804,16 @@ class TokenInterceptor {
2804
2804
  console.log("app.config.json excluded");
2805
2805
  return next.handle(req);
2806
2806
  }
2807
+ /* WHY???
2807
2808
  if (req.url.includes("GenerateTemplate")) {
2808
- console.log("GenerateTemplate excluded");
2809
+ console.log("GenerateTemplate excluded")
2809
2810
  return next.handle(req);
2810
2811
  }
2811
2812
  if (req.url.includes("ExportCorePageListGridToExcel")) {
2812
- console.log("ExportCorePageListGridToExcel excluded");
2813
+ console.log("ExportCorePageListGridToExcel excluded")
2813
2814
  return next.handle(req);
2814
2815
  }
2816
+ */
2815
2817
  let ok;
2816
2818
  // extend server response observable with logging
2817
2819
  return next.handle(req)
@@ -2861,7 +2863,7 @@ class TokenInterceptor {
2861
2863
  switchMap(() => next.handle(this.addAuthenticationToken(req))));
2862
2864
  }
2863
2865
  else {
2864
- console.error(response.error?.message.toUpperCase() || response);
2866
+ console.error(response.error?.message?.toUpperCase() || response);
2865
2867
  this.refreshTokenInProgress = true;
2866
2868
  // Set the refreshTokenSubject to null
2867
2869
  // so that subsequent API calls will wait
@@ -2999,7 +3001,7 @@ class ResponseInterceptor {
2999
3001
  It is highly recommended to change the back end code. Otherwise your code might not work, or does work but NOT CORRECTLY!
3000
3002
  `, noneAutoClosedAlertOptions);
3001
3003
  }
3002
- if (isDevMode() && event.url?.toLowerCase().indexOf('/api/grpc') > 0) {
3004
+ if (event.url?.toLowerCase().indexOf('/api/grpc') > 0) {
3003
3005
  const newInnerBody = this.grpcService.convertToCamelCase(JSON.parse(event.body?.innerBody));
3004
3006
  return event.clone({ body: {
3005
3007
  ...event.body,