tango-app-ui-shared 3.6.0-cookie-4 → 3.6.0-cookie-2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -22,28 +22,131 @@ export class HttpAuthInterceptor {
22
22
  }
23
23
  });
24
24
  }
25
+ // intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
26
+ // const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
27
+ // request = request.clone({
28
+ // setHeaders: {
29
+ // Authorization: 'Bearer ' + user.authenticationToken
30
+ // }
31
+ // });
32
+ // return next.handle(request)
33
+ // .pipe(tap((response:any)=>{
34
+ // if(response?.body?.data?.result === 'RESTRICTED-IP'){
35
+ // this.router.navigateByUrl('/error/403-ip')
36
+ // }
37
+ // }))
38
+ // .pipe(
39
+ // catchError((error:any)=>{
40
+ // if (error instanceof HttpErrorResponse && error.status === 401) {
41
+ // // If the error is due to unauthorized access, try to refresh the token
42
+ // return this.handle401Error(request, next);
43
+ // }
44
+ // // else if (error instanceof HttpErrorResponse && error.status === 403) {
45
+ // // // If the error is due to unauthorized access, try to refresh the token
46
+ // // this.router.navigate(['/manage/brands'])
47
+ // // }
48
+ // return throwError(error);
49
+ // })
50
+ // );
51
+ // }
52
+ // private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
53
+ // if (!this.isRefreshingToken) {
54
+ // this.isRefreshingToken = true;
55
+ // return this.authService.refreshToken().pipe(
56
+ // switchMap((res: any) => {
57
+ // if (res && res.code == 200 && res.data.result) {
58
+ // // Update local storage with the new token
59
+ // localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
60
+ // // Clone the request with the new token
61
+ // request = request.clone({
62
+ // setHeaders: {
63
+ // Authorization: `Bearer ${res.data.result.authenticationToken}`
64
+ // }
65
+ // });
66
+ // // Reset the flag for token refreshing
67
+ // this.isRefreshingToken = false;
68
+ // // Retry the original request with the new token
69
+ // return next.handle(request);
70
+ // } else {
71
+ // // Logout user if refresh token fails
72
+ // this.authService.logout();
73
+ // const keysToKeep = ['data-mismatch-draft'];
74
+ // const valuesToKeep:any = {};
75
+ // keysToKeep.forEach(key => {
76
+ // const value = localStorage.getItem(key);
77
+ // if (value !== null) {
78
+ // valuesToKeep[key] = value;
79
+ // }
80
+ // });
81
+ // localStorage.clear();
82
+ // Object.keys(valuesToKeep).forEach(key => {
83
+ // localStorage.setItem(key, valuesToKeep[key]);
84
+ // });
85
+ // this.router.navigate(['/auth/login']);
86
+ // return throwError('Token Expired Please Login Again!');
87
+ // }
88
+ // }),
89
+ // catchError((error) => {
90
+ // // Logout user if refresh token fails
91
+ // this.authService.logout();
92
+ // const keysToKeep = ['data-mismatch-draft'];
93
+ // const valuesToKeep:any = {};
94
+ // keysToKeep.forEach(key => {
95
+ // const value = localStorage.getItem(key);
96
+ // if (value !== null) {
97
+ // valuesToKeep[key] = value;
98
+ // }
99
+ // });
100
+ // localStorage.clear();
101
+ // Object.keys(valuesToKeep).forEach(key => {
102
+ // localStorage.setItem(key, valuesToKeep[key]);
103
+ // });
104
+ // this.router.navigate(['/auth/login']);
105
+ // return throwError(error);
106
+ // })
107
+ // );
108
+ // } else {
109
+ // // If already refreshing the token, queue the request and wait
110
+ // return this.tokenRefreshed.pipe(
111
+ // switchMap(() => {
112
+ // const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
113
+ // request = request.clone({
114
+ // setHeaders: {
115
+ // Authorization: 'Bearer ' + tokens.authenticationToken
116
+ // }
117
+ // });
118
+ // return next.handle(request);
119
+ // })
120
+ // );
121
+ // }
122
+ // }
25
123
  intercept(request, next) {
26
- const user = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
27
- request = request.clone({
28
- setHeaders: {
29
- Authorization: 'Bearer ' + user.authenticationToken
124
+ const tokenObjStr = this.authService.getCookie(this.authlocalStorageToken);
125
+ let token = '';
126
+ if (tokenObjStr) {
127
+ try {
128
+ const tokenObj = JSON.parse(tokenObjStr);
129
+ token = tokenObj?.authenticationToken || '';
30
130
  }
31
- });
32
- return next.handle(request)
33
- .pipe(tap((response) => {
131
+ catch (e) {
132
+ console.error('Invalid auth token format in cookie', e);
133
+ }
134
+ }
135
+ if (token) {
136
+ request = request.clone({
137
+ setHeaders: {
138
+ Authorization: 'Bearer ' + token,
139
+ },
140
+ });
141
+ }
142
+ return next.handle(request).pipe(tap((response) => {
34
143
  if (response?.body?.data?.result === 'RESTRICTED-IP') {
35
144
  this.router.navigateByUrl('/error/403-ip');
36
145
  }
37
- }))
38
- .pipe(catchError((error) => {
146
+ }), catchError((error) => {
39
147
  if (error instanceof HttpErrorResponse && error.status === 401) {
40
- // If the error is due to unauthorized access, try to refresh the token
41
148
  return this.handle401Error(request, next);
42
149
  }
43
- // else if (error instanceof HttpErrorResponse && error.status === 403) {
44
- // // If the error is due to unauthorized access, try to refresh the token
45
- // this.router.navigate(['/manage/brands'])
46
- // }
47
150
  return throwError(error);
48
151
  }));
49
152
  }
@@ -51,74 +154,48 @@ export class HttpAuthInterceptor {
51
154
  if (!this.isRefreshingToken) {
52
155
  this.isRefreshingToken = true;
53
156
  return this.authService.refreshToken().pipe(switchMap((res) => {
54
- if (res && res.code == 200 && res.data.result) {
55
- // Update local storage with the new token
56
- localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
57
- // Clone the request with the new token
157
+ if (res && res.code === 200 && res.data?.result) {
158
+ this.authService.setCookie(this.authlocalStorageToken, JSON.stringify(res.data.result), 1);
159
+ const newToken = res.data.result.authenticationToken;
58
160
  request = request.clone({
59
161
  setHeaders: {
60
- Authorization: `Bearer ${res.data.result.authenticationToken}`
61
- }
162
+ Authorization: 'Bearer ' + newToken,
163
+ },
62
164
  });
63
- // Reset the flag for token refreshing
64
165
  this.isRefreshingToken = false;
65
- // Retry the original request with the new token
66
166
  return next.handle(request);
67
167
  }
68
168
  else {
69
- // Logout user if refresh token fails
70
- this.authService.logout();
71
- const keysToKeep = ['data-mismatch-draft'];
72
- const valuesToKeep = {};
73
- keysToKeep.forEach(key => {
74
- const value = localStorage.getItem(key);
75
- if (value !== null) {
76
- valuesToKeep[key] = value;
77
- }
78
- });
79
- localStorage.clear();
80
- Object.keys(valuesToKeep).forEach(key => {
81
- localStorage.setItem(key, valuesToKeep[key]);
82
- });
83
- this.router.navigate(['/auth/login']);
84
- return throwError('Token Expired Please Login Again!');
169
+ return this.forceLogout('Token Expired. Please login again.');
85
170
  }
86
- }), catchError((error) => {
87
- // Logout user if refresh token fails
88
- this.authService.logout();
89
- const keysToKeep = ['data-mismatch-draft'];
90
- const valuesToKeep = {};
91
- keysToKeep.forEach(key => {
92
- const value = localStorage.getItem(key);
93
- if (value !== null) {
94
- valuesToKeep[key] = value;
95
- }
96
- });
97
- localStorage.clear();
98
- Object.keys(valuesToKeep).forEach(key => {
99
- localStorage.setItem(key, valuesToKeep[key]);
100
- });
101
- this.router.navigate(['/auth/login']);
102
- return throwError(error);
103
- }));
171
+ }), catchError((err) => this.forceLogout(err)));
104
172
  }
105
173
  else {
106
- // If already refreshing the token, queue the request and wait
107
- return this.tokenRefreshed.pipe(switchMap(() => {
108
- const tokens = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
109
- request = request.clone({
110
- setHeaders: {
111
- Authorization: 'Bearer ' + tokens.authenticationToken
112
- }
113
- });
114
- return next.handle(request);
115
- }));
174
+ // Optional: implement logic to queue and retry if multiple requests during refresh
175
+ return throwError('Token refresh already in progress');
116
176
  }
117
177
  }
178
+ forceLogout(message) {
179
+ this.authService.logout();
180
+ const keysToKeep = ['data-mismatch-draft'];
181
+ const valuesToKeep = {};
182
+ keysToKeep.forEach((key) => {
183
+ const val = localStorage.getItem(key);
184
+ if (val)
185
+ valuesToKeep[key] = val;
186
+ });
187
+ localStorage.clear();
188
+ // Object.entries(valuesToKeep).forEach(([k, v]) => {
189
+ // return localStorage.setItem(k, v);
190
+ // });
191
+ this.authService.deleteCookie(this.authlocalStorageToken);
192
+ this.router.navigate(['/auth/login']);
193
+ return throwError(() => message);
194
+ }
118
195
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.GlobalStateService }, { token: i2.AuthService }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Injectable });
119
196
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor });
120
197
  }
