mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-04 04:08:16 +00:00 
			
		
		
		
	Avoid creating a new 'err' variable in the 'if'-branch, shadowing the one in the outer scope. Any error from subsequent 'cloud, err = GetCloudProvider()' was not propagated to 'err' variable in the outer scope and thus errors were never returned from this function. This is hard to debug error on OpenStack, when content of --cloud-config= file is wrong or connection to OpenStack fails. Such error is never logged and Kubernetes thinks everything is OK.
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2014 The Kubernetes Authors All rights reserved.
 | 
						|
 | 
						|
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 cloudprovider
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"io"
 | 
						|
	"os"
 | 
						|
	"sync"
 | 
						|
 | 
						|
	"github.com/golang/glog"
 | 
						|
)
 | 
						|
 | 
						|
// Factory is a function that returns a cloudprovider.Interface.
 | 
						|
// The config parameter provides an io.Reader handler to the factory in
 | 
						|
// order to load specific configurations. If no configuration is provided
 | 
						|
// the parameter is nil.
 | 
						|
type Factory func(config io.Reader) (Interface, error)
 | 
						|
 | 
						|
// All registered cloud providers.
 | 
						|
var providersMutex sync.Mutex
 | 
						|
var providers = make(map[string]Factory)
 | 
						|
 | 
						|
// RegisterCloudProvider registers a cloudprovider.Factory by name.  This
 | 
						|
// is expected to happen during app startup.
 | 
						|
func RegisterCloudProvider(name string, cloud Factory) {
 | 
						|
	providersMutex.Lock()
 | 
						|
	defer providersMutex.Unlock()
 | 
						|
	if _, found := providers[name]; found {
 | 
						|
		glog.Fatalf("Cloud provider %q was registered twice", name)
 | 
						|
	}
 | 
						|
	glog.V(1).Infof("Registered cloud provider %q", name)
 | 
						|
	providers[name] = cloud
 | 
						|
}
 | 
						|
 | 
						|
// GetCloudProvider creates an instance of the named cloud provider, or nil if
 | 
						|
// the name is not known.  The error return is only used if the named provider
 | 
						|
// was known but failed to initialize. The config parameter specifies the
 | 
						|
// io.Reader handler of the configuration file for the cloud provider, or nil
 | 
						|
// for no configuation.
 | 
						|
func GetCloudProvider(name string, config io.Reader) (Interface, error) {
 | 
						|
	providersMutex.Lock()
 | 
						|
	defer providersMutex.Unlock()
 | 
						|
	f, found := providers[name]
 | 
						|
	if !found {
 | 
						|
		return nil, nil
 | 
						|
	}
 | 
						|
	return f(config)
 | 
						|
}
 | 
						|
 | 
						|
// InitCloudProvider creates an instance of the named cloud provider.
 | 
						|
func InitCloudProvider(name string, configFilePath string) (Interface, error) {
 | 
						|
	var cloud Interface
 | 
						|
	var err error
 | 
						|
 | 
						|
	if name == "" {
 | 
						|
		glog.Info("No cloud provider specified.")
 | 
						|
		return nil, nil
 | 
						|
	}
 | 
						|
 | 
						|
	if configFilePath != "" {
 | 
						|
		var config *os.File
 | 
						|
		config, err = os.Open(configFilePath)
 | 
						|
		if err != nil {
 | 
						|
			glog.Fatalf("Couldn't open cloud provider configuration %s: %#v",
 | 
						|
				configFilePath, err)
 | 
						|
		}
 | 
						|
 | 
						|
		defer config.Close()
 | 
						|
		cloud, err = GetCloudProvider(name, config)
 | 
						|
	} else {
 | 
						|
		// Pass explicit nil so plugins can actually check for nil. See
 | 
						|
		// "Why is my nil error value not equal to nil?" in golang.org/doc/faq.
 | 
						|
		cloud, err = GetCloudProvider(name, nil)
 | 
						|
	}
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		return nil, fmt.Errorf("could not init cloud provider %q: %v", name, err)
 | 
						|
	}
 | 
						|
	if cloud == nil {
 | 
						|
		return nil, fmt.Errorf("unknown cloud provider %q", name)
 | 
						|
	}
 | 
						|
 | 
						|
	return cloud, nil
 | 
						|
}
 |