-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathflags.go
53 lines (39 loc) · 3.16 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
// SPDX-License-Identifier: MIT
package flags
import (
"fmt"
"os"
"github.com/spf13/pflag"
"github.com/mercedes-benz/garm-operator/pkg/defaults"
)
func InitiateFlags() *pflag.FlagSet {
f := pflag.NewFlagSet("config", pflag.PanicOnError)
f.Usage = func() {
fmt.Println(f.FlagUsages())
os.Exit(0)
}
// configure f for koanf
f.String("config", "", "path to .yaml config file")
f.String("operator-metrics-bind-address", defaults.DefaultMetricsBindAddress, "The address the metric endpoint binds to.")
f.String("operator-health-probe-bind-address", defaults.DefaultHealthProbeBindAddress, "The address the probe endpoint binds to.")
f.Bool("operator-leader-election", defaults.DefaultLeaderElection, "Enable leader election for controller manager. "+"Enabling this will ensure there is only one active controller manager.")
f.Duration("operator-sync-period", defaults.DefaultSyncPeriod, "The minimum interval at which watched resources are reconciled (e.g. 5m)")
f.String("operator-watch-namespace", defaults.DefaultWatchNamespace, "Namespace that the controller watches to reconcile garm objects. "+"If unspecified, the controller watches for garm objects across all namespaces.")
f.Duration("operator-sync-runners-interval", defaults.DefaultSyncRunnersInterval, "Specifies interval in which runners from garm-api are polled and synced to Runner CustomResource")
f.Duration("operator-min-idle-runners-age", defaults.DefaultMinIdleRunnersAge, "The minimum age an idle runner should have to get marked for deletion (e.g. 30m)")
f.Int("operator-runner-concurrency", defaults.DefaultRunnerConcurrency, "Specifies the maximum number of concurrent runners that can be reconciled simultaneously")
f.Int("operator-repository-concurrency", defaults.DefaultRepositoryConcurrency, "Specifies the maximum number of concurrent repositories that can be reconciled simultaneously")
f.Int("operator-organization-concurrency", defaults.DefaultOrganizationConcurrency, "Specifies the maximum number of concurrent organizations that can be reconciled simultaneously")
f.Int("operator-enterprise-concurrency", defaults.DefaultEnterpriseConcurrency, "Specifies the maximum number of concurrent enterprises that can be reconciled simultaneously")
f.Int("operator-pool-concurrency", defaults.DefaultPoolConcurrency, "Specifies the maximum number of concurrent pools that can be reconciled simultaneously")
f.Bool("operator-runner-reconciliation", defaults.DefaultRunnerReconciliation, "Specifies if runner reconciliation should be enabled")
f.Int("operator-log-verbosity-level", defaults.DefaultLogVerbosityLevel, "Specifies the log verbosity level (0-5).")
f.String("garm-server", "", "The address of the GARM server")
f.String("garm-username", "", "The username for the GARM server")
f.String("garm-password", "", "The password for the GARM server")
f.Bool("garm-init", defaults.DefaultGarmInit, "Enable initialization of new GARM Instance")
f.String("garm-email", defaults.DefaultGarmEmail, "The email address for the GARM server (only required if garm-init is set to true)")
f.Bool("dry-run", false, "If true, only print the object that would be sent, without sending it.")
f.Parse(os.Args[1:])
return f
}