@progress-chef/platform-http-interceptor 1.0.28 → 1.0.29
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.
|
@@ -318,10 +318,10 @@ class HttpAuthInterceptor {
|
|
|
318
318
|
});
|
|
319
319
|
}
|
|
320
320
|
}
|
|
321
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
322
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
321
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.Router }, { token: i2.ToastNotificationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
322
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: HttpAuthInterceptor, providedIn: 'root' }); }
|
|
323
323
|
}
|
|
324
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
324
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
|
|
325
325
|
type: Injectable,
|
|
326
326
|
args: [{
|
|
327
327
|
providedIn: 'root'
|
package/package.json
CHANGED
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@progress-chef/platform-http-interceptor",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.29",
|
|
4
4
|
"peerDependencies": {
|
|
5
|
-
"@angular/common": "^
|
|
6
|
-
"@angular/core": "^
|
|
5
|
+
"@angular/common": "^19.2.17",
|
|
6
|
+
"@angular/core": "^19.2.17",
|
|
7
|
+
"@ngrx/effects": "^20.1.0",
|
|
8
|
+
"@ngrx/entity": "^20.1.0",
|
|
9
|
+
"@ngrx/router-store": "^20.1.0",
|
|
10
|
+
"@ngrx/store": "^20.1.0",
|
|
7
11
|
"@progress-chef/platform-storage-service": "^1.0.21",
|
|
8
12
|
"@progress-chef/platform-toast-notification-service": "^0.0.2",
|
|
9
13
|
"rxjs": "~7.5.0"
|
|
@@ -23,8 +27,6 @@
|
|
|
23
27
|
},
|
|
24
28
|
".": {
|
|
25
29
|
"types": "./index.d.ts",
|
|
26
|
-
"esm2022": "./esm2022/progress-chef-platform-http-interceptor.mjs",
|
|
27
|
-
"esm": "./esm2022/progress-chef-platform-http-interceptor.mjs",
|
|
28
30
|
"default": "./fesm2022/progress-chef-platform-http-interceptor.mjs"
|
|
29
31
|
}
|
|
30
32
|
}
|
|
@@ -1,329 +0,0 @@
|
|
|
1
|
-
import { HttpEventType } from '@angular/common/http';
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';
|
|
4
|
-
import { catchError, finalize, tap, throwError, Subject, switchMap } from "rxjs";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/router";
|
|
7
|
-
import * as i2 from "@progress-chef/platform-toast-notification-service";
|
|
8
|
-
export class HttpAuthInterceptor {
|
|
9
|
-
constructor(router, toastNotificationService) {
|
|
10
|
-
this.router = router;
|
|
11
|
-
this.toastNotificationService = toastNotificationService;
|
|
12
|
-
this.authTokenSet = new Set();
|
|
13
|
-
this.isSessionExpired = false;
|
|
14
|
-
this.requestQueue = [];
|
|
15
|
-
this.REFRESH_TOKEN_URL = '/identity/user/jwt/refresh';
|
|
16
|
-
this.SSO_TOKEN_URL = '/sso/api/v1/token';
|
|
17
|
-
this.LOCAL_LOGIN_URL = '/identity/user/login';
|
|
18
|
-
this.JWT_URL = '/identity/user/jwt';
|
|
19
|
-
this.ORGANIZATIONS_URL = '/self/organizations';
|
|
20
|
-
this.ROLES_URL = '/self/roles';
|
|
21
|
-
this.APIS_TO_EXCLUDE_FROM_207_NOTIFICATION = [
|
|
22
|
-
'/node/bulk-approve'
|
|
23
|
-
];
|
|
24
|
-
}
|
|
25
|
-
intercept(request, next) {
|
|
26
|
-
if (!this.isTokenRefreshInProgress()) {
|
|
27
|
-
return this.processHttpHandle(request, next);
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
if (request.url.includes(this.REFRESH_TOKEN_URL)) {
|
|
31
|
-
LocalStorageService.setItem(StorageKeys.TOKEN_REFRESH, { "active": true, "time": new Date().getTime() });
|
|
32
|
-
}
|
|
33
|
-
this.startStorageListenerTimer();
|
|
34
|
-
return this.createQueueRequest(request).pipe(switchMap((req) => {
|
|
35
|
-
return this.processHttpHandle(req, next);
|
|
36
|
-
}));
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
isTokenRefreshInProgress() {
|
|
40
|
-
return LocalStorageService.getItem(StorageKeys.TOKEN_REFRESH)?.active;
|
|
41
|
-
}
|
|
42
|
-
processQueue() {
|
|
43
|
-
const nextRequest = this.requestQueue.shift();
|
|
44
|
-
if (nextRequest) {
|
|
45
|
-
nextRequest.notifier.next(nextRequest.req);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
createQueueRequest(request) {
|
|
49
|
-
const requestObj = {};
|
|
50
|
-
requestObj.req = request;
|
|
51
|
-
requestObj.notifier = new Subject();
|
|
52
|
-
this.requestQueue.push(requestObj);
|
|
53
|
-
return requestObj.notifier.asObservable();
|
|
54
|
-
}
|
|
55
|
-
startStorageListenerTimer() {
|
|
56
|
-
if (this.storageListenerTimer) {
|
|
57
|
-
clearInterval(this.storageListenerTimer);
|
|
58
|
-
}
|
|
59
|
-
this.storageListenerTimer = setInterval(() => {
|
|
60
|
-
if (LocalStorageService.getItem(StorageKeys.TOKEN_REFRESH) &&
|
|
61
|
-
LocalStorageService.getItem(StorageKeys.TOKEN_REFRESH).active === false) {
|
|
62
|
-
clearInterval(this.storageListenerTimer);
|
|
63
|
-
this.processQueue();
|
|
64
|
-
}
|
|
65
|
-
}, 200);
|
|
66
|
-
}
|
|
67
|
-
processHttpHandle(request, next) {
|
|
68
|
-
let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);
|
|
69
|
-
let authReq = request;
|
|
70
|
-
if (authToken) {
|
|
71
|
-
authReq = request.clone({
|
|
72
|
-
setHeaders: {
|
|
73
|
-
Authorization: `Bearer ${authToken}`
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
if (!this.authTokenSet.has(authToken)) {
|
|
77
|
-
this.isSessionExpired = false;
|
|
78
|
-
}
|
|
79
|
-
this.authTokenSet.add(authToken);
|
|
80
|
-
}
|
|
81
|
-
return next.handle(authReq).pipe(tap((event) => {
|
|
82
|
-
if (event.type === HttpEventType.Response) {
|
|
83
|
-
switch (event.status) {
|
|
84
|
-
case 202:
|
|
85
|
-
this.toastNotificationService.showToastNotification({
|
|
86
|
-
content: event?.body?.item?.message || `Request under processing`,
|
|
87
|
-
type: { style: 'info', icon: true },
|
|
88
|
-
action: {}
|
|
89
|
-
});
|
|
90
|
-
break;
|
|
91
|
-
case 207:
|
|
92
|
-
if (this.APIS_TO_EXCLUDE_FROM_207_NOTIFICATION.some(url => request.url.includes(url))) {
|
|
93
|
-
break;
|
|
94
|
-
}
|
|
95
|
-
let message = {
|
|
96
|
-
content: 'Request was successful',
|
|
97
|
-
notificationStyle: 'success',
|
|
98
|
-
closable: false
|
|
99
|
-
};
|
|
100
|
-
try {
|
|
101
|
-
for (let item of event.body?.items) {
|
|
102
|
-
for (let err of item?.userRoleMapping) { /* Currently 207 is handled only for single use case, so it is hardcoded.If there are more use cases, then this should be updated accordingly. */
|
|
103
|
-
if (err.error !== null) {
|
|
104
|
-
message = {
|
|
105
|
-
content: 'User not allowed for this operation',
|
|
106
|
-
notificationStyle: 'error',
|
|
107
|
-
closable: true
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
this.toastNotificationService.showToastNotification({
|
|
113
|
-
content: message.content,
|
|
114
|
-
type: { style: message.notificationStyle, icon: true },
|
|
115
|
-
closable: message.closable,
|
|
116
|
-
action: {}
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
catch (e) {
|
|
120
|
-
console.log("Exception occurred at HttpAuthInterceptor 207 notification", e);
|
|
121
|
-
this.toastNotificationService.showToastNotification({
|
|
122
|
-
content: `The request has been accepted for processing, but has been partially completed.`,
|
|
123
|
-
type: { style: 'info', icon: true },
|
|
124
|
-
action: {}
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
break;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}), catchError((error) => {
|
|
131
|
-
const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);
|
|
132
|
-
if (this.router.url.includes('/login/user-login')) {
|
|
133
|
-
const skipUrls = [
|
|
134
|
-
this.JWT_URL,
|
|
135
|
-
this.SSO_TOKEN_URL,
|
|
136
|
-
this.LOCAL_LOGIN_URL,
|
|
137
|
-
this.ORGANIZATIONS_URL,
|
|
138
|
-
this.ROLES_URL
|
|
139
|
-
];
|
|
140
|
-
if (skipUrls.some(url => request.url.includes(url))) {
|
|
141
|
-
// Skip error handling for these URLs; errors will be handled by corresponding web components
|
|
142
|
-
return throwError(() => error);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
switch (error.status) {
|
|
146
|
-
case 401:
|
|
147
|
-
if (loginType === 'saml' || loginType === 'oauth') {
|
|
148
|
-
LocalStorageService.removeItem(StorageKeys.USER_NAME);
|
|
149
|
-
LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME);
|
|
150
|
-
}
|
|
151
|
-
LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);
|
|
152
|
-
LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);
|
|
153
|
-
LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);
|
|
154
|
-
LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);
|
|
155
|
-
LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);
|
|
156
|
-
LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);
|
|
157
|
-
LocalStorageService.removeItem(StorageKeys.LICENSE_DETAILS);
|
|
158
|
-
if (this.router.url.startsWith('/login/user-login')) {
|
|
159
|
-
this.handleUnauthorizedError(error);
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
this.router.navigate(['/login']).then((navigated) => {
|
|
163
|
-
if (navigated) {
|
|
164
|
-
this.handleUnauthorizedError(error);
|
|
165
|
-
}
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
break;
|
|
169
|
-
case 402:
|
|
170
|
-
if (loginType === 'saml' || loginType === 'oauth') {
|
|
171
|
-
LocalStorageService.removeItem(StorageKeys.USER_NAME);
|
|
172
|
-
LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME);
|
|
173
|
-
}
|
|
174
|
-
LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);
|
|
175
|
-
LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);
|
|
176
|
-
LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);
|
|
177
|
-
LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);
|
|
178
|
-
LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);
|
|
179
|
-
LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);
|
|
180
|
-
LocalStorageService.removeItem(StorageKeys.LICENSE_DETAILS);
|
|
181
|
-
this.router.navigate(['/login']).then((navigated) => {
|
|
182
|
-
if (navigated) {
|
|
183
|
-
this.toastNotificationService.showToastNotification({
|
|
184
|
-
content: `License expired, please contact your support representative.`,
|
|
185
|
-
type: { style: 'error', icon: true },
|
|
186
|
-
closable: true,
|
|
187
|
-
action: {}
|
|
188
|
-
});
|
|
189
|
-
}
|
|
190
|
-
});
|
|
191
|
-
break;
|
|
192
|
-
case 403:
|
|
193
|
-
try {
|
|
194
|
-
for (let err of error.error.errors) {
|
|
195
|
-
const message = err?.message?.toLowerCase();
|
|
196
|
-
const content = message?.includes('one time password') && message?.includes('expired')
|
|
197
|
-
? 'One Time Password entered has already expired.'
|
|
198
|
-
: 'This operation is not permitted for the current role.';
|
|
199
|
-
this.toastNotificationService.showToastNotification({
|
|
200
|
-
content,
|
|
201
|
-
type: { style: 'error', icon: true },
|
|
202
|
-
closable: true,
|
|
203
|
-
action: {},
|
|
204
|
-
});
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
catch (e) {
|
|
208
|
-
console.log("HttpAuthInterceptor: Exception occurred at 403", e);
|
|
209
|
-
this.toastNotificationService.showToastNotification({
|
|
210
|
-
content: `This operation is not permitted for the current role.`,
|
|
211
|
-
type: { style: 'error', icon: true },
|
|
212
|
-
closable: true,
|
|
213
|
-
action: {}
|
|
214
|
-
});
|
|
215
|
-
}
|
|
216
|
-
break;
|
|
217
|
-
case 405:
|
|
218
|
-
try {
|
|
219
|
-
for (let err of error.error.errors) {
|
|
220
|
-
this.toastNotificationService.showToastNotification({
|
|
221
|
-
content: err?.reason || `HTTP method not allowed.`,
|
|
222
|
-
type: { style: 'error', icon: true },
|
|
223
|
-
closable: true,
|
|
224
|
-
action: {}
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
catch (e) {
|
|
229
|
-
console.log("HttpAuthInterceptor: Exception occurred at 405", e);
|
|
230
|
-
this.toastNotificationService.showToastNotification({
|
|
231
|
-
content: `HTTP method not allowed.`,
|
|
232
|
-
type: { style: 'error', icon: true },
|
|
233
|
-
closable: true,
|
|
234
|
-
action: {}
|
|
235
|
-
});
|
|
236
|
-
}
|
|
237
|
-
break;
|
|
238
|
-
case 500:
|
|
239
|
-
try {
|
|
240
|
-
for (let err of error?.error?.errors) {
|
|
241
|
-
this.toastNotificationService.showToastNotification({
|
|
242
|
-
content: err?.message || `Something went wrong. Please try again.`,
|
|
243
|
-
type: { style: 'error', icon: true },
|
|
244
|
-
closable: true,
|
|
245
|
-
action: {}
|
|
246
|
-
});
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
catch (e) {
|
|
250
|
-
console.log("HttpAuthInterceptor: Exception occurred at 500", e);
|
|
251
|
-
this.toastNotificationService.showToastNotification({
|
|
252
|
-
content: `Something went wrong. Please try again.`,
|
|
253
|
-
type: { style: 'error', icon: true },
|
|
254
|
-
closable: true,
|
|
255
|
-
action: {}
|
|
256
|
-
});
|
|
257
|
-
}
|
|
258
|
-
break;
|
|
259
|
-
case 502:
|
|
260
|
-
this.toastNotificationService.showToastNotification({
|
|
261
|
-
content: `Bad Gateway. Please try again.`,
|
|
262
|
-
type: { style: 'error', icon: true },
|
|
263
|
-
closable: true,
|
|
264
|
-
action: {}
|
|
265
|
-
});
|
|
266
|
-
break;
|
|
267
|
-
case 503:
|
|
268
|
-
this.toastNotificationService.showToastNotification({
|
|
269
|
-
content: `Service Unavailable. Please try again.`,
|
|
270
|
-
type: { style: 'error', icon: true },
|
|
271
|
-
closable: true,
|
|
272
|
-
action: {}
|
|
273
|
-
});
|
|
274
|
-
break;
|
|
275
|
-
case 0:
|
|
276
|
-
case 504:
|
|
277
|
-
this.toastNotificationService.showToastNotification({
|
|
278
|
-
content: `Unable to reach server. Please try again.`,
|
|
279
|
-
type: { style: 'error', icon: true },
|
|
280
|
-
closable: true,
|
|
281
|
-
action: {}
|
|
282
|
-
});
|
|
283
|
-
break;
|
|
284
|
-
}
|
|
285
|
-
return throwError(() => error);
|
|
286
|
-
}), finalize(() => {
|
|
287
|
-
if (!this.isTokenRefreshInProgress()) {
|
|
288
|
-
this.processQueue(); // Process next request in the queue
|
|
289
|
-
}
|
|
290
|
-
}));
|
|
291
|
-
}
|
|
292
|
-
handleUnauthorizedError(error) {
|
|
293
|
-
try {
|
|
294
|
-
for (let err of error?.error?.errors) {
|
|
295
|
-
let message = '';
|
|
296
|
-
if (err?.message.toLowerCase() === 'invalid credentials') {
|
|
297
|
-
message = 'Invalid username or password.';
|
|
298
|
-
}
|
|
299
|
-
else if (err?.message.includes('expired')) {
|
|
300
|
-
message = 'Your session has expired. Please login again.';
|
|
301
|
-
}
|
|
302
|
-
this.toastNotificationService.showToastNotification({
|
|
303
|
-
content: message || err?.message || `Unauthorized`,
|
|
304
|
-
type: { style: 'error', icon: true },
|
|
305
|
-
closable: true,
|
|
306
|
-
action: {}
|
|
307
|
-
});
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
catch (e) {
|
|
311
|
-
console.log("HttpAuthInterceptor: Exception occurred at 401", e);
|
|
312
|
-
this.toastNotificationService.showToastNotification({
|
|
313
|
-
content: `Something went wrong. Please try again.`,
|
|
314
|
-
type: { style: 'error', icon: true },
|
|
315
|
-
closable: true,
|
|
316
|
-
action: {}
|
|
317
|
-
});
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.Router }, { token: i2.ToastNotificationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
321
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, providedIn: 'root' }); }
|
|
322
|
-
}
|
|
323
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
|
|
324
|
-
type: Injectable,
|
|
325
|
-
args: [{
|
|
326
|
-
providedIn: 'root'
|
|
327
|
-
}]
|
|
328
|
-
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.ToastNotificationService }] });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth.interceptor.js","sourceRoot":"","sources":["../../../../projects/platform-http-interceptor/src/lib/http-auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  HttpErrorResponse, HttpEvent, HttpEventType, HttpHandler, HttpInterceptor, HttpRequest\n} from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { LocalStorageService, StorageKeys } from '@progress-chef/platform-storage-service';\nimport { ToastNotificationService } from \"@progress-chef/platform-toast-notification-service\";\nimport { Observable, catchError, finalize, tap, throwError, Subject, switchMap } from \"rxjs\";\n\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class HttpAuthInterceptor implements HttpInterceptor {\n  authTokenSet = new Set();\n  isSessionExpired = false;\n  requestQueue: QueuedRequest[] = [];\n  storageListenerTimer: any;\n  REFRESH_TOKEN_URL = '/identity/user/jwt/refresh';\n  SSO_TOKEN_URL = '/sso/api/v1/token';\n  LOCAL_LOGIN_URL = '/identity/user/login';\n  JWT_URL = '/identity/user/jwt';\n  ORGANIZATIONS_URL = '/self/organizations';\n  ROLES_URL = '/self/roles';\n  APIS_TO_EXCLUDE_FROM_207_NOTIFICATION = [\n    '/node/bulk-approve'\n  ];\n\n  constructor(\n    private readonly router: Router,\n    private readonly toastNotificationService: ToastNotificationService\n  ) { }\n\n  intercept(\n    request: HttpRequest<unknown>,\n    next: HttpHandler\n  ): Observable<HttpEvent<unknown>> {\n    if (!this.isTokenRefreshInProgress()) {\n      return this.processHttpHandle(request, next);\n    } else {\n      if (request.url.includes(this.REFRESH_TOKEN_URL)) {\n        LocalStorageService.setItem(StorageKeys.TOKEN_REFRESH, { \"active\": true, \"time\": new Date().getTime() });\n      }\n      this.startStorageListenerTimer();\n      return this.createQueueRequest(request).pipe(\n        switchMap((req: HttpRequest<any>) => {\n          return this.processHttpHandle(req, next);\n        })\n      );\n    }\n  }\n\n  isTokenRefreshInProgress(): boolean {\n    return LocalStorageService.getItem(\n      StorageKeys.TOKEN_REFRESH\n    )?.active;\n  }\n\n  processQueue(): void {\n    const nextRequest = this.requestQueue.shift();\n    if (nextRequest) {\n      nextRequest.notifier.next(nextRequest.req);\n    }\n  }\n\n  createQueueRequest(request: HttpRequest<unknown>): Observable<any> {\n    const requestObj: QueuedRequest = {} as QueuedRequest;\n    requestObj.req = request;\n    requestObj.notifier = new Subject<HttpRequest<any>>();\n    this.requestQueue.push(requestObj);\n    return requestObj.notifier.asObservable();\n  }\n\n  startStorageListenerTimer(): void {\n    if (this.storageListenerTimer) {\n      clearInterval(this.storageListenerTimer);\n    }\n    this.storageListenerTimer = setInterval(() => {\n      if (LocalStorageService.getItem(StorageKeys.TOKEN_REFRESH) &&\n        LocalStorageService.getItem(StorageKeys.TOKEN_REFRESH).active === false) {\n        clearInterval(this.storageListenerTimer);\n        this.processQueue();\n      }\n    }, 200);\n  }\n\n  processHttpHandle(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n    let authToken = LocalStorageService.getItem(StorageKeys.AUTH_TOKEN);\n    let authReq = request;\n    if (authToken) {\n      authReq = request.clone({\n        setHeaders: {\n          Authorization: `Bearer ${authToken}`\n        }\n      })\n      if (!this.authTokenSet.has(authToken)) {\n        this.isSessionExpired = false;\n      }\n      this.authTokenSet.add(authToken);\n    }\n    return next.handle(authReq).pipe(\n      tap((event) => {\n        if (event.type === HttpEventType.Response) {\n          switch (event.status) {\n            case 202:\n              this.toastNotificationService.showToastNotification({\n                content: event?.body?.item?.message || `Request under processing`,\n                type: { style: 'info', icon: true },\n                action: {}\n              });\n              break;\n            case 207:\n              if (this.APIS_TO_EXCLUDE_FROM_207_NOTIFICATION.some(url => request.url.includes(url))) {\n                break;\n              }\n              let message = {\n                content: 'Request was successful',\n                notificationStyle: 'success',\n                closable: false\n              }\n              try {\n                for (let item of event.body?.items) {\n                  for (let err of item?.userRoleMapping) { /* Currently 207 is handled only for single use case, so it is hardcoded.If there are more use cases, then this should be updated accordingly.  */\n                    if (err.error !== null) {\n                      message = {\n                        content: 'User not allowed for this operation',\n                        notificationStyle: 'error',\n                        closable: true\n                      }\n                    }\n                  }\n                }\n                this.toastNotificationService.showToastNotification({\n                  content: message.content,\n                  type: { style: message.notificationStyle, icon: true },\n                  closable: message.closable,\n                  action: {}\n                });\n              } catch (e) {\n                console.log(\"Exception occurred at HttpAuthInterceptor 207 notification\", e);\n                this.toastNotificationService.showToastNotification({\n                  content: `The request has been accepted for processing, but has been partially completed.`,\n                  type: { style: 'info', icon: true },\n                  action: {}\n                });\n              }\n              break;\n          }\n        }\n      }),\n      catchError((error: HttpErrorResponse) => {\n        const loginType = LocalStorageService.getItem(StorageKeys.LOGIN_TYPE);\n        if (this.router.url.includes('/login/user-login')) {\n          const skipUrls = [\n            this.JWT_URL,\n            this.SSO_TOKEN_URL,\n            this.LOCAL_LOGIN_URL,\n            this.ORGANIZATIONS_URL,\n            this.ROLES_URL\n          ];\n          if (skipUrls.some(url => request.url.includes(url))) {\n            // Skip error handling for these URLs; errors will be handled by corresponding web components\n            return throwError(() => error);\n          }\n        }\n        switch (error.status) {\n          case 401:\n            if (loginType === 'saml' || loginType === 'oauth') {\n              LocalStorageService.removeItem(StorageKeys.USER_NAME);\n              LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME);\n            }\n            LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n            LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n            LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n            LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.LICENSE_DETAILS);\n\n            if (this.router.url.startsWith('/login/user-login')) {\n              this.handleUnauthorizedError(error);\n            } else {\n              this.router.navigate(['/login']).then((navigated) => {\n                if (navigated) {\n                  this.handleUnauthorizedError(error);\n                }\n              })\n            }\n            break;\n          case 402:\n            if (loginType === 'saml' || loginType === 'oauth') {\n              LocalStorageService.removeItem(StorageKeys.USER_NAME);\n              LocalStorageService.removeItem(StorageKeys.IS_REMEMBER_ME);\n            }\n            LocalStorageService.setItem(StorageKeys.IS_USER_ORG_AND_ROLE_SET, false);\n            LocalStorageService.setItem(StorageKeys.IS_USER_AUTHENTICATED, false);\n            LocalStorageService.removeItem(StorageKeys.AUTH_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.LOGIN_TYPE);\n            LocalStorageService.removeItem(StorageKeys.IDENTITY_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.USER_ORG_AND_ROLE_TOKEN);\n            LocalStorageService.removeItem(StorageKeys.LICENSE_DETAILS);\n\n            this.router.navigate(['/login']).then((navigated) => {\n              if (navigated) {\n                this.toastNotificationService.showToastNotification({\n                  content: `License expired, please contact your support representative.`,\n                  type: { style: 'error', icon: true },\n                  closable: true,\n                  action: {}\n                });\n              }\n            })\n            break;\n          case 403:\n            try {\n              for (let err of error.error.errors) {\n                const message = err?.message?.toLowerCase();\n                const content = message?.includes('one time password') && message?.includes('expired')\n                  ? 'One Time Password entered has already expired.'\n                  : 'This operation is not permitted for the current role.';\n\n                this.toastNotificationService.showToastNotification({\n                  content,\n                  type: { style: 'error', icon: true },\n                  closable: true,\n                  action: {},\n                });\n              }\n            } catch (e) {\n              console.log(\"HttpAuthInterceptor: Exception occurred at 403\", e);\n              this.toastNotificationService.showToastNotification({\n                content: `This operation is not permitted for the current role.`,\n                type: { style: 'error', icon: true },\n                closable: true,\n                action: {}\n              });\n            }\n            break;\n          case 405:\n            try {\n              for (let err of error.error.errors) {\n                this.toastNotificationService.showToastNotification({\n                  content: err?.reason || `HTTP method not allowed.`,\n                  type: { style: 'error', icon: true },\n                  closable: true,\n                  action: {}\n                });\n              }\n            } catch (e) {\n              console.log(\"HttpAuthInterceptor: Exception occurred at 405\", e);\n              this.toastNotificationService.showToastNotification({\n                content: `HTTP method not allowed.`,\n                type: { style: 'error', icon: true },\n                closable: true,\n                action: {}\n              });\n            }\n            break;\n          case 500:\n            try {\n              for (let err of error?.error?.errors) {\n                this.toastNotificationService.showToastNotification({\n                  content: err?.message || `Something went wrong. Please try again.`,\n                  type: { style: 'error', icon: true },\n                  closable: true,\n                  action: {}\n                });\n              }\n            } catch (e) {\n              console.log(\"HttpAuthInterceptor: Exception occurred at 500\", e);\n              this.toastNotificationService.showToastNotification({\n                content: `Something went wrong. Please try again.`,\n                type: { style: 'error', icon: true },\n                closable: true,\n                action: {}\n              });\n            }\n            break;\n          case 502:\n            this.toastNotificationService.showToastNotification({\n              content: `Bad Gateway. Please try again.`,\n              type: { style: 'error', icon: true },\n              closable: true,\n              action: {}\n            });\n            break;\n          case 503:\n            this.toastNotificationService.showToastNotification({\n              content: `Service Unavailable. Please try again.`,\n              type: { style: 'error', icon: true },\n              closable: true,\n              action: {}\n            });\n            break;\n          case 0:\n          case 504:\n            this.toastNotificationService.showToastNotification({\n              content: `Unable to reach server. Please try again.`,\n              type: { style: 'error', icon: true },\n              closable: true,\n              action: {}\n            });\n            break;\n\n        }\n        return throwError(() => error);\n      }),\n      finalize(() => {\n        if (!this.isTokenRefreshInProgress()) {\n          this.processQueue();  // Process next request in the queue\n        }\n      })\n    );\n  }\n\n  handleUnauthorizedError(error: HttpErrorResponse) {\n    try {\n      for (let err of error?.error?.errors) {\n        let message = '';\n        if (err?.message.toLowerCase() === 'invalid credentials') {\n          message = 'Invalid username or password.';\n        } else if (err?.message.includes('expired')) {\n          message = 'Your session has expired. Please login again.';\n        }\n        this.toastNotificationService.showToastNotification({\n          content: message || err?.message || `Unauthorized`,\n          type: { style: 'error', icon: true },\n          closable: true,\n          action: {}\n        });\n      }\n    } catch (e) {\n      console.log(\"HttpAuthInterceptor: Exception occurred at 401\", e);\n      this.toastNotificationService.showToastNotification({\n        content: `Something went wrong. Please try again.`,\n        type: { style: 'error', icon: true },\n        closable: true,\n        action: {}\n      });\n    }\n  }\n}\n\ninterface QueuedRequest {\n  req: HttpRequest<any>;\n  notifier: Subject<any>;\n}\n"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtY2hlZi1wbGF0Zm9ybS1odHRwLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvcGxhdGZvcm0taHR0cC1pbnRlcmNlcHRvci9zcmMvcHJvZ3Jlc3MtY2hlZi1wbGF0Zm9ybS1odHRwLWludGVyY2VwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of platform-http-interceptor
|
|
3
|
-
*/
|
|
4
|
-
export * from './lib/http-auth.interceptor';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3BsYXRmb3JtLWh0dHAtaW50ZXJjZXB0b3Ivc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBwbGF0Zm9ybS1odHRwLWludGVyY2VwdG9yXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvaHR0cC1hdXRoLmludGVyY2VwdG9yJztcbiJdfQ==
|