Get UI for activating github build triggers in place and working. Note that the actual server-side activation is still not done (but the proper method is invoked)
This commit is contained in:
		
							parent
							
								
									c494c889f5
								
							
						
					
					
						commit
						5519d93a64
					
				
					 8 changed files with 388 additions and 15 deletions
				
			
		|  | @ -21,10 +21,12 @@ CHUNK_SIZE = 512 * 1024 | |||
| class BuildArchiveException(Exception): | ||||
|   pass | ||||
| 
 | ||||
| 
 | ||||
| class InvalidServiceException(Exception): | ||||
|   pass | ||||
| 
 | ||||
| class TriggerActivationException(Exception): | ||||
|   pass | ||||
| 
 | ||||
| 
 | ||||
| class BuildTrigger(object): | ||||
|   def __init__(self): | ||||
|  | @ -43,6 +45,18 @@ class BuildTrigger(object): | |||
|     """ | ||||
|     raise NotImplementedError | ||||
| 
 | ||||
|   def is_active(self, config): | ||||
|     """ | ||||
|     Returns True if the current build trigger is active. Inactive means further setup is needed. | ||||
|     """ | ||||
|     raise NotImplementedError | ||||
| 
 | ||||
|   def activate(self, auth_token, config): | ||||
|     """  | ||||
|     Activates the trigger for the service, with the given new configuration. | ||||
|     """ | ||||
|     raise NotImplementedError | ||||
| 
 | ||||
|   @classmethod | ||||
|   def service_name(cls): | ||||
|     """ | ||||
|  | @ -73,15 +87,43 @@ class GithubBuildTrigger(BuildTrigger): | |||
|   def service_name(cls): | ||||
|     return 'github' | ||||
| 
 | ||||
|   def is_active(self, config): | ||||
|     return 'build_source' in config and len(config['build_source']) > 0 | ||||
| 
 | ||||
|   def activate(self, auth_token, config): | ||||
|     # TODO: Add the callback web hook to the github repository. | ||||
|     pass | ||||
| 
 | ||||
|   def list_build_sources(self, auth_token): | ||||
|     gh_client = self._get_client(auth_token) | ||||
|     usr = gh_client.get_user() | ||||
| 
 | ||||
|     repo_list = [repo.full_name for repo in usr.get_repos()] | ||||
|     for org in usr.get_orgs(): | ||||
|       repo_list.extend((repo.full_name for repo in org.get_repos())) | ||||
|     personal = { | ||||
|       'personal': True, | ||||
|       'repos': [repo.full_name for repo in usr.get_repos()], | ||||
|       'info': { | ||||
|         'name': usr.login, | ||||
|         'avatar_url': usr.avatar_url, | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     return repo_list | ||||
|     repos_by_org = [personal] | ||||
| 
 | ||||
|     for org in usr.get_orgs(): | ||||
|       repo_list = [] | ||||
|       for repo in org.get_repos(): | ||||
|         repo_list.append(repo.full_name) | ||||
| 
 | ||||
|       repos_by_org.append({ | ||||
|         'personal': False, | ||||
|         'repos': repo_list, | ||||
|         'info': { | ||||
|           'name': org.name, | ||||
|           'avatar_url': org.avatar_url | ||||
|         } | ||||
|       }) | ||||
| 
 | ||||
|     return repos_by_org | ||||
| 
 | ||||
|   def handle_trigger_request(self, request, auth_token, config): | ||||
|     payload = request.get_json() | ||||
|  | @ -110,4 +152,4 @@ class GithubBuildTrigger(BuildTrigger): | |||
| 
 | ||||
|     logger.debug('Successfully prepared job') | ||||
| 
 | ||||
|     return dockerfile_id, branch_name, commit_id | ||||
|     return dockerfile_id, branch_name, commit_id | ||||
|  |  | |||
		Reference in a new issue