@regacy-innovation/shared-services
Version:
Shared services for NestJS microservices
50 lines (49 loc) • 2.35 kB
JavaScript
;
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var GlobalExceptionFilter_1;
Object.defineProperty(exports, "__esModule", { value: true });
exports.GlobalExceptionFilter = void 0;
const common_1 = require("@nestjs/common");
let GlobalExceptionFilter = GlobalExceptionFilter_1 = class GlobalExceptionFilter {
constructor() {
this.logger = new common_1.Logger(GlobalExceptionFilter_1.name);
}
catch(exception, host) {
const ctx = host.switchToHttp();
const response = ctx.getResponse();
let status = 500;
let message = 'Internal Server Error';
if (exception instanceof common_1.HttpException) {
status = exception.getStatus();
const responseContent = exception.getResponse();
message =
typeof responseContent === 'string'
? responseContent
: responseContent.message || JSON.stringify(responseContent);
}
else if (exception instanceof Error) {
message = exception.message;
this.logger.error(`Exception Name: ${exception.name}`);
this.logger.error(`Exception Message: ${exception.message}`);
this.logger.error(`Exception Stack: ${exception.stack}`);
}
else {
this.logger.error(`Raw Exception: ${JSON.stringify(exception, null, 2)}`);
}
this.logger.error(`Exception Response: ${message}`);
response.status(status).json({
statusCode: status,
message,
timestamp: new Date().toISOString(),
});
}
};
exports.GlobalExceptionFilter = GlobalExceptionFilter;
exports.GlobalExceptionFilter = GlobalExceptionFilter = GlobalExceptionFilter_1 = __decorate([
(0, common_1.Catch)()
], GlobalExceptionFilter);