2018-11-14 19:41:16 +06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
2019-08-19 18:05:57 +06:00
|
|
|
"time"
|
2018-11-14 19:41:16 +06:00
|
|
|
|
|
|
|
"github.com/bugsnag/bugsnag-go"
|
2019-08-19 18:05:57 +06:00
|
|
|
"github.com/getsentry/sentry-go"
|
2018-11-14 19:41:16 +06:00
|
|
|
"github.com/honeybadger-io/honeybadger-go"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
bugsnagEnabled bool
|
|
|
|
honeybadgerEnabled bool
|
2019-01-14 11:42:10 +01:00
|
|
|
sentryEnabled bool
|
2018-11-14 19:41:16 +06:00
|
|
|
|
|
|
|
headersReplacer = strings.NewReplacer("-", "_")
|
2019-08-19 18:05:57 +06:00
|
|
|
sentryTimeout = 5 * time.Second
|
2018-11-14 19:41:16 +06:00
|
|
|
)
|
|
|
|
|
|
|
|
func initErrorsReporting() {
|
|
|
|
if len(conf.BugsnagKey) > 0 {
|
|
|
|
bugsnag.Configure(bugsnag.Configuration{
|
|
|
|
APIKey: conf.BugsnagKey,
|
|
|
|
ReleaseStage: conf.BugsnagStage,
|
|
|
|
})
|
|
|
|
bugsnagEnabled = true
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(conf.HoneybadgerKey) > 0 {
|
|
|
|
honeybadger.Configure(honeybadger.Configuration{
|
|
|
|
APIKey: conf.HoneybadgerKey,
|
|
|
|
Env: conf.HoneybadgerEnv,
|
|
|
|
})
|
|
|
|
honeybadgerEnabled = true
|
|
|
|
}
|
2019-01-14 11:42:10 +01:00
|
|
|
|
|
|
|
if len(conf.SentryDSN) > 0 {
|
2019-08-19 18:05:57 +06:00
|
|
|
sentry.Init(sentry.ClientOptions{
|
|
|
|
Dsn: conf.SentryDSN,
|
|
|
|
Release: conf.SentryRelease,
|
|
|
|
Environment: conf.SentryEnvironment,
|
|
|
|
})
|
2019-01-14 11:42:10 +01:00
|
|
|
|
|
|
|
sentryEnabled = true
|
|
|
|
}
|
2018-11-14 19:41:16 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
func reportError(err error, req *http.Request) {
|
|
|
|
if bugsnagEnabled {
|
|
|
|
bugsnag.Notify(err, req)
|
|
|
|
}
|
|
|
|
|
|
|
|
if honeybadgerEnabled {
|
|
|
|
headers := make(honeybadger.CGIData)
|
|
|
|
|
|
|
|
for k, v := range req.Header {
|
|
|
|
key := "HTTP_" + headersReplacer.Replace(strings.ToUpper(k))
|
|
|
|
headers[key] = v[0]
|
|
|
|
}
|
|
|
|
|
|
|
|
honeybadger.Notify(err, req.URL, headers)
|
|
|
|
}
|
2019-01-14 11:42:10 +01:00
|
|
|
|
|
|
|
if sentryEnabled {
|
2019-08-19 18:05:57 +06:00
|
|
|
hub := sentry.CurrentHub().Clone()
|
|
|
|
hub.Scope().SetRequest(sentry.Request{}.FromHTTPRequest(req))
|
|
|
|
hub.Scope().SetLevel(sentry.LevelError)
|
|
|
|
eventID := hub.CaptureException(err)
|
|
|
|
if eventID != nil {
|
|
|
|
hub.Flush(sentryTimeout)
|
|
|
|
}
|
2019-01-14 11:42:10 +01:00
|
|
|
}
|
2018-11-14 19:41:16 +06:00
|
|
|
}
|