refactor: retirer serpents et réimplémenter cobra+viper

Package ne suivait pas les mises à jour sur cobra et viper, leur
utilisation decoupled devrait être plus solide.
This commit is contained in:
Victor Lacasse-Beaudoin 2024-09-16 14:31:30 -04:00
parent 3cae1789b9
commit 0da02e98e3
3 changed files with 134 additions and 123 deletions

View file

@ -2,10 +2,10 @@ package cmd
import (
"fmt"
"log"
"os"
"strings"
"codeberg.org/vlbeaudoin/serpents"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
@ -33,94 +33,112 @@ func init() {
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.bottin-agenda.yaml)")
// web.api.host
serpents.String(rootCmd.PersistentFlags(),
"web.api.host", "web-api-host", "api",
"Remote API server host")
rootCmd.PersistentFlags().String("web-api-host", "api", "Remote API server host")
if err := viper.BindPFlag("web.api.host", rootCmd.PersistentFlags().Lookup("web-api-host")); err != nil {
log.Fatal(err)
}
// web.api.key
serpents.String(rootCmd.PersistentFlags(),
"web.api.key", "web-api-key", "bottin-agenda",
"Remote API server key")
rootCmd.PersistentFlags().String("web-api-key", "bottin-agenda", "Remote API server key")
if err := viper.BindPFlag("web.api.key", rootCmd.PersistentFlags().Lookup("web-api-key")); err != nil {
log.Fatal(err)
}
// web.api.protocol
serpents.String(rootCmd.PersistentFlags(),
"web.api.protocol", "web-api-protocol", "http",
"Remote API server protocol")
rootCmd.PersistentFlags().String("web-api-protocol", "http", "Remote API server protocol")
if err := viper.BindPFlag("web.api.protocol", rootCmd.PersistentFlags().Lookup("web-api-protocol")); err != nil {
log.Fatal(err)
}
// web.api.port
serpents.Int(rootCmd.PersistentFlags(),
"web.api.port", "web-api-port", 1313,
"Remote API server port")
rootCmd.PersistentFlags().Int("web-api-port", 1313, "Remote API server port")
if err := viper.BindPFlag("web.api.port", rootCmd.PersistentFlags().Lookup("web-api-port")); err != nil {
log.Fatal(err)
}
// web.password
serpents.String(rootCmd.PersistentFlags(),
"web.password", "web-password", "bottin-agenda",
"Web client password")
rootCmd.PersistentFlags().String("web-password", "bottin-agenda", "Web client password")
if err := viper.BindPFlag("web.password", rootCmd.PersistentFlags().Lookup("web-password")); err != nil {
log.Fatal(err)
}
// web.port
serpents.Int(rootCmd.PersistentFlags(),
"web.port", "web-port", 2313,
"Web client port")
rootCmd.PersistentFlags().Int("web-port", 2313, "Web client port")
if err := viper.BindPFlag("web.port", rootCmd.PersistentFlags().Lookup("web-port")); err != nil {
log.Fatal(err)
}
// web.user
serpents.String(rootCmd.PersistentFlags(),
"web.user", "web-user", "bottin-agenda",
"Web client user")
rootCmd.PersistentFlags().String("web-user", "bottin-agenda", "Web client user")
if err := viper.BindPFlag("web.user", rootCmd.PersistentFlags().Lookup("web-user")); err != nil {
log.Fatal(err)
}
// api.key
serpents.String(rootCmd.PersistentFlags(),
"api.key", "api-key", "bottin-agenda",
"API server key. Leave empty for no key auth.")
rootCmd.PersistentFlags().String("api-key", "bottin-agenda", "API server key. Leave empty for no key auth.")
if err := viper.BindPFlag("api.key", rootCmd.PersistentFlags().Lookup("api-key")); err != nil {
log.Fatal(err)
}
// api.port
serpents.Int(rootCmd.PersistentFlags(),
"api.port", "api-port", 1313,
"API server port")
rootCmd.PersistentFlags().Int("api-port", 1313, "API server port")
if err := viper.BindPFlag("api.port", rootCmd.PersistentFlags().Lookup("api-port")); err != nil {
log.Fatal(err)
}
// bottin.api.host
serpents.String(rootCmd.PersistentFlags(),
"bottin.api.host", "bottin-api-host", "api",
"Remote bottin API server host")
rootCmd.PersistentFlags().String("bottin-api-host", "api", "Remote bottin API server host")
if err := viper.BindPFlag("bottin.api.host", rootCmd.PersistentFlags().Lookup("bottin-api-host")); err != nil {
log.Fatal(err)
}
// bottin.api.key
serpents.String(rootCmd.PersistentFlags(),
"bottin.api.key", "bottin-api-key", "bottin",
"Remote bottin API server key")
rootCmd.PersistentFlags().String("bottin-api-key", "bottin", "Remote bottin API server key")
if err := viper.BindPFlag("bottin.api.key", rootCmd.PersistentFlags().Lookup("bottin-api-key")); err != nil {
log.Fatal(err)
}
// bottin.api.protocol
serpents.String(rootCmd.PersistentFlags(),
"bottin.api.protocol", "bottin-api-protocol", "http",
"Remote bottin API server protocol")
rootCmd.PersistentFlags().String("bottin-api-protocol", "http", "Remote bottin API server protocol")
if err := viper.BindPFlag("bottin.api.protocol", rootCmd.PersistentFlags().Lookup("bottin-api-protocol")); err != nil {
log.Fatal(err)
}
// bottin.api.port
serpents.Int(rootCmd.PersistentFlags(),
"bottin.api.port", "bottin-api-port", 1312,
"Remote bottin API server port")
rootCmd.PersistentFlags().Int("bottin-api-port", 1312, "Remote bottin API server port")
if err := viper.BindPFlag("bottin.api.port", rootCmd.PersistentFlags().Lookup("bottin-api-port")); err != nil {
log.Fatal(err)
}
// db.database
serpents.String(rootCmd.PersistentFlags(),
"db.database", "db-database", "bottin-agenda",
"Postgres database")
rootCmd.PersistentFlags().String("db-database", "bottin-agenda", "Postgres database")
if err := viper.BindPFlag("db.database", rootCmd.PersistentFlags().Lookup("db-database")); err != nil {
log.Fatal(err)
}
// db.host
serpents.String(rootCmd.PersistentFlags(),
"db.host", "db-host", "db",
"Postgres host")
rootCmd.PersistentFlags().String("db-host", "db", "Postgres host")
if err := viper.BindPFlag("db.host", rootCmd.PersistentFlags().Lookup("db-host")); err != nil {
log.Fatal(err)
}
// db.password
serpents.String(rootCmd.PersistentFlags(),
"db.password", "db-password", "bottin-agenda",
"Postgres password")
rootCmd.PersistentFlags().String("db-password", "bottin-agenda", "Postgres password")
if err := viper.BindPFlag("db.password", rootCmd.PersistentFlags().Lookup("db-password")); err != nil {
log.Fatal(err)
}
// db.port
serpents.Int(rootCmd.PersistentFlags(),
"db.port", "db-port", 5432,
"Postgres port")
rootCmd.PersistentFlags().Int("db-port", 5432, "Postgres port")
if err := viper.BindPFlag("db.port", rootCmd.PersistentFlags().Lookup("db-port")); err != nil {
log.Fatal(err)
}
// db.user
serpents.String(rootCmd.PersistentFlags(),
"db.user", "db-user", "bottin-agenda",
"Postgres user")
rootCmd.PersistentFlags().String("db-user", "bottin-agenda", "Postgres user")
if err := viper.BindPFlag("db.user", rootCmd.PersistentFlags().Lookup("db-user")); err != nil {
log.Fatal(err)
}
}
// initConfig reads in config file and ENV variables if set.