summaryrefslogtreecommitdiff
path: root/internal/config/config.go
blob: 09ae994c160600704dc1462fa73228462359a767 (plain)
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
package config

const (
	// ControlUser is used for various DTail specific operations.
	ControlUser string = "DTAIL-CONTROL"
	// ScheduleUser is used for non-interactive scheduled mapreduce queries.
	ScheduleUser string = "DTAIL-SCHEDULE"
	// ContinuousUser is used for non-interactive continuous mapreduce queries.
	ContinuousUser string = "DTAIL-CONTINUOUS"
	// InterruptTimeoutS is used to terminate DTail when Ctrl+C was pressed twice within a given interval.
	InterruptTimeoutS int = 3
	// ConnectionsPerCPU controls how many connections are established concurrently as a start (slow start)
	DefaultConnectionsPerCPU int = 10
	// DTailSSHServerDefaultPort is the default DServer port.
	DefaultSSHPort int = 2222
)

// Client holds a DTail client configuration.
var Client *ClientConfig

// Server holds a DTail server configuration.
var Server *ServerConfig

// Common holds common configs of both both, client and server.
var Common *CommonConfig

// Setup the DTail configuration.
func Setup(args *Args, additionalArgs []string) {
	initializer := initializer{
		Common: newDefaultCommonConfig(),
		Server: newDefaultServerConfig(),
		Client: newDefaultClientConfig(),
	}
	initializer.parseConfig(args)
	Client, Server, Common = initializer.transformConfig(
		args, additionalArgs,
		initializer.Client,
		initializer.Server,
		initializer.Common,
	)
}