Save user's key in opennebula
This commit is contained in:
		
					parent
					
						
							
								cd47af23f1
							
						
					
				
			
			
				commit
				
					
						1d70563ea2
					
				
			
		
					 3 changed files with 35 additions and 52 deletions
				
			
		|  | @ -197,54 +197,7 @@ def create_vm_task(self, vm_template_id, user, specs, template, order_id): | |||
|                 get_or_create_vm_detail(custom_user, manager, vm_id) | ||||
|                 if custom_user is not None: | ||||
|                     public_keys = get_all_public_keys(custom_user) | ||||
|                     keys = [{'value': key, 'state': True} for key in | ||||
|                             public_keys] | ||||
|                     if len(keys) > 0: | ||||
|                         logger.debug( | ||||
|                             "Calling configure on {host} for " | ||||
|                             "{num_keys} keys".format( | ||||
|                                 host=vm_ipv6, num_keys=len(keys) | ||||
|                             ) | ||||
|                         ) | ||||
|                         # Let's wait until the IP responds to ping before we | ||||
|                         # run the cdist configure on the host | ||||
|                         did_manage_public_key = False | ||||
|                         for i in range(0, 15): | ||||
|                             if ping_ok(vm_ipv6): | ||||
|                                 logger.debug( | ||||
|                                     "{} is pingable. Doing a " | ||||
|                                     "manage_public_key".format(vm_ipv6) | ||||
|                                 ) | ||||
|                                 sleep(10) | ||||
|                                 manager.manage_public_key( | ||||
|                                     keys, hosts=[vm_ipv6] | ||||
|                                 ) | ||||
|                                 did_manage_public_key = True | ||||
|                                 break | ||||
|                             else: | ||||
|                                 logger.debug( | ||||
|                                     "Can't ping {}. Wait 5 secs".format( | ||||
|                                         vm_ipv6 | ||||
|                                     ) | ||||
|                                 ) | ||||
|                                 sleep(5) | ||||
|                         if not did_manage_public_key: | ||||
|                             emsg = ("Waited for over 75 seconds for {} to be " | ||||
|                                     "pingable. But the VM was not reachable. " | ||||
|                                     "So, gave up manage_public_key. Please do " | ||||
|                                     "this manually".format(vm_ipv6)) | ||||
|                             logger.error(emsg) | ||||
|                             email_data = { | ||||
|                                 'subject': '{} CELERY TASK INCOMPLETE: {} not ' | ||||
|                                            'pingable for 75 seconds'.format( | ||||
|                                                 settings.DCL_TEXT, vm_ipv6 | ||||
|                                             ), | ||||
|                                 'from_email': current_task.request.hostname, | ||||
|                                 'to': settings.DCL_ERROR_EMAILS_TO_LIST, | ||||
|                                 'body': emsg | ||||
|                             } | ||||
|                             email = EmailMessage(**email_data) | ||||
|                             email.send() | ||||
|                     manager.save_key_in_opennebula('\n'.join(public_keys)) | ||||
|             else: | ||||
|                 logger.debug("VM's ipv6 is None. Hence not created VMDetail") | ||||
|     except Exception as e: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue