tango-app-ui-shared 3.5.0-alpha.10 → 3.5.0-alpha.11

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,131 +22,28 @@ 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
- // }
123
25
  intercept(request, next) {
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 || '';
26
+ const user = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
27
+ request = request.clone({
28
+ setHeaders: {
29
+ Authorization: 'Bearer ' + user.authenticationToken
130
30
  }
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) => {
31
+ });
32
+ return next.handle(request)
33
+ .pipe(tap((response) => {
143
34
  if (response?.body?.data?.result === 'RESTRICTED-IP') {
144
35
  this.router.navigateByUrl('/error/403-ip');
145
36
  }
146
- }), catchError((error) => {
37
+ }))
38
+ .pipe(catchError((error) => {
147
39
  if (error instanceof HttpErrorResponse && error.status === 401) {
40
+ // If the error is due to unauthorized access, try to refresh the token
148
41
  return this.handle401Error(request, next);
149
42
  }
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
+ // }
150
47
  return throwError(error);
151
48
  }));
152
49
  }
@@ -154,48 +51,74 @@ export class HttpAuthInterceptor {
154
51
  if (!this.isRefreshingToken) {
155
52
  this.isRefreshingToken = true;
156
53
  return this.authService.refreshToken().pipe(switchMap((res) => {
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;
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
160
58
  request = request.clone({
161
59
  setHeaders: {
162
- Authorization: 'Bearer ' + newToken,
163
- },
60
+ Authorization: `Bearer ${res.data.result.authenticationToken}`
61
+ }
164
62
  });
63
+ // Reset the flag for token refreshing
165
64
  this.isRefreshingToken = false;
65
+ // Retry the original request with the new token
166
66
  return next.handle(request);
167
67
  }
168
68
  else {
169
- return this.forceLogout('Token Expired. Please login again.');
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!');
170
85
  }
171
- }), catchError((err) => this.forceLogout(err)));
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
+ }));
172
104
  }
173
105
  else {
174
- // Optional: implement logic to queue and retry if multiple requests during refresh
175
- return throwError('Token refresh already in progress');
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
+ }));
176
116
  }
177
117
  }
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
- }
195
118
  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 });
196
119
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor });
197
120
  }
198
121
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
199
122
  type: Injectable
200
123
  }], ctorParameters: () => [{ type: i1.GlobalStateService }, { type: i2.AuthService }, { type: i3.Router }] });
