rework: config and cmd
Renamed `web` command to `server ui` (web is still an alias to ui) Completely changed the config options and flags Usage of PersistentFlags now allow clearer `--help` BREAKING: cmd modified BREAKING: config overhauled BREAKING: Bump API to v8
This commit is contained in:
parent
e14ff3d04e
commit
eb1982898c
8 changed files with 475 additions and 346 deletions
664
config.go
664
config.go
|
@ -10,278 +10,52 @@ import (
|
|||
"github.com/spf13/viper"
|
||||
)
|
||||
|
||||
const (
|
||||
ViperAPITLSEnabled string = "api.tls.enabled"
|
||||
FlagAPITLSEnabled string = "api-tls-enabled"
|
||||
DefaultAPITLSEnabled bool = false
|
||||
DescriptionAPITLSEnabled string = "Whether to use TLS or not. Requires certificate and private key files."
|
||||
|
||||
ViperAPITLSCertfile string = "api.tls.certfile"
|
||||
FlagAPITLSCertfile string = "api-tls-certfile"
|
||||
DefaultAPITLSCertfile string = "/etc/bottin/cert.pem"
|
||||
DescriptionAPITLSCertfile string = "Path to TLS certificate file"
|
||||
|
||||
ViperAPITLSKeyfile string = "api.tls.keyfile"
|
||||
FlagAPITLSKeyfile string = "api-tls-keyfile"
|
||||
DefaultAPITLSKeyfile string = "/etc/bottin/key.pem"
|
||||
DescriptionAPITLSKeyFile string = "Path to TLS private key file"
|
||||
|
||||
ViperAPIPort string = "api.port"
|
||||
FlagAPIPort string = "api-port"
|
||||
DefaultAPIPort int = 1312
|
||||
DescriptionAPIPort string = "API server port"
|
||||
|
||||
ViperAPIKey string = "api.key"
|
||||
FlagAPIKey string = "api-key"
|
||||
DefaultAPIKey string = "bottin"
|
||||
DescriptionAPIKey string = "API server key. Leave empty for no key auth (not recommended)"
|
||||
|
||||
ViperDBDatabase string = "db.database"
|
||||
FlagDBDatabase string = "db-database"
|
||||
DefaultDBDatabase string = "bottin"
|
||||
DescriptionDBDatabase string = "Postgres database"
|
||||
|
||||
ViperDBSSLMode string = "db.sslmode"
|
||||
FlagDBSSLMode string = "db-sslmode"
|
||||
DefaultDBSSLMode string = "prefer"
|
||||
DescriptionDBSSLMode string = "Postgres sslmode"
|
||||
|
||||
ViperDBHost string = "db.host"
|
||||
FlagDBHost string = "db-host"
|
||||
DefaultDBHost string = "db"
|
||||
DescriptionDBHost string = "Postgres host"
|
||||
|
||||
ViperDBPassword string = "db.password"
|
||||
FlagDBPassword string = "db-password"
|
||||
DefaultDBPassword string = "bottin"
|
||||
DescriptionDBPassword string = "Postgres password"
|
||||
|
||||
ViperDBPort string = "db.port"
|
||||
FlagDBPort string = "db-port"
|
||||
DefaultDBPort int = 5432
|
||||
DescriptionDBPort string = "Postgres port"
|
||||
|
||||
ViperDBUser string = "db.user"
|
||||
FlagDBUser string = "db-user"
|
||||
DefaultDBUser string = "bottin"
|
||||
DescriptionDBUser string = "Postgres user"
|
||||
|
||||
ViperWebUser string = "web.user"
|
||||
FlagWebUser string = "web-user"
|
||||
DefaultWebUser string = "bottin"
|
||||
DescriptionWebUser string = "Web client basic auth user"
|
||||
|
||||
ViperWebPassword string = "web.password"
|
||||
FlagWebPassword string = "web-password"
|
||||
DefaultWebPassword string = "bottin"
|
||||
DescriptionWebPassword string = "Web client basic auth password"
|
||||
|
||||
ViperWebPort string = "web.port"
|
||||
FlagWebPort string = "web-port"
|
||||
DefaultWebPort int = 2312
|
||||
DescriptionWebPort string = "Web client port"
|
||||
|
||||
ViperWebAPIHost string = "web.api.host"
|
||||
FlagWebAPIHost string = "web-api-host"
|
||||
DefaultWebAPIHost string = "api"
|
||||
DescriptionWebAPIHost string = "Target API server host"
|
||||
|
||||
ViperWebAPIKey string = "web.api.key"
|
||||
FlagWebAPIKey string = "web-api-key"
|
||||
DefaultWebAPIKey string = "bottin"
|
||||
DescriptionWebAPIKey string = "Target API server key"
|
||||
|
||||
ViperWebAPIPort string = "web.api.port"
|
||||
FlagWebAPIPort string = "web-api-port"
|
||||
DefaultWebAPIPort int = 1312
|
||||
DescriptionWebAPIPort string = "Target API server port"
|
||||
|
||||
ViperWebAPIProtocol string = "web.api.protocol"
|
||||
FlagWebAPIProtocol string = "web-api-protocol"
|
||||
DefaultWebAPIProtocol string = "http"
|
||||
DescriptionWebAPIProtocol string = "Target API server protocol (http/https)"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
API struct {
|
||||
TLS struct {
|
||||
Enabled bool `yaml:"enabled"`
|
||||
|
||||
// Path to file containing TLS certificate
|
||||
Certfile string `yaml:"certfile"`
|
||||
|
||||
// Path to file containing TLS private key
|
||||
Keyfile string `yaml:"keyfile"`
|
||||
} `yaml:"tls"`
|
||||
Port int `yaml:"port"`
|
||||
Key string `yaml:"key"`
|
||||
} `yaml:"api"`
|
||||
DB struct {
|
||||
Database string `yaml:"database"`
|
||||
Host string `yaml:"host"`
|
||||
SSLMode string `yaml:"sslmode"`
|
||||
Password string `yaml:"password"`
|
||||
Port int `yaml:"port"`
|
||||
User string `yaml:"user"`
|
||||
} `yaml:"db"`
|
||||
Web struct {
|
||||
User string `yaml:"user"`
|
||||
Password string `yaml:"password"`
|
||||
Port int `yaml:"port"`
|
||||
API struct {
|
||||
Client struct {
|
||||
API struct {
|
||||
Host string `yaml:"host"`
|
||||
Key string `yaml:"key"`
|
||||
Port int `yaml:"port"`
|
||||
Protocol string `yaml:"protocol"`
|
||||
} `yaml:"api"`
|
||||
} `yaml:"web"`
|
||||
}
|
||||
} `yaml:"client"`
|
||||
|
||||
// DefaultConfig returns a Config filled with the default values from the
|
||||
// `Default*` constants defined in this file.
|
||||
func DefaultConfig() (cfg Config) {
|
||||
cfg.API.TLS.Enabled = DefaultAPITLSEnabled
|
||||
cfg.API.TLS.Certfile = DefaultAPITLSCertfile
|
||||
cfg.API.TLS.Keyfile = DefaultAPITLSKeyfile
|
||||
cfg.API.Port = DefaultAPIPort
|
||||
cfg.API.Key = DefaultAPIKey
|
||||
cfg.DB.Database = DefaultDBDatabase
|
||||
cfg.DB.Host = DefaultDBHost
|
||||
cfg.DB.SSLMode = DefaultDBSSLMode
|
||||
cfg.DB.Password = DefaultDBPassword
|
||||
cfg.DB.Port = DefaultDBPort
|
||||
cfg.DB.User = DefaultDBUser
|
||||
cfg.Web.User = DefaultWebUser
|
||||
cfg.Web.Password = DefaultWebPassword
|
||||
cfg.Web.Port = DefaultWebPort
|
||||
cfg.Web.API.Host = DefaultWebAPIHost
|
||||
cfg.Web.API.Key = DefaultWebAPIKey
|
||||
cfg.Web.API.Port = DefaultWebAPIPort
|
||||
cfg.Web.API.Protocol = DefaultWebAPIProtocol
|
||||
return
|
||||
}
|
||||
|
||||
func init() {
|
||||
// rootCmd
|
||||
|
||||
cobra.OnInitialize(initConfig)
|
||||
|
||||
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.bottin.yaml)")
|
||||
|
||||
// apiCmd
|
||||
|
||||
rootCmd.AddCommand(apiCmd)
|
||||
|
||||
// api.tls.enabled
|
||||
apiCmd.Flags().Bool(FlagAPITLSEnabled, DefaultAPITLSEnabled, DescriptionAPITLSEnabled)
|
||||
if err := viper.BindPFlag(ViperAPITLSEnabled, apiCmd.Flags().Lookup(FlagAPITLSEnabled)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// api.tls.certfile
|
||||
apiCmd.Flags().String(FlagAPITLSCertfile, DefaultAPITLSCertfile, DescriptionAPITLSCertfile)
|
||||
if err := viper.BindPFlag(ViperAPITLSCertfile, apiCmd.Flags().Lookup(FlagAPITLSCertfile)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// api.tls.keyfile
|
||||
apiCmd.Flags().String(FlagAPITLSKeyfile, DefaultAPITLSKeyfile, DescriptionAPITLSKeyFile)
|
||||
if err := viper.BindPFlag(ViperAPITLSKeyfile, apiCmd.Flags().Lookup(FlagAPITLSKeyfile)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// api.key
|
||||
apiCmd.Flags().String(FlagAPIKey, DefaultAPIKey, DescriptionAPIKey)
|
||||
if err := viper.BindPFlag(ViperAPIKey, apiCmd.Flags().Lookup(FlagAPIKey)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// api.port
|
||||
apiCmd.Flags().Int(FlagAPIPort, DefaultAPIPort, DescriptionAPIPort)
|
||||
if err := viper.BindPFlag(ViperAPIPort, apiCmd.Flags().Lookup(FlagAPIPort)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.database
|
||||
apiCmd.Flags().String(FlagDBDatabase, DefaultDBDatabase, DescriptionDBDatabase)
|
||||
if err := viper.BindPFlag(ViperDBDatabase, apiCmd.Flags().Lookup(FlagDBDatabase)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.sslmode
|
||||
apiCmd.Flags().String(FlagDBSSLMode, DefaultDBSSLMode, DescriptionDBSSLMode)
|
||||
if err := viper.BindPFlag(ViperDBSSLMode, apiCmd.Flags().Lookup(FlagDBSSLMode)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.host
|
||||
apiCmd.Flags().String(FlagDBHost, DefaultDBHost, DescriptionDBHost)
|
||||
if err := viper.BindPFlag(ViperDBHost, apiCmd.Flags().Lookup(FlagDBHost)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.password
|
||||
apiCmd.Flags().String(FlagDBPassword, DefaultDBPassword, DescriptionDBPassword)
|
||||
if err := viper.BindPFlag(ViperDBPassword, apiCmd.Flags().Lookup(FlagDBPassword)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.port
|
||||
apiCmd.Flags().Int(FlagDBPort, DefaultDBPort, DescriptionDBPort)
|
||||
if err := viper.BindPFlag(ViperDBPort, apiCmd.Flags().Lookup(FlagDBPort)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// db.user
|
||||
apiCmd.Flags().String(FlagDBUser, DefaultDBUser, DescriptionDBUser)
|
||||
if err := viper.BindPFlag(ViperDBUser, apiCmd.Flags().Lookup(FlagDBUser)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// WebCmd
|
||||
rootCmd.AddCommand(webCmd)
|
||||
|
||||
// web.api.host
|
||||
webCmd.Flags().String(FlagWebAPIHost, DefaultWebAPIHost, DescriptionWebAPIHost)
|
||||
if err := viper.BindPFlag(ViperWebAPIHost, webCmd.Flags().Lookup(FlagWebAPIHost)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.api.key
|
||||
webCmd.Flags().String(FlagWebAPIKey, DefaultWebAPIKey, DescriptionWebAPIKey)
|
||||
if err := viper.BindPFlag(ViperWebAPIKey, webCmd.Flags().Lookup(FlagWebAPIKey)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.api.protocol
|
||||
webCmd.Flags().String(FlagWebAPIProtocol, DefaultWebAPIProtocol, DescriptionWebAPIProtocol)
|
||||
if err := viper.BindPFlag(ViperWebAPIProtocol, webCmd.Flags().Lookup(FlagWebAPIProtocol)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.api.port
|
||||
webCmd.Flags().Int(FlagWebAPIPort, DefaultWebAPIPort, DescriptionWebAPIPort)
|
||||
if err := viper.BindPFlag(ViperWebAPIPort, webCmd.Flags().Lookup(FlagWebAPIPort)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.password
|
||||
webCmd.Flags().String(FlagWebPassword, DefaultWebPassword, DescriptionWebPassword)
|
||||
if err := viper.BindPFlag(ViperWebPassword, webCmd.Flags().Lookup(FlagWebPassword)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.port
|
||||
webCmd.Flags().Int(FlagWebPort, DefaultWebPort, DescriptionWebPort)
|
||||
if err := viper.BindPFlag(ViperWebPort, webCmd.Flags().Lookup(FlagWebPort)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// web.user
|
||||
webCmd.Flags().String(FlagWebUser, DefaultWebUser, DescriptionWebUser)
|
||||
if err := viper.BindPFlag(ViperWebUser, webCmd.Flags().Lookup(FlagWebUser)); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
Server struct {
|
||||
API struct {
|
||||
DB struct {
|
||||
Database string `yaml:"database"`
|
||||
Host string `yaml:"host"`
|
||||
Password string `yaml:"password"`
|
||||
Port int `yaml:"port"`
|
||||
SSLMode string `yaml:"sslmode"`
|
||||
User string `yaml:"user"`
|
||||
} `yaml:"db"`
|
||||
Host string `yaml:"host"`
|
||||
Key string `yaml:"key"`
|
||||
Port int `yaml:"port"`
|
||||
TLS struct {
|
||||
Enabled bool `yaml:"enabled"`
|
||||
Certfile string `yaml:"certfile"`
|
||||
Keyfile string `yaml:"keyfile"`
|
||||
} `yaml:"tls"`
|
||||
} `yaml:"api"`
|
||||
UI struct {
|
||||
API struct {
|
||||
Host string `yaml:"host"`
|
||||
Key string `yaml:"key"`
|
||||
Port int `yaml:"port"`
|
||||
Protocol string `yaml:"protocol"`
|
||||
} `yaml:"api"`
|
||||
Password string `yaml:"password"`
|
||||
Port int `yaml:"port"`
|
||||
TLS struct {
|
||||
Enabled bool `yaml:"enabled"`
|
||||
Certfile string `yaml:"certfile"`
|
||||
Keyfile string `yaml:"keyfile"`
|
||||
} `yaml:"tls"`
|
||||
User string `yaml:"user"`
|
||||
} `yaml:"ui"`
|
||||
} `yaml:"server"`
|
||||
}
|
||||
|
||||
var cfgFile string
|
||||
|
@ -311,3 +85,363 @@ func initConfig() {
|
|||
fmt.Fprintln(os.Stderr, "Using config file:", viper.ConfigFileUsed())
|
||||
}
|
||||
}
|
||||
|
||||
func init() {
|
||||
// rootCmd
|
||||
|
||||
cobra.OnInitialize(initConfig)
|
||||
|
||||
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.bottin.yaml)")
|
||||
|
||||
// client.api.host
|
||||
rootCmd.PersistentFlags().String(
|
||||
"client-api-host",
|
||||
"api",
|
||||
"API server host",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"client.api.host",
|
||||
rootCmd.PersistentFlags().Lookup("client-api-host"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// client.api.key
|
||||
rootCmd.PersistentFlags().String(
|
||||
"client-api-key",
|
||||
"bottin",
|
||||
"API server key",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"client.api.key",
|
||||
rootCmd.PersistentFlags().Lookup("client-api-key"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// client.api.port
|
||||
rootCmd.PersistentFlags().Int(
|
||||
"client-api-port",
|
||||
1312,
|
||||
"API server port",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"client.api.port",
|
||||
rootCmd.PersistentFlags().Lookup("client-api-port"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// client.api.protocol
|
||||
rootCmd.PersistentFlags().String(
|
||||
"client-api-protocol",
|
||||
"https",
|
||||
"API server protocol",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"client.api.protocol",
|
||||
rootCmd.PersistentFlags().Lookup("client-api-protocol"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server
|
||||
rootCmd.AddCommand(serverCmd)
|
||||
|
||||
// server api
|
||||
serverCmd.AddCommand(apiCmd)
|
||||
|
||||
// server api db
|
||||
// server.api.db.database
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-db-database",
|
||||
"bottin",
|
||||
"Postgres database name",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.database",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-database"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.db.host
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-db-host",
|
||||
"db",
|
||||
"Postgres host name",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.host",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-host"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.db.password
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-db-password",
|
||||
"bottin",
|
||||
"Postgres password",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.password",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-password"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.db.port
|
||||
apiCmd.PersistentFlags().Int(
|
||||
"server-api-db-port",
|
||||
5432,
|
||||
"Postgres port",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.port",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-port"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.db.sslmode
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-db-sslmode",
|
||||
"prefer",
|
||||
"Postgres sslmode",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.sslmode",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-sslmode"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.db.user
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-db-user",
|
||||
"bottin",
|
||||
"Postgres user name",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.db.user",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-db-user"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.host
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-host",
|
||||
"",
|
||||
"API server hostname or IP to answer on (empty = any)",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.host",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-host"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.key
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-key",
|
||||
"bottin",
|
||||
"API server key",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.key",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-key"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.port
|
||||
apiCmd.PersistentFlags().Int(
|
||||
"server-api-port",
|
||||
1312,
|
||||
"API server port",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.port",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-port"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server api tls
|
||||
// server.api.tls.enabled
|
||||
apiCmd.PersistentFlags().Bool(
|
||||
"server-api-tls-enabled",
|
||||
true,
|
||||
"Use TLS for API server connections (requires certfile and keyfile)",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.tls.enabled",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-tls-enabled"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.tls.certfile
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-tls-certfile",
|
||||
"/etc/bottin/cert.pem",
|
||||
"Path to certificate file",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.tls.certfile",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-tls-certfile"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.api.tls.keyfile
|
||||
apiCmd.PersistentFlags().String(
|
||||
"server-api-tls-keyfile",
|
||||
"/etc/bottin/key.pem",
|
||||
"Path to private key file",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.api.tls.keyfile",
|
||||
apiCmd.PersistentFlags().Lookup("server-api-tls-keyfile"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server ui
|
||||
serverCmd.AddCommand(uiCmd)
|
||||
|
||||
// server ui api
|
||||
|
||||
// server.ui.api.host
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-api-host",
|
||||
"api",
|
||||
"Web UI backend API server host name",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.api.host",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-api-host"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.api.key
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-api-key",
|
||||
"bottin",
|
||||
"Web UI backend API server key",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.api.key",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-api-key"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.api.port
|
||||
uiCmd.PersistentFlags().Int(
|
||||
"server-ui-api-port",
|
||||
1312,
|
||||
"Web UI backend API server port",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.api.port",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-api-port"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.api.protocol
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-api-protocol",
|
||||
"https",
|
||||
"Web UI backend API server protocol",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.api.protocol",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-api-protocol"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.password
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-password",
|
||||
"bottin",
|
||||
"Web UI password",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.password",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-password"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.port
|
||||
uiCmd.PersistentFlags().Int(
|
||||
"server-ui-port",
|
||||
2312,
|
||||
"Web UI port",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.port",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-port"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.user
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-user",
|
||||
"bottin",
|
||||
"Web UI user",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.user",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-user"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server ui tls
|
||||
// server.ui.tls.enabled
|
||||
uiCmd.PersistentFlags().Bool(
|
||||
"server-ui-tls-enabled",
|
||||
true,
|
||||
"Web UI enable TLS (requires certfile and keyfile)",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.tls.enabled",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-tls-enabled"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.tls.certfile
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-tls-certfile",
|
||||
"/etc/bottin/cert.pem",
|
||||
"Path to Web UI TLS certificate file",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.tls.certfile",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-tls-certfile"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// server.ui.tls.keyfile
|
||||
uiCmd.PersistentFlags().String(
|
||||
"server-ui-tls-keyfile",
|
||||
"/etc/bottin/key.pem",
|
||||
"Path to Web UI TLS private key file",
|
||||
)
|
||||
if err := viper.BindPFlag(
|
||||
"server.ui.tls.keyfile",
|
||||
uiCmd.PersistentFlags().Lookup("server-ui-tls-keyfile"),
|
||||
); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
|
|
Reference in a new issue