-
Notifications
You must be signed in to change notification settings - Fork 109
/
get_node_user_crds.go
executable file
·98 lines (80 loc) · 2.47 KB
/
get_node_user_crds.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
/*
Copyright 2021 Flant JSC
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 hooks
import (
"fmt"
"strings"
"github.com/flant/addon-operator/pkg/module_manager/go_hook"
"github.com/flant/addon-operator/sdk"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"github.com/deckhouse/deckhouse/modules/040-node-manager/hooks/internal/v1alpha1"
)
// get_node_user_crds retrieves all NodeUser CRs, checks uniqueness of UIDs and
// sets nodeManager.internal.nodeUsers value.
var _ = sdk.RegisterFunc(&go_hook.HookConfig{
Queue: "/modules/node-manager",
Kubernetes: []go_hook.KubernetesConfig{
{
Name: "nodeuser",
ApiVersion: "deckhouse.io/v1",
Kind: "NodeUser",
FilterFunc: getNodeUserCRDFilter,
},
},
}, getNodeUserCRDsHandler)
type NodeUserInfo struct {
Name string `json:"name"`
Spec v1alpha1.NodeUserSpec `json:"spec"`
}
func getNodeUserCRDFilter(obj *unstructured.Unstructured) (go_hook.FilterResult, error) {
nodeUser := new(v1alpha1.NodeUser)
err := sdk.FromUnstructured(obj, nodeUser)
if err != nil {
return nil, err
}
return NodeUserInfo{
Name: nodeUser.Name,
Spec: nodeUser.Spec,
}, nil
}
func getNodeUserCRDsHandler(input *go_hook.HookInput) error {
nodeUsers := input.Snapshots["nodeuser"]
if len(nodeUsers) == 0 {
nodeUsers = make([]go_hook.FilterResult, 0)
}
unique := true
idx := make(map[int32][]string)
for _, nodeUser := range nodeUsers {
info := nodeUser.(NodeUserInfo)
uid := info.Spec.UID
if _, has := idx[uid]; !has {
idx[uid] = make([]string, 0)
}
idx[uid] = append(idx[uid], info.Name)
if len(idx[uid]) > 1 {
unique = false
}
}
// Prepare error message with NodeUser names.
if !unique {
msgs := make([]string, 0)
for uid, names := range idx {
if len(names) > 1 {
msgs = append(msgs, fmt.Sprintf("%d in %v", uid, names))
}
}
return fmt.Errorf("UIDs are not unique among NodeUser CRs: %s", strings.Join(msgs, ", "))
}
input.Values.Set("nodeManager.internal.nodeUsers", nodeUsers)
return nil
}