101 lines
2.3 KiB
Go
101 lines
2.3 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"log/slog"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/jackc/pgx/v5"
|
|
"github.com/redis/go-redis/v9"
|
|
"github.com/spf13/cobra"
|
|
|
|
rconfig "xcontrol/internal/rag/config"
|
|
"xcontrol/server"
|
|
"xcontrol/server/api"
|
|
"xcontrol/server/config"
|
|
"xcontrol/server/proxy"
|
|
)
|
|
|
|
var (
|
|
configPath string
|
|
logLevel string
|
|
)
|
|
|
|
var rootCmd = &cobra.Command{
|
|
Use: "xcontrol-server",
|
|
Short: "Start the xcontrol server",
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
cfg, err := config.Load(configPath)
|
|
if err != nil {
|
|
slog.Warn("load config", "err", err)
|
|
cfg = &config.Config{}
|
|
}
|
|
if logLevel != "" {
|
|
cfg.Log.Level = logLevel
|
|
}
|
|
if configPath != "" {
|
|
api.ConfigPath = configPath
|
|
rconfig.ServerConfigPath = configPath
|
|
}
|
|
proxy.Set(cfg.Global.Proxy)
|
|
|
|
level := slog.LevelInfo
|
|
switch strings.ToLower(cfg.Log.Level) {
|
|
case "debug":
|
|
level = slog.LevelDebug
|
|
case "warn", "warning":
|
|
level = slog.LevelWarn
|
|
case "error":
|
|
level = slog.LevelError
|
|
}
|
|
logger := slog.New(slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{Level: level}))
|
|
slog.SetDefault(logger)
|
|
|
|
var conn *pgx.Conn
|
|
if dsn := cfg.Global.VectorDB.DSN(); dsn != "" {
|
|
logger.Debug("connecting to postgres", "dsn", dsn)
|
|
conn, err = pgx.Connect(context.Background(), dsn)
|
|
if err != nil {
|
|
logger.Error("postgres connect error", "err", err)
|
|
} else {
|
|
logger.Info("postgres connected")
|
|
}
|
|
} else {
|
|
logger.Warn("postgres dsn not provided")
|
|
}
|
|
|
|
if addr := cfg.Global.Redis.Addr; addr != "" {
|
|
logger.Debug("connecting to redis", "addr", addr)
|
|
rdb := redis.NewClient(&redis.Options{
|
|
Addr: addr,
|
|
Password: cfg.Global.Redis.Password,
|
|
})
|
|
if err := rdb.Ping(context.Background()).Err(); err != nil {
|
|
logger.Error("redis connect error", "err", err)
|
|
} else {
|
|
logger.Info("redis connected")
|
|
}
|
|
} else {
|
|
logger.Warn("redis addr not provided")
|
|
}
|
|
|
|
r := server.New(
|
|
api.RegisterRoutes(conn, cfg.Sync.Repo.Proxy),
|
|
)
|
|
|
|
r.Run() // listen and serve on 0.0.0.0:8080
|
|
},
|
|
}
|
|
|
|
func init() {
|
|
rootCmd.Flags().StringVar(&configPath, "config", "", "path to server configuration file")
|
|
rootCmd.Flags().StringVar(&logLevel, "log-level", "", "log level (debug, info, warn, error)")
|
|
}
|
|
|
|
func main() {
|
|
if err := rootCmd.Execute(); err != nil {
|
|
os.Exit(1)
|
|
}
|
|
}
|