@@ -27,8 +27,8 @@ import (
27
27
genericapiserver "k8s.io/apiserver/pkg/server"
28
28
29
29
"github.com/kubernetes-incubator/custom-metrics-apiserver/pkg/provider"
30
- cm_install "k8s.io/metrics/pkg/apis/custom_metrics/install"
31
- em_install "k8s.io/metrics/pkg/apis/external_metrics/install"
30
+ cminstall "k8s.io/metrics/pkg/apis/custom_metrics/install"
31
+ eminstall "k8s.io/metrics/pkg/apis/external_metrics/install"
32
32
)
33
33
34
34
var (
39
39
)
40
40
41
41
func init () {
42
- cm_install .Install (groupFactoryRegistry , registry , Scheme )
43
- em_install .Install (groupFactoryRegistry , registry , Scheme )
42
+ cminstall .Install (groupFactoryRegistry , registry , Scheme )
43
+ eminstall .Install (groupFactoryRegistry , registry , Scheme )
44
44
45
45
// we need to add the options to empty v1
46
46
// TODO fix the server code to avoid this
@@ -63,8 +63,9 @@ type Config struct {
63
63
64
64
// CustomMetricsAdapterServer contains state for a Kubernetes cluster master/api server.
65
65
type CustomMetricsAdapterServer struct {
66
- GenericAPIServer * genericapiserver.GenericAPIServer
67
- Provider provider.MetricsProvider
66
+ GenericAPIServer * genericapiserver.GenericAPIServer
67
+ customMetricsProvider provider.CustomMetricsProvider
68
+ externalMetricsProvider provider.ExternalMetricsProvider
68
69
}
69
70
70
71
type completedConfig struct {
@@ -82,23 +83,26 @@ func (c *Config) Complete() completedConfig {
82
83
83
84
// New returns a new instance of CustomMetricsAdapterServer from the given config.
84
85
// name is used to differentiate for logging.
85
- func (c completedConfig ) New (name string , metricsProvider provider.MetricsProvider , enableCustomMetricsAPI bool , enableExternalMetricsAPI bool ) (* CustomMetricsAdapterServer , error ) {
86
+ // Each of the arguments: customMetricsProvider, externalMetricsProvider can be set either to
87
+ // a provider implementation, or to nil to disable one of the APIs.
88
+ func (c completedConfig ) New (name string , customMetricsProvider provider.CustomMetricsProvider , externalMetricsProvider provider.ExternalMetricsProvider ) (* CustomMetricsAdapterServer , error ) {
86
89
genericServer , err := c .CompletedConfig .New (name , genericapiserver .EmptyDelegate ) // completion is done in Complete, no need for a second time
87
90
if err != nil {
88
91
return nil , err
89
92
}
90
93
91
94
s := & CustomMetricsAdapterServer {
92
- GenericAPIServer : genericServer ,
93
- Provider : metricsProvider ,
95
+ GenericAPIServer : genericServer ,
96
+ customMetricsProvider : customMetricsProvider ,
97
+ externalMetricsProvider : externalMetricsProvider ,
94
98
}
95
99
96
- if enableCustomMetricsAPI {
100
+ if customMetricsProvider != nil {
97
101
if err := s .InstallCustomMetricsAPI (); err != nil {
98
102
return nil , err
99
103
}
100
104
}
101
- if enableExternalMetricsAPI {
105
+ if externalMetricsProvider != nil {
102
106
if err := s .InstallExternalMetricsAPI (); err != nil {
103
107
return nil , err
104
108
}
0 commit comments