121
198
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
122
199
  type: Injectable
123
200
  }], ctorParameters: () => [{ type: i1.GlobalStateService }, { type: i2.AuthService }, { type: i3.Router }] });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth-interceptor.js","sourceRoot":"","sources":["../../../../../projects/tango-app-shared/src/lib/interceptors/http-auth-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport {\r\n  HttpRequest,\r\n  HttpHandler,\r\n  HttpEvent,\r\n  HttpInterceptor,\r\n  HttpErrorResponse\r\n} from '@angular/common/http';\r\nimport { BehaviorSubject, Observable, catchError, switchMap, throwError, tap } from 'rxjs';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\nimport { AuthService } from '../services/auth.service';\r\nimport { Router } from '@angular/router';\r\n@Injectable()\r\nexport class HttpAuthInterceptor implements HttpInterceptor {\r\n\r\n  authlocalStorageToken: string='';\r\n  private isRefreshingToken: boolean = false;\r\n  private tokenRefreshed: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\r\n  \r\n  constructor(\r\n    private gs:GlobalStateService,\r\n    private authService: AuthService,private router:Router\r\n  ) {\r\n    this.gs.environment.subscribe((env)=>{\r\n      if(env){\r\n       this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;}\r\n     })\r\n  }\r\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n    request = request.clone({\r\n      setHeaders: {\r\n        Authorization: 'Bearer ' + user.authenticationToken\r\n      }\r\n    });\r\n    return next.handle(request)\r\n    .pipe(tap((response:any)=>{\r\n      if(response?.body?.data?.result === 'RESTRICTED-IP'){\r\n        this.router.navigateByUrl('/error/403-ip')\r\n      }\r\n    }))\r\n    .pipe(\r\n      catchError((error:any)=>{\r\n        if (error instanceof HttpErrorResponse && error.status === 401) {\r\n          // If the error is due to unauthorized access, try to refresh the token\r\n          return this.handle401Error(request, next);\r\n        } \r\n        // else if (error instanceof HttpErrorResponse && error.status === 403) {\r\n        //   // If the error is due to unauthorized access, try to refresh the token\r\n        //  this.router.navigate(['/manage/brands'])\r\n        // } \r\n        return throwError(error);\r\n      })\r\n    );\r\n  }\r\n\r\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    if (!this.isRefreshingToken) {\r\n      this.isRefreshingToken = true;\r\n      return this.authService.refreshToken().pipe(\r\n        switchMap((res: any) => {\r\n          if (res && res.code == 200 && res.data.result) {\r\n            // Update local storage with the new token\r\n            localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));\r\n            \r\n            // Clone the request with the new token\r\n            request = request.clone({\r\n              setHeaders: {\r\n                Authorization: `Bearer ${res.data.result.authenticationToken}`\r\n              }\r\n            });\r\n  \r\n            // Reset the flag for token refreshing\r\n            this.isRefreshingToken = false;\r\n  \r\n            // Retry the original request with the new token\r\n            return next.handle(request);\r\n          } else {\r\n            // Logout user if refresh token fails\r\n            this.authService.logout();\r\n            const keysToKeep = ['data-mismatch-draft'];\r\n            const valuesToKeep:any = {};\r\n  \r\n            keysToKeep.forEach(key => {\r\n              const value = localStorage.getItem(key);\r\n              if (value !== null) {\r\n                valuesToKeep[key] = value;\r\n              }\r\n            });\r\n  \r\n            localStorage.clear();\r\n  \r\n            Object.keys(valuesToKeep).forEach(key => {\r\n              localStorage.setItem(key, valuesToKeep[key]);\r\n            }); \r\n            this.router.navigate(['/auth/login']);\r\n            return throwError('Token Expired Please Login Again!');\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          // Logout user if refresh token fails\r\n          this.authService.logout();\r\n          const keysToKeep = ['data-mismatch-draft'];\r\n          const valuesToKeep:any = {};\r\n\r\n          keysToKeep.forEach(key => {\r\n            const value = localStorage.getItem(key);\r\n            if (value !== null) {\r\n              valuesToKeep[key] = value;\r\n            }\r\n          });\r\n\r\n          localStorage.clear();\r\n\r\n          Object.keys(valuesToKeep).forEach(key => {\r\n            localStorage.setItem(key, valuesToKeep[key]);\r\n          }); \r\n          \r\n          this.router.navigate(['/auth/login']);\r\n          return throwError(error);\r\n        })\r\n      );\r\n    } else {\r\n      // If already refreshing the token, queue the request and wait\r\n      return this.tokenRefreshed.pipe(\r\n        switchMap(() => {\r\n          const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n          request = request.clone({\r\n            setHeaders: {\r\n              Authorization: 'Bearer ' + tokens.authenticationToken\r\n            }\r\n          });\r\n          return next.handle(request);\r\n        })\r\n      );\r\n    }\r\n  }\r\n  // intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n  //   const tokenObjStr = this.authService.getCookie(this.authlocalStorageToken);\r\n  //   let token = '';\r\n\r\n  //   if (tokenObjStr) {\r\n  //     try {\r\n  //       const tokenObj = JSON.parse(tokenObjStr);\r\n  //       token = tokenObj?.authenticationToken || '';\r\n  //     } catch (e) {\r\n  //       console.error('Invalid auth token format in cookie', e);\r\n  //     }\r\n  //   }\r\n\r\n  //   if (token) {\r\n  //     request = request.clone({\r\n  //       setHeaders: {\r\n  //         Authorization: 'Bearer ' + token,\r\n  //       },\r\n  //     });\r\n  //   }\r\n\r\n  //   return next.handle(request).pipe(\r\n  //     tap((response: any) => {\r\n  //       if (response?.body?.data?.result === 'RESTRICTED-IP') {\r\n  //         this.router.navigateByUrl('/error/403-ip');\r\n  //       }\r\n  //     }),\r\n  //     catchError((error: any) => {\r\n  //       if (error instanceof HttpErrorResponse && error.status === 401) {\r\n  //         return this.handle401Error(request, next);\r\n  //       }\r\n  //       return throwError(error);\r\n  //     })\r\n  //   );\r\n  // }\r\n\r\n  // private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n  //   if (!this.isRefreshingToken) {\r\n  //     this.isRefreshingToken = true;\r\n\r\n  //     return this.authService.refreshToken().pipe(\r\n  //       switchMap((res: any) => {\r\n  //         if (res && res.code === 200 && res.data?.result) {\r\n  //           this.authService.setCookie(this.authlocalStorageToken, JSON.stringify(res.data.result), 1);\r\n\r\n  //           const newToken = res.data.result.authenticationToken;\r\n  //           request = request.clone({\r\n  //             setHeaders: {\r\n  //               Authorization: 'Bearer ' + newToken,\r\n  //             },\r\n  //           });\r\n\r\n  //           this.isRefreshingToken = false;\r\n  //           return next.handle(request);\r\n  //         } else {\r\n  //           return this.forceLogout('Token Expired. Please login again.');\r\n  //         }\r\n  //       }),\r\n  //       catchError((err) => this.forceLogout(err))\r\n  //     );\r\n  //   } else {\r\n  //     // Optional: implement logic to queue and retry if multiple requests during refresh\r\n  //     return throwError('Token refresh already in progress');\r\n  //   }\r\n  // }\r\n\r\n  // private forceLogout(message: string): Observable<never> {\r\n  //   this.authService.logout();\r\n\r\n  //   const keysToKeep = ['data-mismatch-draft'];\r\n  //   const valuesToKeep: any = {};\r\n\r\n  //   keysToKeep.forEach((key) => {\r\n  //     const val = localStorage.getItem(key);\r\n  //     if (val) valuesToKeep[key] = val;\r\n  //   });\r\n\r\n  //   localStorage.clear();\r\n\r\n  //   // Object.entries(valuesToKeep).forEach(([k, v]) => {\r\n  //   //   return localStorage.setItem(k, v);\r\n  //   // });\r\n\r\n  //   this.authService.deleteCookie(this.authlocalStorageToken);\r\n  //   this.router.navigate(['/auth/login']);\r\n  //   return throwError(() => message);\r\n  // }\r\n}"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth-interceptor.js","sourceRoot":"","sources":["../../../../../projects/tango-app-shared/src/lib/interceptors/http-auth-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport {\r\n  HttpRequest,\r\n  HttpHandler,\r\n  HttpEvent,\r\n  HttpInterceptor,\r\n  HttpErrorResponse\r\n} from '@angular/common/http';\r\nimport { BehaviorSubject, Observable, catchError, switchMap, throwError, tap } from 'rxjs';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\nimport { AuthService } from '../services/auth.service';\r\nimport { Router } from '@angular/router';\r\n@Injectable()\r\nexport class HttpAuthInterceptor implements HttpInterceptor {\r\n\r\n  authlocalStorageToken: string='';\r\n  private isRefreshingToken: boolean = false;\r\n  private tokenRefreshed: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\r\n  \r\n  constructor(\r\n    private gs:GlobalStateService,\r\n    private authService: AuthService,private router:Router\r\n  ) {\r\n    this.gs.environment.subscribe((env)=>{\r\n      if(env){\r\n       this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;}\r\n     })\r\n  }\r\n  // intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n  //   const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n  //   request = request.clone({\r\n  //     setHeaders: {\r\n  //       Authorization: 'Bearer ' + user.authenticationToken\r\n  //     }\r\n  //   });\r\n  //   return next.handle(request)\r\n  //   .pipe(tap((response:any)=>{\r\n  //     if(response?.body?.data?.result === 'RESTRICTED-IP'){\r\n  //       this.router.navigateByUrl('/error/403-ip')\r\n  //     }\r\n  //   }))\r\n  //   .pipe(\r\n  //     catchError((error:any)=>{\r\n  //       if (error instanceof HttpErrorResponse && error.status === 401) {\r\n  //         // If the error is due to unauthorized access, try to refresh the token\r\n  //         return this.handle401Error(request, next);\r\n  //       } \r\n  //       // else if (error instanceof HttpErrorResponse && error.status === 403) {\r\n  //       //   // If the error is due to unauthorized access, try to refresh the token\r\n  //       //  this.router.navigate(['/manage/brands'])\r\n  //       // } \r\n  //       return throwError(error);\r\n  //     })\r\n  //   );\r\n  // }\r\n\r\n  // private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n  //   if (!this.isRefreshingToken) {\r\n  //     this.isRefreshingToken = true;\r\n  //     return this.authService.refreshToken().pipe(\r\n  //       switchMap((res: any) => {\r\n  //         if (res && res.code == 200 && res.data.result) {\r\n  //           // Update local storage with the new token\r\n  //           localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));\r\n            \r\n  //           // Clone the request with the new token\r\n  //           request = request.clone({\r\n  //             setHeaders: {\r\n  //               Authorization: `Bearer ${res.data.result.authenticationToken}`\r\n  //             }\r\n  //           });\r\n  \r\n  //           // Reset the flag for token refreshing\r\n  //           this.isRefreshingToken = false;\r\n  \r\n  //           // Retry the original request with the new token\r\n  //           return next.handle(request);\r\n  //         } else {\r\n  //           // Logout user if refresh token fails\r\n  //           this.authService.logout();\r\n  //           const keysToKeep = ['data-mismatch-draft'];\r\n  //           const valuesToKeep:any = {};\r\n  \r\n  //           keysToKeep.forEach(key => {\r\n  //             const value = localStorage.getItem(key);\r\n  //             if (value !== null) {\r\n  //               valuesToKeep[key] = value;\r\n  //             }\r\n  //           });\r\n  \r\n  //           localStorage.clear();\r\n  \r\n  //           Object.keys(valuesToKeep).forEach(key => {\r\n  //             localStorage.setItem(key, valuesToKeep[key]);\r\n  //           }); \r\n  //           this.router.navigate(['/auth/login']);\r\n  //           return throwError('Token Expired Please Login Again!');\r\n  //         }\r\n  //       }),\r\n  //       catchError((error) => {\r\n  //         // Logout user if refresh token fails\r\n  //         this.authService.logout();\r\n  //         const keysToKeep = ['data-mismatch-draft'];\r\n  //         const valuesToKeep:any = {};\r\n\r\n  //         keysToKeep.forEach(key => {\r\n  //           const value = localStorage.getItem(key);\r\n  //           if (value !== null) {\r\n  //             valuesToKeep[key] = value;\r\n  //           }\r\n  //         });\r\n\r\n  //         localStorage.clear();\r\n\r\n  //         Object.keys(valuesToKeep).forEach(key => {\r\n  //           localStorage.setItem(key, valuesToKeep[key]);\r\n  //         }); \r\n          \r\n  //         this.router.navigate(['/auth/login']);\r\n  //         return throwError(error);\r\n  //       })\r\n  //     );\r\n  //   } else {\r\n  //     // If already refreshing the token, queue the request and wait\r\n  //     return this.tokenRefreshed.pipe(\r\n  //       switchMap(() => {\r\n  //         const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n  //         request = request.clone({\r\n  //           setHeaders: {\r\n  //             Authorization: 'Bearer ' + tokens.authenticationToken\r\n  //           }\r\n  //         });\r\n  //         return next.handle(request);\r\n  //       })\r\n  //     );\r\n  //   }\r\n  // }\r\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    const tokenObjStr = this.authService.getCookie(this.authlocalStorageToken);\r\n    let token = '';\r\n\r\n    if (tokenObjStr) {\r\n      try {\r\n        const tokenObj = JSON.parse(tokenObjStr);\r\n        token = tokenObj?.authenticationToken || '';\r\n      } catch (e) {\r\n        console.error('Invalid auth token format in cookie', e);\r\n      }\r\n    }\r\n\r\n    if (token) {\r\n      request = request.clone({\r\n        setHeaders: {\r\n          Authorization: 'Bearer ' + token,\r\n        },\r\n      });\r\n    }\r\n\r\n    return next.handle(request).pipe(\r\n      tap((response: any) => {\r\n        if (response?.body?.data?.result === 'RESTRICTED-IP') {\r\n          this.router.navigateByUrl('/error/403-ip');\r\n        }\r\n      }),\r\n      catchError((error: any) => {\r\n        if (error instanceof HttpErrorResponse && error.status === 401) {\r\n          return this.handle401Error(request, next);\r\n        }\r\n        return throwError(error);\r\n      })\r\n    );\r\n  }\r\n\r\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    if (!this.isRefreshingToken) {\r\n      this.isRefreshingToken = true;\r\n\r\n      return this.authService.refreshToken().pipe(\r\n        switchMap((res: any) => {\r\n          if (res && res.code === 200 && res.data?.result) {\r\n            this.authService.setCookie(this.authlocalStorageToken, JSON.stringify(res.data.result), 1);\r\n\r\n            const newToken = res.data.result.authenticationToken;\r\n            request = request.clone({\r\n              setHeaders: {\r\n                Authorization: 'Bearer ' + newToken,\r\n              },\r\n            });\r\n\r\n            this.isRefreshingToken = false;\r\n            return next.handle(request);\r\n          } else {\r\n            return this.forceLogout('Token Expired. Please login again.');\r\n          }\r\n        }),\r\n        catchError((err) => this.forceLogout(err))\r\n      );\r\n    } else {\r\n      // Optional: implement logic to queue and retry if multiple requests during refresh\r\n      return throwError('Token refresh already in progress');\r\n    }\r\n  }\r\n\r\n  private forceLogout(message: string): Observable<never> {\r\n    this.authService.logout();\r\n\r\n    const keysToKeep = ['data-mismatch-draft'];\r\n    const valuesToKeep: any = {};\r\n\r\n    keysToKeep.forEach((key) => {\r\n      const val = localStorage.getItem(key);\r\n      if (val) valuesToKeep[key] = val;\r\n    });\r\n\r\n    localStorage.clear();\r\n\r\n    // Object.entries(valuesToKeep).forEach(([k, v]) => {\r\n    //   return localStorage.setItem(k, v);\r\n    // });\r\n\r\n    this.authService.deleteCookie(this.authlocalStorageToken);\r\n    this.router.navigate(['/auth/login']);\r\n    return throwError(() => message);\r\n  }\r\n}"]}
@@ -50,7 +50,7 @@ export class AuthService {
50
50
  return headers;
51
51
  }
52
52
  logout() {
53
- // this.deleteCookie(this.authlocalStorageToken);
53
+ this.deleteCookie(this.authlocalStorageToken);
54
54
  return this.http.get(`${this.userApiUrl}/logout`);
55
55
  }
56
56
  getClients() {
@@ -166,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
166
166
  providedIn: 'root'
167
167
  }]
168
168
  }], ctorParameters: () => [{ type: i1.Router }, { type: i2.GlobalStateService }, { type: i3.HttpClient }] });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-app-shared/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Observable, catchError, map, of, throwError,BehaviorSubject } from 'rxjs';\r\nimport { Router } from '@angular/router';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class AuthService {\r\n  clientApiUrl: string;\r\n  authlocalStorageToken: string;\r\n  userApiUrl: string;\r\n  storeApiUrl: string;\r\n  billingApiUrl:string;\r\n  oldDashboardUrl: string;\r\n  dropDownTrigger = new BehaviorSubject(null)\r\n  trafficApiUrl: any;\r\n  traxUrl:any;\r\n  galleryApiUrl:any;\r\n  storeBuilderApiUrl: any;\r\n  constructor(private router:Router,private gs:GlobalStateService,private http:HttpClient) {  \r\n    this.gs.environment.subscribe((env)=>{\r\n    if(env){\r\n     this.clientApiUrl =  env.clientApiUrl;\r\n     this.userApiUrl = env.userApiUrl; \r\n     this.storeApiUrl =env.storeApiUrl;\r\n     this.oldDashboardUrl =env.oldDashboardUrl;\r\n     this.trafficApiUrl = env.trafficApiUrl\r\n     this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;\r\n     this.billingApiUrl = env.billingApiUrl\r\n     this.trafficApiUrl = env.trafficApiUrl;\r\n     this.galleryApiUrl = env.galleryApiUrl;\r\n     this.traxUrl = env.trafficApiUrl;\r\n     this.traxUrl = env.traxUrl;\r\n     this.storeBuilderApiUrl = env.storeBuilderUrl;\r\n    }\r\n   }) }\r\n   \r\n   handleError(res: any) {\r\n    return throwError(res.error);\r\n}\r\ngetHeaders() {\r\n  const headers = {\r\n      'Authorization': 'Bearer ' + this.authlocalStorageToken\r\n  };\r\n\r\n  return headers;\r\n}\r\n\r\n  logout() {\r\n    // this.deleteCookie(this.authlocalStorageToken);\r\n    return this.http.get(`${this.userApiUrl}/logout`)\r\n  }\r\n  getClients(){\r\n    return this.http.get(`${this.clientApiUrl}/get-clients`, {\r\n  })\r\n      .pipe(map((response: any) => response),\r\n          catchError(this.handleError));\r\n  }\r\n  getStores(id:any){\r\n    return this.http.get(`${this.storeApiUrl}/get-stores?clientId=${id}`, {\r\n  })\r\n      .pipe(map((response: any) => response),\r\n          catchError(this.handleError));\r\n  }\r\n  getOldDashboardRedirect(data:any){\r\n    return this.http.post(`${this.oldDashboardUrl}/auth/oldDashboardUserLogin`,data, {\r\n      headers: this.getHeaders()\r\n    })\r\n  }\r\n  userProfileDet(): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  refreshToken() {\r\n    const userId = JSON.parse(localStorage.getItem(\"user-info\") || \"\")?._id;\r\n    const refreshToken = JSON.parse(\r\n      localStorage.getItem(this.authlocalStorageToken) || \"\"\r\n    )?.refreshToken;\r\n    let params: any = {\r\n      userId: userId,\r\n      refreshToken: refreshToken,\r\n    };\r\n    return this.http\r\n      .get(`${this.userApiUrl}/refresh-token`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  getPersonalInfo(): Observable<any> {\r\n    return this.http.get<any>(`${this.userApiUrl}/profileV2`).pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  getAssignedUsers(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.userApiUrl}/get-assign-client?clientId=${clientId}` )\r\n  }\r\n\r\n  checkToShowPopup(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.clientApiUrl}/show-csm-assign-confirmation?clientId=${clientId}` )\r\n  }\r\n\r\n  csmAssignClientAction(clientId:string, data:any):Observable<any>{ \r\n    return this.http.post(`${this.clientApiUrl}/client-csm-assign-action?clientId=${clientId}`, data )\r\n  }\r\n  // getLocation(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerLocations_v1`, data)\r\n  // }\r\n\r\n  // getGroups(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerGroups_v1`, data)\r\n  // }\r\n\r\n  // getHeaderStores(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerStores_v1`, data)\r\n  // }\r\n\r\n  getLeadProducts(email:string):Observable<any>{ \r\n    return this.http.get(`${this.billingApiUrl}/getLeadProducts/${email}` )\r\n  }\r\n\r\n  getClientProducts(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.billingApiUrl}/getClientProducts/${clientId}` )\r\n  }\r\n\r\n  getLocation(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerLocations_v2`,data)\r\n  }\r\n  getGroups(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headercluster_v2`,data)\r\n  }\r\n  getHeaderStores(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerStores_v2`,data)\r\n  }\r\n  getHeadertraxStores(data:any):Observable<any>{ \r\n    return this.http.post(`${this.galleryApiUrl}/headerStores_v2`,data)\r\n  }\r\n\r\n  getBrandDetails(id: any) {\r\n    return this.http.get(`${this.clientApiUrl}/client-details/${id}`)\r\n  }\r\n\r\n  getHeaderUsers(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerUserEmails_v2`,data)\r\n  }\r\n\r\n  getCountry(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerCountry_v2`,data)\r\n  }\r\n  getPlanoUsers() {\r\n    return this.http.get(`${this.storeBuilderApiUrl}/getPlanoUser`);\r\n  }\r\n  getHeaderZone(data:any):Observable<any>{\r\n    return this.http.post(`${this.trafficApiUrl}/headerZoneV2`,data)\r\n  }\r\n\r\n  private base64Encode(str: any) {\r\n  return btoa(encodeURIComponent(str));\r\n}\r\n\r\nprivate base64Decode(str: any) {\r\n  return decodeURIComponent(atob(str));\r\n}\r\nsetCookie(name: string, value: string, days: number = 1): void {\r\n  const encodedValue = this.base64Encode(value);\r\n  const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n  document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;\r\n}\r\n\r\ngetCookie(name: string): string | null {\r\n  const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));\r\n  return match ? this.base64Decode(match[2]) : null;\r\n}\r\n  deleteCookie(name: string): void {\r\n    document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`;\r\n  }\r\n}\r\n"]}
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-app-shared/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Observable, catchError, map, of, throwError,BehaviorSubject } from 'rxjs';\r\nimport { Router } from '@angular/router';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class AuthService {\r\n  clientApiUrl: string;\r\n  authlocalStorageToken: string;\r\n  userApiUrl: string;\r\n  storeApiUrl: string;\r\n  billingApiUrl:string;\r\n  oldDashboardUrl: string;\r\n  dropDownTrigger = new BehaviorSubject(null)\r\n  trafficApiUrl: any;\r\n  traxUrl:any;\r\n  galleryApiUrl:any;\r\n  storeBuilderApiUrl: any;\r\n  constructor(private router:Router,private gs:GlobalStateService,private http:HttpClient) {  \r\n    this.gs.environment.subscribe((env)=>{\r\n    if(env){\r\n     this.clientApiUrl =  env.clientApiUrl;\r\n     this.userApiUrl = env.userApiUrl; \r\n     this.storeApiUrl =env.storeApiUrl;\r\n     this.oldDashboardUrl =env.oldDashboardUrl;\r\n     this.trafficApiUrl = env.trafficApiUrl\r\n     this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;\r\n     this.billingApiUrl = env.billingApiUrl\r\n     this.trafficApiUrl = env.trafficApiUrl;\r\n     this.galleryApiUrl = env.galleryApiUrl;\r\n     this.traxUrl = env.trafficApiUrl;\r\n     this.traxUrl = env.traxUrl;\r\n     this.storeBuilderApiUrl = env.storeBuilderUrl;\r\n    }\r\n   }) }\r\n   \r\n   handleError(res: any) {\r\n    return throwError(res.error);\r\n}\r\ngetHeaders() {\r\n  const headers = {\r\n      'Authorization': 'Bearer ' + this.authlocalStorageToken\r\n  };\r\n\r\n  return headers;\r\n}\r\n\r\n  logout() {\r\n    this.deleteCookie(this.authlocalStorageToken);\r\n    return this.http.get(`${this.userApiUrl}/logout`)\r\n  }\r\n  getClients(){\r\n    return this.http.get(`${this.clientApiUrl}/get-clients`, {\r\n  })\r\n      .pipe(map((response: any) => response),\r\n          catchError(this.handleError));\r\n  }\r\n  getStores(id:any){\r\n    return this.http.get(`${this.storeApiUrl}/get-stores?clientId=${id}`, {\r\n  })\r\n      .pipe(map((response: any) => response),\r\n          catchError(this.handleError));\r\n  }\r\n  getOldDashboardRedirect(data:any){\r\n    return this.http.post(`${this.oldDashboardUrl}/auth/oldDashboardUserLogin`,data, {\r\n      headers: this.getHeaders()\r\n    })\r\n  }\r\n  userProfileDet(): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  refreshToken() {\r\n    const userId = JSON.parse(localStorage.getItem(\"user-info\") || \"\")?._id;\r\n    const refreshToken = JSON.parse(\r\n      localStorage.getItem(this.authlocalStorageToken) || \"\"\r\n    )?.refreshToken;\r\n    let params: any = {\r\n      userId: userId,\r\n      refreshToken: refreshToken,\r\n    };\r\n    return this.http\r\n      .get(`${this.userApiUrl}/refresh-token`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  getPersonalInfo(): Observable<any> {\r\n    return this.http.get<any>(`${this.userApiUrl}/profileV2`).pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  getAssignedUsers(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.userApiUrl}/get-assign-client?clientId=${clientId}` )\r\n  }\r\n\r\n  checkToShowPopup(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.clientApiUrl}/show-csm-assign-confirmation?clientId=${clientId}` )\r\n  }\r\n\r\n  csmAssignClientAction(clientId:string, data:any):Observable<any>{ \r\n    return this.http.post(`${this.clientApiUrl}/client-csm-assign-action?clientId=${clientId}`, data )\r\n  }\r\n  // getLocation(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerLocations_v1`, data)\r\n  // }\r\n\r\n  // getGroups(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerGroups_v1`, data)\r\n  // }\r\n\r\n  // getHeaderStores(data:any):Observable<any>{ \r\n  //   return this.http.post(`${this.trafficApiUrl}/headerStores_v1`, data)\r\n  // }\r\n\r\n  getLeadProducts(email:string):Observable<any>{ \r\n    return this.http.get(`${this.billingApiUrl}/getLeadProducts/${email}` )\r\n  }\r\n\r\n  getClientProducts(clientId:string):Observable<any>{ \r\n    return this.http.get(`${this.billingApiUrl}/getClientProducts/${clientId}` )\r\n  }\r\n\r\n  getLocation(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerLocations_v2`,data)\r\n  }\r\n  getGroups(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headercluster_v2`,data)\r\n  }\r\n  getHeaderStores(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerStores_v2`,data)\r\n  }\r\n  getHeadertraxStores(data:any):Observable<any>{ \r\n    return this.http.post(`${this.galleryApiUrl}/headerStores_v2`,data)\r\n  }\r\n\r\n  getBrandDetails(id: any) {\r\n    return this.http.get(`${this.clientApiUrl}/client-details/${id}`)\r\n  }\r\n\r\n  getHeaderUsers(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerUserEmails_v2`,data)\r\n  }\r\n\r\n  getCountry(data:any):Observable<any>{ \r\n    return this.http.post(`${this.trafficApiUrl}/headerCountry_v2`,data)\r\n  }\r\n  getPlanoUsers() {\r\n    return this.http.get(`${this.storeBuilderApiUrl}/getPlanoUser`);\r\n  }\r\n  getHeaderZone(data:any):Observable<any>{\r\n    return this.http.post(`${this.trafficApiUrl}/headerZoneV2`,data)\r\n  }\r\n\r\n  private base64Encode(str: any) {\r\n  return btoa(encodeURIComponent(str));\r\n}\r\n\r\nprivate base64Decode(str: any) {\r\n  return decodeURIComponent(atob(str));\r\n}\r\nsetCookie(name: string, value: string, days: number = 1): void {\r\n  const encodedValue = this.base64Encode(value);\r\n  const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n  document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;\r\n}\r\n\r\ngetCookie(name: string): string | null {\r\n  const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));\r\n  return match ? this.base64Decode(match[2]) : null;\r\n}\r\n  deleteCookie(name: string): void {\r\n    document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`;\r\n  }\r\n}\r\n"]}