diff options
author | 2022-05-16 14:13:19 +0200 | |
---|---|---|
committer | 2022-05-16 14:13:19 +0200 | |
commit | b915a418115c7873913bafbc0337b6050c473d6a (patch) | |
tree | c101d927d881d22d5320064ad8414919a646dda4 /cmd | |
parent | [docs] Mention `AmbientCapabilities=CAP_NET_BIND_SERVICE` in example systemd ... (diff) | |
download | gotosocial-b915a418115c7873913bafbc0337b6050c473d6a.tar.xz |
[feature] Basic config validation (#562)
* add optional config validation
* clarify that host and protocol are required
* add validation for host and protocol
* pass prerunArgs as a struct (validate by default)
Diffstat (limited to 'cmd')
-rw-r--r-- | cmd/gotosocial/admin.go | 18 | ||||
-rw-r--r-- | cmd/gotosocial/common.go | 17 | ||||
-rw-r--r-- | cmd/gotosocial/debug.go | 2 | ||||
-rw-r--r-- | cmd/gotosocial/flag/usage.go | 4 | ||||
-rw-r--r-- | cmd/gotosocial/server.go | 2 |
5 files changed, 28 insertions, 15 deletions
diff --git a/cmd/gotosocial/admin.go b/cmd/gotosocial/admin.go index dcce7fb0a..2e4336d7a 100644 --- a/cmd/gotosocial/admin.go +++ b/cmd/gotosocial/admin.go @@ -46,7 +46,7 @@ func adminCommands() *cobra.Command { Use: "create", Short: "create a new account", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Create) @@ -59,7 +59,7 @@ func adminCommands() *cobra.Command { Use: "confirm", Short: "confirm an existing account manually, thereby skipping email confirmation", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Confirm) @@ -72,7 +72,7 @@ func adminCommands() *cobra.Command { Use: "promote", Short: "promote an account to admin", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Promote) @@ -85,7 +85,7 @@ func adminCommands() *cobra.Command { Use: "demote", Short: "demote an account from admin to normal user", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Demote) @@ -98,7 +98,7 @@ func adminCommands() *cobra.Command { Use: "disable", Short: "prevent an account from signing in or posting etc, but don't delete anything", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Disable) @@ -111,7 +111,7 @@ func adminCommands() *cobra.Command { Use: "suspend", Short: "completely remove an account and all of its posts, media, etc", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Suspend) @@ -124,7 +124,7 @@ func adminCommands() *cobra.Command { Use: "password", Short: "set a new password for the given account", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), account.Password) @@ -143,7 +143,7 @@ func adminCommands() *cobra.Command { Use: "export", Short: "export data from the database to file at the given path", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), trans.Export) @@ -156,7 +156,7 @@ func adminCommands() *cobra.Command { Use: "import", Short: "import data from a file into the database", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), trans.Import) diff --git a/cmd/gotosocial/common.go b/cmd/gotosocial/common.go index 0c65be657..48d56a7a2 100644 --- a/cmd/gotosocial/common.go +++ b/cmd/gotosocial/common.go @@ -28,15 +28,22 @@ import ( "github.com/superseriousbusiness/gotosocial/internal/log" ) +type preRunArgs struct { + cmd *cobra.Command + skipValidation bool +} + // preRun should be run in the pre-run stage of every cobra command. // The goal here is to initialize the viper config store, and also read in // the config file (if present). // +// Config then undergoes basic validation if 'skipValidation' is not true. +// // The order of these is important: the init-config function reads the location // of the config file from the viper store so that it can be picked up by either // env vars or cli flag. -func preRun(cmd *cobra.Command) error { - if err := config.InitViper(cmd.Flags()); err != nil { +func preRun(a preRunArgs) error { + if err := config.InitViper(a.cmd.Flags()); err != nil { return fmt.Errorf("error initializing viper: %s", err) } @@ -44,6 +51,12 @@ func preRun(cmd *cobra.Command) error { return fmt.Errorf("error initializing config: %s", err) } + if !a.skipValidation { + if err := config.Validate(); err != nil { + return fmt.Errorf("invalid config: %s", err) + } + } + return nil } diff --git a/cmd/gotosocial/debug.go b/cmd/gotosocial/debug.go index e5a26b7fa..b1a1560ec 100644 --- a/cmd/gotosocial/debug.go +++ b/cmd/gotosocial/debug.go @@ -35,7 +35,7 @@ func debugCommands() *cobra.Command { Use: "config", Short: "print the collated config (derived from env, flag, and config file) to stdout", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd, skipValidation: true}) // don't do validation for debugging config }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), configaction.Config) diff --git a/cmd/gotosocial/flag/usage.go b/cmd/gotosocial/flag/usage.go index 63c3eac5d..3393f4675 100644 --- a/cmd/gotosocial/flag/usage.go +++ b/cmd/gotosocial/flag/usage.go @@ -25,9 +25,9 @@ var usage = config.KeyNames{ LogDbQueries: "Log database queries verbosely when log-level is trace or debug", ApplicationName: "Name of the application, used in various places internally", ConfigPath: "Path to a file containing gotosocial configuration. Values set in this file will be overwritten by values set as env vars or arguments", - Host: "Hostname to use for the server (eg., example.org, gotosocial.whatever.com). DO NOT change this on a server that's already run!", + Host: "Hostname to use for the server (eg., example.org, gotosocial.whatever.com). This value must be set. DO NOT change this on a server that's already run!", AccountDomain: "Domain to use in account names (eg., example.org, whatever.com). If not set, will default to the setting for host. DO NOT change this on a server that's already run!", - Protocol: "Protocol to use for the REST api of the server (only use http for debugging and tests!)", + Protocol: "Protocol to use for the REST api of the server. This value must be set to one of http or https; only use http for debugging and tests!", BindAddress: "Bind address to use for the GoToSocial server (eg., 0.0.0.0, 172.138.0.9, [::], localhost). For ipv6, enclose the address in square brackets, eg [2001:db8::fed1]. Default binds to all interfaces.", Port: "Port to use for GoToSocial. Change this to 443 if you're running the binary directly on the host machine.", TrustedProxies: "Proxies to trust when parsing x-forwarded headers into real IPs.", diff --git a/cmd/gotosocial/server.go b/cmd/gotosocial/server.go index 690f928fa..fda5bad90 100644 --- a/cmd/gotosocial/server.go +++ b/cmd/gotosocial/server.go @@ -36,7 +36,7 @@ func serverCommands() *cobra.Command { Use: "start", Short: "start the gotosocial server", PreRunE: func(cmd *cobra.Command, args []string) error { - return preRun(cmd) + return preRun(preRunArgs{cmd: cmd}) }, RunE: func(cmd *cobra.Command, args []string) error { return run(cmd.Context(), server.Start) |