forked from k3s-io/helm-controller
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
95 lines (81 loc) · 3.31 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
package main
import (
"fmt"
"log"
"net/http"
_ "net/http/pprof"
"github.com/k3s-io/helm-controller/pkg/controllers"
"github.com/k3s-io/helm-controller/pkg/controllers/common"
"github.com/k3s-io/helm-controller/pkg/crd"
"github.com/k3s-io/helm-controller/pkg/version"
command "github.com/rancher/wrangler-cli"
wcrd "github.com/rancher/wrangler/pkg/crd"
_ "github.com/rancher/wrangler/pkg/generated/controllers/apiextensions.k8s.io"
_ "github.com/rancher/wrangler/pkg/generated/controllers/networking.k8s.io"
"github.com/rancher/wrangler/pkg/kubeconfig"
"github.com/rancher/wrangler/pkg/ratelimit"
"github.com/spf13/cobra"
"k8s.io/client-go/tools/clientcmd"
clientcmdapi "k8s.io/client-go/tools/clientcmd/api"
)
var (
debugConfig command.DebugConfig
)
type HelmController struct {
Kubeconfig string `short:"k" usage:"Kubernetes config files, e.g. $HOME/.kube/config" env:"KUBECONFIG"`
MasterURL string `short:"m" usage:"Kubernetes cluster master URL" env:"MASTERURL"`
Namespace string `short:"n" usage:"Namespace to watch, empty means it will watch CRDs in all namespaces." env:"NAMESPACE"`
Threads int `short:"t" usage:"Threadiness level to set, defaults to 2." default:"2" env:"THREADS"`
ControllerName string `usage:"Unique name to identify this controller that is added to all HelmCharts tracked by this controller" default:"helm-controller" env:"CONTROLLER_NAME"`
NodeName string `usage:"Name of the node this controller is running on" env:"NODE_NAME"`
PprofPort int `usage:"Port to publish HTTP server runtime profiling data in the format expected by the pprof visualization tool. Only enabled if in debug mode" default:"6060"`
}
func (a *HelmController) Run(cmd *cobra.Command, args []string) error {
if debugConfig.Debug && a.PprofPort > 0 {
go func() {
// Serves HTTP server runtime profiling data in the format expected by the
// pprof visualization tool at the provided endpoint on the local network
// See https://pkg.go.dev/net/http/pprof?utm_source=gopls for more information
log.Println(http.ListenAndServe(fmt.Sprintf("localhost:%d", a.PprofPort), nil))
}()
}
debugConfig.MustSetupDebug()
cfg := a.GetNonInteractiveClientConfig()
clientConfig, err := cfg.ClientConfig()
if err != nil {
return err
}
clientConfig.RateLimiter = ratelimit.None
ctx := cmd.Context()
if err := wcrd.Create(ctx, clientConfig, crd.List()); err != nil {
return err
}
opts := common.Options{
Threadiness: a.Threads,
NodeName: a.NodeName,
}
if err := opts.Validate(); err != nil {
return err
}
if err := controllers.Register(ctx, a.Namespace, a.ControllerName, cfg, opts); err != nil {
return err
}
<-cmd.Context().Done()
return nil
}
func (a *HelmController) GetNonInteractiveClientConfig() clientcmd.ClientConfig {
// Modified https://github.com/rancher/wrangler/blob/3ecd23dfea3bb4c76cbe8e06fb158eed6ae3dd31/pkg/kubeconfig/loader.go#L12-L32
return clientcmd.NewInteractiveDeferredLoadingClientConfig(
kubeconfig.GetLoadingRules(a.Kubeconfig),
&clientcmd.ConfigOverrides{
ClusterDefaults: clientcmd.ClusterDefaults,
ClusterInfo: clientcmdapi.Cluster{Server: a.MasterURL},
}, nil)
}
func main() {
cmd := command.Command(&HelmController{}, cobra.Command{
Version: version.FriendlyVersion(),
})
cmd = command.AddDebug(cmd, &debugConfig)
command.Main(cmd)
}