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,13 +1,16 @@ | |||
| from oauth.services.gitlab import GitLabOAuthService | ||||
| from util.config import URLSchemeAndHostname | ||||
| from util.config.validators import BaseValidator, ConfigValidationException | ||||
| 
 | ||||
| class GitLabTriggerValidator(BaseValidator): | ||||
|   name = "gitlab-trigger" | ||||
| 
 | ||||
|   @classmethod | ||||
|   def validate(cls, config, user, user_password, app): | ||||
|   def validate(cls, validator_context): | ||||
|     """ Validates the OAuth credentials and API endpoint for a GitLab service. """ | ||||
|     config = validator_context.config | ||||
|     url_scheme_and_hostname = validator_context.url_scheme_and_hostname | ||||
|     client = validator_context.http_client | ||||
| 
 | ||||
|     github_config = config.get('GITLAB_TRIGGER_CONFIG') | ||||
|     if not github_config: | ||||
|       raise ConfigValidationException('Missing GitLab client id and client secret') | ||||
|  | @ -23,9 +26,7 @@ class GitLabTriggerValidator(BaseValidator): | |||
|     if not github_config.get('CLIENT_SECRET'): | ||||
|       raise ConfigValidationException('Missing Client Secret') | ||||
| 
 | ||||
|     client = app.config['HTTPCLIENT'] | ||||
|     oauth = GitLabOAuthService(config, 'GITLAB_TRIGGER_CONFIG') | ||||
|     url_scheme_and_hostname = URLSchemeAndHostname(app.config['PREFERRED_URL_SCHEME'], app.config['SERVER_HOSTNAME']) | ||||
|     result = oauth.validate_client_id_and_secret(client, url_scheme_and_hostname) | ||||
|     if not result: | ||||
|       raise ConfigValidationException('Invalid client id or client secret') | ||||
|  |  | |||
		Reference in a new issue