/
provider.go
107 lines (90 loc) · 2.76 KB
/
provider.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
99
100
101
102
103
104
105
106
107
package cluster
import (
"path"
"strings"
devopsv1 "github.com/wtxue/kok-operator/pkg/apis/devops/v1"
"github.com/wtxue/kok-operator/pkg/constants"
"github.com/wtxue/kok-operator/pkg/controllers/common"
"github.com/wtxue/kok-operator/pkg/provider/baremetal/validation"
clusterprovider "github.com/wtxue/kok-operator/pkg/provider/cluster"
"github.com/wtxue/kok-operator/pkg/provider/config"
"github.com/wtxue/kok-operator/pkg/util/pointer"
"k8s.io/apimachinery/pkg/util/validation/field"
"k8s.io/apiserver/pkg/server/mux"
)
func Add(mgr *clusterprovider.CpManager, cfg *config.Config) error {
p, err := NewProvider(mgr, cfg)
if err != nil {
return err
}
mgr.Register(p.Name(), p)
return nil
}
type Provider struct {
*clusterprovider.DelegateProvider
Mgr *clusterprovider.CpManager
Cfg *config.Config
}
var _ clusterprovider.Provider = &Provider{}
func NewProvider(mgr *clusterprovider.CpManager, cfg *config.Config) (*Provider, error) {
p := &Provider{
Mgr: mgr,
Cfg: cfg,
}
p.DelegateProvider = &clusterprovider.DelegateProvider{
ProviderName: "hosted",
CreateHandlers: []clusterprovider.Handler{
p.EnsureCopyFiles,
p.EnsurePreInstallHook,
p.EnsureClusterComplete,
p.EnsureEtcd,
p.EnsureCerts,
p.EnsureKubeMisc,
p.EnsureKubeMaster,
p.EnsureExtKubeconfig,
p.EnsurePostInstallHook,
},
UpdateHandlers: []clusterprovider.Handler{
p.EnsureExtKubeconfig,
p.EnsureKubeMaster,
p.EnsureAddons,
p.EnsureCni,
p.EnsureMetricsServer,
},
}
return p, nil
}
func (p *Provider) RegisterHandler(mux *mux.PathRecorderMux) {
prefix := "/provider/" + strings.ToLower(p.Name())
mux.HandleFunc(path.Join(prefix, "ping"), p.ping)
}
func (p *Provider) Validate(ctx *common.ClusterContext) field.ErrorList {
return validation.ValidateCluster(ctx)
}
func (p *Provider) PreCreate(ctx *common.ClusterContext) error {
if ctx.Cluster.Spec.Version == "" {
ctx.Cluster.Spec.Version = constants.K8sVersions[0]
}
if ctx.Cluster.Spec.ClusterCIDR == "" {
ctx.Cluster.Spec.ClusterCIDR = "10.244.0.0/16"
}
if ctx.Cluster.Spec.NetworkDevice == "" {
ctx.Cluster.Spec.NetworkDevice = "eth0"
}
if ctx.Cluster.Spec.Features.IPVS == nil {
ctx.Cluster.Spec.Features.IPVS = pointer.ToBool(true)
}
if ctx.Cluster.Spec.Properties.MaxClusterServiceNum == nil && ctx.Cluster.Spec.ServiceCIDR == nil {
ctx.Cluster.Spec.Properties.MaxClusterServiceNum = pointer.ToInt32(256)
}
if ctx.Cluster.Spec.Properties.MaxNodePodNum == nil {
ctx.Cluster.Spec.Properties.MaxNodePodNum = pointer.ToInt32(256)
}
if ctx.Cluster.Spec.Features.SkipConditions == nil {
ctx.Cluster.Spec.Features.SkipConditions = p.Cfg.Feature.SkipConditions
}
if ctx.Cluster.Spec.Etcd == nil {
ctx.Cluster.Spec.Etcd = &devopsv1.Etcd{Local: &devopsv1.LocalEtcd{}}
}
return nil
}