@greguintow/nestjs-sentry
Version:
Provides an injectable sentry.io client to provide enterprise logging nestjs modules
162 lines • 6.9 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 __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
var SentryService_1;
Object.defineProperty(exports, "__esModule", { value: true });
exports.SentryService = void 0;
const common_1 = require("@nestjs/common");
const Sentry = require("@sentry/node");
const sentry_constants_1 = require("./sentry.constants");
let SentryService = SentryService_1 = class SentryService extends common_1.ConsoleLogger {
constructor(opts) {
super();
this.opts = opts;
this.app = '@greguintow/nestjs-sentry: ';
if (!(opts && opts.dsn)) {
return;
}
const { debug, integrations = [] } = opts, sentryOptions = __rest(opts, ["debug", "integrations"]);
Sentry.init(Object.assign(Object.assign({}, sentryOptions), { integrations: [
new Sentry.Integrations.OnUncaughtException({
onFatalError: (err) => __awaiter(this, void 0, void 0, function* () {
if (err.name === 'SentryError') {
console.log(err);
}
else {
;
Sentry.getCurrentHub().getClient().captureException(err);
process.exit(1);
}
})
}),
new Sentry.Integrations.OnUnhandledRejection({ mode: 'warn' }),
...integrations
] }));
}
static SentryServiceInstance() {
if (!SentryService_1.serviceInstance) {
SentryService_1.serviceInstance = new SentryService_1();
}
return SentryService_1.serviceInstance;
}
log(message, context, asBreadcrumb) {
message = `${this.app} ${message}`;
try {
super.log(message, context);
asBreadcrumb
? Sentry.addBreadcrumb({
message,
level: Sentry.Severity.Log,
data: {
context
}
})
: Sentry.captureMessage(message, Sentry.Severity.Log);
}
catch (err) { }
}
error(message, trace, context) {
message = `${this.app} ${message}`;
try {
super.error(message, trace, context);
Sentry.captureMessage(message, Sentry.Severity.Error);
}
catch (err) { }
}
warn(message, context, asBreadcrumb) {
message = `${this.app} ${message}`;
try {
super.warn(message, context);
asBreadcrumb
? Sentry.addBreadcrumb({
message,
level: Sentry.Severity.Warning,
data: {
context
}
})
: Sentry.captureMessage(message, Sentry.Severity.Warning);
}
catch (err) { }
}
debug(message, context, asBreadcrumb) {
message = `${this.app} ${message}`;
try {
super.debug(message, context);
asBreadcrumb
? Sentry.addBreadcrumb({
message,
level: Sentry.Severity.Debug,
data: {
context
}
})
: Sentry.captureMessage(message, Sentry.Severity.Debug);
}
catch (err) { }
}
verbose(message, context, asBreadcrumb) {
message = `${this.app} ${message}`;
try {
super.verbose(message, context);
asBreadcrumb
? Sentry.addBreadcrumb({
message,
level: Sentry.Severity.Info,
data: {
context
}
})
: Sentry.captureMessage(message, Sentry.Severity.Info);
}
catch (err) { }
}
instance() {
return Sentry;
}
onApplicationShutdown(signal) {
var _a, _b, _c;
return __awaiter(this, void 0, void 0, function* () {
if (((_b = (_a = this.opts) === null || _a === void 0 ? void 0 : _a.close) === null || _b === void 0 ? void 0 : _b.enabled) === true) {
yield Sentry.close((_c = this.opts) === null || _c === void 0 ? void 0 : _c.close.timeout);
}
});
}
};
SentryService = SentryService_1 = __decorate([
(0, common_1.Injectable)(),
__param(0, (0, common_1.Inject)(sentry_constants_1.SENTRY_MODULE_OPTIONS)),
__metadata("design:paramtypes", [Object])
], SentryService);
exports.SentryService = SentryService;
//# sourceMappingURL=sentry.service.js.map