Add init script to download extra ca certs
This commit is contained in:
		
							parent
							
								
									5b400f4c22
								
							
						
					
					
						commit
						ff294d6c52
					
				
					 7 changed files with 112 additions and 17 deletions
				
			
		|  | @ -10,6 +10,9 @@ proxy_redirect off; | |||
| 
 | ||||
| proxy_set_header Transfer-Encoding $http_transfer_encoding; | ||||
| 
 | ||||
| # The DB migrations sometimes take a while, so increase timeoutso we don't report an error | ||||
| proxy_read_timeout 300s; | ||||
| 
 | ||||
| location / { | ||||
|     proxy_pass   http://web_app_server; | ||||
| } | ||||
|  |  | |||
|  | @ -54,8 +54,8 @@ class SuperUserCustomCertificate(ApiResource): | |||
|       return '', 204 | ||||
| 
 | ||||
|     # Call the update script with config dir location to install the certificate immediately. | ||||
|     if subprocess.call([os.path.join(INIT_SCRIPTS_LOCATION, 'certs_install.sh')], | ||||
|                        env={ 'QUAYCONFIG': config_provider.get_config_dir_path() }) != 0: | ||||
|     cert_dir = os.path.join(config_provider.get_config_dir_path(), EXTRA_CA_DIRECTORY) | ||||
|     if subprocess.call([os.path.join(INIT_SCRIPTS_LOCATION, 'certs_install.sh')], env={ 'CERTDIR': cert_dir }) != 0: | ||||
|       raise Exception('Could not install certificates') | ||||
| 
 | ||||
|     return '', 204 | ||||
|  |  | |||
|  | @ -44,6 +44,10 @@ class TransientDirectoryProvider(FileConfigProvider): | |||
|   def save_configuration_to_kubernetes(self): | ||||
|     data = {} | ||||
| 
 | ||||
|     # Kubernetes secrets don't have sub-directories, so for the extra_ca_certs dir | ||||
|     # we have to put the extra certs in with a prefix, and then one of our init scripts | ||||
|     # (02_get_kube_certs.sh) will expand the prefixed certs into the equivalent directory | ||||
|     # so that they'll be installed correctly on startup by the certs_install script | ||||
|     certs_dir = os.path.join(self.config_volume, EXTRA_CA_DIRECTORY) | ||||
|     if os.path.exists(certs_dir): | ||||
|       for extra_cert in os.listdir(certs_dir): | ||||
|  |  | |||
|  | @ -24,7 +24,7 @@ export class KubeDeployModalComponent { | |||
|         this.state = 'loadingDeployments'; | ||||
| 
 | ||||
|         ApiService.scGetNumDeployments().then(resp => { | ||||
|             this.deploymentsStatus = resp.items.map(dep => ({ name: dep.metadata.name, numPods: dep.status.replicas })); | ||||
|             this.deploymentsStatus = resp.items.map(dep => ({ name: dep.metadata.name, numPods: dep.spec.replicas })); | ||||
|             this.state = 'readyToDeploy'; | ||||
|         }).catch(err => { | ||||
|             this.state = 'error'; | ||||
|  | @ -37,7 +37,7 @@ export class KubeDeployModalComponent { | |||
| 
 | ||||
|     deployConfiguration(): void { | ||||
|         this.ApiService.scDeployConfiguration().then(() => { | ||||
|             const deploymentNames: string[]= this.deploymentsStatus.map(dep => dep.name); | ||||
|             const deploymentNames: string[] = this.deploymentsStatus.map(dep => dep.name); | ||||
| 
 | ||||
|             this.ApiService.scCycleQEDeployments({ deploymentNames }).then(() => { | ||||
|                 this.state = 'deployed' | ||||
|  | @ -46,7 +46,6 @@ export class KubeDeployModalComponent { | |||
|                 this.errorMessage = `Could cycle the deployments with the new configuration. Error: ${err.toString()}`; | ||||
|             }) | ||||
|         }).catch(err => { | ||||
|             console.log(err) | ||||
|             this.state = 'error'; | ||||
|             this.errorMessage = `Could not deploy the configuration. Error: ${err.toString()}`; | ||||
|         }) | ||||
|  |  | |||
		Reference in a new issue