2021-04-26 17:52:50 +06:00
|
|
|
package sentry
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/getsentry/sentry-go"
|
2021-09-30 20:23:30 +06:00
|
|
|
"github.com/imgproxy/imgproxy/v3/config"
|
2021-04-26 17:52:50 +06:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
enabled bool
|
|
|
|
|
|
|
|
timeout = 5 * time.Second
|
|
|
|
)
|
|
|
|
|
|
|
|
func Init() {
|
|
|
|
if len(config.SentryDSN) > 0 {
|
|
|
|
sentry.Init(sentry.ClientOptions{
|
|
|
|
Dsn: config.SentryDSN,
|
|
|
|
Release: config.SentryRelease,
|
|
|
|
Environment: config.SentryEnvironment,
|
|
|
|
})
|
|
|
|
|
|
|
|
enabled = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Report(err error, req *http.Request) {
|
|
|
|
if enabled {
|
|
|
|
hub := sentry.CurrentHub().Clone()
|
|
|
|
hub.Scope().SetRequest(req)
|
|
|
|
hub.Scope().SetLevel(sentry.LevelError)
|
|
|
|
eventID := hub.CaptureException(err)
|
|
|
|
if eventID != nil {
|
|
|
|
hub.Flush(timeout)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|