Semaphore/cli/cmd/root.go

140 lines
3.3 KiB
Go
Raw Normal View History

2021-08-25 22:12:19 +02:00
package cmd
import (
"fmt"
"net/http"
"os"
"strings"
"github.com/ansible-semaphore/semaphore/api"
"github.com/ansible-semaphore/semaphore/api/sockets"
2021-08-25 22:12:19 +02:00
"github.com/ansible-semaphore/semaphore/db"
"github.com/ansible-semaphore/semaphore/db/factory"
"github.com/ansible-semaphore/semaphore/services/schedules"
"github.com/ansible-semaphore/semaphore/services/tasks"
2021-08-25 22:12:19 +02:00
"github.com/ansible-semaphore/semaphore/util"
"github.com/gorilla/context"
"github.com/gorilla/handlers"
log "github.com/sirupsen/logrus"
2021-08-25 22:12:19 +02:00
"github.com/spf13/cobra"
)
var persistentFlags struct {
configPath string
noConfig bool
logLevel string
}
2021-08-25 22:12:19 +02:00
var rootCmd = &cobra.Command{
Use: "semaphore",
Short: "Semaphore UI is a beautiful web UI for Ansible",
Long: `Semaphore UI is a beautiful web UI for Ansible.
2021-08-27 10:50:26 +02:00
Source code is available at https://github.com/ansible-semaphore/semaphore.
Complete documentation is available at https://ansible-semaphore.com.`,
2021-08-25 22:12:19 +02:00
Run: func(cmd *cobra.Command, args []string) {
_ = cmd.Help()
os.Exit(0)
2021-08-25 22:12:19 +02:00
},
2024-10-13 15:10:54 +02:00
PersistentPreRun: func(cmd *cobra.Command, args []string) {
if persistentFlags.logLevel == "" {
return
}
lvl, err := log.ParseLevel(persistentFlags.logLevel)
if err != nil {
log.Panic(err)
}
log.SetLevel(lvl)
},
2021-08-25 22:12:19 +02:00
}
func Execute() {
rootCmd.PersistentFlags().StringVar(&persistentFlags.logLevel, "log-level", "", "Log level: DEBUG, INFO, WARN, ERROR, FATAL, PANIC")
rootCmd.PersistentFlags().StringVar(&persistentFlags.configPath, "config", "", "Configuration file path")
rootCmd.PersistentFlags().BoolVar(&persistentFlags.noConfig, "no-config", false, "Don't use configuration file")
2021-08-25 22:12:19 +02:00
if err := rootCmd.Execute(); err != nil {
_, _ = fmt.Fprintln(os.Stderr, err)
2021-08-25 22:12:19 +02:00
os.Exit(1)
}
}
func runService() {
store := createStore("root")
taskPool := tasks.CreateTaskPool(store)
schedulePool := schedules.CreateSchedulePool(store, &taskPool)
defer schedulePool.Destroy()
2021-08-28 18:24:54 +02:00
util.Config.PrintDbInfo()
2023-09-20 10:22:26 +02:00
port := util.Config.Port
if !strings.HasPrefix(port, ":") {
port = ":" + port
}
fmt.Printf("Tmp Path (projects home) %v\n", util.Config.TmpPath)
fmt.Printf("Semaphore %v\n", util.Version())
fmt.Printf("Interface %v\n", util.Config.Interface)
fmt.Printf("Port %v\n", util.Config.Port)
go sockets.StartWS()
go schedulePool.Run()
go taskPool.Run()
route := api.Route()
route.Use(func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
context.Set(r, "store", store)
context.Set(r, "schedule_pool", schedulePool)
context.Set(r, "task_pool", &taskPool)
next.ServeHTTP(w, r)
})
})
var router http.Handler = route
router = handlers.ProxyHeaders(router)
http.Handle("/", router)
fmt.Println("Server is running")
if store.PermanentConnection() {
defer store.Close("root")
} else {
store.Close("root")
}
2023-09-20 10:22:26 +02:00
err := http.ListenAndServe(util.Config.Interface+port, cropTrailingSlashMiddleware(router))
if err != nil {
log.Panic(err)
}
}
func createStore(token string) db.Store {
util.ConfigInit(persistentFlags.configPath, persistentFlags.noConfig)
2021-08-25 22:12:19 +02:00
store := factory.CreateStore()
store.Connect(token)
err := db.Migrate(store)
2021-12-18 14:16:34 +01:00
if err != nil {
panic(err)
}
2024-07-07 19:12:21 +02:00
err = db.FillConfigFromDB(store)
if err != nil {
panic(err)
}
2024-07-10 14:35:21 +02:00
util.LookupDefaultApps()
2024-07-09 10:57:33 +02:00
2021-08-25 22:12:19 +02:00
return store
2021-12-18 14:16:34 +01:00
}