mirror of
https://github.com/Instadapp/trustwallet-assets.git
synced 2024-07-29 22:37:31 +00:00
156 lines
4.0 KiB
Go
156 lines
4.0 KiB
Go
|
package manager
|
||
|
|
||
|
import (
|
||
|
"os"
|
||
|
|
||
|
"github.com/trustwallet/assets-go-libs/path"
|
||
|
"github.com/trustwallet/go-primitives/asset"
|
||
|
"github.com/trustwallet/go-primitives/coin"
|
||
|
|
||
|
"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"
|
||
|
|
||
|
log "github.com/sirupsen/logrus"
|
||
|
"github.com/spf13/cobra"
|
||
|
)
|
||
|
|
||
|
var configPath, root string
|
||
|
|
||
|
func InitCommands() {
|
||
|
rootCmd.Flags().StringVar(&configPath, "config", ".github/assets.config.yaml",
|
||
|
"config file (default is $HOME/.github/assets.config.yaml)")
|
||
|
rootCmd.Flags().StringVar(&root, "root", ".", "root path to files")
|
||
|
|
||
|
rootCmd.AddCommand(checkCmd)
|
||
|
rootCmd.AddCommand(fixCmd)
|
||
|
rootCmd.AddCommand(updateAutoCmd)
|
||
|
rootCmd.AddCommand(addTokenCmd)
|
||
|
rootCmd.AddCommand(addTokenlistCmd)
|
||
|
rootCmd.AddCommand(addTokenlistExtendedCmd)
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
rootCmd = &cobra.Command{
|
||
|
Use: "assets",
|
||
|
Short: "",
|
||
|
Long: "",
|
||
|
Run: func(cmd *cobra.Command, args []string) {},
|
||
|
}
|
||
|
checkCmd = &cobra.Command{
|
||
|
Use: "check",
|
||
|
Short: " Execute validation checks",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
assetsService := InitAssetsService()
|
||
|
assetsService.RunJob(assetsService.Check)
|
||
|
},
|
||
|
}
|
||
|
fixCmd = &cobra.Command{
|
||
|
Use: "fix",
|
||
|
Short: "Perform automatic fixes where possible",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
assetsService := InitAssetsService()
|
||
|
assetsService.RunJob(assetsService.Fix)
|
||
|
},
|
||
|
}
|
||
|
updateAutoCmd = &cobra.Command{
|
||
|
Use: "update-auto",
|
||
|
Short: "Run automatic updates from external sources",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
assetsService := InitAssetsService()
|
||
|
assetsService.RunUpdateAuto()
|
||
|
},
|
||
|
}
|
||
|
|
||
|
addTokenCmd = &cobra.Command{
|
||
|
Use: "add-token",
|
||
|
Short: "Creates info.json template for the asset",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
if len(args) != 1 {
|
||
|
log.Fatal("1 argument was expected")
|
||
|
}
|
||
|
|
||
|
err := CreateAssetInfoJSONTemplate(args[0])
|
||
|
if err != nil {
|
||
|
log.Fatalf("Can't create asset info json template: %v", err)
|
||
|
}
|
||
|
},
|
||
|
}
|
||
|
|
||
|
addTokenlistCmd = &cobra.Command{
|
||
|
Use: "add-tokenlist",
|
||
|
Short: "Adds token to tokenlist.json",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
handleAddTokenList(args, path.TokenlistDefault)
|
||
|
},
|
||
|
}
|
||
|
|
||
|
addTokenlistExtendedCmd = &cobra.Command{
|
||
|
Use: "add-tokenlist-extended",
|
||
|
Short: "Adds token to tokenlist-extended.json",
|
||
|
Run: func(cmd *cobra.Command, args []string) {
|
||
|
handleAddTokenList(args, path.TokenlistExtended)
|
||
|
},
|
||
|
}
|
||
|
)
|
||
|
|
||
|
func handleAddTokenList(args []string, tokenlistType path.TokenListType) {
|
||
|
if len(args) != 1 {
|
||
|
log.Fatal("1 argument was expected")
|
||
|
}
|
||
|
|
||
|
c, tokenID, err := asset.ParseID(args[0])
|
||
|
if err != nil {
|
||
|
log.Fatalf("Can't parse token: %v", err)
|
||
|
}
|
||
|
|
||
|
chain, ok := coin.Coins[c]
|
||
|
if !ok {
|
||
|
log.Fatal("Invalid token")
|
||
|
}
|
||
|
|
||
|
err = AddTokenToTokenListJSON(chain, args[0], tokenID, tokenlistType)
|
||
|
if err != nil {
|
||
|
log.Fatalf("Can't add token: %v", err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func InitAssetsService() *service.Service {
|
||
|
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()
|
||
|
|
||
|
return service.NewService(fileService, validatorsService, reportService, paths)
|
||
|
}
|
||
|
|
||
|
func setup() {
|
||
|
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)
|
||
|
}
|
||
|
|
||
|
// Execute adds all child commands to the root command and sets flags appropriately.
|
||
|
// This is called by main.main(). It only needs to happen once to the rootCmd.
|
||
|
func Execute() {
|
||
|
err := rootCmd.Execute()
|
||
|
if err != nil {
|
||
|
os.Exit(1)
|
||
|
}
|
||
|
}
|