forked from jbott/gollum
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflags.go
67 lines (60 loc) · 3.05 KB
/
flags.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Copyright 2015-2018 trivago N.V.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package main
import (
"fmt"
"github.com/sirupsen/logrus"
"github.com/trivago/gollum/core"
"github.com/trivago/tgo/tflag"
)
var (
flagHelp = tflag.Switch("h", "help", "Print this help message.")
flagVersion = tflag.Switch("v", "version", "Print version information and quit.")
flagExtVersion = tflag.Switch("r", "runtime", "Print runtime information and quit.")
flagModules = tflag.Switch("l", "list", "Print plugin information and quit.")
flagConfigFile = tflag.String("c", "config", "", "Use a given configuration file.")
flagTestConfigFile = tflag.String("tc", "testconfig", "", "Test the given configuration file and exit.")
flagLoglevel = tflag.Int("ll", "loglevel", 2, "Set the loglevel [0-3] as in {0=Error, 1=+Warning, 2=+Info, 3=+Debug}.")
flagLogColors = tflag.String("lc", "log-colors", "auto", "Use Logrus's \"colored\" log format. One of \"never\", \"auto\" (default), \"always\"")
flagNumCPU = tflag.Int("n", "numcpu", 0, "Number of CPUs to use. Set 0 for all CPUs.")
flagPidFile = tflag.String("p", "pidfile", "", "Write the process id into a given file.")
flagMetricsAddress = tflag.String("m", "metrics", "", "Address to use for metric queries. Disabled by default.")
flagMetricsType = tflag.String("mt", "metricstype", "", "Type of metrics to generate. Defaults to \"prometheus\"")
flagHealthCheck = tflag.String("hc", "healthcheck", "", "Listening address ([IP]:PORT) to use for healthcheck HTTP endpoint. Disabled by default.")
flagCPUProfile = tflag.String("pc", "profilecpu", "", "Write CPU profiler results to a given file.")
flagMemProfile = tflag.String("pm", "profilemem", "", "Write heap profile results to a given file.")
flagProfile = tflag.Switch("ps", "profilespeed", "Write msg/sec measurements to log.")
flagProfileTrace = tflag.String("pt", "profiletrace", "", "Write profile trace results to a given file.")
flagTrace = tflag.Switch("t", "trace", "Write message trace results _TRACE_ stream.")
)
func parseFlags() {
tflag.Parse()
}
func printFlags() {
helpMessageStr := fmt.Sprintf("Usage: gollum [OPTIONS]\n\nGollum - An n:m message multiplexer.\nVersion: %s\n\nOptions:", core.GetVersionString())
tflag.PrintFlags(helpMessageStr)
}
func getLogrusLevel(intLevel int) logrus.Level {
switch intLevel {
case 0:
return logrus.ErrorLevel
case 1:
return logrus.WarnLevel
case 2:
return logrus.InfoLevel
case 3:
return logrus.DebugLevel
}
return logrus.DebugLevel
}