201
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1hdXRoLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL2ludGVyY2VwdG9ycy9odHRwLWF1dGgtaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBS0wsaUJBQWlCLEVBQ2xCLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLGVBQWUsRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSzNGLE1BQU0sT0FBTyxtQkFBbUI7SUFPcEI7SUFDQTtJQUFpQztJQU4zQyxxQkFBcUIsR0FBUyxFQUFFLENBQUM7SUFDekIsaUJBQWlCLEdBQVksS0FBSyxDQUFDO0lBQ25DLGNBQWMsR0FBNkIsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7SUFFdkYsWUFDVSxFQUFxQixFQUNyQixXQUF3QixFQUFTLE1BQWE7UUFEOUMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFDckIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBRXRELElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ25DLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDO0lBQ0Qsd0ZBQXdGO0lBQ3hGLDRGQUE0RjtJQUM1Riw4QkFBOEI7SUFDOUIsb0JBQW9CO0lBQ3BCLDREQUE0RDtJQUM1RCxRQUFRO0lBQ1Is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LCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgSHR0cFJlcXVlc3QsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEV2ZW50LFxyXG4gIEh0dHBJbnRlcmNlcHRvcixcclxuICBIdHRwRXJyb3JSZXNwb25zZVxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjYXRjaEVycm9yLCBzd2l0Y2hNYXAsIHRocm93RXJyb3IsIHRhcCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICd0YW5nby1hcHAtdWktZ2xvYmFsJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBIdHRwQXV0aEludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgYXV0aGxvY2FsU3RvcmFnZVRva2VuOiBzdHJpbmc9Jyc7XHJcbiAgcHJpdmF0ZSBpc1JlZnJlc2hpbmdUb2tlbjogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIHByaXZhdGUgdG9rZW5SZWZyZXNoZWQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xyXG4gIFxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxwcml2YXRlIHJvdXRlcjpSb3V0ZXJcclxuICApIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpPT57XHJcbiAgICAgIGlmKGVudil7XHJcbiAgICAgICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDt9XHJcbiAgICAgfSlcclxuICB9XHJcbiAgLy8gaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIC8vICAgY29uc3QgdXNlcjogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgLy8gICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgLy8gICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB1c2VyLmF1dGhlbnRpY2F0aW9uVG9rZW5cclxuICAvLyAgICAgfVxyXG4gIC8vICAgfSk7XHJcbiAgLy8gICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdClcclxuICAvLyAgIC5waXBlKHRhcCgocmVzcG9uc2U6YW55KT0+e1xyXG4gIC8vICAgICBpZihyZXNwb25zZT8uYm9keT8uZGF0YT8ucmVzdWx0ID09PSAnUkVTVFJJQ1RFRC1JUCcpe1xyXG4gIC8vICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwoJy9lcnJvci80MDMtaXAnKVxyXG4gIC8vICAgICB9XHJcbiAgLy8gICB9KSlcclxuICAvLyAgIC5waXBlKFxyXG4gIC8vICAgICBjYXRjaEVycm9yKChlcnJvcjphbnkpPT57XHJcbiAgLy8gICAgICAgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDEpIHtcclxuICAvLyAgICAgICAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAvLyAgICAgICB9IFxyXG4gIC8vICAgICAgIC8vIGVsc2UgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDMpIHtcclxuICAvLyAgICAgICAvLyAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgLy8gICAgICAgLy8gIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL21hbmFnZS9icmFuZHMnXSlcclxuICAvLyAgICAgICAvLyB9IFxyXG4gIC8vICAgICAgIHJldHVybiB0aHJvd0Vycm9yKGVycm9yKTtcclxuICAvLyAgICAgfSlcclxuICAvLyAgICk7XHJcbiAgLy8gfVxyXG5cclxuICAvLyBwcml2YXRlIGhhbmRsZTQwMUVycm9yKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIC8vICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZ1Rva2VuKSB7XHJcbiAgLy8gICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSB0cnVlO1xyXG4gIC8vICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gIC8vICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAvLyAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT0gMjAwICYmIHJlcy5kYXRhLnJlc3VsdCkge1xyXG4gIC8vICAgICAgICAgICAvLyBVcGRhdGUgbG9jYWwgc3RvcmFnZSB3aXRoIHRoZSBuZXcgdG9rZW5cclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0odGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4sIEpTT04uc3RyaW5naWZ5KHJlcy5kYXRhLnJlc3VsdCkpO1xyXG4gICAgICAgICAgICBcclxuICAvLyAgICAgICAgICAgLy8gQ2xvbmUgdGhlIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgLy8gICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAvLyAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgLy8gICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7cmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW59YFxyXG4gIC8vICAgICAgICAgICAgIH1cclxuICAvLyAgICAgICAgICAgfSk7XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIC8vIFJlc2V0IHRoZSBmbGFnIGZvciB0b2tlbiByZWZyZXNoaW5nXHJcbiAgLy8gICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICBcclxuICAvLyAgICAgICAgICAgLy8gUmV0cnkgdGhlIG9yaWdpbmFsIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgLy8gICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAvLyAgICAgICAgIH0gZWxzZSB7XHJcbiAgLy8gICAgICAgICAgIC8vIExvZ291dCB1c2VyIGlmIHJlZnJlc2ggdG9rZW4gZmFpbHNcclxuICAvLyAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAvLyAgICAgICAgICAgY29uc3Qga2V5c1RvS2VlcCA9IFsnZGF0YS1taXNtYXRjaC1kcmFmdCddO1xyXG4gIC8vICAgICAgICAgICBjb25zdCB2YWx1ZXNUb0tlZXA6YW55ID0ge307XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIGtleXNUb0tlZXAuZm9yRWFjaChrZXkgPT4ge1xyXG4gIC8vICAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICAvLyAgICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAvLyAgICAgICAgICAgICAgIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsdWU7XHJcbiAgLy8gICAgICAgICAgICAgfVxyXG4gIC8vICAgICAgICAgICB9KTtcclxuICBcclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIE9iamVjdC5rZXlzKHZhbHVlc1RvS2VlcCkuZm9yRWFjaChrZXkgPT4ge1xyXG4gIC8vICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgdmFsdWVzVG9LZWVwW2tleV0pO1xyXG4gIC8vICAgICAgICAgICB9KTsgXHJcbiAgLy8gICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgLy8gICAgICAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiBFeHBpcmVkIFBsZWFzZSBMb2dpbiBBZ2FpbiEnKTtcclxuICAvLyAgICAgICAgIH1cclxuICAvLyAgICAgICB9KSxcclxuICAvLyAgICAgICBjYXRjaEVycm9yKChlcnJvcikgPT4ge1xyXG4gIC8vICAgICAgICAgLy8gTG9nb3V0IHVzZXIgaWYgcmVmcmVzaCB0b2tlbiBmYWlsc1xyXG4gIC8vICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAvLyAgICAgICAgIGNvbnN0IGtleXNUb0tlZXAgPSBbJ2RhdGEtbWlzbWF0Y2gtZHJhZnQnXTtcclxuICAvLyAgICAgICAgIGNvbnN0IHZhbHVlc1RvS2VlcDphbnkgPSB7fTtcclxuXHJcbiAgLy8gICAgICAgICBrZXlzVG9LZWVwLmZvckVhY2goa2V5ID0+IHtcclxuICAvLyAgICAgICAgICAgY29uc3QgdmFsdWUgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xyXG4gIC8vICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAvLyAgICAgICAgICAgICB2YWx1ZXNUb0tlZXBba2V5XSA9IHZhbHVlO1xyXG4gIC8vICAgICAgICAgICB9XHJcbiAgLy8gICAgICAgICB9KTtcclxuXHJcbiAgLy8gICAgICAgICBsb2NhbFN0b3JhZ2UuY2xlYXIoKTtcclxuXHJcbiAgLy8gICAgICAgICBPYmplY3Qua2V5cyh2YWx1ZXNUb0tlZXApLmZvckVhY2goa2V5ID0+IHtcclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oa2V5LCB2YWx1ZXNUb0tlZXBba2V5XSk7XHJcbiAgLy8gICAgICAgICB9KTsgXHJcbiAgICAgICAgICBcclxuICAvLyAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhyb3dFcnJvcihlcnJvcik7XHJcbiAgLy8gICAgICAgfSlcclxuICAvLyAgICAgKTtcclxuICAvLyAgIH0gZWxzZSB7XHJcbiAgLy8gICAgIC8vIElmIGFscmVhZHkgcmVmcmVzaGluZyB0aGUgdG9rZW4sIHF1ZXVlIHRoZSByZXF1ZXN0IGFuZCB3YWl0XHJcbiAgLy8gICAgIHJldHVybiB0aGlzLnRva2VuUmVmcmVzaGVkLnBpcGUoXHJcbiAgLy8gICAgICAgc3dpdGNoTWFwKCgpID0+IHtcclxuICAvLyAgICAgICAgIGNvbnN0IHRva2VuczogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgLy8gICAgICAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgLy8gICAgICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB0b2tlbnMuYXV0aGVudGljYXRpb25Ub2tlblxyXG4gIC8vICAgICAgICAgICB9XHJcbiAgLy8gICAgICAgICB9KTtcclxuICAvLyAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAvLyAgICAgICB9KVxyXG4gIC8vICAgICApO1xyXG4gIC8vICAgfVxyXG4gIC8vIH1cclxuICBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICBjb25zdCB0b2tlbk9ialN0ciA9IHRoaXMuYXV0aFNlcnZpY2UuZ2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuKTtcclxuICAgIGxldCB0b2tlbiA9ICcnO1xyXG5cclxuICAgIGlmICh0b2tlbk9ialN0cikge1xyXG4gICAgICB0cnkge1xyXG4gICAgICAgIGNvbnN0IHRva2VuT2JqID0gSlNPTi5wYXJzZSh0b2tlbk9ialN0cik7XHJcbiAgICAgICAgdG9rZW4gPSB0b2tlbk9iaj8uYXV0aGVudGljYXRpb25Ub2tlbiB8fCAnJztcclxuICAgICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgYXV0aCB0b2tlbiBmb3JtYXQgaW4gY29va2llJywgZSk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBpZiAodG9rZW4pIHtcclxuICAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xyXG4gICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICAgIEF1dGhvcml6YXRpb246ICdCZWFyZXIgJyArIHRva2VuLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gICAgICB0YXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAgICAgICBpZiAocmVzcG9uc2U/LmJvZHk/LmRhdGE/LnJlc3VsdCA9PT0gJ1JFU1RSSUNURUQtSVAnKSB7XHJcbiAgICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvZXJyb3IvNDAzLWlwJyk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KSxcclxuICAgICAgY2F0Y2hFcnJvcigoZXJyb3I6IGFueSkgPT4ge1xyXG4gICAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEh0dHBFcnJvclJlc3BvbnNlICYmIGVycm9yLnN0YXR1cyA9PT0gNDAxKSB7XHJcbiAgICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgaGFuZGxlNDAxRXJyb3IocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICBpZiAoIXRoaXMuaXNSZWZyZXNoaW5nVG9rZW4pIHtcclxuICAgICAgdGhpcy5pc1JlZnJlc2hpbmdUb2tlbiA9IHRydWU7XHJcblxyXG4gICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT09IDIwMCAmJiByZXMuZGF0YT8ucmVzdWx0KSB7XHJcbiAgICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuLCBKU09OLnN0cmluZ2lmeShyZXMuZGF0YS5yZXN1bHQpLCAxKTtcclxuXHJcbiAgICAgICAgICAgIGNvbnN0IG5ld1Rva2VuID0gcmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW47XHJcbiAgICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyBuZXdUb2tlbixcclxuICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpO1xyXG4gICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuZm9yY2VMb2dvdXQoJ1Rva2VuIEV4cGlyZWQuIFBsZWFzZSBsb2dpbiBhZ2Fpbi4nKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHRoaXMuZm9yY2VMb2dvdXQoZXJyKSlcclxuICAgICAgKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIE9wdGlvbmFsOiBpbXBsZW1lbnQgbG9naWMgdG8gcXVldWUgYW5kIHJldHJ5IGlmIG11bHRpcGxlIHJlcXVlc3RzIGR1cmluZyByZWZyZXNoXHJcbiAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiByZWZyZXNoIGFscmVhZHkgaW4gcHJvZ3Jlc3MnKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgZm9yY2VMb2dvdXQobWVzc2FnZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxuZXZlcj4ge1xyXG4gICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuXHJcbiAgICBjb25zdCBrZXlzVG9LZWVwID0gWydkYXRhLW1pc21hdGNoLWRyYWZ0J107XHJcbiAgICBjb25zdCB2YWx1ZXNUb0tlZXA6IGFueSA9IHt9O1xyXG5cclxuICAgIGtleXNUb0tlZXAuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgICAgIGNvbnN0IHZhbCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKGtleSk7XHJcbiAgICAgIGlmICh2YWwpIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsO1xyXG4gICAgfSk7XHJcblxyXG4gICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcblxyXG4gICAgLy8gT2JqZWN0LmVudHJpZXModmFsdWVzVG9LZWVwKS5mb3JFYWNoKChbaywgdl0pID0+IHtcclxuICAgIC8vICAgcmV0dXJuIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGssIHYpO1xyXG4gICAgLy8gfSk7XHJcblxyXG4gICAgdGhpcy5hdXRoU2VydmljZS5kZWxldGVDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG4gICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgIHJldHVybiB0aHJvd0Vycm9yKCgpID0+IG1lc3NhZ2UpO1xyXG4gIH1cclxufSJdfQ==
124
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1hdXRoLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL2ludGVyY2VwdG9ycy9odHRwLWF1dGgtaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBS0wsaUJBQWlCLEVBQ2xCLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLGVBQWUsRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSzNGLE1BQU0sT0FBTyxtQkFBbUI7SUFPcEI7SUFDQTtJQUFpQztJQU4zQyxxQkFBcUIsR0FBUyxFQUFFLENBQUM7SUFDekIsaUJBQWlCLEdBQVksS0FBSyxDQUFDO0lBQ25DLGNBQWMsR0FBNkIsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7SUFFdkYsWUFDVSxFQUFxQixFQUNyQixXQUF3QixFQUFTLE1BQWE7UUFEOUMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFDckIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBRXRELElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ25DLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDO0lBQ0QsU0FBUyxDQUFDLE9BQXlCLEVBQUUsSUFBaUI7UUFDcEQsTUFBTSxJQUFJLEdBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENB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O1NBQ0g7YUFBTTtZQUNMLDhEQUE4RDtZQUM5RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUM3QixTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNiLE1BQU0sTUFBTSxHQUFRLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQztnQkFDekYsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7b0JBQ3RCLFVBQVUsRUFBRTt3QkFDVixhQUFhLEVBQUUsU0FBUyxHQUFHLE1BQU0sQ0FBQyxtQkFBbUI7cUJBQ3REO2lCQUNGLENBQUMsQ0FBQztnQkFDSCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDOUIsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUNIO0lBQ0gsQ0FBQzt3R0EzSFUsbUJBQW1COzRHQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgSHR0cFJlcXVlc3QsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEV2ZW50LFxyXG4gIEh0dHBJbnRlcmNlcHRvcixcclxuICBIdHRwRXJyb3JSZXNwb25zZVxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjYXRjaEVycm9yLCBzd2l0Y2hNYXAsIHRocm93RXJyb3IsIHRhcCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICd0YW5nby1hcHAtdWktZ2xvYmFsJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBIdHRwQXV0aEludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgYXV0aGxvY2FsU3RvcmFnZVRva2VuOiBzdHJpbmc9Jyc7XHJcbiAgcHJpdmF0ZSBpc1JlZnJlc2hpbmdUb2tlbjogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIHByaXZhdGUgdG9rZW5SZWZyZXNoZWQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xyXG4gIFxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxwcml2YXRlIHJvdXRlcjpSb3V0ZXJcclxuICApIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpPT57XHJcbiAgICAgIGlmKGVudil7XHJcbiAgICAgICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDt9XHJcbiAgICAgfSlcclxuICB9XHJcbiAgaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgY29uc3QgdXNlcjogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB1c2VyLmF1dGhlbnRpY2F0aW9uVG9rZW5cclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdClcclxuICAgIC5waXBlKHRhcCgocmVzcG9uc2U6YW55KT0+e1xyXG4gICAgICBpZihyZXNwb25zZT8uYm9keT8uZGF0YT8ucmVzdWx0ID09PSAnUkVTVFJJQ1RFRC1JUCcpe1xyXG4gICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwoJy9lcnJvci80MDMtaXAnKVxyXG4gICAgICB9XHJcbiAgICB9KSlcclxuICAgIC5waXBlKFxyXG4gICAgICBjYXRjaEVycm9yKChlcnJvcjphbnkpPT57XHJcbiAgICAgICAgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDEpIHtcclxuICAgICAgICAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAgICAgICB9IFxyXG4gICAgICAgIC8vIGVsc2UgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDMpIHtcclxuICAgICAgICAvLyAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgICAgICAgLy8gIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL21hbmFnZS9icmFuZHMnXSlcclxuICAgICAgICAvLyB9IFxyXG4gICAgICAgIHJldHVybiB0aHJvd0Vycm9yKGVycm9yKTtcclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGhhbmRsZTQwMUVycm9yKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZ1Rva2VuKSB7XHJcbiAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSB0cnVlO1xyXG4gICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT0gMjAwICYmIHJlcy5kYXRhLnJlc3VsdCkge1xyXG4gICAgICAgICAgICAvLyBVcGRhdGUgbG9jYWwgc3RvcmFnZSB3aXRoIHRoZSBuZXcgdG9rZW5cclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0odGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4sIEpTT04uc3RyaW5naWZ5KHJlcy5kYXRhLnJlc3VsdCkpO1xyXG4gICAgICAgICAgICBcclxuICAgICAgICAgICAgLy8gQ2xvbmUgdGhlIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7cmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW59YFxyXG4gICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSk7XHJcbiAgXHJcbiAgICAgICAgICAgIC8vIFJlc2V0IHRoZSBmbGFnIGZvciB0b2tlbiByZWZyZXNoaW5nXHJcbiAgICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICBcclxuICAgICAgICAgICAgLy8gUmV0cnkgdGhlIG9yaWdpbmFsIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIC8vIExvZ291dCB1c2VyIGlmIHJlZnJlc2ggdG9rZW4gZmFpbHNcclxuICAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAgICAgICAgICAgY29uc3Qga2V5c1RvS2VlcCA9IFsnZGF0YS1taXNtYXRjaC1kcmFmdCddO1xyXG4gICAgICAgICAgICBjb25zdCB2YWx1ZXNUb0tlZXA6YW55ID0ge307XHJcbiAgXHJcbiAgICAgICAgICAgIGtleXNUb0tlZXAuZm9yRWFjaChrZXkgPT4ge1xyXG4gICAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICAgICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAgICAgICAgICAgICAgIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsdWU7XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KTtcclxuICBcclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcbiAgXHJcbiAgICAgICAgICAgIE9iamVjdC5rZXlzKHZhbHVlc1RvS2VlcCkuZm9yRWFjaChrZXkgPT4ge1xyXG4gICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgdmFsdWVzVG9LZWVwW2tleV0pO1xyXG4gICAgICAgICAgICB9KTsgXHJcbiAgICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgICAgICAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiBFeHBpcmVkIFBsZWFzZSBMb2dpbiBBZ2FpbiEnKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlcnJvcikgPT4ge1xyXG4gICAgICAgICAgLy8gTG9nb3V0IHVzZXIgaWYgcmVmcmVzaCB0b2tlbiBmYWlsc1xyXG4gICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAgICAgICAgIGNvbnN0IGtleXNUb0tlZXAgPSBbJ2RhdGEtbWlzbWF0Y2gtZHJhZnQnXTtcclxuICAgICAgICAgIGNvbnN0IHZhbHVlc1RvS2VlcDphbnkgPSB7fTtcclxuXHJcbiAgICAgICAgICBrZXlzVG9LZWVwLmZvckVhY2goa2V5ID0+IHtcclxuICAgICAgICAgICAgY29uc3QgdmFsdWUgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xyXG4gICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAgICAgICAgICAgICB2YWx1ZXNUb0tlZXBba2V5XSA9IHZhbHVlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgICBsb2NhbFN0b3JhZ2UuY2xlYXIoKTtcclxuXHJcbiAgICAgICAgICBPYmplY3Qua2V5cyh2YWx1ZXNUb0tlZXApLmZvckVhY2goa2V5ID0+IHtcclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oa2V5LCB2YWx1ZXNUb0tlZXBba2V5XSk7XHJcbiAgICAgICAgICB9KTsgXHJcbiAgICAgICAgICBcclxuICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgICAgICAgICByZXR1cm4gdGhyb3dFcnJvcihlcnJvcik7XHJcbiAgICAgICAgfSlcclxuICAgICAgKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIElmIGFscmVhZHkgcmVmcmVzaGluZyB0aGUgdG9rZW4sIHF1ZXVlIHRoZSByZXF1ZXN0IGFuZCB3YWl0XHJcbiAgICAgIHJldHVybiB0aGlzLnRva2VuUmVmcmVzaGVkLnBpcGUoXHJcbiAgICAgICAgc3dpdGNoTWFwKCgpID0+IHtcclxuICAgICAgICAgIGNvbnN0IHRva2VuczogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgICAgICAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgICAgICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB0b2tlbnMuYXV0aGVudGljYXRpb25Ub2tlblxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KTtcclxuICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gICAgfVxyXG4gIH1cclxuICAvLyBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgLy8gICBjb25zdCB0b2tlbk9ialN0ciA9IHRoaXMuYXV0aFNlcnZpY2UuZ2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuKTtcclxuICAvLyAgIGxldCB0b2tlbiA9ICcnO1xyXG5cclxuICAvLyAgIGlmICh0b2tlbk9ialN0cikge1xyXG4gIC8vICAgICB0cnkge1xyXG4gIC8vICAgICAgIGNvbnN0IHRva2VuT2JqID0gSlNPTi5wYXJzZSh0b2tlbk9ialN0cik7XHJcbiAgLy8gICAgICAgdG9rZW4gPSB0b2tlbk9iaj8uYXV0aGVudGljYXRpb25Ub2tlbiB8fCAnJztcclxuICAvLyAgICAgfSBjYXRjaCAoZSkge1xyXG4gIC8vICAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgYXV0aCB0b2tlbiBmb3JtYXQgaW4gY29va2llJywgZSk7XHJcbiAgLy8gICAgIH1cclxuICAvLyAgIH1cclxuXHJcbiAgLy8gICBpZiAodG9rZW4pIHtcclxuICAvLyAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xyXG4gIC8vICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICAgIEF1dGhvcml6YXRpb246ICdCZWFyZXIgJyArIHRva2VuLFxyXG4gIC8vICAgICAgIH0sXHJcbiAgLy8gICAgIH0pO1xyXG4gIC8vICAgfVxyXG5cclxuICAvLyAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gIC8vICAgICB0YXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAvLyAgICAgICBpZiAocmVzcG9uc2U/LmJvZHk/LmRhdGE/LnJlc3VsdCA9PT0gJ1JFU1RSSUNURUQtSVAnKSB7XHJcbiAgLy8gICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvZXJyb3IvNDAzLWlwJyk7XHJcbiAgLy8gICAgICAgfVxyXG4gIC8vICAgICB9KSxcclxuICAvLyAgICAgY2F0Y2hFcnJvcigoZXJyb3I6IGFueSkgPT4ge1xyXG4gIC8vICAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEh0dHBFcnJvclJlc3BvbnNlICYmIGVycm9yLnN0YXR1cyA9PT0gNDAxKSB7XHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAvLyAgICAgICB9XHJcbiAgLy8gICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gIC8vICAgICB9KVxyXG4gIC8vICAgKTtcclxuICAvLyB9XHJcblxyXG4gIC8vIHByaXZhdGUgaGFuZGxlNDAxRXJyb3IocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgLy8gICBpZiAoIXRoaXMuaXNSZWZyZXNoaW5nVG9rZW4pIHtcclxuICAvLyAgICAgdGhpcy5pc1JlZnJlc2hpbmdUb2tlbiA9IHRydWU7XHJcblxyXG4gIC8vICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gIC8vICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAvLyAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT09IDIwMCAmJiByZXMuZGF0YT8ucmVzdWx0KSB7XHJcbiAgLy8gICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuLCBKU09OLnN0cmluZ2lmeShyZXMuZGF0YS5yZXN1bHQpLCAxKTtcclxuXHJcbiAgLy8gICAgICAgICAgIGNvbnN0IG5ld1Rva2VuID0gcmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW47XHJcbiAgLy8gICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAvLyAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgLy8gICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyBuZXdUb2tlbixcclxuICAvLyAgICAgICAgICAgICB9LFxyXG4gIC8vICAgICAgICAgICB9KTtcclxuXHJcbiAgLy8gICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICAvLyAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpO1xyXG4gIC8vICAgICAgICAgfSBlbHNlIHtcclxuICAvLyAgICAgICAgICAgcmV0dXJuIHRoaXMuZm9yY2VMb2dvdXQoJ1Rva2VuIEV4cGlyZWQuIFBsZWFzZSBsb2dpbiBhZ2Fpbi4nKTtcclxuICAvLyAgICAgICAgIH1cclxuICAvLyAgICAgICB9KSxcclxuICAvLyAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHRoaXMuZm9yY2VMb2dvdXQoZXJyKSlcclxuICAvLyAgICAgKTtcclxuICAvLyAgIH0gZWxzZSB7XHJcbiAgLy8gICAgIC8vIE9wdGlvbmFsOiBpbXBsZW1lbnQgbG9naWMgdG8gcXVldWUgYW5kIHJldHJ5IGlmIG11bHRpcGxlIHJlcXVlc3RzIGR1cmluZyByZWZyZXNoXHJcbiAgLy8gICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiByZWZyZXNoIGFscmVhZHkgaW4gcHJvZ3Jlc3MnKTtcclxuICAvLyAgIH1cclxuICAvLyB9XHJcblxyXG4gIC8vIHByaXZhdGUgZm9yY2VMb2dvdXQobWVzc2FnZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxuZXZlcj4ge1xyXG4gIC8vICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuXHJcbiAgLy8gICBjb25zdCBrZXlzVG9LZWVwID0gWydkYXRhLW1pc21hdGNoLWRyYWZ0J107XHJcbiAgLy8gICBjb25zdCB2YWx1ZXNUb0tlZXA6IGFueSA9IHt9O1xyXG5cclxuICAvLyAgIGtleXNUb0tlZXAuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgLy8gICAgIGNvbnN0IHZhbCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKGtleSk7XHJcbiAgLy8gICAgIGlmICh2YWwpIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsO1xyXG4gIC8vICAgfSk7XHJcblxyXG4gIC8vICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcblxyXG4gIC8vICAgLy8gT2JqZWN0LmVudHJpZXModmFsdWVzVG9LZWVwKS5mb3JFYWNoKChbaywgdl0pID0+IHtcclxuICAvLyAgIC8vICAgcmV0dXJuIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGssIHYpO1xyXG4gIC8vICAgLy8gfSk7XHJcblxyXG4gIC8vICAgdGhpcy5hdXRoU2VydmljZS5kZWxldGVDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG4gIC8vICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAvLyAgIHJldHVybiB0aHJvd0Vycm9yKCgpID0+IG1lc3NhZ2UpO1xyXG4gIC8vIH1cclxufSJdfQ==
@@ -10931,131 +10931,28 @@ class HttpAuthInterceptor {
10931
10931
  }
