trustwallet-assets/cmd/main.go

72 lines
1.8 KiB
Go
Raw Normal View History

package main
import (
"flag"
log "github.com/sirupsen/logrus"
"github.com/trustwallet/assets/internal/config"
"github.com/trustwallet/assets/internal/file"
"github.com/trustwallet/assets/internal/processor"
"github.com/trustwallet/assets/internal/report"
"github.com/trustwallet/assets/internal/service"
)
var (
2021-11-23 13:34:25 +00:00
configPath, root, script string
)
func main() {
setup()
paths, err := file.ReadLocalFileStructure(root, config.Default.ValidatorsSettings.RootFolder.SkipFiles)
if err != nil {
log.WithError(err).Fatal("Failed to load file structure.")
}
fileService := file.NewService(paths...)
validatorsService := processor.NewService(fileService)
reportService := report.NewService()
assetfsProcessor := service.NewService(fileService, validatorsService, reportService)
2021-11-23 13:34:25 +00:00
switch script {
2021-12-11 21:30:03 +00:00
case "checker":
assetfsProcessor.RunJob(paths, assetfsProcessor.Check)
2021-12-11 21:30:03 +00:00
case "fixer":
assetfsProcessor.RunJob(paths, assetfsProcessor.Fix)
2021-12-11 21:30:03 +00:00
case "updater-auto":
assetfsProcessor.RunUpdateAuto()
case "updater-manual":
assetfsProcessor.RunUpdateManual()
2021-11-23 13:34:25 +00:00
default:
log.Info("Nothing to launch. Use --script flag to choose a script to run.")
2021-11-23 13:34:25 +00:00
}
reportMsg := reportService.GetReport()
if reportService.IsFailed() {
log.Fatal(reportMsg)
} else {
log.Info(reportMsg)
}
}
func setup() {
flag.StringVar(&configPath, "config", "./.github/assets.config.yaml", "path to config file")
2021-11-23 13:34:25 +00:00
flag.StringVar(&root, "root", "./", "path to the root of the dir")
flag.StringVar(&script, "script", "", "script type to run")
flag.Parse()
if err := config.SetConfig(configPath); err != nil {
log.WithError(err).Fatal("Failed to set config.")
}
logLevel, err := log.ParseLevel(config.Default.App.LogLevel)
if err != nil {
log.WithError(err).Fatal("Failed to parse log level.")
}
log.SetLevel(logLevel)
}