forked from minishift/minishift
/
util.go
88 lines (72 loc) · 2.73 KB
/
util.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
/*
Copyright (C) 2017 Red Hat, Inc.
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 addon
import (
"fmt"
"reflect"
"github.com/minishift/minishift/cmd/minishift/cmd/config"
"github.com/minishift/minishift/pkg/minikube/constants"
"github.com/minishift/minishift/pkg/minishift/addon"
"github.com/minishift/minishift/pkg/minishift/addon/manager"
"github.com/minishift/minishift/pkg/util/os/atexit"
)
// GetAddOnManager returns the addon manager
func GetAddOnManager() *manager.AddOnManager {
addOnConfigs := GetAddOnConfiguration()
m, err := manager.NewAddOnManager(constants.MakeMiniPath("addons"), addOnConfigs)
if err != nil {
atexit.ExitWithMessage(1, fmt.Sprintf("Cannot initialize the add-on manager: %s", err.Error()))
}
return m
}
func WriteAddOnConfig(addOnConfigMap map[string]*addon.AddOnConfig) {
c, err := config.ReadConfig()
if err != nil {
atexit.ExitWithMessage(1, fmt.Sprintf("Cannot read the Minishift configuration: %s", err.Error()))
}
c[addOnConfigKey] = addOnConfigMap
err = config.WriteConfig(c)
if err != nil {
atexit.ExitWithMessage(1, fmt.Sprintf("Cannot write the Minishift configuration: %s", err.Error()))
}
}
// GetAddOnConfiguration reads the Minishift configuration in $MINISHIFT_HOME/config/config.json related to addons and returns
// a map of addon names to AddOnConfig
func GetAddOnConfiguration() map[string]*addon.AddOnConfig {
c, err := config.ReadConfig()
if err != nil {
atexit.ExitWithMessage(1, fmt.Sprintf("Cannot read the Minishift configuration: %s", err.Error()))
}
var configSlice map[string]interface{}
if c[addOnConfigKey] != nil {
configSlice = c[addOnConfigKey].(map[string]interface{})
} else {
configSlice = make(map[string]interface{})
}
addOnConfigs := make(map[string]*addon.AddOnConfig)
for _, entry := range configSlice {
addOnConfig := &addon.AddOnConfig{}
addOnMap := entry.(map[string]interface{})
fillStruct(addOnMap, addOnConfig)
addOnConfigs[addOnConfig.Name] = addOnConfig
}
return addOnConfigs
}
// fillStruct populates the specified result struct with the data provided in the data map
func fillStruct(data map[string]interface{}, result interface{}) {
t := reflect.ValueOf(result).Elem()
for k, v := range data {
val := t.FieldByName(k)
val.Set(reflect.ValueOf(v))
}
}