-
Notifications
You must be signed in to change notification settings - Fork 517
/
Copy pathmain.go
116 lines (97 loc) · 3.13 KB
/
main.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
package main
import (
"fmt"
"os"
"strings"
mdbv1 "github.com/mongodb/mongodb-kubernetes-operator/api/v1"
"github.com/mongodb/mongodb-kubernetes-operator/controllers"
"github.com/mongodb/mongodb-kubernetes-operator/controllers/construct"
"go.uber.org/zap"
"k8s.io/apimachinery/pkg/runtime"
utilruntime "k8s.io/apimachinery/pkg/util/runtime"
clientgoscheme "k8s.io/client-go/kubernetes/scheme"
"sigs.k8s.io/controller-runtime/pkg/cache"
"sigs.k8s.io/controller-runtime/pkg/client/config"
"sigs.k8s.io/controller-runtime/pkg/manager"
"sigs.k8s.io/controller-runtime/pkg/manager/signals"
)
var (
scheme = runtime.NewScheme()
)
const (
WatchNamespaceEnv = "WATCH_NAMESPACE"
)
func init() {
utilruntime.Must(clientgoscheme.AddToScheme(scheme))
utilruntime.Must(mdbv1.AddToScheme(scheme))
// +kubebuilder:scaffold:scheme
}
func configureLogger() (*zap.Logger, error) {
// TODO: configure non development logger
logger, err := zap.NewDevelopment()
zap.ReplaceGlobals(logger)
return logger, err
}
func hasRequiredVariables(logger *zap.Logger, envVariables ...string) bool {
allPresent := true
for _, envVariable := range envVariables {
if _, envSpecified := os.LookupEnv(envVariable); !envSpecified {
logger.Error(fmt.Sprintf("required environment variable %s not found", envVariable))
allPresent = false
}
}
return allPresent
}
func main() {
log, err := configureLogger()
if err != nil {
log.Sugar().Fatalf("Failed to configure logger: %v", err)
}
if !hasRequiredVariables(log, construct.AgentImageEnv, construct.VersionUpgradeHookImageEnv, construct.ReadinessProbeImageEnv) {
os.Exit(1)
}
// Get watch namespace from environment variable.
namespaces, nsSpecified := os.LookupEnv(WatchNamespaceEnv)
if !nsSpecified {
log.Sugar().Fatal("No namespace specified to watch")
}
// If namespace is a wildcard use the empty string to represent all namespaces
var watchNamespaces []string
if namespaces == "*" {
log.Info("Watching all namespaces")
} else {
for _, ns := range strings.Split(namespaces, ",") {
watchNamespaces = append(watchNamespaces, strings.TrimSpace(ns))
}
log.Sugar().Infof("Watching namespace: %s", strings.Join(watchNamespaces, ","))
}
// Get a config to talk to the apiserver
cfg, err := config.GetConfig()
if err != nil {
log.Sugar().Fatalf("Unable to get config: %v", err)
}
// Create a new Cmd to provide shared dependencies and start components
mgr, err := manager.New(cfg, manager.Options{
Cache: cache.Options{
Namespaces: watchNamespaces,
},
})
if err != nil {
log.Sugar().Fatalf("Unable to create manager: %v", err)
}
log.Info("Registering Components.")
// Setup Scheme for all resources
if err := mdbv1.AddToScheme(mgr.GetScheme()); err != nil {
log.Sugar().Fatalf("Unable to add mdbv1 to scheme: %v", err)
}
// Setup Controller.
if err = controllers.NewReconciler(mgr).SetupWithManager(mgr); err != nil {
log.Sugar().Fatalf("Unable to create controller: %v", err)
}
// +kubebuilder:scaffold:builder
log.Info("Starting the Cmd.")
// Start the Cmd
if err := mgr.Start(signals.SetupSignalHandler()); err != nil {
log.Sugar().Fatalf("Unable to start manager: %v", err)
}
}