2018-11-14 19:41:16 +06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/bugsnag/bugsnag-go"
|
2019-01-14 11:42:10 +01:00
|
|
|
"github.com/getsentry/raven-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("-", "_")
|
|
|
|
)
|
|
|
|
|
|
|
|
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 {
|
|
|
|
raven.SetDSN(conf.SentryDSN)
|
|
|
|
raven.SetEnvironment(conf.SentryEnvironment)
|
|
|
|
raven.SetRelease(conf.SentryRelease)
|
|
|
|
|
|
|
|
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 {
|
|
|
|
raven.SetHttpContext(raven.NewHttp(req))
|
|
|
|
raven.CaptureError(err, nil)
|
|
|
|
}
|
2018-11-14 19:41:16 +06:00
|
|
|
}
|