Change validators to use the validator_context
Change InstanceKeys to take a namedtuple for context
This commit is contained in:
		
							parent
							
								
									e967fde3ae
								
							
						
					
					
						commit
						554d4f47a8
					
				
					 31 changed files with 172 additions and 69 deletions
				
			
		|  | @ -1,20 +1,21 @@ | |||
| from _init import config_provider | ||||
| from storage import get_storage_driver | ||||
| from util.config.validators import BaseValidator, ConfigValidationException | ||||
| from util.ipresolver import NoopIPResolver | ||||
| 
 | ||||
| ip_resolver = NoopIPResolver() | ||||
| 
 | ||||
| 
 | ||||
| class StorageValidator(BaseValidator): | ||||
|   name = "registry-storage" | ||||
| 
 | ||||
|   @classmethod | ||||
|   def validate(cls, config, user, user_password, app): | ||||
|   def validate(cls, validator_context): | ||||
|     """ Validates registry storage. """ | ||||
|     config = validator_context.config | ||||
|     client = validator_context.http_client | ||||
|     ip_resolver = validator_context.ip_resolver | ||||
| 
 | ||||
|     replication_enabled = config.get('FEATURE_STORAGE_REPLICATION', False) | ||||
| 
 | ||||
|     providers = _get_storage_providers(config).items() | ||||
|     providers = _get_storage_providers(config, ip_resolver).items() | ||||
|     if not providers: | ||||
|       raise ConfigValidationException('Storage configuration required') | ||||
| 
 | ||||
|  | @ -25,7 +26,7 @@ class StorageValidator(BaseValidator): | |||
|                                           'with storage replication') | ||||
| 
 | ||||
|         # Run validation on the driver. | ||||
|         driver.validate(app.config['HTTPCLIENT']) | ||||
|         driver.validate(client) | ||||
| 
 | ||||
|         # Run setup on the driver if the read/write succeeded. | ||||
|         driver.setup() | ||||
|  | @ -34,7 +35,7 @@ class StorageValidator(BaseValidator): | |||
|         raise ConfigValidationException('Invalid storage configuration: %s: %s' % (name, msg)) | ||||
| 
 | ||||
| 
 | ||||
| def _get_storage_providers(config): | ||||
| def _get_storage_providers(config, ip_resolver): | ||||
|   storage_config = config.get('DISTRIBUTED_STORAGE_CONFIG', {}) | ||||
|   drivers = {} | ||||
| 
 | ||||
|  |  | |||
		Reference in a new issue