@progress-chef/platform-http-interceptor 0.0.16 → 0.0.18

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.
@@ -1,5 +1,5 @@
1
1
  import { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';
2
- import { catchError, throwError, timer } from 'rxjs';
2
+ import { catchError, throwError } from 'rxjs';
3
3
  import { Injectable } from '@angular/core';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/router";
@@ -14,7 +14,9 @@ export class HttpAuthInterceptor {
14
14
  this.isSessionExpired = false;
15
15
  }
16
16
  intercept(request, next) {
17
- this.triggerRefreshTokenTimer();
17
+ // function to check for the refresh token using referesh token service
18
+ console.log(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> intercept calling");
19
+ this.refreshTokenService.checkForRefresh();
18
20
  let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);
19
21
  let authReq = request;
20
22
  if (authToken) {
@@ -67,18 +69,6 @@ export class HttpAuthInterceptor {
67
69
  return throwError(() => error);
68
70
  }));
69
71
  }
70
- refreshToken() {
71
- const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);
72
- if (!baseUrl)
73
- throw new Error('The backend or server base URL is missing in Local Storage');
74
- this.refreshTokenService.refreshToken({ platformServiceApiBaseUrls: baseUrl });
75
- }
76
- triggerRefreshTokenTimer() {
77
- const refreshTokenTime = 20 * 1000;
78
- timer(0, refreshTokenTime).subscribe(() => {
79
- this.refreshToken();
80
- });
81
- }
82
72
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.Router }, { token: i2.ToastNotificationService }, { token: i3.RefreshTokenService }], target: i0.ɵɵFactoryTarget.Injectable }); }
83
73
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HttpAuthInterceptor, providedIn: 'root' }); }
84
74
  }
@@ -88,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
88
78
  providedIn: 'root'
89
79
  }]
