2017-08-16 15:23:03 +03:00
|
|
|
package bootstrap
|
|
|
|
|
|
|
|
import (
|
2017-08-17 02:47:35 +03:00
|
|
|
"fmt"
|
|
|
|
"net/url"
|
2017-08-16 15:23:03 +03:00
|
|
|
"os"
|
|
|
|
|
2017-09-03 22:45:38 +03:00
|
|
|
"github.com/assembla/cony"
|
2017-08-27 18:10:03 +03:00
|
|
|
"github.com/getsentry/raven-go"
|
2017-08-16 15:23:03 +03:00
|
|
|
"github.com/mono83/slf/rays"
|
2018-01-05 00:10:38 +03:00
|
|
|
"github.com/mono83/slf/recievers/sentry"
|
2017-08-16 15:23:03 +03:00
|
|
|
"github.com/mono83/slf/recievers/statsd"
|
2017-09-03 22:54:46 +03:00
|
|
|
"github.com/mono83/slf/recievers/writer"
|
2017-08-16 15:23:03 +03:00
|
|
|
"github.com/mono83/slf/wd"
|
|
|
|
)
|
|
|
|
|
2017-09-02 21:37:16 +03:00
|
|
|
var version = ""
|
|
|
|
|
|
|
|
func GetVersion() string {
|
|
|
|
return version
|
|
|
|
}
|
|
|
|
|
2017-08-27 18:10:03 +03:00
|
|
|
func CreateLogger(statsdAddr string, sentryAddr string) (wd.Watchdog, error) {
|
2017-09-03 22:54:46 +03:00
|
|
|
wd.AddReceiver(writer.New(writer.Options{
|
|
|
|
Marker: false,
|
|
|
|
TimeFormat: "15:04:05.000",
|
|
|
|
}))
|
2017-08-16 15:23:03 +03:00
|
|
|
if statsdAddr != "" {
|
|
|
|
hostname, _ := os.Hostname()
|
|
|
|
statsdReceiver, err := statsd.NewReceiver(statsd.Config{
|
|
|
|
Address: statsdAddr,
|
|
|
|
Prefix: "ely.skinsystem." + hostname + ".app.",
|
|
|
|
FlushEvery: 1,
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wd.AddReceiver(statsdReceiver)
|
|
|
|
}
|
|
|
|
|
2017-08-27 18:10:03 +03:00
|
|
|
if sentryAddr != "" {
|
|
|
|
ravenClient, err := raven.New(sentryAddr)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
ravenClient.SetEnvironment("production")
|
|
|
|
ravenClient.SetDefaultLoggerName("sentry-watchdog-receiver")
|
2017-09-02 21:37:16 +03:00
|
|
|
programVersion := GetVersion()
|
|
|
|
if programVersion != "" {
|
|
|
|
raven.SetRelease(programVersion)
|
|
|
|
}
|
2017-08-27 18:10:03 +03:00
|
|
|
|
|
|
|
sentryReceiver, err := sentry.NewReceiverWithCustomRaven(ravenClient, &sentry.Config{
|
|
|
|
MinLevel: "warn",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wd.AddReceiver(sentryReceiver)
|
|
|
|
}
|
|
|
|
|
2017-08-16 15:23:03 +03:00
|
|
|
return wd.New("", "").WithParams(rays.Host), nil
|
|
|
|
}
|
2017-08-17 02:47:35 +03:00
|
|
|
|
|
|
|
type RabbitMQConfig struct {
|
|
|
|
Username string
|
|
|
|
Password string
|
|
|
|
Host string
|
|
|
|
Port int
|
|
|
|
Vhost string
|
|
|
|
}
|
|
|
|
|
2017-09-03 22:45:38 +03:00
|
|
|
func CreateRabbitMQClient(config *RabbitMQConfig) *cony.Client {
|
2017-08-17 02:47:35 +03:00
|
|
|
addr := fmt.Sprintf(
|
|
|
|
"amqp://%s:%s@%s:%d/%s",
|
|
|
|
config.Username,
|
|
|
|
config.Password,
|
|
|
|
config.Host,
|
|
|
|
config.Port,
|
|
|
|
url.PathEscape(config.Vhost),
|
|
|
|
)
|
|
|
|
|
2017-09-03 22:45:38 +03:00
|
|
|
client := cony.NewClient(cony.URL(addr), cony.Backoff(cony.DefaultBackoff))
|
2017-08-17 02:47:35 +03:00
|
|
|
|
2017-09-03 22:45:38 +03:00
|
|
|
return client
|
2017-08-17 02:47:35 +03:00
|
|
|
}
|