mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	add idempotent and ='s separated parameters to virt module to make people happy
This commit is contained in:
		
					parent
					
						
							
								415f4baa15
							
						
					
				
			
			
				commit
				
					
						8a61794234
					
				
			
		
					 1 changed files with 54 additions and 42 deletions
				
			
		
							
								
								
									
										76
									
								
								library/virt
									
										
									
									
									
								
							
							
						
						
									
										76
									
								
								library/virt
									
										
									
									
									
								
							|  | @ -353,16 +353,11 @@ def main(): | ||||||
|                 'shutdown', 'undefine', 'destroy', 'get_xml', 'autostart'] |                 'shutdown', 'undefine', 'destroy', 'get_xml', 'autostart'] | ||||||
|     host_commands = ['freemem', 'list_vms', 'info', 'nodeinfo', 'virttype'] |     host_commands = ['freemem', 'list_vms', 'info', 'nodeinfo', 'virttype'] | ||||||
|      |      | ||||||
|      |  | ||||||
|     msg = """ |     msg = """ | ||||||
|     virtmodule arguments: |     virtmodule arguments: | ||||||
|     - queryvm guest <queryable item from libvirt domain api> <more of those> |       state=[running|shutdown] guest=guestname | ||||||
|     - guest commands: (all require a single guest name an argument) |       command=some_virt_command  [guest=guestname] | ||||||
|        %s |     """ | ||||||
|     - host commands: |  | ||||||
|        %s |  | ||||||
|      |  | ||||||
|     """ % (', '.join(sorted(vm_commands)), ', '.join(sorted(host_commands))) |  | ||||||
|      |      | ||||||
|     if len(sys.argv) == 1: |     if len(sys.argv) == 1: | ||||||
|         return VIRT_FAILED, msg |         return VIRT_FAILED, msg | ||||||
|  | @ -378,38 +373,55 @@ def main(): | ||||||
|     if not len(items): |     if not len(items): | ||||||
|         return VIRT_FAILED, msg |         return VIRT_FAILED, msg | ||||||
| 
 | 
 | ||||||
|     basecmd = items[0] | 
 | ||||||
|  |     # vm=name state=[running|shutdown|destroyed|undefined] | ||||||
|  |     # command=[some command] [vm=name] | ||||||
|  |      | ||||||
|  |     params = {} | ||||||
|  |     for x in items: | ||||||
|  |         (k, v) = x.split("=") | ||||||
|  |         params[k] = v | ||||||
|  | 
 | ||||||
|  |     state      = params.get('state', None) | ||||||
|  |     guest      = params.get('guest', None) | ||||||
|  |     command    = params.get('command', None) | ||||||
|  |     options    = params.get('options', []) | ||||||
|  | 
 | ||||||
|     v = Virt() |     v = Virt() | ||||||
| 
 |  | ||||||
|     if basecmd in ('queryvm'): |  | ||||||
|         if len(items) < 3: |  | ||||||
|             msg = "queryvm requires at least 2 arguments: guest itemname [itemname]" |  | ||||||
|             return VIRT_FAILED, msg |  | ||||||
|          |  | ||||||
|         guest = items[1] |  | ||||||
|         reqs = items[2:] |  | ||||||
|     res = {} |     res = {} | ||||||
|         for req in reqs: |  | ||||||
|             vm = v.get_vm(guest) |  | ||||||
|             if hasattr(vm, req): |  | ||||||
|                 data = getattr(vm,req)() |  | ||||||
|                 res[req] = data |  | ||||||
|         return rc, res |  | ||||||
|      |      | ||||||
|     # any methods that require the guest/vmid as the argument must be listed here |     if state: | ||||||
|     elif basecmd in vm_commands: |         if not guest: | ||||||
|         if len(items) < 2: |             msg = "state change requires a guest specified" | ||||||
|             msg = "%s requires 1 argument: guest" % basecmd |  | ||||||
|             return VIRT_FAILED, msg |             return VIRT_FAILED, msg | ||||||
|        |        | ||||||
|         guest = items[1] |         res['changed'] = False | ||||||
|         res = getattr(v, basecmd)(guest) |         if state == 'running': | ||||||
|  |             if v.status(guest) is not 'running': | ||||||
|  |                 res['changed'] = True  | ||||||
|  |                 res['msg'] = v.start(guest) | ||||||
|  |         elif state == 'shutdown': | ||||||
|  |             if v.status(guest) is not 'shutdown': | ||||||
|  |                 res['changed'] = True | ||||||
|  |                 res['msg'] = v.shutdown(guest) | ||||||
|  |          | ||||||
|  |         return VIRT_SUCCESS, res | ||||||
|  |          | ||||||
|  |     if command: | ||||||
|  |         if command in vm_commands: | ||||||
|  |             if not guest: | ||||||
|  |                 msg = "%s requires 1 argument: guest" % command | ||||||
|  |                 return VIRT_FAILED, msg | ||||||
|  |                               | ||||||
|  |             res = getattr(v, command)(guest) | ||||||
|             if type(res) != dict: |             if type(res) != dict: | ||||||
|             res = { basecmd: res } |                 res = { command: res } | ||||||
|             return rc, res |             return rc, res | ||||||
|          |          | ||||||
|     elif hasattr(v, basecmd): |         elif hasattr(v, command): | ||||||
|         res = getattr(v, basecmd)() |             res = getattr(v, command)() | ||||||
|  |             if type(res) != dict: | ||||||
|  |                 res = { command: res } | ||||||
|             return rc, res |             return rc, res | ||||||
|              |              | ||||||
|         else: |         else: | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue