X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/23411fc23dcf82e0ed35a780bfdda2341bedf819..fd01ba0e7e10dc67ac12afb55e91d909727cfcbf:/cmd/mobius-hotline-server/main.go?ds=sidebyside diff --git a/cmd/mobius-hotline-server/main.go b/cmd/mobius-hotline-server/main.go index 8a3135e..2f914c4 100644 --- a/cmd/mobius-hotline-server/main.go +++ b/cmd/mobius-hotline-server/main.go @@ -2,6 +2,7 @@ package main import ( "context" + "embed" "encoding/json" "flag" "fmt" @@ -14,9 +15,13 @@ import ( "net/http" "os" "runtime" + "strings" "time" ) +//go:embed mobius/config +var cfgTemplate embed.FS + const ( defaultPort = 5500 ) @@ -31,6 +36,8 @@ func main() { configDir := flag.String("config", defaultConfigPath(), "Path to config root") version := flag.Bool("version", false, "print version and exit") logLevel := flag.String("log-level", "info", "Log level") + init := flag.Bool("init", false, "Populate the config dir with default configuration") + flag.Parse() if *version { @@ -49,6 +56,26 @@ func main() { defer func() { _ = l.Sync() }() logger := l.Sugar() + if !(strings.HasSuffix(*configDir, "/") || strings.HasSuffix(*configDir, "\\")) { + *configDir = *configDir + "/" + } + + if *init { + if _, err := os.Stat(*configDir + "/config.yaml"); os.IsNotExist(err) { + if err := os.MkdirAll(*configDir, 0750); err != nil { + logger.Fatal(err) + } + + if err := copyDir("mobius/config", *configDir); err != nil { + logger.Fatal(err) + } + logger.Infow("Config dir initialized at " + *configDir) + + } else { + logger.Infow("Existing config dir found. Skipping initialization.") + } + } + if _, err := os.Stat(*configDir); os.IsNotExist(err) { logger.Fatalw("Configuration directory not found", "path", configDir) } @@ -110,7 +137,7 @@ var zapLogLevel = map[string]zapcore.Level{ func defaultConfigPath() (cfgPath string) { switch runtime.GOOS { case "windows": - cfgPath = "config" + cfgPath = "config/" case "darwin": if _, err := os.Stat("/usr/local/var/mobius/config/"); err == nil { cfgPath = "/usr/local/var/mobius/config/" @@ -125,3 +152,53 @@ func defaultConfigPath() (cfgPath string) { return cfgPath } + +// TODO: Simplify this mess. Why is it so difficult to recursively copy a directory? +func copyDir(src, dst string) error { + entries, err := cfgTemplate.ReadDir(src) + if err != nil { + return err + } + for _, dirEntry := range entries { + if dirEntry.IsDir() { + if err := os.MkdirAll(dst+"/"+dirEntry.Name(), 0777); err != nil { + panic(err) + } + subdirEntries, _ := cfgTemplate.ReadDir(src + "/" + dirEntry.Name()) + for _, subDirEntry := range subdirEntries { + f, err := os.Create(dst + "/" + dirEntry.Name() + "/" + subDirEntry.Name()) + if err != nil { + return err + } + + srcFile, err := cfgTemplate.Open(src + "/" + dirEntry.Name() + "/" + subDirEntry.Name()) + if err != nil { + return err + } + _, err = io.Copy(f, srcFile) + if err != nil { + return err + } + f.Close() + } + } else { + f, err := os.Create(dst + "/" + dirEntry.Name()) + if err != nil { + return err + } + + srcFile, err := cfgTemplate.Open(src + "/" + dirEntry.Name()) + if err != nil { + return err + } + _, err = io.Copy(f, srcFile) + if err != nil { + return err + } + f.Close() + } + + } + + return nil +}