90
80
  }], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ToastNotificationService }, { type: i3.RefreshTokenService }]; } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth.interceptor.js","sourceRoot":"","sources":["../../../../projects/platform-http-interceptor/src/lib/http-auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  HttpErrorResponse,\n  HttpEvent,\n  HttpHandler,\n  HttpInterceptor,\n  HttpRequest\n} from '@angular/common/http';\nimport { RefreshTokenService } from '@progress-chef/platform-refresh-token-service'\nimport { Router } from '@angular/router';\nimport { ToastNotificationService } from '@progress-chef/platform-shared-components';\nimport { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';\nimport { Observable, catchError, throwError, timer } from 'rxjs';\nimport { Injectable } from '@angular/core';\n\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class HttpAuthInterceptor implements HttpInterceptor {\n  authTokenSet = new Set();\n  isSessionExpired = false;\n  constructor(\n    private router: Router,\n    private toastNotificationService: ToastNotificationService, \n    private refreshTokenService: RefreshTokenService,\n  ) { }\n\n  intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n    this.triggerRefreshTokenTimer();\n    let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);\n    let authReq =  request;\n    if (authToken) {\n      authReq = request.clone({\n        setHeaders: {\n          Authorization: `Bearer ${authToken}`\n        }\n      })\n      if (!this.authTokenSet.has(authToken)) {\n        this.isSessionExpired = false;\n      }\n      this.authTokenSet.add(authToken);\n    }\n    return next.handle(authReq).pipe(\n      catchError((error: HttpErrorResponse) => {\n        if (error.status === 401) {\n          const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);\n          if (loginType === 'saml' || loginType === 'oauth') {\n            LocalStorageService.removeItem(StorageKeys.USER_NAME);\n            LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME); \n          }\n          LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n          LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n          LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n          LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n          LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n          LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n          // call logout action\n          if (!this.isSessionExpired) {\n            this.toastNotificationService.showToastNotification({\n              content: 'The session has ended.'\n            });\n            this.isSessionExpired = true;\n          }\n          \n          this.router.navigate(['/login'])\n        }\n        if (error.status === 0 || error.status === 504) {\n          this.toastNotificationService.showToastNotification({\n            content: `Unable to reach server. Please try again.`,\n            type: { style: 'error', icon: true },\n            closable: true\n          })\n        }\n        if (error.status === 500) {\n          this.toastNotificationService.showToastNotification({\n            content: `Something went wrong. Please try again.`,\n            type: { style: 'error', icon: true },\n            closable: true\n          })\n        }\n        return throwError(() => error)\n      })\n    );\n  }\n\n  refreshToken() {\n    const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);\n    if (!baseUrl) throw new Error('The backend or server base URL is missing in Local Storage');\n    this.refreshTokenService.refreshToken({ platformServiceApiBaseUrls: baseUrl });\n  }\n\n  triggerRefreshTokenTimer() {\n    const refreshTokenTime = 20 * 1000;\n    timer(0, refreshTokenTime).subscribe(() => {\n      this.refreshToken();\n    })\n  }\n\n  // async manageRefreshTokenExpireTime() {\n  //   const newExpireTime = await this.getExpireAtTime()\n  //   const { halfwayTimeString } = this.handleCalulateHalfTime(newExpireTime)\n  //   LocalStorageService.setItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME, halfwayTimeString)\n  // }\n\n  // manageTokenRefresh() {\n  //   const { isHalfTimeGreater } = this.checkHalfTimeIsGreater();\n  //   if (isHalfTimeGreater) {\n  //     this.refreshToken();\n  //     this.manageRefreshTokenExpireTime();\n  //     // const newExpireTime = this.getExpireAtTime()\n  //     // const { halfwayTimeString } = this.handleCalulateHalfTime(newExpireTime)\n  //     // localStorage.setItem(this.refreshTokenExpireTimeStorageKey, halfwayTimeString)\n  //     // LocalStorageService.setItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME, halfwayTimeString)\n  //   }\n  // }\n\n  // async getExpireAtTime() {\n  //   await this.delay(2000)\n  //   let isIdentityToken = LocalStorageService.getItem(StorageKeys.IDENTITY_TOKEN);\n  //   console.log('======= check is token availabe --------', isIdentityToken)  \n  //   if (!isIdentityToken) throw new Error('identity token is missing in the local storage');\n  //   const { expireAt } = isIdentityToken;\n  //   const date = new Date(expireAt * 1000);\n  //   const hours = date.getUTCHours().toString().padStart(2, '0');\n  //   const minutes = date.getUTCMinutes().toString().padStart(2, '0');\n  //   const seconds = date.getUTCSeconds().toString().padStart(2, '0');\n  //   const latestRefreshTokenExpireTime = `${hours}:${minutes}:${seconds}`; //10:00:00\n  //   return latestRefreshTokenExpireTime;\n  // }\n\n  // getCurrentTime() {\n  //   const now = new Date();\n  //   const options = { timeZone: 'Asia/Kolkata' };\n  //   const formattedTime = now.toLocaleString('en-IN', { hour12: true, ...options });\n  //   const [time, period] = formattedTime.split(', ')[1].split(' ');\n  //   const [hours, minutes, seconds] = time.split(':').map(Number);\n  //   return { hours, minutes, seconds, period };\n  // }\n\n  // timeToSeconds(hours: number, minutes: number, seconds: number) {\n  //   return hours * 3600 + minutes * 60 + seconds;\n  // }\n\n  // secondsToTimeString(seconds: number) {\n  //   const hours = Math.floor(seconds / 3600) % 12 || 12;\n  //   const minutes = Math.floor((seconds % 3600) / 60);\n  //   const secondsPart = seconds % 60;\n  //   return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${secondsPart.toString().padStart(2, '0')}`;\n  // }\n\n  // handleCalulateHalfTime(expireTime: string, isHalfTime: boolean = false) {\n  //   const [expireHours, expireMinutes, expireSeconds] = expireTime.split(':').map(Number);\n  //   const { hours: currentHours, minutes: currentMinutes, seconds: currentSeconds, period: currentPeriod } = this.getCurrentTime();\n\n  //   const expireTimeInSeconds = this.timeToSeconds(expireHours, expireMinutes, expireSeconds);\n  //   const currentTimeInSeconds = this.timeToSeconds(currentHours, currentMinutes, currentSeconds);\n\n  //   let halfwayTimeInSeconds: number;\n  //   if (isHalfTime) {\n  //     halfwayTimeInSeconds = expireTimeInSeconds + currentTimeInSeconds;\n  //   } else {\n  //     halfwayTimeInSeconds = Math.floor((expireTimeInSeconds + currentTimeInSeconds) / 2);\n  //   }\n\n  //   if (halfwayTimeInSeconds < 0) {\n  //     halfwayTimeInSeconds += 12 * 3600;\n  //   } else if (halfwayTimeInSeconds >= 12 * 3600) {\n  //     halfwayTimeInSeconds -= 12 * 3600;\n  //   }\n\n  //   const halfwayTimeString = this.secondsToTimeString(halfwayTimeInSeconds);\n\n  //   let isHalfTimeGreater = false;\n  //   if (halfwayTimeString.endsWith('AM') && expireTime.endsWith('PM')) {\n  //     isHalfTimeGreater = false;\n  //   } else if (halfwayTimeString.endsWith('PM') && expireTime.endsWith('AM')) {\n  //     isHalfTimeGreater = true;\n  //   } else {\n  //     isHalfTimeGreater = halfwayTimeString > expireTime;\n  //   }\n\n  //   return { halfwayTimeString, isHalfTimeGreater };\n  // }\n\n  // checkHalfTimeIsGreater() {\n  //   // const getRefreshTokenHalfTime: string = localStorage.getItem(this.refreshTokenExpireTimeStorageKey) as string;\n  //   const getRefreshTokenHalfTime = LocalStorageService.getItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME)\n  //   if (!getRefreshTokenHalfTime) throw new Error('Refresh token half time is missing');\n  //   const { isHalfTimeGreater, halfwayTimeString } = this.handleCalulateHalfTime(getRefreshTokenHalfTime, true);\n  //   return { isHalfTimeGreater, halfwayTimeString };\n  // }\n\n  // delay(ms: number): Promise<void> {\n  //   return new Promise(resolve => setTimeout(resolve, ms));\n  // }\n}\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth.interceptor.js","sourceRoot":"","sources":["../../../../projects/platform-http-interceptor/src/lib/http-auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  HttpErrorResponse,\n  HttpEvent,\n  HttpHandler,\n  HttpInterceptor,\n  HttpRequest\n} from '@angular/common/http';\nimport { RefreshTokenService } from '@progress-chef/platform-refresh-token-service'\nimport { Router } from '@angular/router';\nimport { ToastNotificationService } from '@progress-chef/platform-shared-components';\nimport { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';\nimport { Observable, catchError, throwError, timer } from 'rxjs';\nimport { Injectable } from '@angular/core';\n\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class HttpAuthInterceptor implements HttpInterceptor {\n  authTokenSet = new Set();\n  isSessionExpired = false;\n  constructor(\n    private router: Router,\n    private toastNotificationService: ToastNotificationService, \n    private refreshTokenService: RefreshTokenService\n  ) { }\n\n  intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n    // function to check for the refresh token using referesh token service\n    console.log(\">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> intercept calling\")\n    this.refreshTokenService.checkForRefresh();\n    let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);\n    let authReq =  request;\n    if (authToken) {\n      authReq = request.clone({\n        setHeaders: {\n          Authorization: `Bearer ${authToken}`\n        }\n      })\n      if (!this.authTokenSet.has(authToken)) {\n        this.isSessionExpired = false;\n      }\n      this.authTokenSet.add(authToken);\n    }\n    return next.handle(authReq).pipe(\n      catchError((error: HttpErrorResponse) => {\n        if (error.status === 401) {\n          const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);\n          if (loginType === 'saml' || loginType === 'oauth') {\n            LocalStorageService.removeItem(StorageKeys.USER_NAME);\n            LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME); \n          }\n          LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n          LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n          LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n          LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n          LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n          LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n          // call logout action\n          if (!this.isSessionExpired) {\n            this.toastNotificationService.showToastNotification({\n              content: 'The session has ended.'\n            });\n            this.isSessionExpired = true;\n          }\n          \n          this.router.navigate(['/login'])\n        }\n        if (error.status === 0 || error.status === 504) {\n          this.toastNotificationService.showToastNotification({\n            content: `Unable to reach server. Please try again.`,\n            type: { style: 'error', icon: true },\n            closable: true\n          })\n        }\n        if (error.status === 500) {\n          this.toastNotificationService.showToastNotification({\n            content: `Something went wrong. Please try again.`,\n            type: { style: 'error', icon: true },\n            closable: true\n          })\n        }\n        return throwError(() => error)\n      })\n    );\n  }\n\n  // refreshToken() {\n  //   const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);\n  //   if (!baseUrl) throw new Error('The backend or server base URL is missing in Local Storage');\n  //   this.refreshTokenService.refreshToken({ platformServiceApiBaseUrl: baseUrl });\n  // }\n\n  // triggerRefreshTokenTimer() {\n  //   const refreshTokenTime = 20 * 1000;\n  //   timer(0, refreshTokenTime).subscribe(() => {\n  //     this.refreshToken();\n  //   })\n  // }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';
2
- import { catchError, throwError, timer } from 'rxjs';
2
+ import { catchError, throwError } from 'rxjs';
3
3
  import * as i0 from '@angular/core';
4
4
  import { Injectable } from '@angular/core';
5
5
  import * as i1 from '@angular/router';
@@ -15,7 +15,9 @@ class HttpAuthInterceptor {
15
15
  this.isSessionExpired = false;
16
16
  }
17
17
  intercept(request, next) {
18
- this.triggerRefreshTokenTimer();
18
+ // function to check for the refresh token using referesh token service
19
+ console.log(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> intercept calling");
20
+ this.refreshTokenService.checkForRefresh();
19
21
  let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);
20
22
  let authReq = request;
21
23
  if (authToken) {
@@ -68,18 +70,6 @@ class HttpAuthInterceptor {
68
70
  return throwError(() => error);
69
71
  }));
70
72
  }
71
- refreshToken() {
72
- const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);
73
- if (!baseUrl)
74
- throw new Error('The backend or server base URL is missing in Local Storage');
75
- this.refreshTokenService.refreshToken({ platformServiceApiBaseUrls: baseUrl });
76
- }
77
- triggerRefreshTokenTimer() {
78
- const refreshTokenTime = 20 * 1000;
79
- timer(0, refreshTokenTime).subscribe(() => {
80
- this.refreshToken();
81
- });
82
- }
83
73
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.Router }, { token: i2.ToastNotificationService }, { token: i3.RefreshTokenService }], target: i0.ɵɵFactoryTarget.Injectable }); }
84
74
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HttpAuthInterceptor, providedIn: 'root' }); }
85
75
  }
