This repository has been archived by the owner on Nov 1, 2022. It is now read-only.
/
secret.go
94 lines (80 loc) · 2.46 KB
/
secret.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
package sync
import (
"context"
"encoding/json"
meta_v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
kubernetes "k8s.io/client-go/kubernetes"
v1 "k8s.io/client-go/kubernetes/typed/core/v1"
"k8s.io/client-go/rest"
)
const syncMarkerKey = "flux.weave.works/sync-hwm"
// NativeSyncProvider keeps information related to the native state of a sync marker stored in a "native" kubernetes resource.
type NativeSyncProvider struct {
namespace string
revision string
resourceName string
resourceAPI v1.SecretInterface
}
// NewNativeSyncProvider creates a new NativeSyncProvider
func NewNativeSyncProvider(namespace string, resourceName string) (NativeSyncProvider, error) {
config, err := rest.InClusterConfig()
if err != nil {
return NativeSyncProvider{}, err
}
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
return NativeSyncProvider{}, err
}
return NativeSyncProvider{
resourceAPI: clientset.CoreV1().Secrets(namespace),
namespace: namespace,
resourceName: resourceName,
}, nil
}
func (p NativeSyncProvider) String() string {
return "kubernetes " + p.namespace + ":secret/" + p.resourceName
}
// GetRevision gets the revision of the current sync marker (representing the place flux has synced to).
func (p NativeSyncProvider) GetRevision(ctx context.Context) (string, error) {
resource, err := p.resourceAPI.Get(ctx, p.resourceName, meta_v1.GetOptions{})
if err != nil {
return "", err
}
revision, exists := resource.Annotations[syncMarkerKey]
if !exists {
return "", p.setRevision(ctx, "")
}
return revision, nil
}
// UpdateMarker updates the revision the sync marker points to.
func (p NativeSyncProvider) UpdateMarker(ctx context.Context, revision string) error {
return p.setRevision(ctx, revision)
}
// DeleteMarker resets the state of the object.
func (p NativeSyncProvider) DeleteMarker(ctx context.Context) error {
return p.setRevision(ctx, "")
}
func (p NativeSyncProvider) setRevision(ctx context.Context, revision string) error {
jsonPatch, err := json.Marshal(patch(revision))
if err != nil {
return err
}
_, err = p.resourceAPI.Patch(
ctx,
p.resourceName,
types.StrategicMergePatchType,
jsonPatch,
meta_v1.PatchOptions{},
)
return err
}
func patch(revision string) map[string]map[string]map[string]string {
return map[string]map[string]map[string]string{
"metadata": map[string]map[string]string{
"annotations": map[string]string{
syncMarkerKey: revision,
},
},
}
}