tango-app-ui-shared 3.6.0-cookie-4 → 3.6.0-cookie-1
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
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
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
|
-
|
|
33
|
-
|
|
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
|
|
55
|
-
|
|
56
|
-
|
|
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:
|
|
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
|
-
|
|
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((
|
|
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
|
-
//
|
|
107
|
-
return
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1hdXRoLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL2ludGVyY2VwdG9ycy9odHRwLWF1dGgtaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBS0wsaUJBQWlCLEVBQ2xCLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLGVBQWUsRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSzNGLE1BQU0sT0FBTyxtQkFBbUI7SUFPcEI7SUFDQTtJQUFpQztJQU4zQyxxQkFBcUIsR0FBUyxFQUFFLENBQUM7SUFDekIsaUJBQWlCLEdBQVksS0FBSyxDQUFDO0lBQ25DLGNBQWMsR0FBNkIsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7SUFFdkYsWUFDVSxFQUFxQixFQUNyQixXQUF3QixFQUFTLE1BQWE7UUFEOUMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFDckIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBRXRELElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ25DLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDO0lBQ0QsU0FBUyxDQUFDLE9BQXlCLEVBQUUsSUFBaUI7UUFDcEQsTUFBTSxJQUFJLEdBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENB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O1NBQ0g7YUFBTTtZQUNMLDhEQUE4RDtZQUM5RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUM3QixTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNiLE1BQU0sTUFBTSxHQUFRLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQztnQkFDekYsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7b0JBQ3RCLFVBQVUsRUFBRTt3QkFDVixhQUFhLEVBQUUsU0FBUyxHQUFHLE1BQU0sQ0FBQyxtQkFBbUI7cUJBQ3REO2lCQUNGLENBQUMsQ0FBQztnQkFDSCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDOUIsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUNIO0lBQ0gsQ0FBQzt3R0EzSFUsbUJBQW1COzRHQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgSHR0cFJlcXVlc3QsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEV2ZW50LFxyXG4gIEh0dHBJbnRlcmNlcHRvcixcclxuICBIdHRwRXJyb3JSZXNwb25zZVxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjYXRjaEVycm9yLCBzd2l0Y2hNYXAsIHRocm93RXJyb3IsIHRhcCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICd0YW5nby1hcHAtdWktZ2xvYmFsJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBIdHRwQXV0aEludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgYXV0aGxvY2FsU3RvcmFnZVRva2VuOiBzdHJpbmc9Jyc7XHJcbiAgcHJpdmF0ZSBpc1JlZnJlc2hpbmdUb2tlbjogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIHByaXZhdGUgdG9rZW5SZWZyZXNoZWQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xyXG4gIFxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxwcml2YXRlIHJvdXRlcjpSb3V0ZXJcclxuICApIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpPT57XHJcbiAgICAgIGlmKGVudil7XHJcbiAgICAgICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDt9XHJcbiAgICAgfSlcclxuICB9XHJcbiAgaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgY29uc3QgdXNlcjogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB1c2VyLmF1dGhlbnRpY2F0aW9uVG9rZW5cclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdClcclxuICAgIC5waXBlKHRhcCgocmVzcG9uc2U6YW55KT0+e1xyXG4gICAgICBpZihyZXNwb25zZT8uYm9keT8uZGF0YT8ucmVzdWx0ID09PSAnUkVTVFJJQ1RFRC1JUCcpe1xyXG4gICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwoJy9lcnJvci80MDMtaXAnKVxyXG4gICAgICB9XHJcbiAgICB9KSlcclxuICAgIC5waXBlKFxyXG4gICAgICBjYXRjaEVycm9yKChlcnJvcjphbnkpPT57XHJcbiAgICAgICAgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDEpIHtcclxuICAgICAgICAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAgICAgICB9IFxyXG4gICAgICAgIC8vIGVsc2UgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDMpIHtcclxuICAgICAgICAvLyAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgICAgICAgLy8gIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL21hbmFnZS9icmFuZHMnXSlcclxuICAgICAgICAvLyB9IFxyXG4gICAgICAgIHJldHVybiB0aHJvd0Vycm9yKGVycm9yKTtcclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGhhbmRsZTQwMUVycm9yKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZ1Rva2VuKSB7XHJcbiAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSB0cnVlO1xyXG4gICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT0gMjAwICYmIHJlcy5kYXRhLnJlc3VsdCkge1xyXG4gICAgICAgICAgICAvLyBVcGRhdGUgbG9jYWwgc3RvcmFnZSB3aXRoIHRoZSBuZXcgdG9rZW5cclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0odGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4sIEpTT04uc3RyaW5naWZ5KHJlcy5kYXRhLnJlc3VsdCkpO1xyXG4gICAgICAgICAgICBcclxuICAgICAgICAgICAgLy8gQ2xvbmUgdGhlIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7cmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW59YFxyXG4gICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSk7XHJcbiAgXHJcbiAgICAgICAgICAgIC8vIFJlc2V0IHRoZSBmbGFnIGZvciB0b2tlbiByZWZyZXNoaW5nXHJcbiAgICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICBcclxuICAgICAgICAgICAgLy8gUmV0cnkgdGhlIG9yaWdpbmFsIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIC8vIExvZ291dCB1c2VyIGlmIHJlZnJlc2ggdG9rZW4gZmFpbHNcclxuICAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAgICAgICAgICAgY29uc3Qga2V5c1RvS2VlcCA9IFsnZGF0YS1taXNtYXRjaC1kcmFmdCddO1xyXG4gICAgICAgICAgICBjb25zdCB2YWx1ZXNUb0tlZXA6YW55ID0ge307XHJcbiAgXHJcbiAgICAgICAgICAgIGtleXNUb0tlZXAuZm9yRWFjaChrZXkgPT4ge1xyXG4gICAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICAgICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAgICAgICAgICAgICAgIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsdWU7XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KTtcclxuICBcclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcbiAgXHJcbiAgICAgICAgICAgIE9iamVjdC5rZXlzKHZhbHVlc1RvS2VlcCkuZm9yRWFjaChrZXkgPT4ge1xyXG4gICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgdmFsdWVzVG9LZWVwW2tleV0pO1xyXG4gICAgICAgICAgICB9KTsgXHJcbiAgICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgICAgICAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiBFeHBpcmVkIFBsZWFzZSBMb2dpbiBBZ2FpbiEnKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlcnJvcikgPT4ge1xyXG4gICAgICAgICAgLy8gTG9nb3V0IHVzZXIgaWYgcmVmcmVzaCB0b2tlbiBmYWlsc1xyXG4gICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAgICAgICAgIGNvbnN0IGtleXNUb0tlZXAgPSBbJ2RhdGEtbWlzbWF0Y2gtZHJhZnQnXTtcclxuICAgICAgICAgIGNvbnN0IHZhbHVlc1RvS2VlcDphbnkgPSB7fTtcclxuXHJcbiAgICAgICAgICBrZXlzVG9LZWVwLmZvckVhY2goa2V5ID0+IHtcclxuICAgICAgICAgICAgY29uc3QgdmFsdWUgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xyXG4gICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAgICAgICAgICAgICB2YWx1ZXNUb0tlZXBba2V5XSA9IHZhbHVlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgICBsb2NhbFN0b3JhZ2UuY2xlYXIoKTtcclxuXHJcbiAgICAgICAgICBPYmplY3Qua2V5cyh2YWx1ZXNUb0tlZXApLmZvckVhY2goa2V5ID0+IHtcclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oa2V5LCB2YWx1ZXNUb0tlZXBba2V5XSk7XHJcbiAgICAgICAgICB9KTsgXHJcbiAgICAgICAgICBcclxuICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgICAgICAgICByZXR1cm4gdGhyb3dFcnJvcihlcnJvcik7XHJcbiAgICAgICAgfSlcclxuICAgICAgKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIElmIGFscmVhZHkgcmVmcmVzaGluZyB0aGUgdG9rZW4sIHF1ZXVlIHRoZSByZXF1ZXN0IGFuZCB3YWl0XHJcbiAgICAgIHJldHVybiB0aGlzLnRva2VuUmVmcmVzaGVkLnBpcGUoXHJcbiAgICAgICAgc3dpdGNoTWFwKCgpID0+IHtcclxuICAgICAgICAgIGNvbnN0IHRva2VuczogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgICAgICAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgICAgICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB0b2tlbnMuYXV0aGVudGljYXRpb25Ub2tlblxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KTtcclxuICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gICAgfVxyXG4gIH1cclxuICAvLyBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgLy8gICBjb25zdCB0b2tlbk9ialN0ciA9IHRoaXMuYXV0aFNlcnZpY2UuZ2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuKTtcclxuICAvLyAgIGxldCB0b2tlbiA9ICcnO1xyXG5cclxuICAvLyAgIGlmICh0b2tlbk9ialN0cikge1xyXG4gIC8vICAgICB0cnkge1xyXG4gIC8vICAgICAgIGNvbnN0IHRva2VuT2JqID0gSlNPTi5wYXJzZSh0b2tlbk9ialN0cik7XHJcbiAgLy8gICAgICAgdG9rZW4gPSB0b2tlbk9iaj8uYXV0aGVudGljYXRpb25Ub2tlbiB8fCAnJztcclxuICAvLyAgICAgfSBjYXRjaCAoZSkge1xyXG4gIC8vICAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgYXV0aCB0b2tlbiBmb3JtYXQgaW4gY29va2llJywgZSk7XHJcbiAgLy8gICAgIH1cclxuICAvLyAgIH1cclxuXHJcbiAgLy8gICBpZiAodG9rZW4pIHtcclxuICAvLyAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xyXG4gIC8vICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICAgIEF1dGhvcml6YXRpb246ICdCZWFyZXIgJyArIHRva2VuLFxyXG4gIC8vICAgICAgIH0sXHJcbiAgLy8gICAgIH0pO1xyXG4gIC8vICAgfVxyXG5cclxuICAvLyAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gIC8vICAgICB0YXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAvLyAgICAgICBpZiAocmVzcG9uc2U/LmJvZHk/LmRhdGE/LnJlc3VsdCA9PT0gJ1JFU1RSSUNURUQtSVAnKSB7XHJcbiAgLy8gICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvZXJyb3IvNDAzLWlwJyk7XHJcbiAgLy8gICAgICAgfVxyXG4gIC8vICAgICB9KSxcclxuICAvLyAgICAgY2F0Y2hFcnJvcigoZXJyb3I6IGFueSkgPT4ge1xyXG4gIC8vICAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEh0dHBFcnJvclJlc3BvbnNlICYmIGVycm9yLnN0YXR1cyA9PT0gNDAxKSB7XHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAvLyAgICAgICB9XHJcbiAgLy8gICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gIC8vICAgICB9KVxyXG4gIC8vICAgKTtcclxuICAvLyB9XHJcblxyXG4gIC8vIHByaXZhdGUgaGFuZGxlNDAxRXJyb3IocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgLy8gICBpZiAoIXRoaXMuaXNSZWZyZXNoaW5nVG9rZW4pIHtcclxuICAvLyAgICAgdGhpcy5pc1JlZnJlc2hpbmdUb2tlbiA9IHRydWU7XHJcblxyXG4gIC8vICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gIC8vICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAvLyAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT09IDIwMCAmJiByZXMuZGF0YT8ucmVzdWx0KSB7XHJcbiAgLy8gICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuLCBKU09OLnN0cmluZ2lmeShyZXMuZGF0YS5yZXN1bHQpLCAxKTtcclxuXHJcbiAgLy8gICAgICAgICAgIGNvbnN0IG5ld1Rva2VuID0gcmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW47XHJcbiAgLy8gICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAvLyAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgLy8gICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyBuZXdUb2tlbixcclxuICAvLyAgICAgICAgICAgICB9LFxyXG4gIC8vICAgICAgICAgICB9KTtcclxuXHJcbiAgLy8gICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICAvLyAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpO1xyXG4gIC8vICAgICAgICAgfSBlbHNlIHtcclxuICAvLyAgICAgICAgICAgcmV0dXJuIHRoaXMuZm9yY2VMb2dvdXQoJ1Rva2VuIEV4cGlyZWQuIFBsZWFzZSBsb2dpbiBhZ2Fpbi4nKTtcclxuICAvLyAgICAgICAgIH1cclxuICAvLyAgICAgICB9KSxcclxuICAvLyAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHRoaXMuZm9yY2VMb2dvdXQoZXJyKSlcclxuICAvLyAgICAgKTtcclxuICAvLyAgIH0gZWxzZSB7XHJcbiAgLy8gICAgIC8vIE9wdGlvbmFsOiBpbXBsZW1lbnQgbG9naWMgdG8gcXVldWUgYW5kIHJldHJ5IGlmIG11bHRpcGxlIHJlcXVlc3RzIGR1cmluZyByZWZyZXNoXHJcbiAgLy8gICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiByZWZyZXNoIGFscmVhZHkgaW4gcHJvZ3Jlc3MnKTtcclxuICAvLyAgIH1cclxuICAvLyB9XHJcblxyXG4gIC8vIHByaXZhdGUgZm9yY2VMb2dvdXQobWVzc2FnZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxuZXZlcj4ge1xyXG4gIC8vICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuXHJcbiAgLy8gICBjb25zdCBrZXlzVG9LZWVwID0gWydkYXRhLW1pc21hdGNoLWRyYWZ0J107XHJcbiAgLy8gICBjb25zdCB2YWx1ZXNUb0tlZXA6IGFueSA9IHt9O1xyXG5cclxuICAvLyAgIGtleXNUb0tlZXAuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgLy8gICAgIGNvbnN0IHZhbCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKGtleSk7XHJcbiAgLy8gICAgIGlmICh2YWwpIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsO1xyXG4gIC8vICAgfSk7XHJcblxyXG4gIC8vICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcblxyXG4gIC8vICAgLy8gT2JqZWN0LmVudHJpZXModmFsdWVzVG9LZWVwKS5mb3JFYWNoKChbaywgdl0pID0+IHtcclxuICAvLyAgIC8vICAgcmV0dXJuIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGssIHYpO1xyXG4gIC8vICAgLy8gfSk7XHJcblxyXG4gIC8vICAgdGhpcy5hdXRoU2VydmljZS5kZWxldGVDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG4gIC8vICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAvLyAgIHJldHVybiB0aHJvd0Vycm9yKCgpID0+IG1lc3NhZ2UpO1xyXG4gIC8vIH1cclxufSJdfQ==
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1hdXRoLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL2ludGVyY2VwdG9ycy9odHRwLWF1dGgtaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBS0wsaUJBQWlCLEVBQ2xCLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLGVBQWUsRUFBYyxVQUFVLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSzNGLE1BQU0sT0FBTyxtQkFBbUI7SUFPcEI7SUFDQTtJQUFpQztJQU4zQyxxQkFBcUIsR0FBUyxFQUFFLENBQUM7SUFDekIsaUJBQWlCLEdBQVksS0FBSyxDQUFDO0lBQ25DLGNBQWMsR0FBNkIsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7SUFFdkYsWUFDVSxFQUFxQixFQUNyQixXQUF3QixFQUFTLE1BQWE7UUFEOUMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFDckIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBRXRELElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ25DLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDO0lBQ0Qsd0ZBQXdGO0lBQ3hGLDRGQUE0RjtJQUM1Riw4QkFBOEI7SUFDOUIsb0JBQW9CO0lBQ3BCLDREQUE0RDtJQUM1RCxRQUFRO0lBQ1IsUUFBUTtJQUNSLGdDQUFnQztJQUNoQyxnQ0FBZ0M7SUFDaEMsNERBQTREO0lBQzVELG1EQUFtRDtJQUNuRCxRQUFRO0lBQ1IsUUFBUTtJQUNSLFdBQVc7SUFDWCxnQ0FBZ0M7SUFDaEMsMEVBQTBFO0lBQzFFLGtGQUFrRjtJQUNsRixxREFBcUQ7SUFDckQsV0FBVztJQUNYLGtGQUFrRjtJQUNsRixxRkFBcUY7SUFDckYscURBQXFEO0lBQ3JELGNBQWM7SUFDZCxrQ0FBa0M7SUFDbEMsU0FBUztJQUNULE9BQU87SUFDUCxJQUFJO0lBRUoscUdBQXFHO0lBQ3JHLG1DQUFtQztJQUNuQyxxQ0FBcUM7SUFDckMsbURBQW1EO0lBQ25ELGtDQUFrQztJQUNsQywyREFBMkQ7SUFDM0QsdURBQXVEO0lBQ3ZELCtGQUErRjtJQUUvRixvREFBb0Q7SUFDcEQsc0NBQXNDO0lBQ3RDLDRCQUE0QjtJQUM1QiwrRUFBK0U7SUFDL0UsZ0JBQWdCO0lBQ2hCLGdCQUFnQjtJQUVoQixtREFBbUQ7SUFDbkQsNENBQTRDO0lBRTVDLDZEQUE2RDtJQUM3RCx5Q0FBeUM7SUFDekMsbUJBQW1CO0lBQ25CLGtEQUFrRDtJQUNsRCx1Q0FBdUM7SUFDdkMsd0RBQXdEO0lBQ3hELHlDQUF5QztJQUV6Qyx3Q0FBd0M7SUFDeEMsdURBQXVEO0lBQ3ZELG9DQUFvQztJQUNwQywyQ0FBMkM7SUFDM0MsZ0JBQWdCO0lBQ2hCLGdCQUFnQjtJQUVoQixrQ0FBa0M7SUFFbEMsdURBQXVEO0lBQ3ZELDREQUE0RDtJQUM1RCxpQkFBaUI7SUFDakIsbURBQW1EO0lBQ25ELG9FQUFvRTtJQUNwRSxZQUFZO0lBQ1osWUFBWTtJQUNaLGdDQUFnQztJQUNoQyxnREFBZ0Q7SUFDaEQscUNBQXFDO0lBQ3JDLHNEQUFzRDtJQUN0RCx1Q0FBdUM7SUFFdkMsc0NBQXNDO0lBQ3RDLHFEQUFxRDtJQUNyRCxrQ0FBa0M7SUFDbEMseUNBQXlDO0lBQ3pDLGNBQWM7SUFDZCxjQUFjO0lBRWQsZ0NBQWdDO0lBRWhDLHFEQUFxRDtJQUNyRCwwREFBMEQ7SUFDMUQsZUFBZTtJQUVmLGlEQUFpRDtJQUNqRCxvQ0FBb0M7SUFDcEMsV0FBVztJQUNYLFNBQVM7SUFDVCxhQUFhO0lBQ2IscUVBQXFFO0lBQ3JFLHVDQUF1QztJQUN2QywwQkFBMEI7SUFDMUIsb0dBQW9HO0lBQ3BHLG9DQUFvQztJQUNwQywwQkFBMEI7SUFDMUIsb0VBQW9FO0lBQ3BFLGNBQWM7SUFDZCxjQUFjO0lBQ2QsdUNBQXVDO0lBQ3ZDLFdBQVc7SUFDWCxTQUFTO0lBQ1QsTUFBTTtJQUNOLElBQUk7SUFDSixTQUFTLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNwRCxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUMzRSxJQUFJLEtBQUssR0FBRyxFQUFFLENBQUM7UUFFZixJQUFJLFdBQVcsRUFBRTtZQUNmLElBQUk7Z0JBQ0YsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDekMsS0FBSyxHQUFHLFFBQVEsRUFBRSxtQkFBbUIsSUFBSSxFQUFFLENBQUM7YUFDN0M7WUFBQyxPQUFPLENBQUMsRUFBRTtnQkFDVixPQUFPLENBQUMsS0FBSyxDQUFDLHFDQUFxQyxFQUFFLENBQUMsQ0FBQyxDQUFDO2FBQ3pEO1NBQ0Y7UUFFRCxJQUFJLEtBQUssRUFBRTtZQUNULE9BQU8sR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDO2dCQUN0QixVQUFVLEVBQUU7b0JBQ1YsYUFBYSxFQUFFLFNBQVMsR0FBRyxLQUFLO2lCQUNqQzthQUNGLENBQUMsQ0FBQztTQUNKO1FBRUQsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDOUIsR0FBRyxDQUFDLENBQUMsUUFBYSxFQUFFLEVBQUU7WUFDcEIsSUFBSSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEtBQUssZUFBZSxFQUFFO2dCQUNwRCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsQ0FBQzthQUM1QztRQUNILENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLEtBQVUsRUFBRSxFQUFFO1lBQ3hCLElBQUksS0FBSyxZQUFZLGlCQUFpQixJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFO2dCQUM5RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDO2FBQzNDO1lBQ0QsT0FBTyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFTyxjQUFjLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNqRSxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFO1lBQzNCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUM7WUFFOUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRSxDQUFDLElBQUksQ0FDekMsU0FBUyxDQUFDLENBQUMsR0FBUSxFQUFFLEVBQUU7Z0JBQ3JCLElBQUksR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFO29CQUMvQyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO29CQUUzRixNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQztvQkFDckQsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7d0JBQ3RCLFVBQVUsRUFBRTs0QkFDVixhQUFhLEVBQUUsU0FBUyxHQUFHLFFBQVE7eUJBQ3BDO3FCQUNGLENBQUMsQ0FBQztvQkFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsS0FBSyxDQUFDO29CQUMvQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7aUJBQzdCO3FCQUFNO29CQUNMLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQ0FBb0MsQ0FBQyxDQUFDO2lCQUMvRDtZQUNILENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUMzQyxDQUFDO1NBQ0g7YUFBTTtZQUNMLG1GQUFtRjtZQUNuRixPQUFPLFVBQVUsQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFDO1NBQ3hEO0lBQ0gsQ0FBQztJQUVPLFdBQVcsQ0FBQyxPQUFlO1FBQ2pDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUM7UUFFMUIsTUFBTSxVQUFVLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQzNDLE1BQU0sWUFBWSxHQUFRLEVBQUUsQ0FBQztRQUU3QixVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDekIsTUFBTSxHQUFHLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN0QyxJQUFJLEdBQUc7Z0JBQUUsWUFBWSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQztRQUNuQyxDQUFDLENBQUMsQ0FBQztRQUVILFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUVyQixxREFBcUQ7UUFDckQsdUNBQXVDO1FBQ3ZDLE1BQU07UUFFTixJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUMxRCxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDdEMsT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbkMsQ0FBQzt3R0FsTlUsbUJBQW1COzRHQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgSHR0cFJlcXVlc3QsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEV2ZW50LFxyXG4gIEh0dHBJbnRlcmNlcHRvcixcclxuICBIdHRwRXJyb3JSZXNwb25zZVxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjYXRjaEVycm9yLCBzd2l0Y2hNYXAsIHRocm93RXJyb3IsIHRhcCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICd0YW5nby1hcHAtdWktZ2xvYmFsJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBIdHRwQXV0aEludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgYXV0aGxvY2FsU3RvcmFnZVRva2VuOiBzdHJpbmc9Jyc7XHJcbiAgcHJpdmF0ZSBpc1JlZnJlc2hpbmdUb2tlbjogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIHByaXZhdGUgdG9rZW5SZWZyZXNoZWQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xyXG4gIFxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxwcml2YXRlIHJvdXRlcjpSb3V0ZXJcclxuICApIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpPT57XHJcbiAgICAgIGlmKGVudil7XHJcbiAgICAgICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDt9XHJcbiAgICAgfSlcclxuICB9XHJcbiAgLy8gaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIC8vICAgY29uc3QgdXNlcjogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgLy8gICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgLy8gICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB1c2VyLmF1dGhlbnRpY2F0aW9uVG9rZW5cclxuICAvLyAgICAgfVxyXG4gIC8vICAgfSk7XHJcbiAgLy8gICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdClcclxuICAvLyAgIC5waXBlKHRhcCgocmVzcG9uc2U6YW55KT0+e1xyXG4gIC8vICAgICBpZihyZXNwb25zZT8uYm9keT8uZGF0YT8ucmVzdWx0ID09PSAnUkVTVFJJQ1RFRC1JUCcpe1xyXG4gIC8vICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwoJy9lcnJvci80MDMtaXAnKVxyXG4gIC8vICAgICB9XHJcbiAgLy8gICB9KSlcclxuICAvLyAgIC5waXBlKFxyXG4gIC8vICAgICBjYXRjaEVycm9yKChlcnJvcjphbnkpPT57XHJcbiAgLy8gICAgICAgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDEpIHtcclxuICAvLyAgICAgICAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAvLyAgICAgICB9IFxyXG4gIC8vICAgICAgIC8vIGVsc2UgaWYgKGVycm9yIGluc3RhbmNlb2YgSHR0cEVycm9yUmVzcG9uc2UgJiYgZXJyb3Iuc3RhdHVzID09PSA0MDMpIHtcclxuICAvLyAgICAgICAvLyAgIC8vIElmIHRoZSBlcnJvciBpcyBkdWUgdG8gdW5hdXRob3JpemVkIGFjY2VzcywgdHJ5IHRvIHJlZnJlc2ggdGhlIHRva2VuXHJcbiAgLy8gICAgICAgLy8gIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL21hbmFnZS9icmFuZHMnXSlcclxuICAvLyAgICAgICAvLyB9IFxyXG4gIC8vICAgICAgIHJldHVybiB0aHJvd0Vycm9yKGVycm9yKTtcclxuICAvLyAgICAgfSlcclxuICAvLyAgICk7XHJcbiAgLy8gfVxyXG5cclxuICAvLyBwcml2YXRlIGhhbmRsZTQwMUVycm9yKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gIC8vICAgaWYgKCF0aGlzLmlzUmVmcmVzaGluZ1Rva2VuKSB7XHJcbiAgLy8gICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSB0cnVlO1xyXG4gIC8vICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gIC8vICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAvLyAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT0gMjAwICYmIHJlcy5kYXRhLnJlc3VsdCkge1xyXG4gIC8vICAgICAgICAgICAvLyBVcGRhdGUgbG9jYWwgc3RvcmFnZSB3aXRoIHRoZSBuZXcgdG9rZW5cclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0odGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4sIEpTT04uc3RyaW5naWZ5KHJlcy5kYXRhLnJlc3VsdCkpO1xyXG4gICAgICAgICAgICBcclxuICAvLyAgICAgICAgICAgLy8gQ2xvbmUgdGhlIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgLy8gICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAvLyAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgLy8gICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7cmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW59YFxyXG4gIC8vICAgICAgICAgICAgIH1cclxuICAvLyAgICAgICAgICAgfSk7XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIC8vIFJlc2V0IHRoZSBmbGFnIGZvciB0b2tlbiByZWZyZXNoaW5nXHJcbiAgLy8gICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICBcclxuICAvLyAgICAgICAgICAgLy8gUmV0cnkgdGhlIG9yaWdpbmFsIHJlcXVlc3Qgd2l0aCB0aGUgbmV3IHRva2VuXHJcbiAgLy8gICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAvLyAgICAgICAgIH0gZWxzZSB7XHJcbiAgLy8gICAgICAgICAgIC8vIExvZ291dCB1c2VyIGlmIHJlZnJlc2ggdG9rZW4gZmFpbHNcclxuICAvLyAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAvLyAgICAgICAgICAgY29uc3Qga2V5c1RvS2VlcCA9IFsnZGF0YS1taXNtYXRjaC1kcmFmdCddO1xyXG4gIC8vICAgICAgICAgICBjb25zdCB2YWx1ZXNUb0tlZXA6YW55ID0ge307XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIGtleXNUb0tlZXAuZm9yRWFjaChrZXkgPT4ge1xyXG4gIC8vICAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICAvLyAgICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAvLyAgICAgICAgICAgICAgIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsdWU7XHJcbiAgLy8gICAgICAgICAgICAgfVxyXG4gIC8vICAgICAgICAgICB9KTtcclxuICBcclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcbiAgXHJcbiAgLy8gICAgICAgICAgIE9iamVjdC5rZXlzKHZhbHVlc1RvS2VlcCkuZm9yRWFjaChrZXkgPT4ge1xyXG4gIC8vICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgdmFsdWVzVG9LZWVwW2tleV0pO1xyXG4gIC8vICAgICAgICAgICB9KTsgXHJcbiAgLy8gICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgLy8gICAgICAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiBFeHBpcmVkIFBsZWFzZSBMb2dpbiBBZ2FpbiEnKTtcclxuICAvLyAgICAgICAgIH1cclxuICAvLyAgICAgICB9KSxcclxuICAvLyAgICAgICBjYXRjaEVycm9yKChlcnJvcikgPT4ge1xyXG4gIC8vICAgICAgICAgLy8gTG9nb3V0IHVzZXIgaWYgcmVmcmVzaCB0b2tlbiBmYWlsc1xyXG4gIC8vICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAvLyAgICAgICAgIGNvbnN0IGtleXNUb0tlZXAgPSBbJ2RhdGEtbWlzbWF0Y2gtZHJhZnQnXTtcclxuICAvLyAgICAgICAgIGNvbnN0IHZhbHVlc1RvS2VlcDphbnkgPSB7fTtcclxuXHJcbiAgLy8gICAgICAgICBrZXlzVG9LZWVwLmZvckVhY2goa2V5ID0+IHtcclxuICAvLyAgICAgICAgICAgY29uc3QgdmFsdWUgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xyXG4gIC8vICAgICAgICAgICBpZiAodmFsdWUgIT09IG51bGwpIHtcclxuICAvLyAgICAgICAgICAgICB2YWx1ZXNUb0tlZXBba2V5XSA9IHZhbHVlO1xyXG4gIC8vICAgICAgICAgICB9XHJcbiAgLy8gICAgICAgICB9KTtcclxuXHJcbiAgLy8gICAgICAgICBsb2NhbFN0b3JhZ2UuY2xlYXIoKTtcclxuXHJcbiAgLy8gICAgICAgICBPYmplY3Qua2V5cyh2YWx1ZXNUb0tlZXApLmZvckVhY2goa2V5ID0+IHtcclxuICAvLyAgICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oa2V5LCB2YWx1ZXNUb0tlZXBba2V5XSk7XHJcbiAgLy8gICAgICAgICB9KTsgXHJcbiAgICAgICAgICBcclxuICAvLyAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7XHJcbiAgLy8gICAgICAgICByZXR1cm4gdGhyb3dFcnJvcihlcnJvcik7XHJcbiAgLy8gICAgICAgfSlcclxuICAvLyAgICAgKTtcclxuICAvLyAgIH0gZWxzZSB7XHJcbiAgLy8gICAgIC8vIElmIGFscmVhZHkgcmVmcmVzaGluZyB0aGUgdG9rZW4sIHF1ZXVlIHRoZSByZXF1ZXN0IGFuZCB3YWl0XHJcbiAgLy8gICAgIHJldHVybiB0aGlzLnRva2VuUmVmcmVzaGVkLnBpcGUoXHJcbiAgLy8gICAgICAgc3dpdGNoTWFwKCgpID0+IHtcclxuICAvLyAgICAgICAgIGNvbnN0IHRva2VuczogYW55ID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbikgfHwgJ3t9Jyk7XHJcbiAgLy8gICAgICAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XHJcbiAgLy8gICAgICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAvLyAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyB0b2tlbnMuYXV0aGVudGljYXRpb25Ub2tlblxyXG4gIC8vICAgICAgICAgICB9XHJcbiAgLy8gICAgICAgICB9KTtcclxuICAvLyAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcclxuICAvLyAgICAgICB9KVxyXG4gIC8vICAgICApO1xyXG4gIC8vICAgfVxyXG4gIC8vIH1cclxuICBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICBjb25zdCB0b2tlbk9ialN0ciA9IHRoaXMuYXV0aFNlcnZpY2UuZ2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuKTtcclxuICAgIGxldCB0b2tlbiA9ICcnO1xyXG5cclxuICAgIGlmICh0b2tlbk9ialN0cikge1xyXG4gICAgICB0cnkge1xyXG4gICAgICAgIGNvbnN0IHRva2VuT2JqID0gSlNPTi5wYXJzZSh0b2tlbk9ialN0cik7XHJcbiAgICAgICAgdG9rZW4gPSB0b2tlbk9iaj8uYXV0aGVudGljYXRpb25Ub2tlbiB8fCAnJztcclxuICAgICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgYXV0aCB0b2tlbiBmb3JtYXQgaW4gY29va2llJywgZSk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBpZiAodG9rZW4pIHtcclxuICAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xyXG4gICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICAgIEF1dGhvcml6YXRpb246ICdCZWFyZXIgJyArIHRva2VuLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gICAgICB0YXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAgICAgICBpZiAocmVzcG9uc2U/LmJvZHk/LmRhdGE/LnJlc3VsdCA9PT0gJ1JFU1RSSUNURUQtSVAnKSB7XHJcbiAgICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvZXJyb3IvNDAzLWlwJyk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KSxcclxuICAgICAgY2F0Y2hFcnJvcigoZXJyb3I6IGFueSkgPT4ge1xyXG4gICAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEh0dHBFcnJvclJlc3BvbnNlICYmIGVycm9yLnN0YXR1cyA9PT0gNDAxKSB7XHJcbiAgICAgICAgICByZXR1cm4gdGhpcy5oYW5kbGU0MDFFcnJvcihyZXF1ZXN0LCBuZXh0KTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgaGFuZGxlNDAxRXJyb3IocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV4dDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICBpZiAoIXRoaXMuaXNSZWZyZXNoaW5nVG9rZW4pIHtcclxuICAgICAgdGhpcy5pc1JlZnJlc2hpbmdUb2tlbiA9IHRydWU7XHJcblxyXG4gICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5yZWZyZXNoVG9rZW4oKS5waXBlKFxyXG4gICAgICAgIHN3aXRjaE1hcCgocmVzOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXMgJiYgcmVzLmNvZGUgPT09IDIwMCAmJiByZXMuZGF0YT8ucmVzdWx0KSB7XHJcbiAgICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0Q29va2llKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuLCBKU09OLnN0cmluZ2lmeShyZXMuZGF0YS5yZXN1bHQpLCAxKTtcclxuXHJcbiAgICAgICAgICAgIGNvbnN0IG5ld1Rva2VuID0gcmVzLmRhdGEucmVzdWx0LmF1dGhlbnRpY2F0aW9uVG9rZW47XHJcbiAgICAgICAgICAgIHJlcXVlc3QgPSByZXF1ZXN0LmNsb25lKHtcclxuICAgICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiAnQmVhcmVyICcgKyBuZXdUb2tlbixcclxuICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgICAgIHRoaXMuaXNSZWZyZXNoaW5nVG9rZW4gPSBmYWxzZTtcclxuICAgICAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpO1xyXG4gICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuZm9yY2VMb2dvdXQoJ1Rva2VuIEV4cGlyZWQuIFBsZWFzZSBsb2dpbiBhZ2Fpbi4nKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHRoaXMuZm9yY2VMb2dvdXQoZXJyKSlcclxuICAgICAgKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIE9wdGlvbmFsOiBpbXBsZW1lbnQgbG9naWMgdG8gcXVldWUgYW5kIHJldHJ5IGlmIG11bHRpcGxlIHJlcXVlc3RzIGR1cmluZyByZWZyZXNoXHJcbiAgICAgIHJldHVybiB0aHJvd0Vycm9yKCdUb2tlbiByZWZyZXNoIGFscmVhZHkgaW4gcHJvZ3Jlc3MnKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgZm9yY2VMb2dvdXQobWVzc2FnZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxuZXZlcj4ge1xyXG4gICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuXHJcbiAgICBjb25zdCBrZXlzVG9LZWVwID0gWydkYXRhLW1pc21hdGNoLWRyYWZ0J107XHJcbiAgICBjb25zdCB2YWx1ZXNUb0tlZXA6IGFueSA9IHt9O1xyXG5cclxuICAgIGtleXNUb0tlZXAuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgICAgIGNvbnN0IHZhbCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKGtleSk7XHJcbiAgICAgIGlmICh2YWwpIHZhbHVlc1RvS2VlcFtrZXldID0gdmFsO1xyXG4gICAgfSk7XHJcblxyXG4gICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcblxyXG4gICAgLy8gT2JqZWN0LmVudHJpZXModmFsdWVzVG9LZWVwKS5mb3JFYWNoKChbaywgdl0pID0+IHtcclxuICAgIC8vICAgcmV0dXJuIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGssIHYpO1xyXG4gICAgLy8gfSk7XHJcblxyXG4gICAgdGhpcy5hdXRoU2VydmljZS5kZWxldGVDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG4gICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgIHJldHVybiB0aHJvd0Vycm9yKCgpID0+IG1lc3NhZ2UpO1xyXG4gIH1cclxufSJdfQ==
|
|
@@ -11191,28 +11191,131 @@ class HttpAuthInterceptor {
|
|
|
11191
11191
|
}
|
|
11192
11192
|
});
|
|
11193
11193
|
}
|
|
11194
|
+
// intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
|
|
11195
|
+
// const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
|
|
11196
|
+
// request = request.clone({
|
|
11197
|
+
// setHeaders: {
|
|
11198
|
+
// Authorization: 'Bearer ' + user.authenticationToken
|
|
11199
|
+
// }
|
|
11200
|
+
// });
|
|
11201
|
+
// return next.handle(request)
|
|
11202
|
+
// .pipe(tap((response:any)=>{
|
|
11203
|
+
// if(response?.body?.data?.result === 'RESTRICTED-IP'){
|
|
11204
|
+
// this.router.navigateByUrl('/error/403-ip')
|
|
11205
|
+
// }
|
|
11206
|
+
// }))
|
|
11207
|
+
// .pipe(
|
|
11208
|
+
// catchError((error:any)=>{
|
|
11209
|
+
// if (error instanceof HttpErrorResponse && error.status === 401) {
|
|
11210
|
+
// // If the error is due to unauthorized access, try to refresh the token
|
|
11211
|
+
// return this.handle401Error(request, next);
|
|
11212
|
+
// }
|
|
11213
|
+
// // else if (error instanceof HttpErrorResponse && error.status === 403) {
|
|
11214
|
+
// // // If the error is due to unauthorized access, try to refresh the token
|
|
11215
|
+
// // this.router.navigate(['/manage/brands'])
|
|
11216
|
+
// // }
|
|
11217
|
+
// return throwError(error);
|
|
11218
|
+
// })
|
|
11219
|
+
// );
|
|
11220
|
+
// }
|
|
11221
|
+
// private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
|
|
11222
|
+
// if (!this.isRefreshingToken) {
|
|
11223
|
+
// this.isRefreshingToken = true;
|
|
11224
|
+
// return this.authService.refreshToken().pipe(
|
|
11225
|
+
// switchMap((res: any) => {
|
|
11226
|
+
// if (res && res.code == 200 && res.data.result) {
|
|
11227
|
+
// // Update local storage with the new token
|
|
11228
|
+
// localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
|
|
11229
|
+
// // Clone the request with the new token
|
|
11230
|
+
// request = request.clone({
|
|
11231
|
+
// setHeaders: {
|
|
11232
|
+
// Authorization: `Bearer ${res.data.result.authenticationToken}`
|
|
11233
|
+
// }
|
|
11234
|
+
// });
|
|
11235
|
+
// // Reset the flag for token refreshing
|
|
11236
|
+
// this.isRefreshingToken = false;
|
|
11237
|
+
// // Retry the original request with the new token
|
|
11238
|
+
// return next.handle(request);
|
|
11239
|
+
// } else {
|
|
11240
|
+
// // Logout user if refresh token fails
|
|
11241
|
+
// this.authService.logout();
|
|
11242
|
+
// const keysToKeep = ['data-mismatch-draft'];
|
|
11243
|
+
// const valuesToKeep:any = {};
|
|
11244
|
+
// keysToKeep.forEach(key => {
|
|
11245
|
+
// const value = localStorage.getItem(key);
|
|
11246
|
+
// if (value !== null) {
|
|
11247
|
+
// valuesToKeep[key] = value;
|
|
11248
|
+
// }
|
|
11249
|
+
// });
|
|
11250
|
+
// localStorage.clear();
|
|
11251
|
+
// Object.keys(valuesToKeep).forEach(key => {
|
|
11252
|
+
// localStorage.setItem(key, valuesToKeep[key]);
|
|
11253
|
+
// });
|
|
11254
|
+
// this.router.navigate(['/auth/login']);
|
|
11255
|
+
// return throwError('Token Expired Please Login Again!');
|
|
11256
|
+
// }
|
|
11257
|
+
// }),
|
|
11258
|
+
// catchError((error) => {
|
|
11259
|
+
// // Logout user if refresh token fails
|
|
11260
|
+
// this.authService.logout();
|
|
11261
|
+
// const keysToKeep = ['data-mismatch-draft'];
|
|
11262
|
+
// const valuesToKeep:any = {};
|
|
11263
|
+
// keysToKeep.forEach(key => {
|
|
11264
|
+
// const value = localStorage.getItem(key);
|
|
11265
|
+
// if (value !== null) {
|
|
11266
|
+
// valuesToKeep[key] = value;
|
|
11267
|
+
// }
|
|
11268
|
+
// });
|
|
11269
|
+
// localStorage.clear();
|
|
11270
|
+
// Object.keys(valuesToKeep).forEach(key => {
|
|
11271
|
+
// localStorage.setItem(key, valuesToKeep[key]);
|
|
11272
|
+
// });
|
|
11273
|
+
// this.router.navigate(['/auth/login']);
|
|
11274
|
+
// return throwError(error);
|
|
11275
|
+
// })
|
|
11276
|
+
// );
|
|
11277
|
+
// } else {
|
|
11278
|
+
// // If already refreshing the token, queue the request and wait
|
|
11279
|
+
// return this.tokenRefreshed.pipe(
|
|
11280
|
+
// switchMap(() => {
|
|
11281
|
+
// const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
|
|
11282
|
+
// request = request.clone({
|
|
11283
|
+
// setHeaders: {
|
|
11284
|
+
// Authorization: 'Bearer ' + tokens.authenticationToken
|
|
11285
|
+
// }
|
|
11286
|
+
// });
|
|
11287
|
+
// return next.handle(request);
|
|
11288
|
+
// })
|
|
11289
|
+
// );
|
|
11290
|
+
// }
|
|
11291
|
+
// }
|
|
11194
11292
|
intercept(request, next) {
|
|
11195
|
-
const
|
|
11196
|
-
|
|
11197
|
-
|
|
11198
|
-
|
|
11293
|
+
const tokenObjStr = this.authService.getCookie(this.authlocalStorageToken);
|
|
11294
|
+
let token = '';
|
|
11295
|
+
if (tokenObjStr) {
|
|
11296
|
+
try {
|
|
11297
|
+
const tokenObj = JSON.parse(tokenObjStr);
|
|
11298
|
+
token = tokenObj?.authenticationToken || '';
|
|
11199
11299
|
}
|
|
11200
|
-
|
|
11201
|
-
|
|
11202
|
-
|
|
11300
|
+
catch (e) {
|
|
11301
|
+
console.error('Invalid auth token format in cookie', e);
|
|
11302
|
+
}
|
|
11303
|
+
}
|
|
11304
|
+
if (token) {
|
|
11305
|
+
request = request.clone({
|
|
11306
|
+
setHeaders: {
|
|
11307
|
+
Authorization: 'Bearer ' + token,
|
|
11308
|
+
},
|
|
11309
|
+
});
|
|
11310
|
+
}
|
|
11311
|
+
return next.handle(request).pipe(tap((response) => {
|
|
11203
11312
|
if (response?.body?.data?.result === 'RESTRICTED-IP') {
|
|
11204
11313
|
this.router.navigateByUrl('/error/403-ip');
|
|
11205
11314
|
}
|
|
11206
|
-
}))
|
|
11207
|
-
.pipe(catchError((error) => {
|
|
11315
|
+
}), catchError((error) => {
|
|
11208
11316
|
if (error instanceof HttpErrorResponse && error.status === 401) {
|
|
11209
|
-
// If the error is due to unauthorized access, try to refresh the token
|
|
11210
11317
|
return this.handle401Error(request, next);
|
|
11211
11318
|
}
|
|
11212
|
-
// else if (error instanceof HttpErrorResponse && error.status === 403) {
|
|
11213
|
-
// // If the error is due to unauthorized access, try to refresh the token
|
|
11214
|
-
// this.router.navigate(['/manage/brands'])
|
|
11215
|
-
// }
|
|
11216
11319
|
return throwError(error);
|
|
11217
11320
|
}));
|
|
11218
11321
|
}
|
|
@@ -11220,70 +11323,44 @@ class HttpAuthInterceptor {
|
|
|
11220
11323
|
if (!this.isRefreshingToken) {
|
|
11221
11324
|
this.isRefreshingToken = true;
|
|
11222
11325
|
return this.authService.refreshToken().pipe(switchMap((res) => {
|
|
11223
|
-
if (res && res.code
|
|
11224
|
-
|
|
11225
|
-
|
|
11226
|
-
// Clone the request with the new token
|
|
11326
|
+
if (res && res.code === 200 && res.data?.result) {
|
|
11327
|
+
this.authService.setCookie(this.authlocalStorageToken, JSON.stringify(res.data.result), 1);
|
|
11328
|
+
const newToken = res.data.result.authenticationToken;
|
|
11227
11329
|
request = request.clone({
|
|
11228
11330
|
setHeaders: {
|
|
11229
|
-
Authorization:
|
|
11230
|
-
}
|
|
11331
|
+
Authorization: 'Bearer ' + newToken,
|
|
11332
|
+
},
|
|
11231
11333
|
});
|
|
11232
|
-
// Reset the flag for token refreshing
|
|
11233
11334
|
this.isRefreshingToken = false;
|
|
11234
|
-
// Retry the original request with the new token
|
|
11235
11335
|
return next.handle(request);
|
|
11236
11336
|
}
|
|
11237
11337
|
else {
|
|
11238
|
-
|
|
11239
|
-
|
|
11240
|
-
|
|
11241
|
-
const valuesToKeep = {};
|
|
11242
|
-
keysToKeep.forEach(key => {
|
|
11243
|
-
const value = localStorage.getItem(key);
|
|
11244
|
-
if (value !== null) {
|
|
11245
|
-
valuesToKeep[key] = value;
|
|
11246
|
-
}
|
|
11247
|
-
});
|
|
11248
|
-
localStorage.clear();
|
|
11249
|
-
Object.keys(valuesToKeep).forEach(key => {
|
|
11250
|
-
localStorage.setItem(key, valuesToKeep[key]);
|
|
11251
|
-
});
|
|
11252
|
-
this.router.navigate(['/auth/login']);
|
|
11253
|
-
return throwError('Token Expired Please Login Again!');
|
|
11254
|
-
}
|
|
11255
|
-
}), catchError((error) => {
|
|
11256
|
-
// Logout user if refresh token fails
|
|
11257
|
-
this.authService.logout();
|
|
11258
|
-
const keysToKeep = ['data-mismatch-draft'];
|
|
11259
|
-
const valuesToKeep = {};
|
|
11260
|
-
keysToKeep.forEach(key => {
|
|
11261
|
-
const value = localStorage.getItem(key);
|
|
11262
|
-
if (value !== null) {
|
|
11263
|
-
valuesToKeep[key] = value;
|
|
11264
|
-
}
|
|
11265
|
-
});
|
|
11266
|
-
localStorage.clear();
|
|
11267
|
-
Object.keys(valuesToKeep).forEach(key => {
|
|
11268
|
-
localStorage.setItem(key, valuesToKeep[key]);
|
|
11269
|
-
});
|
|
11270
|
-
this.router.navigate(['/auth/login']);
|
|
11271
|
-
return throwError(error);
|
|
11272
|
-
}));
|
|
11338
|
+
return this.forceLogout('Token Expired. Please login again.');
|
|
11339
|
+
}
|
|
11340
|
+
}), catchError((err) => this.forceLogout(err)));
|
|
11273
11341
|
}
|
|
11274
11342
|
else {
|
|
11275
|
-
//
|
|
11276
|
-
return
|
|
11277
|
-
const tokens = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
|
|
11278
|
-
request = request.clone({
|
|
11279
|
-
setHeaders: {
|
|
11280
|
-
Authorization: 'Bearer ' + tokens.authenticationToken
|
|
11281
|
-
}
|
|
11282
|
-
});
|
|
11283
|
-
return next.handle(request);
|
|
11284
|
-
}));
|
|
11343
|
+
// Optional: implement logic to queue and retry if multiple requests during refresh
|
|
11344
|
+
return throwError('Token refresh already in progress');
|
|
11285
11345
|
}
|
|
11286
11346
|
}
|
|
11347
|
+
forceLogout(message) {
|
|
11348
|
+
this.authService.logout();
|
|
11349
|
+
const keysToKeep = ['data-mismatch-draft'];
|
|
11350
|
+
const valuesToKeep = {};
|
|
11351
|
+
keysToKeep.forEach((key) => {
|
|
11352
|
+
const val = localStorage.getItem(key);
|
|
11353
|
+
if (val)
|
|
11354
|
+
valuesToKeep[key] = val;
|
|
11355
|
+
});
|
|
11356
|
+
localStorage.clear();
|
|
11357
|
+
// Object.entries(valuesToKeep).forEach(([k, v]) => {
|
|
11358
|
+
// return localStorage.setItem(k, v);
|
|
11359
|
+
// });
|
|
11360
|
+
this.authService.deleteCookie(this.authlocalStorageToken);
|
|
11361
|
+
this.router.navigate(['/auth/login']);
|
|
11362
|
+
return throwError(() => message);
|
|
11363
|
+
}
|
|
11287
11364
|
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 });
|
|
11288
11365
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor });
|
|
11289
11366
|
}
|