@@ -1 +1 @@
1
- {"version":3,"file":"progress-chef-platform-http-interceptor.mjs","sources":["../../../projects/platform-http-interceptor/src/lib/http-auth.interceptor.ts","../../../projects/platform-http-interceptor/src/public-api.ts","../../../projects/platform-http-interceptor/src/progress-chef-platform-http-interceptor.ts"],"sourcesContent":["import {\n HttpErrorResponse,\n HttpEvent,\n HttpHandler,\n HttpInterceptor,\n HttpRequest\n} from '@angular/common/http';\nimport { RefreshTokenService } from '@progress-chef/platform-refresh-token-service'\nimport { Router } from '@angular/router';\nimport { ToastNotificationService } from '@progress-chef/platform-shared-components';\nimport { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';\nimport { Observable, catchError, throwError, timer } from 'rxjs';\nimport { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\n\nexport class HttpAuthInterceptor implements HttpInterceptor {\n authTokenSet = new Set();\n isSessionExpired = false;\n constructor(\n private router: Router,\n private toastNotificationService: ToastNotificationService, \n private refreshTokenService: RefreshTokenService,\n ) { }\n\n intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n this.triggerRefreshTokenTimer();\n let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);\n let authReq = request;\n if (authToken) {\n authReq = request.clone({\n setHeaders: {\n Authorization: `Bearer ${authToken}`\n }\n })\n if (!this.authTokenSet.has(authToken)) {\n this.isSessionExpired = false;\n }\n this.authTokenSet.add(authToken);\n }\n return next.handle(authReq).pipe(\n catchError((error: HttpErrorResponse) => {\n if (error.status === 401) {\n const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);\n if (loginType === 'saml' || loginType === 'oauth') {\n LocalStorageService.removeItem(StorageKeys.USER_NAME);\n LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME); \n }\n LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n // call logout action\n if (!this.isSessionExpired) {\n this.toastNotificationService.showToastNotification({\n content: 'The session has ended.'\n });\n this.isSessionExpired = true;\n }\n \n this.router.navigate(['/login'])\n }\n if (error.status === 0 || error.status === 504) {\n this.toastNotificationService.showToastNotification({\n content: `Unable to reach server. Please try again.`,\n type: { style: 'error', icon: true },\n closable: true\n })\n }\n if (error.status === 500) {\n this.toastNotificationService.showToastNotification({\n content: `Something went wrong. Please try again.`,\n type: { style: 'error', icon: true },\n closable: true\n })\n }\n return throwError(() => error)\n })\n );\n }\n\n refreshToken() {\n const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);\n if (!baseUrl) throw new Error('The backend or server base URL is missing in Local Storage');\n this.refreshTokenService.refreshToken({ platformServiceApiBaseUrls: baseUrl });\n }\n\n triggerRefreshTokenTimer() {\n const refreshTokenTime = 20 * 1000;\n timer(0, refreshTokenTime).subscribe(() => {\n this.refreshToken();\n })\n }\n\n // async manageRefreshTokenExpireTime() {\n // const newExpireTime = await this.getExpireAtTime()\n // const { halfwayTimeString } = this.handleCalulateHalfTime(newExpireTime)\n // LocalStorageService.setItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME, halfwayTimeString)\n // }\n\n // manageTokenRefresh() {\n // const { isHalfTimeGreater } = this.checkHalfTimeIsGreater();\n // if (isHalfTimeGreater) {\n // this.refreshToken();\n // this.manageRefreshTokenExpireTime();\n // // const newExpireTime = this.getExpireAtTime()\n // // const { halfwayTimeString } = this.handleCalulateHalfTime(newExpireTime)\n // // localStorage.setItem(this.refreshTokenExpireTimeStorageKey, halfwayTimeString)\n // // LocalStorageService.setItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME, halfwayTimeString)\n // }\n // }\n\n // async getExpireAtTime() {\n // await this.delay(2000)\n // let isIdentityToken = LocalStorageService.getItem(StorageKeys.IDENTITY_TOKEN);\n // console.log('======= check is token availabe --------', isIdentityToken) \n // if (!isIdentityToken) throw new Error('identity token is missing in the local storage');\n // const { expireAt } = isIdentityToken;\n // const date = new Date(expireAt * 1000);\n // const hours = date.getUTCHours().toString().padStart(2, '0');\n // const minutes = date.getUTCMinutes().toString().padStart(2, '0');\n // const seconds = date.getUTCSeconds().toString().padStart(2, '0');\n // const latestRefreshTokenExpireTime = `${hours}:${minutes}:${seconds}`; //10:00:00\n // return latestRefreshTokenExpireTime;\n // }\n\n // getCurrentTime() {\n // const now = new Date();\n // const options = { timeZone: 'Asia/Kolkata' };\n // const formattedTime = now.toLocaleString('en-IN', { hour12: true, ...options });\n // const [time, period] = formattedTime.split(', ')[1].split(' ');\n // const [hours, minutes, seconds] = time.split(':').map(Number);\n // return { hours, minutes, seconds, period };\n // }\n\n // timeToSeconds(hours: number, minutes: number, seconds: number) {\n // return hours * 3600 + minutes * 60 + seconds;\n // }\n\n // secondsToTimeString(seconds: number) {\n // const hours = Math.floor(seconds / 3600) % 12 || 12;\n // const minutes = Math.floor((seconds % 3600) / 60);\n // const secondsPart = seconds % 60;\n // return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${secondsPart.toString().padStart(2, '0')}`;\n // }\n\n // handleCalulateHalfTime(expireTime: string, isHalfTime: boolean = false) {\n // const [expireHours, expireMinutes, expireSeconds] = expireTime.split(':').map(Number);\n // const { hours: currentHours, minutes: currentMinutes, seconds: currentSeconds, period: currentPeriod } = this.getCurrentTime();\n\n // const expireTimeInSeconds = this.timeToSeconds(expireHours, expireMinutes, expireSeconds);\n // const currentTimeInSeconds = this.timeToSeconds(currentHours, currentMinutes, currentSeconds);\n\n // let halfwayTimeInSeconds: number;\n // if (isHalfTime) {\n // halfwayTimeInSeconds = expireTimeInSeconds + currentTimeInSeconds;\n // } else {\n // halfwayTimeInSeconds = Math.floor((expireTimeInSeconds + currentTimeInSeconds) / 2);\n // }\n\n // if (halfwayTimeInSeconds < 0) {\n // halfwayTimeInSeconds += 12 * 3600;\n // } else if (halfwayTimeInSeconds >= 12 * 3600) {\n // halfwayTimeInSeconds -= 12 * 3600;\n // }\n\n // const halfwayTimeString = this.secondsToTimeString(halfwayTimeInSeconds);\n\n // let isHalfTimeGreater = false;\n // if (halfwayTimeString.endsWith('AM') && expireTime.endsWith('PM')) {\n // isHalfTimeGreater = false;\n // } else if (halfwayTimeString.endsWith('PM') && expireTime.endsWith('AM')) {\n // isHalfTimeGreater = true;\n // } else {\n // isHalfTimeGreater = halfwayTimeString > expireTime;\n // }\n\n // return { halfwayTimeString, isHalfTimeGreater };\n // }\n\n // checkHalfTimeIsGreater() {\n // // const getRefreshTokenHalfTime: string = localStorage.getItem(this.refreshTokenExpireTimeStorageKey) as string;\n // const getRefreshTokenHalfTime = LocalStorageService.getItem(StorageKeys.REFRESH_TOKEN_HALF_EXPRE_TIME)\n // if (!getRefreshTokenHalfTime) throw new Error('Refresh token half time is missing');\n // const { isHalfTimeGreater, halfwayTimeString } = this.handleCalulateHalfTime(getRefreshTokenHalfTime, true);\n // return { isHalfTimeGreater, halfwayTimeString };\n // }\n\n // delay(ms: number): Promise<void> {\n // return new Promise(resolve => setTimeout(resolve, ms));\n // }\n}\n","/*\n * Public API Surface of platform-http-interceptor\n */\n\nexport * from './lib/http-auth.interceptor';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"progress-chef-platform-http-interceptor.mjs","sources":["../../../projects/platform-http-interceptor/src/lib/http-auth.interceptor.ts","../../../projects/platform-http-interceptor/src/public-api.ts","../../../projects/platform-http-interceptor/src/progress-chef-platform-http-interceptor.ts"],"sourcesContent":["import {\n HttpErrorResponse,\n HttpEvent,\n HttpHandler,\n HttpInterceptor,\n HttpRequest\n} from '@angular/common/http';\nimport { RefreshTokenService } from '@progress-chef/platform-refresh-token-service'\nimport { Router } from '@angular/router';\nimport { ToastNotificationService } from '@progress-chef/platform-shared-components';\nimport { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';\nimport { Observable, catchError, throwError, timer } from 'rxjs';\nimport { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\n\nexport class HttpAuthInterceptor implements HttpInterceptor {\n authTokenSet = new Set();\n isSessionExpired = false;\n constructor(\n private router: Router,\n private toastNotificationService: ToastNotificationService, \n private refreshTokenService: RefreshTokenService\n ) { }\n\n intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n // function to check for the refresh token using referesh token service\n console.log(\">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> intercept calling\")\n this.refreshTokenService.checkForRefresh();\n let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);\n let authReq = request;\n if (authToken) {\n authReq = request.clone({\n setHeaders: {\n Authorization: `Bearer ${authToken}`\n }\n })\n if (!this.authTokenSet.has(authToken)) {\n this.isSessionExpired = false;\n }\n this.authTokenSet.add(authToken);\n }\n return next.handle(authReq).pipe(\n catchError((error: HttpErrorResponse) => {\n if (error.status === 401) {\n const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);\n if (loginType === 'saml' || loginType === 'oauth') {\n LocalStorageService.removeItem(StorageKeys.USER_NAME);\n LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME); \n }\n LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n // call logout action\n if (!this.isSessionExpired) {\n this.toastNotificationService.showToastNotification({\n content: 'The session has ended.'\n });\n this.isSessionExpired = true;\n }\n \n this.router.navigate(['/login'])\n }\n if (error.status === 0 || error.status === 504) {\n this.toastNotificationService.showToastNotification({\n content: `Unable to reach server. Please try again.`,\n type: { style: 'error', icon: true },\n closable: true\n })\n }\n if (error.status === 500) {\n this.toastNotificationService.showToastNotification({\n content: `Something went wrong. Please try again.`,\n type: { style: 'error', icon: true },\n closable: true\n })\n }\n return throwError(() => error)\n })\n );\n }\n\n // refreshToken() {\n // const baseUrl = LocalStorageService.getItem(StorageKeys.CURRENT_SERVER_BASE_URL);\n // if (!baseUrl) throw new Error('The backend or server base URL is missing in Local Storage');\n // this.refreshTokenService.refreshToken({ platformServiceApiBaseUrl: baseUrl });\n // }\n\n // triggerRefreshTokenTimer() {\n // const refreshTokenTime = 20 * 1000;\n // timer(0, refreshTokenTime).subscribe(() => {\n // this.refreshToken();\n // })\n // }\n}\n","/*\n * Public API Surface of platform-http-interceptor\n */\n\nexport * from './lib/http-auth.interceptor';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
@@ -12,8 +12,6 @@ export declare class HttpAuthInterceptor implements HttpInterceptor {
12
12
  isSessionExpired: boolean;
13
13
  constructor(router: Router, toastNotificationService: ToastNotificationService, refreshTokenService: RefreshTokenService);
14
14
  intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>>;
15
- refreshToken(): void;
16
- triggerRefreshTokenTimer(): void;
17
15
  static ɵfac: i0.ɵɵFactoryDeclaration<HttpAuthInterceptor, never>;
18
16
  static ɵprov: i0.ɵɵInjectableDeclaration<HttpAuthInterceptor>;
19
17
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@progress-chef/platform-http-interceptor",
3
- "version": "0.0.16",
3
+ "version": "0.0.18",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^16.2.0",
6
6
  "@angular/core": "^16.2.0"