cli

package
v0.2.11 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 23, 2018 License: MPL-2.0 Imports: 19 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var RootCmd = &cobra.Command{
	Use:   buildtime.PROGNAME,
	Short: buildtime.PROGNAME + `is the Triton Service Groups API`,
	Long: fmt.Sprintf(`
%s - Triton Service Groups API

Everything used to configure and run the central API server of the Triton
Service Groups service. Includes configuring default values, database and client
connections settings, environment variable overrides, binding and serving HTTP
access, and optionally enabling introspective utilities like gops(1) and pprof.

`, buildtime.PROGNAME),
	PersistentPreRunE: func(cmd *cobra.Command, args []string) error {

		{
			// os.Stdout isn't guaranteed to be thread-safe, wrap in a sync writer.
			// Files are guaranteed to be safe, terminals are not.
			var logWriter io.Writer
			if isatty.IsTerminal(os.Stdout.Fd()) ||
				isatty.IsCygwinTerminal(os.Stdout.Fd()) {
				logWriter = conswriter.GetTerminal()
			} else {
				logWriter = os.Stdout
			}

			agentFmt := viper.GetString(config.KeyAgentLogFormat)
			logFmt, err := config.LogLevelParse(agentFmt)
			if err != nil {
				return errors.Wrap(err, "unable to parse log format")
			}

			if logFmt == config.LogFormatAuto {
				if isatty.IsTerminal(os.Stdout.Fd()) ||
					isatty.IsCygwinTerminal(os.Stdout.Fd()) {
					logFmt = config.LogFormatHuman
				} else {
					logFmt = config.LogFormatZerolog
				}
			}

			var zlog zerolog.Logger
			switch logFmt {
			case config.LogFormatZerolog:
				zlog = zerolog.New(logWriter).With().Timestamp().Logger()
			case config.LogFormatHuman:
				w := zerolog.ConsoleWriter{
					Out:     logWriter,
					NoColor: false,
				}
				zlog = zerolog.New(w).With().Timestamp().Logger()
			default:
				return fmt.Errorf("unsupported log format: %q", logFmt)
			}

			log.Logger = zlog

			stdlog.SetFlags(0)
			stdlog.SetOutput(zlog)
		}

		logLevel := strings.ToUpper(viper.GetString(config.KeyLogLevel))
		switch logLevel {
		case "DEBUG":
			zerolog.SetGlobalLevel(zerolog.DebugLevel)
		case "INFO":
			zerolog.SetGlobalLevel(zerolog.InfoLevel)
		case "WARN":
			zerolog.SetGlobalLevel(zerolog.WarnLevel)
		case "ERROR":
			zerolog.SetGlobalLevel(zerolog.ErrorLevel)
		case "FATAL":
			zerolog.SetGlobalLevel(zerolog.FatalLevel)
		default:

			return fmt.Errorf("unsupported error level: %q (supported levels: %s)", logLevel,
				strings.Join([]string{
					"DEBUG",
					"INFO",
					"WARN",
					"ERROR",
					"FATAL",
				}, " "))
		}

		go func() {
			if !viper.GetBool(config.KeyGoogleAgentEnable) {
				log.Debug().Msg("disabled gops(1) agent")
				return
			}

			log.Info().Msg("enabled gops(1) agent")

			var (
				bind = viper.GetString(config.KeyGoogleAgentBind)
				port = viper.GetInt(config.KeyGoogleAgentPort)
				addr = fmt.Sprintf("%s:%d", bind, port)
				opts = gops.Options{
					Addr: addr,
				}
			)

			log.Debug().
				Str("gops-bind", bind).
				Int("gops-port", port).
				Msgf("starting gops(1) agent at %q", addr)

			if err := gops.Listen(opts); err != nil {
				log.Fatal().
					Err(err).
					Msg("failed to start gops(1) agent thread")
				return
			}
		}()

		go func() {
			if !viper.GetBool(config.KeyPProfEnable) {
				log.Debug().Msg("pprof endpoint disabled by request")
				return
			}

			log.Info().Msg("enabled pprof endpoint")

			var (
				bind = viper.GetString(config.KeyPProfBind)
				port = viper.GetInt(config.KeyPProfPort)
				addr = fmt.Sprintf("%s:%d", bind, port)
			)

			log.Debug().
				Str("pprof-bind", bind).
				Int("pprof-port", port).
				Msgf("starting pprof endpoint at %q", addr)

			if err := http.ListenAndServe(addr, nil); err != nil {
				log.Fatal().
					Err(err).
					Msg("failed to start pprof listener")
				return
			}
		}()

		return nil
	},
}

Functions

func Execute

func Execute() error

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL