diff --git a/go.mod b/go.mod index f56602e..e88baba 100644 --- a/go.mod +++ b/go.mod @@ -1,3 +1,8 @@ module git.juancwu.dev/juancwu/forgejo-cli go 1.25.6 + +require ( + golang.org/x/sys v0.40.0 // indirect + golang.org/x/term v0.39.0 // indirect +) diff --git a/go.sum b/go.sum new file mode 100644 index 0000000..a4e0649 --- /dev/null +++ b/go.sum @@ -0,0 +1,4 @@ +golang.org/x/sys v0.40.0 h1:DBZZqJ2Rkml6QMQsZywtnjnnGvHza6BTfYFWY9kjEWQ= +golang.org/x/sys v0.40.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks= +golang.org/x/term v0.39.0 h1:RclSuaJf32jOqZz74CkPA9qFuVTX7vhLlpfj/IGWlqY= +golang.org/x/term v0.39.0/go.mod h1:yxzUCTP/U+FzoxfdKmLaA0RV1WgE0VY7hXBwKtY/4ww= diff --git a/internal/cli/cli.go b/internal/cli/cli.go index be3941f..4d8fdd7 100644 --- a/internal/cli/cli.go +++ b/internal/cli/cli.go @@ -2,6 +2,7 @@ package cli import ( "flag" + "fmt" "git.juancwu.dev/juancwu/forgejo-cli/internal/config" ) @@ -10,10 +11,36 @@ func Run() error { var configPath string flag.StringVar(&configPath, "config", "", "Configuration file path") - _, err := config.Load(configPath) + cfg, err := config.Load(configPath) if err != nil { return err } + if cfg.ForgejoInstanceURL == "" { + err := onboard(cfg) + if err != nil { + return err + } + } + + return nil +} + +// onboard asks the user for the Forgejo instance URL and save it to the config file. +func onboard(cfg *config.Config) error { + var url string + + fmt.Print("Enter Forgejo instance URL: ") + _, err := fmt.Scanln(&url) + if err != nil { + return fmt.Errorf("failed to read url: %w", err) + } + + cfg.ForgejoInstanceURL = url + err = cfg.Save("") + if err != nil { + return fmt.Errorf("failed to save config: %w", err) + } + return nil }