@trudb/tru-common-lib 0.1.551 → 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/services/tru-error-manager.mjs +34 -38
- package/fesm2022/trudb-tru-common-lib.mjs +50 -37
- package/fesm2022/trudb-tru-common-lib.mjs.map +1 -1
- package/lib/classes/tru-server-error.d.ts +10 -0
- package/lib/components/login/classes/tru-auth-strategy-provider.d.ts +1 -1
- package/lib/services/tru-error-manager.d.ts +3 -2
- 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==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Injectable } from "@angular/core";
|
|
2
2
|
import { TruErrorDialog } from "../components/error-dialog/tru-error-dialog";
|
|
3
3
|
import { TruErrorDialogConfig } from "../components/error-dialog/classes/tru-error-dialog-config";
|
|
4
|
+
import { TruServerError } from "../classes/tru-server-error";
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common/http";
|
|
6
7
|
import * as i2 from "@angular/material/dialog";
|
|
@@ -24,24 +25,35 @@ export class TruErrorManager {
|
|
|
24
25
|
this.baseUrl = appEnvironment.appUri;
|
|
25
26
|
this.appName = appEnvironment.appName;
|
|
26
27
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
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') {
|
|
40
52
|
//var service = $injector.get(error.httpResponse.data.serviceName);
|
|
41
53
|
//var exceptionData = error.httpResponse.data.data;
|
|
42
54
|
//service(exceptionData);
|
|
43
55
|
}
|
|
44
|
-
else if (
|
|
56
|
+
else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
|
|
45
57
|
let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
|
|
46
58
|
this.dialog.open(TruErrorDialog, {
|
|
47
59
|
disableClose: true,
|
|
@@ -50,7 +62,7 @@ export class TruErrorManager {
|
|
|
50
62
|
data: dialogConfig
|
|
51
63
|
});
|
|
52
64
|
}
|
|
53
|
-
else if (
|
|
65
|
+
else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
|
|
54
66
|
let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
|
|
55
67
|
.replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
|
|
56
68
|
.replace('dbo.', '')
|
|
@@ -63,7 +75,7 @@ export class TruErrorManager {
|
|
|
63
75
|
data: dialogConfig
|
|
64
76
|
});
|
|
65
77
|
}
|
|
66
|
-
else if (
|
|
78
|
+
else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
|
|
67
79
|
let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
|
|
68
80
|
this.dialog.open(TruErrorDialog, {
|
|
69
81
|
disableClose: true,
|
|
@@ -82,28 +94,12 @@ export class TruErrorManager {
|
|
|
82
94
|
//this.uiNotification.showErrorDialog(message);
|
|
83
95
|
//this.logErrorEvent(message);
|
|
84
96
|
}
|
|
85
|
-
//if (window.appInsights) window.appInsights.trackException(error, null, {
|
|
86
|
-
// 'User': dataService.activeUser.username
|
|
87
|
-
//});
|
|
88
97
|
};
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
eventDate: new Date(),
|
|
95
|
-
applicationName: this.appName,
|
|
96
|
-
applicationUrl: this.baseUrl,
|
|
97
|
-
applicationArea: area,
|
|
98
|
-
context: context,
|
|
99
|
-
message: message
|
|
100
|
-
};
|
|
101
|
-
this.http
|
|
102
|
-
.post(`${this.baseUrl}/api/log/logevent`, logEvent)
|
|
103
|
-
.subscribe(() => {
|
|
104
|
-
}, (ex) => {
|
|
105
|
-
console.log('Unable to log error to server. ' + ex);
|
|
106
|
-
});
|
|
98
|
+
handleError = (error) => {
|
|
99
|
+
if (error.type)
|
|
100
|
+
this.handleClientSideError(error);
|
|
101
|
+
else
|
|
102
|
+
this.handleServerSideError(error);
|
|
107
103
|
};
|
|
108
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 });
|
|
109
105
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
|
|
@@ -114,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
114
110
|
providedIn: 'root',
|
|
115
111
|
}]
|
|
116
112
|
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.MatDialog }, { type: i3.TruTextManager }, { type: i4.TruUiNotification }, { type: i5.TruAppEnvironment }] });
|
|
117
|
-
//# 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\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 parseErrorMessage(error: HttpErrorResponse): string {\r\n    if (error.error && error.error.message) {\r\n      return error.error.message;\r\n    } else if (error.error && typeof error.error === 'string') {\r\n      return error.error;\r\n    } else {\r\n      return `Server returned code ${error.status}, body was: ${error.error}`;\r\n    }\r\n  }\r\n\r\n  handleError = (error: HttpErrorResponse) => {\r\n    if (error.type.toString() === '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 (error.type.toString().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 (error.type.toString().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 (error.type.toString().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    //if (window.appInsights) window.appInsights.trackException(error, null, {\r\n    //  'User': dataService.activeUser.username\r\n    //});\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"]}
|
|
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"]}
|
|
@@ -9211,6 +9211,24 @@ class TruErrorDialogConfig {
|
|
|
9211
9211
|
}
|
|
9212
9212
|
}
|
|
9213
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
|
+
|
|
9214
9232
|
class TruErrorManager {
|
|
9215
9233
|
http;
|
|
9216
9234
|
dialog;
|
|
@@ -9228,24 +9246,35 @@ class TruErrorManager {
|
|
|
9228
9246
|
this.baseUrl = appEnvironment.appUri;
|
|
9229
9247
|
this.appName = appEnvironment.appName;
|
|
9230
9248
|
}
|
|
9231
|
-
|
|
9232
|
-
|
|
9233
|
-
|
|
9234
|
-
|
|
9235
|
-
|
|
9236
|
-
|
|
9237
|
-
|
|
9238
|
-
|
|
9239
|
-
|
|
9240
|
-
|
|
9241
|
-
|
|
9242
|
-
|
|
9243
|
-
|
|
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') {
|
|
9244
9273
|
//var service = $injector.get(error.httpResponse.data.serviceName);
|
|
9245
9274
|
//var exceptionData = error.httpResponse.data.data;
|
|
9246
9275
|
//service(exceptionData);
|
|
9247
9276
|
}
|
|
9248
|
-
else if (
|
|
9277
|
+
else if (serverError.type.indexOf('TruDbRequireValidChoiceException') !== -1) {
|
|
9249
9278
|
let dialogConfig = new TruErrorDialogConfig('Require Valid Choice Exception', error.message);
|
|
9250
9279
|
this.dialog.open(TruErrorDialog, {
|
|
9251
9280
|
disableClose: true,
|
|
@@ -9254,7 +9283,7 @@ class TruErrorManager {
|
|
|
9254
9283
|
data: dialogConfig
|
|
9255
9284
|
});
|
|
9256
9285
|
}
|
|
9257
|
-
else if (
|
|
9286
|
+
else if (serverError.type.indexOf('DuplicateKeyError') !== -1) {
|
|
9258
9287
|
let dialogConfig = new TruErrorDialogConfig('Duplicate Key Error', error.message
|
|
9259
9288
|
.replace('Cannot insert duplicate key row in object', 'Cannot insert duplicate value in table')
|
|
9260
9289
|
.replace('dbo.', '')
|
|
@@ -9267,7 +9296,7 @@ class TruErrorManager {
|
|
|
9267
9296
|
data: dialogConfig
|
|
9268
9297
|
});
|
|
9269
9298
|
}
|
|
9270
|
-
else if (
|
|
9299
|
+
else if (serverError.type.indexOf('OptimisticLockViolation') !== -1) {
|
|
9271
9300
|
let dialogConfig = new TruErrorDialogConfig('Concurrent saves not allowed', 'Please review any changes and save again.');
|
|
9272
9301
|
this.dialog.open(TruErrorDialog, {
|
|
9273
9302
|
disableClose: true,
|
|
@@ -9286,28 +9315,12 @@ class TruErrorManager {
|
|
|
9286
9315
|
//this.uiNotification.showErrorDialog(message);
|
|
9287
9316
|
//this.logErrorEvent(message);
|
|
9288
9317
|
}
|
|
9289
|
-
//if (window.appInsights) window.appInsights.trackException(error, null, {
|
|
9290
|
-
// 'User': dataService.activeUser.username
|
|
9291
|
-
//});
|
|
9292
9318
|
};
|
|
9293
|
-
|
|
9294
|
-
|
|
9295
|
-
|
|
9296
|
-
|
|
9297
|
-
|
|
9298
|
-
eventDate: new Date(),
|
|
9299
|
-
applicationName: this.appName,
|
|
9300
|
-
applicationUrl: this.baseUrl,
|
|
9301
|
-
applicationArea: area,
|
|
9302
|
-
context: context,
|
|
9303
|
-
message: message
|
|
9304
|
-
};
|
|
9305
|
-
this.http
|
|
9306
|
-
.post(`${this.baseUrl}/api/log/logevent`, logEvent)
|
|
9307
|
-
.subscribe(() => {
|
|
9308
|
-
}, (ex) => {
|
|
9309
|
-
console.log('Unable to log error to server. ' + ex);
|
|
9310
|
-
});
|
|
9319
|
+
handleError = (error) => {
|
|
9320
|
+
if (error.type)
|
|
9321
|
+
this.handleClientSideError(error);
|
|
9322
|
+
else
|
|
9323
|
+
this.handleServerSideError(error);
|
|
9311
9324
|
};
|
|
9312
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 });
|
|
9313
9326
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruErrorManager, providedIn: 'root' });
|