mirror of
https://github.com/elyby/chrly.git
synced 2025-05-31 14:11:51 +05:30
Initialize subscribers on app bootstrapping
This commit is contained in:
43
cmd/serve.go
43
cmd/serve.go
@@ -3,6 +3,7 @@ package cmd
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
|
||||
"github.com/mono83/slf/wd"
|
||||
"github.com/spf13/cobra"
|
||||
@@ -10,6 +11,7 @@ import (
|
||||
|
||||
"github.com/elyby/chrly/bootstrap"
|
||||
"github.com/elyby/chrly/db"
|
||||
"github.com/elyby/chrly/eventsubscribers"
|
||||
"github.com/elyby/chrly/http"
|
||||
"github.com/elyby/chrly/mojangtextures"
|
||||
)
|
||||
@@ -18,14 +20,27 @@ var serveCmd = &cobra.Command{
|
||||
Use: "serve",
|
||||
Short: "Starts HTTP handler for the skins system",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
dispatcher := bootstrap.CreateEventDispatcher()
|
||||
|
||||
// TODO: this is a mess, need to organize this code somehow to make services initialization more compact
|
||||
logger, err := bootstrap.CreateLogger(viper.GetString("statsd.addr"), viper.GetString("sentry.dsn"))
|
||||
logger, err := bootstrap.CreateLogger(viper.GetString("sentry.dsn"))
|
||||
if err != nil {
|
||||
log.Fatal(fmt.Printf("Cannot initialize logger: %v", err))
|
||||
log.Fatalf("Cannot initialize logger: %v", err)
|
||||
}
|
||||
logger.Info("Logger successfully initialized")
|
||||
|
||||
dispatcher := bootstrap.CreateEventDispatcher()
|
||||
(&eventsubscribers.Logger{Logger: logger}).ConfigureWithDispatcher(dispatcher)
|
||||
|
||||
statsdAddr := viper.GetString("statsd.addr")
|
||||
if statsdAddr != "" {
|
||||
statsdReporter, err := bootstrap.CreateStatsReceiver(statsdAddr)
|
||||
if err != nil {
|
||||
logger.Emergency("Invalid statsd configuration :err", wd.ErrParam(err))
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
(&eventsubscribers.StatsReporter{StatsReporter: statsdReporter}).ConfigureWithDispatcher(dispatcher)
|
||||
}
|
||||
|
||||
storageFactory := db.StorageFactory{Config: viper.GetViper()}
|
||||
|
||||
@@ -33,8 +48,8 @@ var serveCmd = &cobra.Command{
|
||||
redisFactory := storageFactory.CreateFactory("redis")
|
||||
skinsRepo, err := redisFactory.CreateSkinsRepository()
|
||||
if err != nil {
|
||||
logger.Emergency(fmt.Sprintf("Error on creating skins repo: %+v", err))
|
||||
return
|
||||
logger.Emergency("Error on creating skins repo: :err", wd.ErrParam(err))
|
||||
os.Exit(1)
|
||||
}
|
||||
logger.Info("Skins repository successfully initialized")
|
||||
|
||||
@@ -42,28 +57,28 @@ var serveCmd = &cobra.Command{
|
||||
filesystemFactory := storageFactory.CreateFactory("filesystem")
|
||||
capesRepo, err := filesystemFactory.CreateCapesRepository()
|
||||
if err != nil {
|
||||
logger.Emergency(fmt.Sprintf("Error on creating capes repo: %v", err))
|
||||
return
|
||||
logger.Emergency("Error on creating capes repo: :err", wd.ErrParam(err))
|
||||
os.Exit(1)
|
||||
}
|
||||
logger.Info("Capes repository successfully initialized")
|
||||
|
||||
logger.Info("Preparing Mojang's textures queue")
|
||||
mojangUuidsRepository, err := redisFactory.CreateMojangUuidsRepository()
|
||||
if err != nil {
|
||||
logger.Emergency(fmt.Sprintf("Error on creating mojang uuids repo: %v", err))
|
||||
return
|
||||
logger.Emergency("Error on creating mojang uuids repo: :err", wd.ErrParam(err))
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
uuidsProvider, err := bootstrap.CreateMojangUUIDsProvider(dispatcher)
|
||||
if err != nil {
|
||||
logger.Emergency("Unable to parse remote url :err", wd.ErrParam(err))
|
||||
return
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
texturesStorage := mojangtextures.NewInMemoryTexturesStorage()
|
||||
texturesStorage.Start()
|
||||
mojangTexturesProvider := &mojangtextures.Provider{
|
||||
Emitter: dispatcher,
|
||||
Emitter: dispatcher,
|
||||
UUIDsProvider: uuidsProvider,
|
||||
TexturesProvider: &mojangtextures.MojangApiTexturesProvider{
|
||||
Emitter: dispatcher,
|
||||
@@ -88,16 +103,16 @@ var serveCmd = &cobra.Command{
|
||||
|
||||
finishChan := make(chan bool)
|
||||
go func() {
|
||||
logger.Info(fmt.Sprintf("Starting the app, HTTP on: %s", address))
|
||||
logger.Info("Starting the app, HTTP on: :addr", wd.StringParam("addr", address))
|
||||
if err := http.Serve(address, handler); err != nil {
|
||||
logger.Error(fmt.Sprintf("Error in main(): %v", err))
|
||||
logger.Emergency("Error in main(): :err", wd.ErrParam(err))
|
||||
finishChan <- true
|
||||
}
|
||||
}()
|
||||
|
||||
go func() {
|
||||
s := waitForExitSignal()
|
||||
logger.Info(fmt.Sprintf("Got signal: %v, exiting.", s))
|
||||
logger.Info("Got signal: :signal, exiting", wd.StringParam("signal", s.String()))
|
||||
finishChan <- true
|
||||
}()
|
||||
|
||||
|
@@ -3,12 +3,14 @@ package cmd
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
|
||||
"github.com/mono83/slf/wd"
|
||||
"github.com/spf13/cobra"
|
||||
"github.com/spf13/viper"
|
||||
|
||||
"github.com/elyby/chrly/bootstrap"
|
||||
"github.com/elyby/chrly/eventsubscribers"
|
||||
"github.com/elyby/chrly/http"
|
||||
)
|
||||
|
||||
@@ -16,18 +18,32 @@ var workerCmd = &cobra.Command{
|
||||
Use: "worker",
|
||||
Short: "Starts HTTP handler for the Mojang usernames to UUIDs worker",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
logger, err := bootstrap.CreateLogger(viper.GetString("statsd.addr"), viper.GetString("sentry.dsn"))
|
||||
dispatcher := bootstrap.CreateEventDispatcher()
|
||||
|
||||
// TODO: need to find a way to unify this initialization with the serve command
|
||||
logger, err := bootstrap.CreateLogger(viper.GetString("sentry.dsn"))
|
||||
if err != nil {
|
||||
log.Fatal(fmt.Printf("Cannot initialize logger: %v", err))
|
||||
log.Fatalf("Cannot initialize logger: %v", err)
|
||||
}
|
||||
logger.Info("Logger successfully initialized")
|
||||
|
||||
dispatcher := bootstrap.CreateEventDispatcher()
|
||||
(&eventsubscribers.Logger{Logger: logger}).ConfigureWithDispatcher(dispatcher)
|
||||
|
||||
statsdAddr := viper.GetString("statsd.addr")
|
||||
if statsdAddr != "" {
|
||||
statsdReporter, err := bootstrap.CreateStatsReceiver(statsdAddr)
|
||||
if err != nil {
|
||||
logger.Emergency("Invalid statsd configuration :err", wd.ErrParam(err))
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
(&eventsubscribers.StatsReporter{StatsReporter: statsdReporter}).ConfigureWithDispatcher(dispatcher)
|
||||
}
|
||||
|
||||
uuidsProvider, err := bootstrap.CreateMojangUUIDsProvider(dispatcher)
|
||||
if err != nil {
|
||||
logger.Emergency("Unable to parse remote url :err", wd.ErrParam(err))
|
||||
return
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
address := fmt.Sprintf("%s:%d", viper.GetString("server.host"), viper.GetInt("server.port"))
|
||||
@@ -38,16 +54,16 @@ var workerCmd = &cobra.Command{
|
||||
|
||||
finishChan := make(chan bool)
|
||||
go func() {
|
||||
logger.Info(fmt.Sprintf("Starting the worker, HTTP on: %s", address))
|
||||
logger.Info("Starting the worker, HTTP on: :addr", wd.StringParam("addr", address))
|
||||
if err := http.Serve(address, handler); err != nil {
|
||||
logger.Error(fmt.Sprintf("Error in main(): %v", err))
|
||||
logger.Error("Error in main(): :err", wd.ErrParam(err))
|
||||
finishChan <- true
|
||||
}
|
||||
}()
|
||||
|
||||
go func() {
|
||||
s := waitForExitSignal()
|
||||
logger.Info(fmt.Sprintf("Got signal: %v, exiting.", s))
|
||||
logger.Info("Got signal: :code, exiting.", wd.StringParam("code", s.String()))
|
||||
finishChan <- true
|
||||
}()
|
||||
|
||||
|
Reference in New Issue
Block a user