2019-10-30 03:54:47 +07:00
|
|
|
//usr/bin/env go run "$0" "$@"; exit
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2019-11-02 21:32:58 +07:00
|
|
|
log "github.com/sirupsen/logrus"
|
2019-10-30 03:54:47 +07:00
|
|
|
"github.com/spf13/cobra"
|
2020-04-05 19:37:21 +07:00
|
|
|
|
|
|
|
"github.com/authelia/authelia/internal/commands"
|
|
|
|
"github.com/authelia/authelia/internal/utils"
|
2019-10-30 03:54:47 +07:00
|
|
|
)
|
|
|
|
|
2019-11-02 21:32:58 +07:00
|
|
|
var logLevel string
|
|
|
|
|
2019-10-30 03:54:47 +07:00
|
|
|
// AutheliaCommandDefinition is the definition of one authelia-scripts command.
|
|
|
|
type AutheliaCommandDefinition struct {
|
|
|
|
Name string
|
|
|
|
Short string
|
|
|
|
Long string
|
|
|
|
CommandLine string
|
|
|
|
Args cobra.PositionalArgs
|
|
|
|
Func func(cmd *cobra.Command, args []string)
|
|
|
|
SubCommands []*cobra.Command
|
|
|
|
}
|
|
|
|
|
|
|
|
// CobraCommands list of cobra commands
|
|
|
|
type CobraCommands = []*cobra.Command
|
|
|
|
|
|
|
|
// Commands is the list of commands of authelia-scripts
|
|
|
|
var Commands = []AutheliaCommandDefinition{
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "bootstrap",
|
|
|
|
Short: "Prepare environment for development and testing.",
|
|
|
|
Long: `Prepare environment for development and testing. This command prepares docker
|
|
|
|
images and download tools like Kind for Kubernetes testing.`,
|
|
|
|
Func: Bootstrap,
|
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "build",
|
|
|
|
Short: "Build Authelia binary and static assets",
|
|
|
|
Func: Build,
|
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "clean",
|
|
|
|
Short: "Clean build artifacts",
|
|
|
|
Func: Clean,
|
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "docker",
|
|
|
|
Short: "Commands related to building and publishing docker image",
|
2019-11-07 07:59:24 +07:00
|
|
|
SubCommands: CobraCommands{DockerBuildCmd, DockerPushCmd, DockerManifestCmd},
|
2019-10-30 03:54:47 +07:00
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "serve [config]",
|
|
|
|
Short: "Serve compiled version of Authelia",
|
|
|
|
Func: ServeCmd,
|
|
|
|
Args: cobra.MinimumNArgs(1),
|
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
2019-11-02 21:32:58 +07:00
|
|
|
Name: "suites",
|
|
|
|
Short: "Compute hash of a password for creating a file-based users database",
|
|
|
|
SubCommands: CobraCommands{
|
|
|
|
SuitesTestCmd,
|
|
|
|
SuitesListCmd,
|
|
|
|
SuitesSetupCmd,
|
|
|
|
SuitesTeardownCmd,
|
|
|
|
},
|
2019-10-30 03:54:47 +07:00
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "ci",
|
|
|
|
Short: "Run continuous integration script",
|
|
|
|
Func: RunCI,
|
|
|
|
},
|
|
|
|
AutheliaCommandDefinition{
|
|
|
|
Name: "unittest",
|
|
|
|
Short: "Run unit tests",
|
|
|
|
Func: RunUnitTest,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2019-11-02 21:32:58 +07:00
|
|
|
func levelStringToLevel(level string) log.Level {
|
|
|
|
if level == "debug" {
|
|
|
|
return log.DebugLevel
|
|
|
|
} else if level == "warning" {
|
|
|
|
return log.WarnLevel
|
|
|
|
}
|
|
|
|
return log.InfoLevel
|
|
|
|
}
|
|
|
|
|
2019-10-30 03:54:47 +07:00
|
|
|
func main() {
|
|
|
|
var rootCmd = &cobra.Command{Use: "authelia-scripts"}
|
|
|
|
cobraCommands := make([]*cobra.Command, 0)
|
|
|
|
|
|
|
|
for _, autheliaCommand := range Commands {
|
|
|
|
var fn func(cobraCmd *cobra.Command, args []string)
|
|
|
|
|
|
|
|
if autheliaCommand.CommandLine != "" {
|
|
|
|
cmdline := autheliaCommand.CommandLine
|
|
|
|
fn = func(cobraCmd *cobra.Command, args []string) {
|
2019-11-02 21:32:58 +07:00
|
|
|
cmd := utils.CommandWithStdout(cmdline, args...)
|
2019-10-30 03:54:47 +07:00
|
|
|
err := cmd.Run()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if autheliaCommand.Func != nil {
|
|
|
|
fn = autheliaCommand.Func
|
|
|
|
}
|
|
|
|
|
|
|
|
command := &cobra.Command{
|
|
|
|
Use: autheliaCommand.Name,
|
|
|
|
Short: autheliaCommand.Short,
|
|
|
|
}
|
|
|
|
|
|
|
|
if autheliaCommand.Long != "" {
|
|
|
|
command.Long = autheliaCommand.Long
|
|
|
|
}
|
|
|
|
|
|
|
|
if fn != nil {
|
|
|
|
command.Run = fn
|
|
|
|
}
|
|
|
|
|
|
|
|
if autheliaCommand.Args != nil {
|
|
|
|
command.Args = autheliaCommand.Args
|
|
|
|
}
|
|
|
|
|
|
|
|
if autheliaCommand.SubCommands != nil {
|
|
|
|
command.AddCommand(autheliaCommand.SubCommands...)
|
|
|
|
}
|
|
|
|
|
|
|
|
cobraCommands = append(cobraCommands, command)
|
|
|
|
}
|
2020-01-22 05:45:04 +07:00
|
|
|
cobraCommands = append(cobraCommands, commands.HashPasswordCmd, commands.MigrateCmd)
|
2019-11-02 21:32:58 +07:00
|
|
|
|
|
|
|
rootCmd.PersistentFlags().StringVar(&logLevel, "log-level", "info", "Set the log level for the command")
|
2019-10-30 03:54:47 +07:00
|
|
|
rootCmd.AddCommand(cobraCommands...)
|
2019-11-02 21:32:58 +07:00
|
|
|
cobra.OnInitialize(initConfig)
|
|
|
|
|
2019-11-07 14:21:21 +07:00
|
|
|
err := rootCmd.Execute()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2019-10-30 03:54:47 +07:00
|
|
|
}
|
2019-11-02 21:32:58 +07:00
|
|
|
|
|
|
|
func initConfig() {
|
|
|
|
log.SetLevel(levelStringToLevel(logLevel))
|
|
|
|
}
|