PluginInitializer as a new part of NewFromPlugins method

This commit is contained in:
Dominika Hodovska 2016-06-08 15:20:37 +02:00
parent fc0a3c6dcb
commit ba40a528e1
3 changed files with 15 additions and 4 deletions

View File

@ -250,7 +250,10 @@ func Run(s *options.APIServer) error {
pluginInit := admission.NewPluginInitializer()
pluginInit.SetNamespaceInformer(namespaceInformer)
admissionController := admission.NewFromPlugins(client, admissionControlPluginNames, s.AdmissionControlConfigFile)
admissionController, err := admission.NewFromPlugins(client, admissionControlPluginNames, s.AdmissionControlConfigFile, pluginInit)
if err != nil {
glog.Errorf("Failed to initialize plugins: %v", err)
}
genericConfig := genericapiserver.NewConfig(s.ServerRunOptions)
// TODO: Move the following to generic api server as well.

View File

@ -125,7 +125,10 @@ func Run(s *genericoptions.ServerRunOptions) error {
pluginInit := admission.NewPluginInitializer()
pluginInit.SetNamespaceInformer(namespaceInformer)
admissionController := admission.NewFromPlugins(client, admissionControlPluginNames, s.AdmissionControlConfigFile)
admissionController, err := admission.NewFromPlugins(client, admissionControlPluginNames, s.AdmissionControlConfigFile, pluginInit)
if err != nil {
glog.Errorf("Failed to initialize plugins: %v", err)
}
genericConfig := genericapiserver.NewConfig(s)
// TODO: Move the following to generic api server as well.
genericConfig.StorageFactory = storageFactory

View File

@ -23,7 +23,7 @@ type chainAdmissionHandler []Interface
// NewFromPlugins returns an admission.Interface that will enforce admission control decisions of all
// the given plugins.
func NewFromPlugins(client clientset.Interface, pluginNames []string, configFilePath string) Interface {
func NewFromPlugins(client clientset.Interface, pluginNames []string, configFilePath string, plugInit PluginInitializer) (Interface, error) {
plugins := []Interface{}
for _, pluginName := range pluginNames {
plugin := InitPlugin(pluginName, client, configFilePath)
@ -31,7 +31,12 @@ func NewFromPlugins(client clientset.Interface, pluginNames []string, configFile
plugins = append(plugins, plugin)
}
}
return chainAdmissionHandler(plugins)
plugInit.Initialize(plugins)
// ensure that plugins have been properly initialized
if err := Validate(plugins); err != nil {
return nil, err
}
return chainAdmissionHandler(plugins), nil
}
// NewChainHandler creates a new chain handler from an array of handlers. Used for testing.