mirror of
				https://github.com/retspen/webvirtcloud
				synced 2025-07-31 12:41:08 +00:00 
			
		
		
		
	Merge remote-tracking branch 'retspen/master'
Conflicts: conf/requirements.txt
This commit is contained in:
		
						commit
						db1ab88f51
					
				
					 11 changed files with 456 additions and 415 deletions
				
			
		|  | @ -7,9 +7,17 @@ from webvirtcloud.settings import QEMU_CONSOLE_DEFAULT_TYPE | |||
| def get_rbd_storage_data(stg): | ||||
|     xml = stg.XMLDesc(0) | ||||
|     ceph_user = util.get_xml_path(xml, "/pool/source/auth/@username") | ||||
|     ceph_host = util.get_xml_path(xml, "/pool/source/host/@name") | ||||
|     secrt_uuid = util.get_xml_path(xml, "/pool/source/auth/secret/@uuid") | ||||
|     return ceph_user, secrt_uuid, ceph_host | ||||
| 
 | ||||
|     def get_ceph_hosts(ctx): | ||||
|         hosts = [] | ||||
|         for host in ctx.xpathEval("/pool/source/host"): | ||||
|             name = host.prop("name") | ||||
|             if name: | ||||
|                 hosts.append({'name': name, 'port': host.prop("port")}) | ||||
|         return hosts | ||||
|     ceph_hosts = util.get_xml_path(xml, func=get_ceph_hosts) | ||||
|     secret_uuid = util.get_xml_path(xml, "/pool/source/auth/secret/@uuid") | ||||
|     return ceph_user, secret_uuid, ceph_hosts | ||||
| 
 | ||||
| 
 | ||||
| class wvmCreate(wvmConnect): | ||||
|  | @ -40,6 +48,17 @@ class wvmCreate(wvmConnect): | |||
|         """Get guest capabilities""" | ||||
|         return util.get_xml_path(self.get_cap_xml(), "/capabilities/host/cpu/arch") | ||||
| 
 | ||||
|     def get_cache_modes(self): | ||||
|         """Get cache available modes""" | ||||
|         return { | ||||
|             'default': 'Default', | ||||
|             'none': 'Disabled', | ||||
|             'writethrough': 'Write through', | ||||
|             'writeback': 'Write back', | ||||
|             'directsync': 'Direct sync',  # since libvirt 0.9.5 | ||||
|             'unsafe': 'Unsafe',  # since libvirt 0.9.7 | ||||
|         } | ||||
| 
 | ||||
|     def create_volume(self, storage, name, size, format='qcow2', metadata=False): | ||||
|         size = int(size) * 1073741824 | ||||
|         stg = self.get_storage(storage) | ||||
|  | @ -121,7 +140,7 @@ class wvmCreate(wvmConnect): | |||
|         vol = self.get_volume_by_path(path) | ||||
|         vol.delete() | ||||
| 
 | ||||
|     def create_instance(self, name, memory, vcpu, host_model, uuid, images, networks, virtio, mac=None): | ||||
|     def create_instance(self, name, memory, vcpu, host_model, uuid, images, cache_mode, networks, virtio, mac=None): | ||||
|         """ | ||||
|         Create VM function | ||||
|         """ | ||||
|  | @ -162,19 +181,27 @@ class wvmCreate(wvmConnect): | |||
|             stg_type = util.get_xml_path(stg.XMLDesc(0), "/pool/@type") | ||||
| 
 | ||||
|             if stg_type == 'rbd': | ||||
|                 ceph_user, secrt_uuid, ceph_host = get_rbd_storage_data(stg) | ||||
|                 ceph_user, secret_uuid, ceph_hosts = get_rbd_storage_data(stg) | ||||
|                 xml += """<disk type='network' device='disk'> | ||||
|                             <driver name='qemu' type='%s'/> | ||||
|                             <driver name='qemu' type='%s' cache='%s'/> | ||||
|                             <auth username='%s'> | ||||
|                                 <secret type='ceph' uuid='%s'/> | ||||
|                             </auth> | ||||
|                             <source protocol='rbd' name='%s'> | ||||
|                                 <host name='%s' port='6789'/> | ||||
|                             </source>""" % (img_type, ceph_user, secrt_uuid, image, ceph_host) | ||||
|                             <source protocol='rbd' name='%s'>""" % (img_type, cache_mode, ceph_user, secret_uuid, image) | ||||
|                 if isinstance(ceph_hosts, list): | ||||
|                     for host in ceph_hosts: | ||||
|                         if host.get('port'): | ||||
|                             xml += """ | ||||
|                                    <host name='%s' port='%s'/>""" % (host.get('name'), host.get('port')) | ||||
|                         else: | ||||
|                             xml += """ | ||||
|                                    <host name='%s'/>""" % host.get('name') | ||||
|                 xml += """ | ||||
|                             </source>""" | ||||
|             else: | ||||
|                 xml += """<disk type='file' device='disk'> | ||||
|                             <driver name='qemu' type='%s'/> | ||||
|                             <source file='%s'/>""" % (img_type, image) | ||||
|                             <driver name='qemu' type='%s' cache='%s'/> | ||||
|                             <source file='%s'/>""" % (img_type, cache_mode, image) | ||||
| 
 | ||||
|             if virtio: | ||||
|                 xml += """<target dev='vd%s' bus='virtio'/>""" % (disk_letters.pop(0),) | ||||
|  |  | |||
|  | @ -82,7 +82,7 @@ class wvmInstances(wvmConnect): | |||
|         dom = self.get_instance(name) | ||||
|         xml = dom.XMLDesc(VIR_DOMAIN_XML_SECURE) | ||||
|         self.wvm.defineXML(xml) | ||||
|          | ||||
| 
 | ||||
|     def graphics_type(self, name): | ||||
|         inst = self.get_instance(name) | ||||
|         console_type = util.get_xml_path(inst.XMLDesc(0), "/domain/devices/graphics/@type") | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue