mirror of
https://github.com/elyby/chrly.git
synced 2025-01-24 12:33:27 +05:30
105 lines
2.2 KiB
Go
105 lines
2.2 KiB
Go
package di
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/defval/di"
|
|
"github.com/getsentry/raven-go"
|
|
"github.com/mono83/slf"
|
|
"github.com/mono83/slf/rays"
|
|
"github.com/mono83/slf/recievers/sentry"
|
|
"github.com/mono83/slf/recievers/statsd"
|
|
"github.com/mono83/slf/recievers/writer"
|
|
"github.com/mono83/slf/wd"
|
|
"github.com/spf13/viper"
|
|
|
|
"ely.by/chrly/internal/eventsubscribers"
|
|
"ely.by/chrly/internal/version"
|
|
)
|
|
|
|
var logger = di.Options(
|
|
di.Provide(newLogger),
|
|
di.Provide(newSentry),
|
|
di.Provide(newStatsReporter),
|
|
)
|
|
|
|
type loggerParams struct {
|
|
di.Inject
|
|
|
|
SentryRaven *raven.Client `di:"" optional:"true"`
|
|
}
|
|
|
|
func newLogger(params loggerParams) slf.Logger {
|
|
dispatcher := &slf.Dispatcher{}
|
|
dispatcher.AddReceiver(writer.New(writer.Options{
|
|
Marker: false,
|
|
TimeFormat: "15:04:05.000",
|
|
}))
|
|
|
|
if params.SentryRaven != nil {
|
|
sentryReceiver, _ := sentry.NewReceiverWithCustomRaven(
|
|
params.SentryRaven,
|
|
&sentry.Config{
|
|
MinLevel: "warn",
|
|
},
|
|
)
|
|
dispatcher.AddReceiver(sentryReceiver)
|
|
}
|
|
|
|
logger := wd.Custom("", "", dispatcher)
|
|
logger.WithParams(rays.Host)
|
|
|
|
return logger
|
|
}
|
|
|
|
func newSentry(config *viper.Viper) (*raven.Client, error) {
|
|
sentryAddr := config.GetString("sentry.dsn")
|
|
if sentryAddr == "" {
|
|
return nil, nil
|
|
}
|
|
|
|
ravenClient, err := raven.New(sentryAddr)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
ravenClient.SetEnvironment("production")
|
|
ravenClient.SetDefaultLoggerName("sentry-watchdog-receiver")
|
|
ravenClient.SetRelease(version.Version())
|
|
|
|
raven.DefaultClient = ravenClient
|
|
|
|
return ravenClient, nil
|
|
}
|
|
|
|
func newStatsReporter(config *viper.Viper) (slf.StatsReporter, error) {
|
|
dispatcher := &slf.Dispatcher{}
|
|
|
|
statsdAddr := config.GetString("statsd.addr")
|
|
if statsdAddr != "" {
|
|
hostname, err := os.Hostname()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
statsdReceiver, err := statsd.NewReceiver(statsd.Config{
|
|
Address: statsdAddr,
|
|
Prefix: "ely.skinsystem." + hostname + ".app.",
|
|
FlushEvery: 1,
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
dispatcher.AddReceiver(statsdReceiver)
|
|
}
|
|
|
|
return wd.Custom("", "", dispatcher), nil
|
|
}
|
|
|
|
func enableReporters(reporter slf.StatsReporter, factories []eventsubscribers.Reporter) {
|
|
for _, factory := range factories {
|
|
factory.Enable(reporter)
|
|
}
|
|
}
|