refactor: simplify config into a single load/save with defaults resolved at load time

This commit is contained in:
2026-06-12 01:21:04 +02:00
parent 7b8202b50b
commit 6421c28191
7 changed files with 132 additions and 187 deletions
+35 -11
View File
@@ -4,6 +4,7 @@ import (
"axolotl/store"
"fmt"
"os"
"slices"
"github.com/spf13/cobra"
)
@@ -15,21 +16,32 @@ var aliasCmd = &cobra.Command{
Run: func(cmd *cobra.Command, args []string) {
w := cmd.OutOrStdout()
if len(args) == 0 {
if aliases, err := cfg.ListAliases(); err == nil {
PrintAliases(w, aliases, jsonFlag)
}
PrintAliases(w, cfg.Aliases, jsonFlag)
return
}
if len(args) == 1 {
a, err := cfg.GetAlias(args[0])
if err != nil {
fmt.Fprintln(os.Stderr, "alias not found:", args[0])
os.Exit(1)
for _, a := range cfg.Aliases {
if a.Name == args[0] {
fmt.Println(a.Command)
return
}
}
fmt.Println(a.Command)
return
fmt.Fprintln(os.Stderr, "alias not found:", args[0])
os.Exit(1)
}
if err := cfg.SetAlias(&store.Alias{Name: args[0], Command: args[1], Description: aliasDesc}); err != nil {
alias := &store.Alias{Name: args[0], Command: args[1], Description: aliasDesc}
found := false
for i, a := range cfg.Aliases {
if a.Name == alias.Name {
cfg.Aliases[i] = alias
found = true
break
}
}
if !found {
cfg.Aliases = append(cfg.Aliases, alias)
}
if err := cfg.Save(); err != nil {
fmt.Fprintln(os.Stderr, "failed to set alias:", err)
} else {
PrintAction(w, "Alias set", args[0], false)
@@ -40,7 +52,19 @@ var aliasCmd = &cobra.Command{
var aliasDelCmd = &cobra.Command{
Use: "del <name>", Short: "Delete an alias", Args: cobra.ExactArgs(1),
Run: func(cmd *cobra.Command, args []string) {
if err := cfg.DeleteAlias(args[0]); err != nil {
found := false
for i, a := range cfg.Aliases {
if a.Name == args[0] {
cfg.Aliases = slices.Delete(cfg.Aliases, i, i+1)
found = true
break
}
}
if !found {
fmt.Fprintln(os.Stderr, "alias not found")
os.Exit(1)
}
if err := cfg.Save(); err != nil {
fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
+1 -1
View File
@@ -33,7 +33,7 @@ var editCmd = &cobra.Command{
tmp.Close()
defer os.Remove(tmp.Name())
c := exec.Command(cfg.GetEditor(), tmp.Name())
c := exec.Command(cfg.Editor, tmp.Name())
c.Stdin, c.Stdout, c.Stderr = os.Stdin, os.Stdout, os.Stderr
if err := c.Run(); err != nil {
fmt.Fprintln(os.Stderr, "editor failed:", err)
+2 -3
View File
@@ -15,12 +15,11 @@ var loginCmd = &cobra.Command{
Use: "login",
Short: "Authenticate with the remote server via OIDC",
Run: func(cmd *cobra.Command, args []string) {
rc, ok := cfg.GetRemoteConfig()
if !ok {
if cfg.Remote.Host == "" {
fmt.Fprintln(os.Stderr, "no remote server configured; set remote.host in your config")
os.Exit(1)
}
base := fmt.Sprintf("http://%s:%d", rc.Host, rc.Port)
base := fmt.Sprintf("http://%s:%d", cfg.Remote.Host, cfg.Remote.Port)
sessionID := tryDeviceFlow(base)
if sessionID == "" {
+6 -6
View File
@@ -12,12 +12,12 @@ import (
)
func getNodeService() (service.NodeService, error) {
user := cfg.GetUser()
user := cfg.User
if user == "" {
return nil, fmt.Errorf("no user configured: run 'ax user set <username>' first")
}
if rc, ok := cfg.GetRemoteConfig(); ok {
base := fmt.Sprintf("http://%s:%d", rc.Host, rc.Port)
if cfg.Remote.Host != "" {
base := fmt.Sprintf("http://%s:%d", cfg.Remote.Host, cfg.Remote.Port)
return service.NewRemoteNodeService(base, user), nil
}
st, err := store.FindAndOpenSQLiteStore()
@@ -33,7 +33,7 @@ var rootCmd = &cobra.Command{Use: "ax", Short: "The axolotl issue tracker"}
func Execute() {
var err error
cfg, err = store.LoadConfigFile()
cfg, err = store.LoadConfig()
if err != nil {
fmt.Fprintln(os.Stderr, "failed to load config:", err)
os.Exit(1)
@@ -50,7 +50,7 @@ func init() {
func RegisterAliasCommands() {
rootCmd.AddGroup(&cobra.Group{ID: "aliases", Title: "Aliases:"})
aliases, _ := cfg.ListAliases()
aliases := cfg.Aliases
for _, a := range aliases {
rootCmd.AddCommand(&cobra.Command{
Use: a.Name,
@@ -59,7 +59,7 @@ func RegisterAliasCommands() {
DisableFlagParsing: true,
Run: func(ccmd *cobra.Command, args []string) {
acmd := a.Command
acmd = strings.ReplaceAll(acmd, "$me", cfg.GetUser())
acmd = strings.ReplaceAll(acmd, "$me", cfg.User)
parts := strings.Fields(acmd)
var expanded []string
usedArgs := make([]bool, len(args))
+3 -4
View File
@@ -16,12 +16,11 @@ var serveCmd = &cobra.Command{
Use: "serve",
Short: "Start the JSON API server",
Run: func(cmd *cobra.Command, args []string) {
sc := cfg.GetServerConfig()
addr := fmt.Sprintf("%s:%d", sc.Host, sc.Port)
addr := fmt.Sprintf("%s:%d", cfg.Serve.Host, cfg.Serve.Port)
var oidcCfg *store.OIDCConfig
if oc, ok := cfg.GetOIDCConfig(); ok {
oidcCfg = oc
if cfg.OIDC.Issuer != "" {
oidcCfg = &cfg.OIDC
}
handler, err := serve.New(func(user string) (service.NodeService, error) {