A Nest module wrapper for bugsnag
A Nest module wrapper for bugsnag logger.
A Nest module wrapper for bugsnag-js logger.
``bash`
$ npm i @bugsnag/plugin-express --save
$ npm i @nkaurelien/nest-bugsnag --save
Import the BugsnagModule into the module. For example AppModule:
`typescript
import { Module } from '@nestjs/common';
import { BugsnagModule } from '@nkaurelien/nest-bugsnag';
import BugsnagPluginExpress from '@bugsnag/plugin-express'
@Module({
imports: [
BugsnagModule.forRoot({
apiKey: '
plugins: [BugsnagPluginExpress],
}),
],
})
export class AppModule { }
`
In the main.ts file, change the HTTP platform to use express
`typescript`
// change
const app = await NestFactory.create(AppModule);
// to
const app = await NestFactory.create
This handles any errors that Express catches
`typescript`
app.get(BugsnagService).handleAnyErrors(app);
Then you can inject BugsnagService. Example:
`typescript
import { Controller } from '@nestjs/common';
import { BugsnagService } from '@nkaurelien/nest-bugsnag';
@Controller('cats')
export class CatsController {
constructor(private readonly logger: BugsnagService) { }
}
`
BugsnagService has instance property which wrap bugsnag client. So you can access it by calling:
`typescript`
try {
something.risky()
} catch (e) {
this.logger.instance.notify('message');
}`
In your controller, you can call req.bugsnag.notify(err) which will include information about the request in the error report. For example:
typescript`
@Get()
getHello(@Request() req): string {
req.bugsnag.notify(
new Error('First Error'),
function (event) {
// event.addMetadata('product', product)
});
return 'Hello World!';
}BugsnagModule
Note that is a global module, it will be available in all you feature modules.
`typescript
import { Module } from '@nestjs/common';
import { BugsnagModule } from '@nkaurelien/nest-bugsnag';
@Module({
imports: [
BugsnagModule.forRootAsync({
useFactory: (configService: ConfigService) => ({
// options
}),
inject: [ConfigService],
}),
],
})
export class AppModule { }
`
The factory might be async and is able to inject dependencies through the inject` option.