Refactoring, Removal of most global vars, config default path is ~/ucloud/
This commit is contained in:
		
					parent
					
						
							
								bc58a6ed9c
							
						
					
				
			
			
				commit
				
					
						04993e4106
					
				
			
		
					 23 changed files with 673 additions and 726 deletions
				
			
		| 
						 | 
				
			
			@ -23,28 +23,28 @@ class CustomConfigParser(configparser.RawConfigParser):
 | 
			
		|||
class Settings(object):
 | 
			
		||||
    def __init__(self, config_key='/uncloud/config/'):
 | 
			
		||||
        conf_name = 'ucloud.conf'
 | 
			
		||||
        conf_dir = os.environ.get('UCLOUD_CONF_DIR', '/etc/ucloud')
 | 
			
		||||
        config_file = os.path.join(conf_dir, conf_name)
 | 
			
		||||
        conf_dir = os.environ.get('UCLOUD_CONF_DIR', os.path.expanduser('~/ucloud/'))
 | 
			
		||||
        self.config_file = os.path.join(conf_dir, conf_name)
 | 
			
		||||
        
 | 
			
		||||
        self.config_parser = CustomConfigParser(allow_no_value=True)
 | 
			
		||||
        self.config_key = config_key
 | 
			
		||||
 | 
			
		||||
        self.read_internal_values()
 | 
			
		||||
        self.read_config_file_values(config_file)
 | 
			
		||||
        self.config_parser.read(self.config_file)
 | 
			
		||||
 | 
			
		||||
        self.etcd_wrapper_args = tuple()
 | 
			
		||||
        self.etcd_wrapper_kwargs = {
 | 
			
		||||
            'host':      self.config_parser['etcd']['url'],
 | 
			
		||||
            'port':      self.config_parser['etcd']['port'],
 | 
			
		||||
            'ca_cert':   self.config_parser['etcd']['ca_cert'],
 | 
			
		||||
            'cert_cert': self.config_parser['etcd']['cert_cert'],
 | 
			
		||||
            'cert_key':  self.config_parser['etcd']['cert_key']
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    
 | 
			
		||||
    def get_etcd_client(self):
 | 
			
		||||
        args = self.etcd_wrapper_args
 | 
			
		||||
        kwargs = self.etcd_wrapper_kwargs
 | 
			
		||||
        args = tuple()
 | 
			
		||||
        try:
 | 
			
		||||
            kwargs = {
 | 
			
		||||
                'host': self.config_parser.get('etcd', 'url'),
 | 
			
		||||
                'port': self.config_parser.get('etcd', 'port'),
 | 
			
		||||
                'ca_cert': self.config_parser.get('etcd', 'ca_cert'),
 | 
			
		||||
                'cert_cert': self.config_parser.get('etcd','cert_cert'),
 | 
			
		||||
                'cert_key': self.config_parser.get('etcd','cert_key')
 | 
			
		||||
            }
 | 
			
		||||
        except configparser.Error as err:
 | 
			
		||||
            raise configparser.Error('{} in config file {}'.format(err.message, self.config_file)) from err
 | 
			
		||||
 | 
			
		||||
        return Etcd3Wrapper(*args, **kwargs)
 | 
			
		||||
        
 | 
			
		||||
    def read_internal_values(self):
 | 
			
		||||
| 
						 | 
				
			
			@ -78,9 +78,11 @@ class Settings(object):
 | 
			
		|||
        if config_from_etcd:
 | 
			
		||||
            self.config_parser.read_dict(config_from_etcd.value)
 | 
			
		||||
        else:
 | 
			
		||||
            return
 | 
			
		||||
            sys.exit("No settings found in etcd at key {}".format(self.config_key))
 | 
			
		||||
    
 | 
			
		||||
            raise KeyError("Key '{}' not found in etcd".format(self.config_key))
 | 
			
		||||
 | 
			
		||||
    def __getitem__(self, key):
 | 
			
		||||
        self.read_values_from_etcd()
 | 
			
		||||
        return self.config_parser[key]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
settings = Settings()
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue