2017-06-30 18:40:25 +03:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2017-08-10 03:14:28 +03:00
|
|
|
"fmt"
|
2017-08-16 15:23:03 +03:00
|
|
|
"log"
|
2020-04-04 19:14:12 +03:00
|
|
|
"os"
|
2017-06-30 18:40:25 +03:00
|
|
|
|
2019-11-24 04:07:56 +03:00
|
|
|
"github.com/mono83/slf/wd"
|
2017-06-30 18:40:25 +03:00
|
|
|
"github.com/spf13/cobra"
|
2017-08-14 21:06:22 +03:00
|
|
|
"github.com/spf13/viper"
|
2017-08-10 03:14:28 +03:00
|
|
|
|
2018-02-16 00:13:57 +03:00
|
|
|
"github.com/elyby/chrly/bootstrap"
|
|
|
|
"github.com/elyby/chrly/db"
|
2020-04-04 19:14:12 +03:00
|
|
|
"github.com/elyby/chrly/eventsubscribers"
|
2018-02-16 00:13:57 +03:00
|
|
|
"github.com/elyby/chrly/http"
|
2019-11-21 01:33:13 +03:00
|
|
|
"github.com/elyby/chrly/mojangtextures"
|
2017-06-30 18:40:25 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
var serveCmd = &cobra.Command{
|
|
|
|
Use: "serve",
|
2020-01-03 00:51:57 +03:00
|
|
|
Short: "Starts HTTP handler for the skins system",
|
2017-06-30 18:40:25 +03:00
|
|
|
Run: func(cmd *cobra.Command, args []string) {
|
2020-04-04 19:14:12 +03:00
|
|
|
dispatcher := bootstrap.CreateEventDispatcher()
|
|
|
|
|
2019-11-24 04:07:56 +03:00
|
|
|
// TODO: this is a mess, need to organize this code somehow to make services initialization more compact
|
2020-04-04 19:14:12 +03:00
|
|
|
logger, err := bootstrap.CreateLogger(viper.GetString("sentry.dsn"))
|
2017-08-16 15:23:03 +03:00
|
|
|
if err != nil {
|
2020-04-04 19:14:12 +03:00
|
|
|
log.Fatalf("Cannot initialize logger: %v", err)
|
2017-08-16 15:23:03 +03:00
|
|
|
}
|
|
|
|
logger.Info("Logger successfully initialized")
|
2017-06-30 18:40:25 +03:00
|
|
|
|
2020-04-04 19:14:12 +03:00
|
|
|
(&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)
|
|
|
|
}
|
2020-02-08 14:31:47 +03:00
|
|
|
|
2017-08-14 21:06:22 +03:00
|
|
|
storageFactory := db.StorageFactory{Config: viper.GetViper()}
|
|
|
|
|
|
|
|
logger.Info("Initializing skins repository")
|
2019-04-27 01:46:15 +03:00
|
|
|
redisFactory := storageFactory.CreateFactory("redis")
|
|
|
|
skinsRepo, err := redisFactory.CreateSkinsRepository()
|
2017-06-30 18:40:25 +03:00
|
|
|
if err != nil {
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Emergency("Error on creating skins repo: :err", wd.ErrParam(err))
|
|
|
|
os.Exit(1)
|
2017-06-30 18:40:25 +03:00
|
|
|
}
|
2017-08-14 21:06:22 +03:00
|
|
|
logger.Info("Skins repository successfully initialized")
|
2017-06-30 18:40:25 +03:00
|
|
|
|
2017-08-14 21:06:22 +03:00
|
|
|
logger.Info("Initializing capes repository")
|
2019-04-27 01:46:15 +03:00
|
|
|
filesystemFactory := storageFactory.CreateFactory("filesystem")
|
|
|
|
capesRepo, err := filesystemFactory.CreateCapesRepository()
|
2017-06-30 18:40:25 +03:00
|
|
|
if err != nil {
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Emergency("Error on creating capes repo: :err", wd.ErrParam(err))
|
|
|
|
os.Exit(1)
|
2017-06-30 18:40:25 +03:00
|
|
|
}
|
2017-08-14 21:06:22 +03:00
|
|
|
logger.Info("Capes repository successfully initialized")
|
2017-06-30 18:40:25 +03:00
|
|
|
|
2019-04-27 01:46:15 +03:00
|
|
|
logger.Info("Preparing Mojang's textures queue")
|
|
|
|
mojangUuidsRepository, err := redisFactory.CreateMojangUuidsRepository()
|
|
|
|
if err != nil {
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Emergency("Error on creating mojang uuids repo: :err", wd.ErrParam(err))
|
|
|
|
os.Exit(1)
|
2019-04-27 01:46:15 +03:00
|
|
|
}
|
|
|
|
|
2020-02-08 14:31:47 +03:00
|
|
|
uuidsProvider, err := bootstrap.CreateMojangUUIDsProvider(dispatcher)
|
2020-01-03 00:51:57 +03:00
|
|
|
if err != nil {
|
|
|
|
logger.Emergency("Unable to parse remote url :err", wd.ErrParam(err))
|
2020-04-04 19:14:12 +03:00
|
|
|
os.Exit(1)
|
2019-11-24 04:07:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
texturesStorage := mojangtextures.NewInMemoryTexturesStorage()
|
|
|
|
texturesStorage.Start()
|
|
|
|
mojangTexturesProvider := &mojangtextures.Provider{
|
2020-04-04 19:14:12 +03:00
|
|
|
Emitter: dispatcher,
|
2020-01-03 00:51:57 +03:00
|
|
|
UUIDsProvider: uuidsProvider,
|
2019-11-21 01:33:13 +03:00
|
|
|
TexturesProvider: &mojangtextures.MojangApiTexturesProvider{
|
2020-02-08 14:31:47 +03:00
|
|
|
Emitter: dispatcher,
|
2019-11-21 01:33:13 +03:00
|
|
|
},
|
|
|
|
Storage: &mojangtextures.SeparatedStorage{
|
2019-04-27 01:46:15 +03:00
|
|
|
UuidsStorage: mojangUuidsRepository,
|
2019-06-19 00:56:09 +03:00
|
|
|
TexturesStorage: texturesStorage,
|
2019-04-27 01:46:15 +03:00
|
|
|
},
|
|
|
|
}
|
|
|
|
logger.Info("Mojang's textures queue is successfully initialized")
|
|
|
|
|
2020-01-29 01:34:15 +03:00
|
|
|
address := fmt.Sprintf("%s:%d", viper.GetString("server.host"), viper.GetInt("server.port"))
|
|
|
|
handler := (&http.Skinsystem{
|
2020-02-08 14:31:47 +03:00
|
|
|
Emitter: dispatcher,
|
2020-01-06 00:16:38 +03:00
|
|
|
SkinsRepo: skinsRepo,
|
|
|
|
CapesRepo: capesRepo,
|
|
|
|
MojangTexturesProvider: mojangTexturesProvider,
|
2020-02-16 13:23:47 +03:00
|
|
|
Authenticator: &http.JwtAuth{Key: []byte(viper.GetString("chrly.secret"))},
|
2020-01-06 00:16:38 +03:00
|
|
|
TexturesExtraParamName: viper.GetString("textures.extra_param_name"),
|
|
|
|
TexturesExtraParamValue: viper.GetString("textures.extra_param_value"),
|
2020-01-29 01:34:15 +03:00
|
|
|
}).CreateHandler()
|
2017-06-30 18:40:25 +03:00
|
|
|
|
2020-01-05 20:39:17 +03:00
|
|
|
finishChan := make(chan bool)
|
|
|
|
go func() {
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Info("Starting the app, HTTP on: :addr", wd.StringParam("addr", address))
|
2020-01-29 01:34:15 +03:00
|
|
|
if err := http.Serve(address, handler); err != nil {
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Emergency("Error in main(): :err", wd.ErrParam(err))
|
2020-01-05 20:39:17 +03:00
|
|
|
finishChan <- true
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
s := waitForExitSignal()
|
2020-04-04 19:14:12 +03:00
|
|
|
logger.Info("Got signal: :signal, exiting", wd.StringParam("signal", s.String()))
|
2020-01-05 20:39:17 +03:00
|
|
|
finishChan <- true
|
|
|
|
}()
|
|
|
|
|
|
|
|
<-finishChan
|
2017-06-30 18:40:25 +03:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
RootCmd.AddCommand(serveCmd)
|
2018-02-15 14:20:17 +03:00
|
|
|
viper.SetDefault("server.host", "")
|
|
|
|
viper.SetDefault("server.port", 80)
|
|
|
|
viper.SetDefault("storage.redis.host", "localhost")
|
|
|
|
viper.SetDefault("storage.redis.port", 6379)
|
|
|
|
viper.SetDefault("storage.redis.poll", 10)
|
|
|
|
viper.SetDefault("storage.filesystem.basePath", "data")
|
|
|
|
viper.SetDefault("storage.filesystem.capesDirName", "capes")
|
2017-06-30 18:40:25 +03:00
|
|
|
}
|