-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommon.go
79 lines (70 loc) · 1.62 KB
/
common.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
package providers
import (
"context"
"encoding/json"
"github.com/chenyu116/node-dynamic-ip/logger"
"go.uber.org/zap"
"io"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
"log"
"time"
)
const (
pattern = "((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})(\\.((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})){3}"
stepPending = iota
stepGetContent
stepDecode
stepPatched
)
func patch(name, ip string) error {
k8sConfig, err := rest.InClusterConfig()
if err != nil {
log.Fatal(err)
}
clientSet, err := kubernetes.NewForConfig(k8sConfig)
if err != nil {
log.Fatal(err)
}
patchTemplate := map[string]interface{}{
"metadata": map[string]interface{}{
"annotations": map[string]interface{}{
"flannel.alpha.coreos.com/public-ip": ip,
},
},
}
patchData, _ := json.Marshal(patchTemplate)
logger.Zap.Info("[patch]", zap.ByteString("patchData", patchData))
_, err = clientSet.CoreV1().Nodes().Patch(context.Background(), name, types.StrategicMergePatchType, patchData, metav1.PatchOptions{})
if err != nil {
logger.Zap.Error("[patch]", zap.Error(err))
return err
}
return nil
}
type Provider interface {
Sync()
Decode(reader io.Reader) (string, error)
}
type ProviderConfig struct {
NodeName string
CheckInterval time.Duration
URL string
}
func NewSyncer() *syncer {
return new(syncer)
}
type syncer struct {
providers []Provider
}
func (s *syncer) Register(provider ...Provider) {
s.providers = append(s.providers, provider...)
}
func (s *syncer) Start() {
for _, p := range s.providers {
go p.Sync()
}
select {}
}