# Bugsnag notifier for Erlang applications
[data:image/s3,"s3://crabby-images/1f7b6/1f7b61f2c7556c6c0fb4d68daeafd102154ea612" alt="Build Status"](https://github.com/dnsimple/bugsnag-erlang/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/2ab32/2ab3264758962dc6ef5365957a8fbe343e142447" alt="Module Version"](https://hex.pm/packages/bugsnag_erlang)
[data:image/s3,"s3://crabby-images/9b6db/9b6db7b2704213e584cc9930ef42bd36a0019b92" alt="Hex Docs"](https://hexdocs.pm/dnsimple/)
[data:image/s3,"s3://crabby-images/2b0f7/2b0f709157755f8be7e84fe7fc3e5f365a93dfb5" alt="Total Download"](https://hex.pm/packages/bugsnag_erlang)
[data:image/s3,"s3://crabby-images/192d4/192d4dad0a56a66c8900b2946d21a83d4e550f4f" alt="License"](https://github.com/dnsimple/bugsnag-erlang/blob/main/LICENSE.md)
[data:image/s3,"s3://crabby-images/c3221/c32219705e4a91ac6959da991c40cbc727f9e1cf" alt="Last Updated"](https://github.com/dnsimple/bugsnag-erlang/commits/main)
## Dependencies
Requires [Lager](https://github.com/erlang-lager/lager)
The following applications must be started
```text
kernel,stdlib,inets,crypto,ssl,lager
```
## Usage
You may send custom errors directly
```erlang
bugsnag:notify(error, fake, "Testing bugsnag with a manual error report", no_module, 0).
```
Or use the Erlang error logger
```erlang
error_logger:error_msg("A sample error caught by the bugsnag error logger.").
```
Or cause an error with a full stack trace
```erlang
bugsnag:test_error().
```
When embedding, make sure to set up the configuration elements in your sys.config (or other config file)
```erlang
[
{bugsnag_erlang, [
{error_logger, true},
{api_key, "ENTER_API_KEY"},
{release_state, "development"}
]}
].
```
And start the application:
```erlang
application:start(bugsnag)
```
Or add the application to your .app configuration.
### Lager handler
We also provide a [lager](https://github.com/basho/lager) to report anything
above a certain level (by default, `error`) to Bugsnag.
For example, simply add
```erlang
{bugsnag_lager_handler, critical}
```
to your lager handler config.
## Formatting
To format the codebase
```shell
make format
```
## Thanks
Thank you to Ken Pratt: his library <https://github.com/kenpratt/erlbrake> provided a lot of code for this library.