mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
3c81e75d79
This adds an access-control command that checks the policy enforcement for a given criteria using a configuration file and refactors the configuration validation command to include all configuration sources.
71 lines
1.4 KiB
Go
71 lines
1.4 KiB
Go
package commands
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/authelia/authelia/v4/internal/configuration/schema"
|
|
)
|
|
|
|
func newValidateConfigCmd() (cmd *cobra.Command) {
|
|
cmd = &cobra.Command{
|
|
Use: "validate-config",
|
|
Short: "Check a configuration against the internal configuration validation mechanisms",
|
|
Args: cobra.NoArgs,
|
|
RunE: cmdValidateConfigRunE,
|
|
}
|
|
|
|
cmdWithConfigFlags(cmd, false, []string{"config.yml"})
|
|
|
|
return cmd
|
|
}
|
|
|
|
func cmdValidateConfigRunE(cmd *cobra.Command, _ []string) (err error) {
|
|
var (
|
|
configs []string
|
|
val *schema.StructValidator
|
|
)
|
|
|
|
if configs, err = cmd.Flags().GetStringSlice("config"); err != nil {
|
|
return err
|
|
}
|
|
|
|
config, val, err = loadConfig(configs, true, true)
|
|
if err != nil {
|
|
return fmt.Errorf("error occurred loading configuration: %v", err)
|
|
}
|
|
|
|
switch {
|
|
case val.HasErrors():
|
|
fmt.Println("Configuration parsed and loaded with errors:")
|
|
fmt.Println("")
|
|
|
|
for _, err = range val.Errors() {
|
|
fmt.Printf("\t - %v\n", err)
|
|
}
|
|
|
|
fmt.Println("")
|
|
|
|
if !val.HasWarnings() {
|
|
break
|
|
}
|
|
|
|
fallthrough
|
|
case val.HasWarnings():
|
|
fmt.Println("Configuration parsed and loaded with warnings:")
|
|
fmt.Println("")
|
|
|
|
for _, err = range val.Warnings() {
|
|
fmt.Printf("\t - %v\n", err)
|
|
}
|
|
|
|
fmt.Println("")
|
|
default:
|
|
fmt.Println("Configuration parsed and loaded successfully without errors.")
|
|
fmt.Println("")
|
|
}
|
|
|
|
return nil
|
|
}
|