@trudb/tru-common-lib 0.1.550 → 0.1.552
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.
- package/esm2022/lib/classes/tru-server-error.mjs +18 -0
- package/esm2022/lib/components/error-dialog/classes/tru-error-dialog-config.mjs +9 -0
- package/esm2022/lib/components/error-dialog/services/tru-error-interceptor.mjs +8 -7
- package/esm2022/lib/services/tru-error-manager.mjs +113 -0
- package/fesm2022/trudb-tru-common-lib.mjs +148 -17
- package/fesm2022/trudb-tru-common-lib.mjs.map +1 -1
- package/lib/classes/tru-server-error.d.ts +10 -0
- package/lib/components/error-dialog/classes/tru-error-dialog-config.d.ts +5 -0
- package/lib/components/error-dialog/services/tru-error-interceptor.d.ts +3 -3
- package/lib/components/login/classes/tru-auth-strategy-provider.d.ts +1 -1
- package/lib/services/tru-error-manager.d.ts +22 -0
- package/package.json +1 -1
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export class TruServerError {
|
|
2
|
+
id;
|
|
3
|
+
type;
|
|
4
|
+
code;
|
|
5
|
+
message;
|
|
6
|
+
stackTrace;
|
|
7
|
+
status;
|
|
8
|
+
constructor(error) {
|
|
9
|
+
let parsedError = JSON.parse(error.error);
|
|
10
|
+
this.id = parsedError.$id;
|
|
11
|
+
this.type = parsedError.$type;
|
|
12
|
+
this.code = parsedError.Code;
|
|
13
|
+
this.message = parsedError.Message;
|
|
14
|
+
this.stackTrace = parsedError.StackTrace;
|
|
15
|
+
this.status = error.status;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXNlcnZlci1lcnJvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY2xhc3Nlcy90cnUtc2VydmVyLWVycm9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLEVBQUUsQ0FBUztJQUNYLElBQUksQ0FBUztJQUNiLElBQUksQ0FBUztJQUNiLE9BQU8sQ0FBUztJQUNoQixVQUFVLENBQVM7SUFDbkIsTUFBTSxDQUFTO0lBRWYsWUFBWSxLQUF3QjtRQUNsQyxJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsRUFBRSxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUM7UUFDMUIsSUFBSSxDQUFDLElBQUksR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQztRQUM3QixJQUFJLENBQUMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFDbkMsSUFBSSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQztJQUM3QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwRXJyb3JSZXNwb25zZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi4vYmFzZS1jbGFzc2VzL3RydS1wcm9wZXJ0eS1jb25maWctYmFzZSc7XHJcblxyXG5leHBvcnQgY2xhc3MgVHJ1U2VydmVyRXJyb3Ige1xyXG4gIGlkOiBzdHJpbmc7XHJcbiAgdHlwZTogc3RyaW5nO1xyXG4gIGNvZGU6IG51bWJlcjtcclxuICBtZXNzYWdlOiBzdHJpbmc7XHJcbiAgc3RhY2tUcmFjZTogc3RyaW5nO1xyXG4gIHN0YXR1czogbnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpIHtcclxuICAgIGxldCBwYXJzZWRFcnJvciA9IEpTT04ucGFyc2UoZXJyb3IuZXJyb3IpO1xyXG4gICAgdGhpcy5pZCA9IHBhcnNlZEVycm9yLiRpZDtcclxuICAgIHRoaXMudHlwZSA9IHBhcnNlZEVycm9yLiR0eXBlO1xyXG4gICAgdGhpcy5jb2RlID0gcGFyc2VkRXJyb3IuQ29kZTtcclxuICAgIHRoaXMubWVzc2FnZSA9IHBhcnNlZEVycm9yLk1lc3NhZ2U7XHJcbiAgICB0aGlzLnN0YWNrVHJhY2UgPSBwYXJzZWRFcnJvci5TdGFja1RyYWNlO1xyXG4gICAgdGhpcy5zdGF0dXMgPSBlcnJvci5zdGF0dXM7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export class TruErrorDialogConfig {
|
|
2
|
+
title;
|
|
3
|
+
message;
|
|
4
|
+
constructor(title, message) {
|
|
5
|
+
this.title = title;
|
|
6
|
+
this.message = message;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVycm9yLWRpYWxvZy1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZXJyb3ItZGlhbG9nL2NsYXNzZXMvdHJ1LWVycm9yLWRpYWxvZy1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLG9CQUFvQjtJQUV0QjtJQUNBO0lBRlQsWUFDUyxLQUFhLEVBQ2IsT0FBZTtRQURmLFVBQUssR0FBTCxLQUFLLENBQVE7UUFDYixZQUFPLEdBQVAsT0FBTyxDQUFRO0lBQ3hCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBUcnVFcnJvckRpYWxvZ0NvbmZpZyB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgdGl0bGU6IHN0cmluZyxcclxuICAgIHB1YmxpYyBtZXNzYWdlOiBzdHJpbmcpIHtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -2,21 +2,22 @@ import { Injectable } from "@angular/core";
|
|
|
2
2
|
import { throwError } from "rxjs";
|
|
3
3
|
import { catchError } from "rxjs/operators";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../../../services/tru-
|
|
5
|
+
import * as i1 from "../../../services/tru-error-manager";
|
|
6
6
|
export class TruErrorInterceptor {
|
|
7
|
-
|
|
8
|
-
constructor(
|
|
9
|
-
this.
|
|
7
|
+
errorManager;
|
|
8
|
+
constructor(errorManager) {
|
|
9
|
+
this.errorManager = errorManager;
|
|
10
10
|
}
|
|
11
11
|
intercept(request, next) {
|
|
12
12
|
return next.handle(request).pipe(catchError((error) => {
|
|
13
|
+
this.errorManager.handleError(error);
|
|
13
14
|
return throwError(error);
|
|
14
15
|
}));
|
|
15
16
|
}
|
|
16
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: i1.
|
|
17
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: i1.TruErrorManager }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
17
18
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
|
|
18
19
|
}
|
|
19
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
|
|
20
21
|
type: Injectable
|
|
21
|
-
}], ctorParameters: () => [{ type: i1.
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
}], ctorParameters: () => [{ type: i1.TruErrorManager }] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVycm9yLWludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL2Vycm9yLWRpYWxvZy9zZXJ2aWNlcy90cnUtZXJyb3ItaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQVFuRCxPQUFPLEVBQWMsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBSTVDLE1BQU0sT0FBTyxtQkFBbUI7SUFDVjtJQUFwQixZQUFvQixZQUE2QjtRQUE3QixpQkFBWSxHQUFaLFlBQVksQ0FBaUI7SUFBSSxDQUFDO0lBRXRELFNBQVMsQ0FDUCxPQUF5QixFQUN6QixJQUFpQjtRQUVqQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUM5QixVQUFVLENBQUMsQ0FBQyxLQUF3QixFQUFFLEVBQUU7WUFDdEMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckMsT0FBTyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7dUdBYlUsbUJBQW1COzJHQUFuQixtQkFBbUI7OzJGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge1xyXG4gIEh0dHBSZXF1ZXN0LFxyXG4gIEh0dHBIYW5kbGVyLFxyXG4gIEh0dHBFdmVudCxcclxuICBIdHRwSW50ZXJjZXB0b3IsXHJcbiAgSHR0cEVycm9yUmVzcG9uc2UsXHJcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIHRocm93RXJyb3IgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcbmltcG9ydCB7IFRydUVycm9yTWFuYWdlciB9IGZyb20gXCIuLi8uLi8uLi9zZXJ2aWNlcy90cnUtZXJyb3ItbWFuYWdlclwiO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgVHJ1RXJyb3JJbnRlcmNlcHRvciBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlcnJvck1hbmFnZXI6IFRydUVycm9yTWFuYWdlcikgeyB9XHJcblxyXG4gIGludGVyY2VwdChcclxuICAgIHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KS5waXBlKFxyXG4gICAgICBjYXRjaEVycm9yKChlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpID0+IHtcclxuICAgICAgICB0aGlzLmVycm9yTWFuYWdlci5oYW5kbGVFcnJvcihlcnJvcik7XHJcbiAgICAgICAgcmV0dXJuIHRocm93RXJyb3IoZXJyb3IpO1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { TruErrorDialog } from "../components/error-dialog/tru-error-dialog";
|
|
3
|
+
import { TruErrorDialogConfig } from "../components/error-dialog/classes/tru-error-dialog-config";
|
|
4
|
+
import { TruServerError } from "../classes/tru-server-error";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
import * as i2 from "@angular/material/dialog";
|
|
8
|
+
import * as i3 from "./tru-text-manager";
|
|
9
|
+
import * as i4 from "./tru-ui-notification";
|
|
10
|
+
import * as i5 from "./tru-app-environment";
|
|
11
|
+
export class TruErrorManager {
|
|
12
|
+
http;
|
|
13
|
+
dialog;
|
|
14
|
+
textManager;
|
|
15
|
+
uiNotification;
|
|
16
|
+
appEnvironment;
|
|
17
|
+
baseUrl;
|
|
18
|
+
appName;
|
|
19
|
+
constructor(http, dialog, textManager, uiNotification, appEnvironment) {
|
|
20
|
+
this.http = http;
|
|
21
|
+
this.dialog = dialog;
|
|
22
|
+
this.textManager = textManager;
|
|
23
|
+
this.uiNotification = uiNotification;
|
|
24
|
+
this.appEnvironment = appEnvironment;
|
|
25
|
+
this.baseUrl = appEnvironment.appUri;
|
|
26
|
+
this.appName = appEnvironment.appName;
|
|
27
|
+
}
|
|
28
|
+
logErrorEvent = (message, context, area) => {
|
|
29
|
+
area = area || 'unknown';
|
|
30
|
+
console.log('[' + area + '|' + context + '] ' + message);
|
|
31
|
+
var logEvent = {
|
|
32
|
+
eventType: 'Error',
|
|
33
|
+
eventDate: new Date(),
|
|
34
|
+
applicationName: this.appName,
|
|
35
|
+
applicationUrl: this.baseUrl,
|
|
36
|
+
applicationArea: area,
|
|
37
|
+
context: context,
|
|
38
|
+
message: message
|
|
39
|
+
};
|
|
40
|
+
this.http
|
|
41
|
+
.post(`${this.baseUrl}/api/log/logevent`, logEvent)
|
|
42
|
+
.subscribe(() => {
|
|
43
|
+
}, (ex) => {
|
|
44
|
+
console.log('Unable to log error to server. ' + ex);
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
handleClientSideError = (error) => {
|
|
48
|
+
};
|
|
49
|
+
handleServerSideError = (error) => {
|
|
50
|
+
let serverError = new TruServerError(error);
|
|
51
|
+
if (serverError.type === 'tru-db-custom-exception') {
|
|
52
|
+
//var service = $injector.get(error.httpResponse.data.serviceName);
|
|
53
|
+
//var exceptionData = error.httpResponse.data.data;
|
|
54
|
+
//service(exceptionData);
|
|
55
|
+
}
|
|
56
|
+
else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
|
|
57
|
+
let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
|
|
58
|
+
this.dialog.open(TruErrorDialog, {
|
|
59
|
+
disableClose: true,
|
|
60
|
+
minWidth: "400px",
|
|
61
|
+
maxWidth: "600px",
|
|
62
|
+
data: dialogConfig
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
|
|
66
|
+
let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
|
|
67
|
+
.replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
|
|
68
|
+
.replace('dbo.', '')
|
|
69
|
+
.replace('UIX_', '')
|
|
70
|
+
.replace('The statement has been terminated.', ''));
|
|
71
|
+
this.dialog.open(TruErrorDialog, {
|
|
72
|
+
disableClose: true,
|
|
73
|
+
minWidth: "400px",
|
|
74
|
+
maxWidth: "600px",
|
|
75
|
+
data: dialogConfig
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
|
|
79
|
+
let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
|
|
80
|
+
this.dialog.open(TruErrorDialog, {
|
|
81
|
+
disableClose: true,
|
|
82
|
+
minWidth: "400px",
|
|
83
|
+
maxWidth: "600px",
|
|
84
|
+
data: dialogConfig
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {
|
|
88
|
+
//this.uiNotification.error(
|
|
89
|
+
// this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),
|
|
90
|
+
// [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
//var message = this.textManager.fmtErrorToShow(error);
|
|
94
|
+
//this.uiNotification.showErrorDialog(message);
|
|
95
|
+
//this.logErrorEvent(message);
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
handleError = (error) => {
|
|
99
|
+
if (error.type)
|
|
100
|
+
this.handleClientSideError(error);
|
|
101
|
+
else
|
|
102
|
+
this.handleServerSideError(error);
|
|
103
|
+
};
|
|
104
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, deps: [{ token: i1.HttpClient }, { token: i2.MatDialog }, { token: i3.TruTextManager }, { token: i4.TruUiNotification }, { token: i5.TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
105
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
|
|
106
|
+
}
|
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, decorators: [{
|
|
108
|
+
type: Injectable,
|
|
109
|
+
args: [{
|
|
110
|
+
providedIn: 'root',
|
|
111
|
+
}]
|
|
112
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.MatDialog }, { type: i3.TruTextManager }, { type: i4.TruUiNotification }, { type: i5.TruAppEnvironment }] });
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-error-manager.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/services/tru-error-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { TruUiNotification } from \"./tru-ui-notification\";\r\nimport { TruTextManager } from \"./tru-text-manager\";\r\nimport { TruErrorDialog } from \"../components/error-dialog/tru-error-dialog\";\r\nimport { TruErrorDialogConfig } from \"../components/error-dialog/classes/tru-error-dialog-config\";\r\nimport { MatDialog } from \"@angular/material/dialog\";\r\nimport { HttpClient, HttpErrorResponse } from \"@angular/common/http\";\r\nimport { TruAppEnvironment } from \"./tru-app-environment\";\r\nimport { TruServerError } from \"../classes/tru-server-error\";\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TruErrorManager {\r\n  private baseUrl: string;\r\n  private appName: string;\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private dialog: MatDialog,\r\n    private textManager: TruTextManager,\r\n    private uiNotification: TruUiNotification,\r\n    private appEnvironment: TruAppEnvironment) {\r\n    this.baseUrl = appEnvironment.appUri;\r\n    this.appName = appEnvironment.appName;\r\n  }\r\n\r\n  private logErrorEvent = (message: string, context: string, area: string) => {\r\n    area = area || 'unknown';\r\n    console.log('[' + area + '|' + context + '] ' + message);\r\n    var logEvent = {\r\n      eventType: 'Error',\r\n      eventDate: new Date(),\r\n      applicationName: this.appName,\r\n      applicationUrl: this.baseUrl,\r\n      applicationArea: area,\r\n      context: context,\r\n      message: message\r\n    };\r\n    this.http\r\n      .post<any>(`${this.baseUrl}/api/log/logevent`, logEvent)\r\n      .subscribe(() => {\r\n\r\n      }, (ex: any) => {\r\n        console.log('Unable to log error to server. ' + ex);\r\n      });\r\n  }\r\n\r\n  private handleClientSideError = (error: HttpErrorResponse) => {\r\n\r\n  }\r\n\r\n  private handleServerSideError = (error: HttpErrorResponse) => {\r\n    let serverError = new TruServerError(error);\r\n    if (serverError.type === 'tru-db-custom-exception') {\r\n      //var service = $injector.get(error.httpResponse.data.serviceName);\r\n      //var exceptionData = error.httpResponse.data.data;\r\n      //service(exceptionData);\r\n    } else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Require Valid Choice Exception',\r\n        error.message);\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n    } else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Duplicate Key Error',\r\n        error.message\r\n          .replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')\r\n          .replace('dbo.', '')\r\n          .replace('UIX_', '')\r\n          .replace('The statement has been terminated.', ''));\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n\r\n    } else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {\r\n\r\n      let dialogConfig = new TruErrorDialogConfig(\r\n        'Concurrent saves not allowed',\r\n        'Please review any changes and save again.');\r\n\r\n      this.dialog.open(TruErrorDialog, {\r\n        disableClose: true,\r\n        minWidth: \"400px\",\r\n        maxWidth: \"600px\",\r\n        data: dialogConfig\r\n      });\r\n    } else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {\r\n\r\n      //this.uiNotification.error(\r\n      //  this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),\r\n      //  [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])\r\n    } else {\r\n      //var message = this.textManager.fmtErrorToShow(error);\r\n      //this.uiNotification.showErrorDialog(message);\r\n      //this.logErrorEvent(message);\r\n    }\r\n  }\r\n\r\n  handleError = (error: HttpErrorResponse) => {\r\n    if (error.type)\r\n      this.handleClientSideError(error);\r\n    else\r\n      this.handleServerSideError(error);\r\n  }\r\n}\r\n"]}
|
|
@@ -9176,23 +9176,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
9176
9176
|
type: Injectable
|
|
9177
9177
|
}] });
|
|
9178
9178
|
|
|
9179
|
-
class TruErrorInterceptor {
|
|
9180
|
-
appEnvironment;
|
|
9181
|
-
constructor(appEnvironment) {
|
|
9182
|
-
this.appEnvironment = appEnvironment;
|
|
9183
|
-
}
|
|
9184
|
-
intercept(request, next) {
|
|
9185
|
-
return next.handle(request).pipe(catchError((error) => {
|
|
9186
|
-
return throwError(error);
|
|
9187
|
-
}));
|
|
9188
|
-
}
|
|
9189
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
9190
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
|
|
9191
|
-
}
|
|
9192
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
|
|
9193
|
-
type: Injectable
|
|
9194
|
-
}], ctorParameters: () => [{ type: TruAppEnvironment }] });
|
|
9195
|
-
|
|
9196
9179
|
class TruErrorDialog {
|
|
9197
9180
|
dialogRef;
|
|
9198
9181
|
data;
|
|
@@ -9219,6 +9202,154 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
9219
9202
|
args: [MAT_DIALOG_DATA]
|
|
9220
9203
|
}] }] });
|
|
9221
9204
|
|
|
9205
|
+
class TruErrorDialogConfig {
|
|
9206
|
+
title;
|
|
9207
|
+
message;
|
|
9208
|
+
constructor(title, message) {
|
|
9209
|
+
this.title = title;
|
|
9210
|
+
this.message = message;
|
|
9211
|
+
}
|
|
9212
|
+
}
|
|
9213
|
+
|
|
9214
|
+
class TruServerError {
|
|
9215
|
+
id;
|
|
9216
|
+
type;
|
|
9217
|
+
code;
|
|
9218
|
+
message;
|
|
9219
|
+
stackTrace;
|
|
9220
|
+
status;
|
|
9221
|
+
constructor(error) {
|
|
9222
|
+
let parsedError = JSON.parse(error.error);
|
|
9223
|
+
this.id = parsedError.$id;
|
|
9224
|
+
this.type = parsedError.$type;
|
|
9225
|
+
this.code = parsedError.Code;
|
|
9226
|
+
this.message = parsedError.Message;
|
|
9227
|
+
this.stackTrace = parsedError.StackTrace;
|
|
9228
|
+
this.status = error.status;
|
|
9229
|
+
}
|
|
9230
|
+
}
|
|
9231
|
+
|
|
9232
|
+
class TruErrorManager {
|
|
9233
|
+
http;
|
|
9234
|
+
dialog;
|
|
9235
|
+
textManager;
|
|
9236
|
+
uiNotification;
|
|
9237
|
+
appEnvironment;
|
|
9238
|
+
baseUrl;
|
|
9239
|
+
appName;
|
|
9240
|
+
constructor(http, dialog, textManager, uiNotification, appEnvironment) {
|
|
9241
|
+
this.http = http;
|
|
9242
|
+
this.dialog = dialog;
|
|
9243
|
+
this.textManager = textManager;
|
|
9244
|
+
this.uiNotification = uiNotification;
|
|
9245
|
+
this.appEnvironment = appEnvironment;
|
|
9246
|
+
this.baseUrl = appEnvironment.appUri;
|
|
9247
|
+
this.appName = appEnvironment.appName;
|
|
9248
|
+
}
|
|
9249
|
+
logErrorEvent = (message, context, area) => {
|
|
9250
|
+
area = area || 'unknown';
|
|
9251
|
+
console.log('[' + area + '|' + context + '] ' + message);
|
|
9252
|
+
var logEvent = {
|
|
9253
|
+
eventType: 'Error',
|
|
9254
|
+
eventDate: new Date(),
|
|
9255
|
+
applicationName: this.appName,
|
|
9256
|
+
applicationUrl: this.baseUrl,
|
|
9257
|
+
applicationArea: area,
|
|
9258
|
+
context: context,
|
|
9259
|
+
message: message
|
|
9260
|
+
};
|
|
9261
|
+
this.http
|
|
9262
|
+
.post(`${this.baseUrl}/api/log/logevent`, logEvent)
|
|
9263
|
+
.subscribe(() => {
|
|
9264
|
+
}, (ex) => {
|
|
9265
|
+
console.log('Unable to log error to server. ' + ex);
|
|
9266
|
+
});
|
|
9267
|
+
};
|
|
9268
|
+
handleClientSideError = (error) => {
|
|
9269
|
+
};
|
|
9270
|
+
handleServerSideError = (error) => {
|
|
9271
|
+
let serverError = new TruServerError(error);
|
|
9272
|
+
if (serverError.type === 'tru-db-custom-exception') {
|
|
9273
|
+
//var service = $injector.get(error.httpResponse.data.serviceName);
|
|
9274
|
+
//var exceptionData = error.httpResponse.data.data;
|
|
9275
|
+
//service(exceptionData);
|
|
9276
|
+
}
|
|
9277
|
+
else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
|
|
9278
|
+
let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
|
|
9279
|
+
this.dialog.open(TruErrorDialog, {
|
|
9280
|
+
disableClose: true,
|
|
9281
|
+
minWidth: "400px",
|
|
9282
|
+
maxWidth: "600px",
|
|
9283
|
+
data: dialogConfig
|
|
9284
|
+
});
|
|
9285
|
+
}
|
|
9286
|
+
else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
|
|
9287
|
+
let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
|
|
9288
|
+
.replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
|
|
9289
|
+
.replace('dbo.', '')
|
|
9290
|
+
.replace('UIX_', '')
|
|
9291
|
+
.replace('The statement has been terminated.', ''));
|
|
9292
|
+
this.dialog.open(TruErrorDialog, {
|
|
9293
|
+
disableClose: true,
|
|
9294
|
+
minWidth: "400px",
|
|
9295
|
+
maxWidth: "600px",
|
|
9296
|
+
data: dialogConfig
|
|
9297
|
+
});
|
|
9298
|
+
}
|
|
9299
|
+
else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
|
|
9300
|
+
let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
|
|
9301
|
+
this.dialog.open(TruErrorDialog, {
|
|
9302
|
+
disableClose: true,
|
|
9303
|
+
minWidth: "400px",
|
|
9304
|
+
maxWidth: "600px",
|
|
9305
|
+
data: dialogConfig
|
|
9306
|
+
});
|
|
9307
|
+
}
|
|
9308
|
+
else if (error.type.toString().lastIndexOf('TruDB.EfMssql.Runtime.DataError', 0) === 0) {
|
|
9309
|
+
//this.uiNotification.error(
|
|
9310
|
+
// this.textManager.fmtDataError(error.httpResponse.data.Detail.$type),
|
|
9311
|
+
// [this.textManager.fmtExceptionToShow(error.httpResponse.data.Exception)])
|
|
9312
|
+
}
|
|
9313
|
+
else {
|
|
9314
|
+
//var message = this.textManager.fmtErrorToShow(error);
|
|
9315
|
+
//this.uiNotification.showErrorDialog(message);
|
|
9316
|
+
//this.logErrorEvent(message);
|
|
9317
|
+
}
|
|
9318
|
+
};
|
|
9319
|
+
handleError = (error) => {
|
|
9320
|
+
if (error.type)
|
|
9321
|
+
this.handleClientSideError(error);
|
|
9322
|
+
else
|
|
9323
|
+
this.handleServerSideError(error);
|
|
9324
|
+
};
|
|
9325
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, deps: [{ token: i2.HttpClient }, { token: i1.MatDialog }, { token: TruTextManager }, { token: TruUiNotification }, { token: TruAppEnvironment }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
9326
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
|
|
9327
|
+
}
|
|
9328
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, decorators: [{
|
|
9329
|
+
type: Injectable,
|
|
9330
|
+
args: [{
|
|
9331
|
+
providedIn: 'root',
|
|
9332
|
+
}]
|
|
9333
|
+
}], ctorParameters: () => [{ type: i2.HttpClient }, { type: i1.MatDialog }, { type: TruTextManager }, { type: TruUiNotification }, { type: TruAppEnvironment }] });
|
|
9334
|
+
|
|
9335
|
+
class TruErrorInterceptor {
|
|
9336
|
+
errorManager;
|
|
9337
|
+
constructor(errorManager) {
|
|
9338
|
+
this.errorManager = errorManager;
|
|
9339
|
+
}
|
|
9340
|
+
intercept(request, next) {
|
|
9341
|
+
return next.handle(request).pipe(catchError((error) => {
|
|
9342
|
+
this.errorManager.handleError(error);
|
|
9343
|
+
return throwError(error);
|
|
9344
|
+
}));
|
|
9345
|
+
}
|
|
9346
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, deps: [{ token: TruErrorManager }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
9347
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor });
|
|
9348
|
+
}
|
|
9349
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorInterceptor, decorators: [{
|
|
9350
|
+
type: Injectable
|
|
9351
|
+
}], ctorParameters: () => [{ type: TruErrorManager }] });
|
|
9352
|
+
|
|
9222
9353
|
class TruErrorDialogModule {
|
|
9223
9354
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9224
9355
|
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.5", ngImport: i0, type: TruErrorDialogModule, declarations: [TruErrorDialog], imports: [CommonModule,
|