1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- package honeybadger
- import (
- "log/slog"
- "net/http"
- "reflect"
- "strings"
- "github.com/honeybadger-io/honeybadger-go"
- "github.com/imgproxy/imgproxy/v3/ierrors"
- )
- var (
- metaReplacer = strings.NewReplacer("-", "_", " ", "_")
- )
- type reporter struct {
- client *honeybadger.Client
- }
- func New(config *Config) (*reporter, error) {
- if err := config.Validate(); err != nil {
- return nil, err
- }
- if len(config.Key) == 0 {
- return nil, nil
- }
- client := honeybadger.New(honeybadger.Configuration{
- APIKey: config.Key,
- Env: config.Env,
- })
- return &reporter{client: client}, nil
- }
- func (r *reporter) Report(err error, req *http.Request, meta map[string]any) {
- extra := make(honeybadger.CGIData, len(req.Header)+len(meta))
- for k, v := range req.Header {
- key := "HTTP_" + metaReplacer.Replace(strings.ToUpper(k))
- extra[key] = v[0]
- }
- for k, v := range meta {
- key := metaReplacer.Replace(strings.ToUpper(k))
- extra[key] = v
- }
- hbErr := honeybadger.NewError(err)
- if e, ok := err.(*ierrors.Error); ok {
- hbErr.Class = reflect.TypeOf(e.Unwrap()).String()
- }
- if _, repErr := r.client.Notify(hbErr, req.URL, extra); repErr != nil {
- slog.Warn("Failed to report error to Honeybadger", "error", repErr)
- }
- }
- func (r *reporter) Close() {
- r.client.Flush()
- }
|