Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var RootCmd = &cobra.Command{ Use: "shar", Short: "SHAR Server", Long: ``, Run: func(cmd *cobra.Command, args []string) { cfg, err := config.GetEnvironment() if err != nil { log.Fatal(err) } var lev slog.Level var addSource bool switch cfg.LogLevel { case "debug": lev = slog.LevelDebug addSource = true case "info": lev = slog.LevelInfo case "warn": lev = slog.LevelWarn default: lev = slog.LevelError } conn, err := nats.Connect(cfg.NatsURL) if err != nil { slog.Error("connect to NATS", "error", err, slog.String("url", cfg.NatsURL)) panic(err) } handlerFactoryFns := map[string]func() slog.Handler{ "text": func() slog.Handler { return common.NewTextHandler(lev, addSource) }, "shar-handler": func() slog.Handler { return common.NewSharHandler(common.HandlerOptions{Level: lev}, &common.NatsLogPublisher{Conn: conn}) }, } cfgHandlers := strings.Split(cfg.LogHandler, ",") handlers := make([]slog.Handler, 0, len(cfgHandlers)) for _, h := range cfgHandlers { handlers = append(handlers, handlerFactoryFns[h]()) } logx.SetDefault("shar", common.NewMultiHandler(handlers)) if err != nil { panic(err) } svr := server.New(server.Concurrency(cfg.Concurrency), server.NatsConn(conn), server.NatsUrl(cfg.NatsURL), server.GrpcPort(cfg.Port)) if err := svr.Listen(); err != nil { panic(fmt.Errorf("create server: %w", err)) } }, PersistentPreRun: func(cmd *cobra.Command, args []string) { }, }
RootCmd represents the base command when called without any subcommands
Functions ¶
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.