forked from virtual-kubelet/systemk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.go
93 lines (82 loc) · 2.43 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
// Copyright © 2017 The virtual-kubelet authors
//
// 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 (
"context"
"fmt"
"log"
"net/http"
"strings"
"github.com/gorilla/mux"
"github.com/miekg/vks/pkg/system"
"github.com/miekg/vks/systemd"
"github.com/spf13/pflag"
cli "github.com/virtual-kubelet/node-cli"
"github.com/virtual-kubelet/node-cli/opts"
"github.com/virtual-kubelet/node-cli/provider"
)
var (
buildVersion = "N/A"
buildTime = "N/A"
k8sVersion = "v1.18.4" // Inject this build time by parsing mod.go
)
func main() {
var (
certFile string
keyFile string
)
flags := pflag.NewFlagSet("client", pflag.ContinueOnError)
flags.StringVar(&certFile, "certfile", "", "certfile")
flags.StringVar(&keyFile, "keyfile", "", "keyfile")
ctx := cli.ContextWithCancelOnSignal(context.Background())
o, err := opts.FromEnv()
if err != nil {
log.Fatal(err)
}
o.Provider = "systemd"
o.Version = strings.Join([]string{k8sVersion, "vk-systemd", buildVersion}, "-")
o.NodeName = system.Hostname()
node, err := cli.New(ctx,
cli.WithBaseOpts(o),
cli.WithPersistentFlags(flags),
cli.WithCLIVersion(buildVersion, buildTime),
cli.WithKubernetesNodeVersion(k8sVersion),
cli.WithProvider("systemd", func(cfg provider.InitConfig) (provider.Provider, error) {
p, err := systemd.New(cfg)
if err != nil {
return p, err
}
if certFile == "" || keyFile == "" {
log.Printf("Not certificates found, disabling GetContainerLogs")
return p, nil
}
r := mux.NewRouter()
r.HandleFunc("/containerLogs/{namespace}/{pod}/{container}", p.GetContainerLogsHandler).Methods("GET")
r.NotFoundHandler = http.HandlerFunc(p.NotFound)
go func() {
err := http.ListenAndServeTLS(fmt.Sprintf(":%d", cfg.DaemonPort), certFile, keyFile, r)
if err != nil {
log.Fatal(err)
}
}()
return p, nil
}),
)
if err != nil {
log.Fatal(err)
}
if err := node.Run(ctx); err != nil {
log.Fatal(err)
}
}