10932
10932
  });
10933
10933
  }
10934
- // intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
10935
- // const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
10936
- // request = request.clone({
10937
- // setHeaders: {
10938
- // Authorization: 'Bearer ' + user.authenticationToken
10939
- // }
10940
- // });
10941
- // return next.handle(request)
10942
- // .pipe(tap((response:any)=>{
10943
- // if(response?.body?.data?.result === 'RESTRICTED-IP'){
10944
- // this.router.navigateByUrl('/error/403-ip')
10945
- // }
10946
- // }))
10947
- // .pipe(
10948
- // catchError((error:any)=>{
10949
- // if (error instanceof HttpErrorResponse && error.status === 401) {
10950
- // // If the error is due to unauthorized access, try to refresh the token
10951
- // return this.handle401Error(request, next);
10952
- // }
10953
- // // else if (error instanceof HttpErrorResponse && error.status === 403) {
10954
- // // // If the error is due to unauthorized access, try to refresh the token
10955
- // // this.router.navigate(['/manage/brands'])
10956
- // // }
10957
- // return throwError(error);
10958
- // })
10959
- // );
10960
- // }
10961
- // private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
10962
- // if (!this.isRefreshingToken) {
10963
- // this.isRefreshingToken = true;
10964
- // return this.authService.refreshToken().pipe(
10965
- // switchMap((res: any) => {
10966
- // if (res && res.code == 200 && res.data.result) {
10967
- // // Update local storage with the new token
10968
- // localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
10969
- // // Clone the request with the new token
10970
- // request = request.clone({
10971
- // setHeaders: {
10972
- // Authorization: `Bearer ${res.data.result.authenticationToken}`
10973
- // }
10974
- // });
10975
- // // Reset the flag for token refreshing
10976
- // this.isRefreshingToken = false;
10977
- // // Retry the original request with the new token
10978
- // return next.handle(request);
10979
- // } else {
10980
- // // Logout user if refresh token fails
10981
- // this.authService.logout();
10982
- // const keysToKeep = ['data-mismatch-draft'];
10983
- // const valuesToKeep:any = {};
10984
- // keysToKeep.forEach(key => {
10985
- // const value = localStorage.getItem(key);
10986
- // if (value !== null) {
10987
- // valuesToKeep[key] = value;
10988
- // }
10989
- // });
10990
- // localStorage.clear();
10991
- // Object.keys(valuesToKeep).forEach(key => {
10992
- // localStorage.setItem(key, valuesToKeep[key]);
10993
- // });
10994
- // this.router.navigate(['/auth/login']);
10995
- // return throwError('Token Expired Please Login Again!');
10996
- // }
10997
- // }),
10998
- // catchError((error) => {
10999
- // // Logout user if refresh token fails
11000
- // this.authService.logout();
11001
- // const keysToKeep = ['data-mismatch-draft'];
11002
- // const valuesToKeep:any = {};
11003
- // keysToKeep.forEach(key => {
11004
- // const value = localStorage.getItem(key);
11005
- // if (value !== null) {
11006
- // valuesToKeep[key] = value;
11007
- // }
11008
- // });
11009
- // localStorage.clear();
11010
- // Object.keys(valuesToKeep).forEach(key => {
11011
- // localStorage.setItem(key, valuesToKeep[key]);
11012
- // });
11013
- // this.router.navigate(['/auth/login']);
11014
- // return throwError(error);
11015
- // })
11016
- // );
11017
- // } else {
11018
- // // If already refreshing the token, queue the request and wait
11019
- // return this.tokenRefreshed.pipe(
11020
- // switchMap(() => {
11021
- // const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
11022
- // request = request.clone({
11023
- // setHeaders: {
11024
- // Authorization: 'Bearer ' + tokens.authenticationToken
11025
- // }
11026
- // });
11027
- // return next.handle(request);
11028
- // })
11029
- // );
11030
- // }
11031
- // }
11032
10934
  intercept(request, next) {
11033
- const tokenObjStr = this.authService.getCookie(this.authlocalStorageToken);
11034
- let token = '';
11035
- if (tokenObjStr) {
11036
- try {
11037
- const tokenObj = JSON.parse(tokenObjStr);
11038
- token = tokenObj?.authenticationToken || '';
11039
- }
11040
- catch (e) {
11041
- console.error('Invalid auth token format in cookie', e);
10935
+ const user = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
10936
+ request = request.clone({
10937
+ setHeaders: {
10938
+ Authorization: 'Bearer ' + user.authenticationToken
11042
10939
  }
11043
- }
11044
- if (token) {
11045
- request = request.clone({
11046
- setHeaders: {
11047
- Authorization: 'Bearer ' + token,
11048
- },
11049
- });
11050
- }
11051
- return next.handle(request).pipe(tap((response) => {
10940
+ });
10941
+ return next.handle(request)
10942
+ .pipe(tap((response) => {
11052
10943
  if (response?.body?.data?.result === 'RESTRICTED-IP') {
11053
10944
  this.router.navigateByUrl('/error/403-ip');
11054
10945
  }
11055
- }), catchError((error) => {
10946
+ }))
10947
+ .pipe(catchError((error) => {
11056
10948
  if (error instanceof HttpErrorResponse && error.status === 401) {
10949
+ // If the error is due to unauthorized access, try to refresh the token
11057
10950
  return this.handle401Error(request, next);
11058
10951
  }
10952
+ // else if (error instanceof HttpErrorResponse && error.status === 403) {
10953
+ // // If the error is due to unauthorized access, try to refresh the token
10954
+ // this.router.navigate(['/manage/brands'])
10955
+ // }
11059
10956
  return throwError(error);
11060
10957
  }));
11061
10958
  }
@@ -11063,44 +10960,70 @@ class HttpAuthInterceptor {
11063
10960
  if (!this.isRefreshingToken) {
11064
10961
  this.isRefreshingToken = true;
11065
10962
  return this.authService.refreshToken().pipe(switchMap((res) => {
11066
- if (res && res.code === 200 && res.data?.result) {
11067
- this.authService.setCookie(this.authlocalStorageToken, JSON.stringify(res.data.result), 1);
11068
- const newToken = res.data.result.authenticationToken;
10963
+ if (res && res.code == 200 && res.data.result) {
10964
+ // Update local storage with the new token
10965
+ localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
10966
+ // Clone the request with the new token
11069
10967
  request = request.clone({
11070
10968
  setHeaders: {
11071
- Authorization: 'Bearer ' + newToken,
11072
- },
10969
+ Authorization: `Bearer ${res.data.result.authenticationToken}`
10970
+ }
11073
10971
  });
10972
+ // Reset the flag for token refreshing
11074
10973
  this.isRefreshingToken = false;
10974
+ // Retry the original request with the new token
11075
10975
  return next.handle(request);
11076
10976
  }
11077
10977
  else {
11078
- return this.forceLogout('Token Expired. Please login again.');
11079
- }
11080
- }), catchError((err) => this.forceLogout(err)));
10978
+ // Logout user if refresh token fails
10979
+ this.authService.logout();
10980
+ const keysToKeep = ['data-mismatch-draft'];
10981
+ const valuesToKeep = {};
10982
+ keysToKeep.forEach(key => {
10983
+ const value = localStorage.getItem(key);
10984
+ if (value !== null) {
10985
+ valuesToKeep[key] = value;
10986
+ }
10987
+ });
10988
+ localStorage.clear();
10989
+ Object.keys(valuesToKeep).forEach(key => {
10990
+ localStorage.setItem(key, valuesToKeep[key]);
10991
+ });
10992
+ this.router.navigate(['/auth/login']);
10993
+ return throwError('Token Expired Please Login Again!');
10994
+ }
10995
+ }), catchError((error) => {
10996
+ // Logout user if refresh token fails
10997
+ this.authService.logout();
10998
+ const keysToKeep = ['data-mismatch-draft'];
10999
+ const valuesToKeep = {};
11000
+ keysToKeep.forEach(key => {
11001
+ const value = localStorage.getItem(key);
11002
+ if (value !== null) {
11003
+ valuesToKeep[key] = value;
11004
+ }
11005
+ });
11006
+ localStorage.clear();
11007
+ Object.keys(valuesToKeep).forEach(key => {
11008
+ localStorage.setItem(key, valuesToKeep[key]);
11009
+ });
11010
+ this.router.navigate(['/auth/login']);
11011
+ return throwError(error);
11012
+ }));
11081
11013
  }
11082
11014
  else {
11083
- // Optional: implement logic to queue and retry if multiple requests during refresh
11084
- return throwError('Token refresh already in progress');
11015
+ // If already refreshing the token, queue the request and wait
11016
+ return this.tokenRefreshed.pipe(switchMap(() => {
11017
+ const tokens = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
11018
+ request = request.clone({
11019
+ setHeaders: {
11020
+ Authorization: 'Bearer ' + tokens.authenticationToken
11021
+ }
11022
+ });
11023
+ return next.handle(request);
11024
+ }));
11085
11025
  }
11086
11026
  }
11087
- forceLogout(message) {
11088
- this.authService.logout();
11089
- const keysToKeep = ['data-mismatch-draft'];
11090
- const valuesToKeep = {};
11091
- keysToKeep.forEach((key) => {
11092
- const val = localStorage.getItem(key);
11093
- if (val)
11094
- valuesToKeep[key] = val;
11095
- });
11096
- localStorage.clear();
11097
- // Object.entries(valuesToKeep).forEach(([k, v]) => {
11098
- // return localStorage.setItem(k, v);
11099
- // });
11100
- this.authService.deleteCookie(this.authlocalStorageToken);
11101
- this.router.navigate(['/auth/login']);
11102
- return throwError(() => message);
11103
- }
11104
11027
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.GlobalStateService }, { token: AuthService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
11105
11028
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor });
11106
11029
  }