From 6eb06280c58adfe3e6e551c8a4a8bc9e4dd95d32 Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 29 Aug 2022 14:55:00 +0300 Subject: [PATCH 01/10] add makemigrations command for missing model scripts --- Dockerfile | 1 + 1 file changed, 1 insertion(+) diff --git a/Dockerfile b/Dockerfile index 4f57585..d6b95ce 100644 --- a/Dockerfile +++ b/Dockerfile @@ -41,6 +41,7 @@ RUN python3 -m venv venv && \ chown -R www-data:www-data /srv/webvirtcloud RUN . venv/bin/activate && \ + python3 manage.py makemigrations && \ python3 manage.py migrate && \ python3 manage.py collectstatic --noinput && \ chown -R www-data:www-data /srv/webvirtcloud From 5425519408e0ef3d94b899f138fcc58a791d1991 Mon Sep 17 00:00:00 2001 From: catborise Date: Fri, 2 Sep 2022 16:54:05 +0300 Subject: [PATCH 02/10] change firmware, graphic, video fields max lenght --- instances/models.py | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/instances/models.py b/instances/models.py index fa18483..b376491 100644 --- a/instances/models.py +++ b/instances/models.py @@ -3,7 +3,6 @@ from django.utils.functional import cached_property from django.utils.translation import gettext_lazy as _ from libvirt import VIR_DOMAIN_XML_SECURE -from vrtManager.create import wvmCreate from webvirtcloud.settings import QEMU_CONSOLE_LISTENER_ADDRESSES from computes.models import Compute @@ -228,7 +227,7 @@ class MigrateInstance(models.Model): class CreateInstance(models.Model): compute = models.ForeignKey(Compute, related_name='host', on_delete=models.DO_NOTHING) name = models.CharField(max_length=64, error_messages={'required': _('No Virtual Machine name has been entered')}) - firmware = models.CharField(max_length=50) + firmware = models.CharField(max_length=64) vcpu = models.IntegerField(error_messages={'required': _('No VCPU has been entered')}) vcpu_mode = models.CharField(max_length=20, blank=True) disk = models.IntegerField(blank=True) @@ -238,15 +237,15 @@ class CreateInstance(models.Model): storage = models.CharField(max_length=256, blank=True) template = models.CharField(max_length=256, blank=True) images = models.CharField(max_length=256, blank=True) - cache_mode = models.CharField(max_length=12, error_messages={'required': _('Please select HDD cache mode')}) + cache_mode = models.CharField(max_length=16, error_messages={'required': _('Please select HDD cache mode')}) hdd_size = models.IntegerField(blank=True) meta_prealloc = models.BooleanField(default=False, blank=True) virtio = models.BooleanField(default=True) qemu_ga = models.BooleanField(default=False) mac = models.CharField(max_length=17, blank=True) console_pass = models.CharField(max_length=64, blank=True) - graphics = models.CharField(max_length=12, error_messages={'required': _('Please select a graphics type')}) - video = models.CharField(max_length=12, error_messages={'required': _('Please select a video driver')}) + graphics = models.CharField(max_length=16, error_messages={'required': _('Please select a graphics type')}) + video = models.CharField(max_length=16, error_messages={'required': _('Please select a video driver')}) listener_addr = models.CharField(max_length=20, choices=QEMU_CONSOLE_LISTENER_ADDRESSES) class Meta: From 31c575e852fc08f98aa390978fcfac43c4d3c992 Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 5 Sep 2022 15:35:51 +0300 Subject: [PATCH 03/10] call function with parameter names --- instances/api/viewsets.py | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/instances/api/viewsets.py b/instances/api/viewsets.py index 4960f07..1fb06bb 100644 --- a/instances/api/viewsets.py +++ b/instances/api/viewsets.py @@ -199,24 +199,24 @@ class CreateInstanceViewSet(viewsets.ViewSet): firmware["secure"] = "yes" ret = conn.create_instance( - serializer.validated_data['name'], - serializer.validated_data['memory'], - serializer.validated_data['vcpu'], - serializer.validated_data['vcpu_mode'], - util.randomUUID(), - arch, - machine, - firmware, - volume_list, - serializer.validated_data['networks'], - serializer.validated_data['nwfilter'], - serializer.validated_data['graphics'], - serializer.validated_data['virtio'], - serializer.validated_data['listener_addr'], - serializer.validated_data['video'], - serializer.validated_data['console_pass'], - serializer.validated_data['mac'], - serializer.validated_data['qemu_ga'], + name=serializer.validated_data['name'], + memory=serializer.validated_data['memory'], + vcpu=serializer.validated_data['vcpu'], + vcpu_mode=serializer.validated_data['vcpu_mode'], + uuid=util.randomUUID(), + arch=arch, + machine=machine, + firmware=firmware, + volumes=volume_list, + networks=serializer.validated_data['networks'], + nwfilter=serializer.validated_data['nwfilter'], + graphics=serializer.validated_data['graphics'], + virtio=serializer.validated_data['virtio'], + listener_addr=serializer.validated_data['listener_addr'], + video=serializer.validated_data['video'], + console_pass=serializer.validated_data['console_pass'], + mac=serializer.validated_data['mac'], + qemu_ga=serializer.validated_data['qemu_ga'], ) msg = f"Instance {serializer.validated_data['name']} is created" return Response({'status': msg }) From 97acbd9843152a1e1c922e14441c9f9b747656ff Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 5 Sep 2022 15:36:37 +0300 Subject: [PATCH 04/10] fix typo error --- admin/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/admin/__init__.py b/admin/__init__.py index b7f8a6a..052dc42 100644 --- a/admin/__init__.py +++ b/admin/__init__.py @@ -1 +1 @@ -defautl_app_config = 'admin.apps.AdminConfig' +default_app_config = 'admin.apps.AdminConfig' From 4abf62702a42c7232998f3aef087f92693ac9df7 Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 5 Sep 2022 15:37:23 +0300 Subject: [PATCH 05/10] take over precedense sata to scsi --- vrtManager/create.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/vrtManager/create.py b/vrtManager/create.py index 0044fe0..3084afc 100644 --- a/vrtManager/create.py +++ b/vrtManager/create.py @@ -296,10 +296,10 @@ class wvmCreate(wvmConnect): """ if "ide" in dom_caps["disk_bus"]: xml += """""" % (hd_disk_letters.pop(0), "ide") - elif "sata" in dom_caps["disk_bus"]: - xml += """""" % (sd_disk_letters.pop(0), "sata") elif "scsi" in dom_caps["disk_bus"]: xml += """""" % (sd_disk_letters.pop(0), "scsi") + elif "sata" in dom_caps["disk_bus"]: + xml += """""" % (sd_disk_letters.pop(0), "sata") else: xml += """""" % (vd_disk_letters.pop(0), "virtio") xml += """""" From c804b2cde8fb435a5c656e191611b6c529188937 Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 5 Sep 2022 15:38:00 +0300 Subject: [PATCH 06/10] fix identation --- appsettings/migrations/0006_auto_20220630_0717.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/appsettings/migrations/0006_auto_20220630_0717.py b/appsettings/migrations/0006_auto_20220630_0717.py index b9d9871..9ffc860 100644 --- a/appsettings/migrations/0006_auto_20220630_0717.py +++ b/appsettings/migrations/0006_auto_20220630_0717.py @@ -24,5 +24,5 @@ class Migration(migrations.Migration): ] operations = [ - migrations.RunPython(add_default_settings, del_default_settings), + migrations.RunPython(add_default_settings, del_default_settings), ] From ea6524f79eb2624e7dcc984b4263cfc2857c32ac Mon Sep 17 00:00:00 2001 From: catborise Date: Mon, 5 Sep 2022 15:39:41 +0300 Subject: [PATCH 07/10] add more default machine type and instance type --- .../migrations/0007_auto_20220905_0918.py | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 appsettings/migrations/0007_auto_20220905_0918.py diff --git a/appsettings/migrations/0007_auto_20220905_0918.py b/appsettings/migrations/0007_auto_20220905_0918.py new file mode 100644 index 0000000..229e1cb --- /dev/null +++ b/appsettings/migrations/0007_auto_20220905_0918.py @@ -0,0 +1,21 @@ +# Generated by Django 3.2.13 on 2022-06-30 07:17 + +from django.db import migrations +from django.utils.translation import gettext_lazy as _ + +def update_default_settings(apps, schema_editor): + setting = apps.get_model("appsettings", "AppSettings") + db_alias = schema_editor.connection.alias + setting.objects.using(db_alias).filter(key="INSTANCE_MACHINE_DEFAULT_TYPE").update(choices="q35,x86_64,virt"), + setting.objects.using(db_alias).filter(key="INSTANCE_ARCH_DEFAULT_TYPE").update(choices="x86_64,i686,aarch64"), + + +class Migration(migrations.Migration): + + dependencies = [ + ('appsettings', '0006_auto_20220630_0717'), + ] + + operations = [ + migrations.RunPython(update_default_settings, None) + ] From 5f5bd379af533ed68a7236c3c914bf86dbbe9a98 Mon Sep 17 00:00:00 2001 From: catborise Date: Wed, 7 Sep 2022 13:46:50 +0300 Subject: [PATCH 08/10] make adding cd-rom optional while vm creating. Add default value for cd-rom bus --- .../migrations/0008_auto_20220905_1459.py | 32 ++++++++++++++ instances/models.py | 1 + instances/templates/create_instance_w2.html | 41 +++++++++++++++++- instances/views.py | 3 ++ vrtManager/create.py | 42 ++++++++++--------- vrtManager/util.py | 12 ++++++ 6 files changed, 110 insertions(+), 21 deletions(-) create mode 100644 appsettings/migrations/0008_auto_20220905_1459.py diff --git a/appsettings/migrations/0008_auto_20220905_1459.py b/appsettings/migrations/0008_auto_20220905_1459.py new file mode 100644 index 0000000..2390d5d --- /dev/null +++ b/appsettings/migrations/0008_auto_20220905_1459.py @@ -0,0 +1,32 @@ +# Generated by Django 3.2.13 on 2022-06-30 07:17 + +from django.db import migrations +from django.utils.translation import gettext_lazy as _ + +def add_default_settings(apps, schema_editor): + setting = apps.get_model("appsettings", "AppSettings") + db_alias = schema_editor.connection.alias + setting.objects.using(db_alias).bulk_create([ + setting(32, _("VM CD-ROM Device"), "INSTANCE_CDROM_ADD", "sata", "None,ide,sata,scsi,virtio", _("Add or not cdrom device while instance creating")), + setting(33, _("VM Video Type"), "INSTANCE_VIDEO_DEFAULT_TYPE", "vga", "None,virtio,vga,cirrus,vmvga,bochs,ramfb", _("Change instance default video type")), + setting(34, _("VM Input Device"), "INSTANCE_INPUT_DEFAULT_DEVICE", "default", "None,default,virtio,usb", _("Add or not input device with specify its type")), + ]) + + +def del_default_settings(apps, schema_editor): + setting = apps.get_model("appsettings", "AppSettings") + db_alias = schema_editor.connection.alias + setting.objects.using(db_alias).filter(key="INSTANCE_CDROM_ADD").delete() + setting.objects.using(db_alias).filter(key="INSTANCE_VIDEO_DEFAULT_TYPE").delete() + setting.objects.using(db_alias).filter(key="INSTANCE_INPUT_DEFAULT_DEVICE").delete() + + +class Migration(migrations.Migration): + + dependencies = [ + ('appsettings', '0007_auto_20220905_0918'), + ] + + operations = [ + migrations.RunPython(add_default_settings, del_default_settings), + ] diff --git a/instances/models.py b/instances/models.py index b376491..ec80685 100644 --- a/instances/models.py +++ b/instances/models.py @@ -244,6 +244,7 @@ class CreateInstance(models.Model): qemu_ga = models.BooleanField(default=False) mac = models.CharField(max_length=17, blank=True) console_pass = models.CharField(max_length=64, blank=True) + add_cdrom = models.CharField(max_length=16) graphics = models.CharField(max_length=16, error_messages={'required': _('Please select a graphics type')}) video = models.CharField(max_length=16, error_messages={'required': _('Please select a video driver')}) listener_addr = models.CharField(max_length=20, choices=QEMU_CONSOLE_LISTENER_ADDRESSES) diff --git a/instances/templates/create_instance_w2.html b/instances/templates/create_instance_w2.html index f71328a..4e98676 100644 --- a/instances/templates/create_instance_w2.html +++ b/instances/templates/create_instance_w2.html @@ -227,7 +227,7 @@ {% endif %} {% for video in videos %} - + {% endfor %} @@ -248,6 +248,19 @@ +
+ +
+ +
+
@@ -478,6 +491,19 @@
+
+ +
+ +
+
@@ -694,6 +720,19 @@
+
+ +
+ +
+
diff --git a/instances/views.py b/instances/views.py index ca998e3..ce2db54 100644 --- a/instances/views.py +++ b/instances/views.py @@ -1376,6 +1376,7 @@ def create_instance(request, compute_id, arch, machine): default_cpu_mode = app_settings.INSTANCE_CPU_DEFAULT_MODE instances = conn.get_instances() videos = conn.get_video_models(arch, machine) + default_video = app_settings.INSTANCE_VIDEO_DEFAULT_TYPE cache_modes = sorted(conn.get_cache_modes().items()) default_cache = app_settings.INSTANCE_VOLUME_DEFAULT_CACHE default_io = app_settings.INSTANCE_VOLUME_DEFAULT_IO @@ -1394,6 +1395,7 @@ def create_instance(request, compute_id, arch, machine): nwfilters = conn.get_nwfilters() storages = sorted(conn.get_storages(only_actives=True)) default_graphics = app_settings.QEMU_CONSOLE_DEFAULT_TYPE + default_cdrom = app_settings.INSTANCE_CDROM_ADD dom_caps = conn.get_dom_capabilities(arch, machine) caps = conn.get_capabilities(arch) @@ -1552,6 +1554,7 @@ def create_instance(request, compute_id, arch, machine): console_pass=data["console_pass"], mac=data["mac"], qemu_ga=data["qemu_ga"], + add_cdrom=data["add_cdrom"] ) create_instance = Instance(compute_id=compute_id, name=data["name"], uuid=uuid) create_instance.save() diff --git a/vrtManager/create.py b/vrtManager/create.py index 3084afc..6aaa1a9 100644 --- a/vrtManager/create.py +++ b/vrtManager/create.py @@ -165,6 +165,7 @@ class wvmCreate(wvmConnect): console_pass="random", mac=None, qemu_ga=True, + add_cdrom="sata", ): """ Create VM function @@ -233,7 +234,18 @@ class wvmCreate(wvmConnect): fd_disk_letters = list(string.ascii_lowercase) hd_disk_letters = list(string.ascii_lowercase) sd_disk_letters = list(string.ascii_lowercase) - add_cd = True + def get_letter(bus_type): + if bus_type == "ide": + return hd_disk_letters.pop(0) + elif bus_type in ["sata", "scsi"]: + return sd_disk_letters.pop(0) + elif bus_type == "fdc": + return fd_disk_letters.pop(0) + elif bus_type == "virtio": + return vd_disk_letters.pop(0) + else: + return sd_disk_letters.pop(0) + for volume in volumes: @@ -251,7 +263,7 @@ class wvmCreate(wvmConnect): stg_type = util.get_xml_path(stg.XMLDesc(0), "/pool/@type") if volume["device"] == "cdrom": - add_cd = False + add_cdrom = None if stg_type == "rbd": ceph_user, secret_uuid, ceph_hosts = get_rbd_storage_data(stg) @@ -274,34 +286,24 @@ class wvmCreate(wvmConnect): xml += f""" """ xml += f""" """ - if volume.get("bus") == "virtio": - xml += """""" % (vd_disk_letters.pop(0), volume.get("bus")) - elif volume.get("bus") == "ide": - xml += """""" % (hd_disk_letters.pop(0), volume.get("bus")) - elif volume.get("bus") == "fdc": - xml += """""" % (fd_disk_letters.pop(0), volume.get("bus")) - elif volume.get("bus") in ["sata", "scsi"]: - xml += """""" % (sd_disk_letters.pop(0), volume.get("bus")) + if volume.get("bus") in dom_caps["disk_bus"]: + dev_prefix = util.vol_dev_type(volume.get("bus")) + xml += """""" % (dev_prefix, get_letter(volume.get("bus")), volume.get("bus")) else: - xml += """""" % sd_disk_letters.pop(0) + xml += """""" % get_letter("sata") xml += """""" if volume.get("bus") == "scsi": xml += f"""""" - if add_cd: + if add_cdrom != "None": xml += """ """ - if "ide" in dom_caps["disk_bus"]: - xml += """""" % (hd_disk_letters.pop(0), "ide") - elif "scsi" in dom_caps["disk_bus"]: - xml += """""" % (sd_disk_letters.pop(0), "scsi") - elif "sata" in dom_caps["disk_bus"]: - xml += """""" % (sd_disk_letters.pop(0), "sata") - else: - xml += """""" % (vd_disk_letters.pop(0), "virtio") + if add_cdrom in dom_caps["disk_bus"]: + dev_prefix = util.vol_dev_type(add_cdrom) + xml += """""" % (dev_prefix, get_letter(add_cdrom), add_cdrom) xml += """""" if mac: diff --git a/vrtManager/util.py b/vrtManager/util.py index d618896..ab47f32 100644 --- a/vrtManager/util.py +++ b/vrtManager/util.py @@ -182,3 +182,15 @@ UEFI_ARCH_PATTERNS = { r".*arm/QEMU_EFI.*", # fedora, gerd's firmware repo ], } + + +def vol_dev_type(vol_bus): + if vol_bus == "ide": + return "hd" + elif vol_bus == "fdc": + return "fd" + elif vol_bus == "virtio": + return "vd" + elif vol_bus in ["scsi", "sata"]: + return "sd" + From 481c110f016d4b43ee731b66ca3a5fb92defc381 Mon Sep 17 00:00:00 2001 From: catborise Date: Thu, 8 Sep 2022 08:02:49 +0300 Subject: [PATCH 09/10] make adding input devices optional. give bus control for input devices whie instance creating --- instances/models.py | 1 + instances/templates/create_instance_w2.html | 39 +++++++++++++++++++++ instances/views.py | 5 ++- vrtManager/create.py | 19 +++++----- 4 files changed, 55 insertions(+), 9 deletions(-) diff --git a/instances/models.py b/instances/models.py index ec80685..222f886 100644 --- a/instances/models.py +++ b/instances/models.py @@ -245,6 +245,7 @@ class CreateInstance(models.Model): mac = models.CharField(max_length=17, blank=True) console_pass = models.CharField(max_length=64, blank=True) add_cdrom = models.CharField(max_length=16) + add_input = models.CharField(max_length=16) graphics = models.CharField(max_length=16, error_messages={'required': _('Please select a graphics type')}) video = models.CharField(max_length=16, error_messages={'required': _('Please select a video driver')}) listener_addr = models.CharField(max_length=20, choices=QEMU_CONSOLE_LISTENER_ADDRESSES) diff --git a/instances/templates/create_instance_w2.html b/instances/templates/create_instance_w2.html index 4e98676..d26b2a6 100644 --- a/instances/templates/create_instance_w2.html +++ b/instances/templates/create_instance_w2.html @@ -261,6 +261,19 @@
+
+ +
+ +
+
@@ -504,6 +517,19 @@
+
+ +
+ +
+
@@ -733,6 +759,19 @@
+
+ +
+ +
+
diff --git a/instances/views.py b/instances/views.py index ce2db54..c308b39 100644 --- a/instances/views.py +++ b/instances/views.py @@ -1396,6 +1396,8 @@ def create_instance(request, compute_id, arch, machine): storages = sorted(conn.get_storages(only_actives=True)) default_graphics = app_settings.QEMU_CONSOLE_DEFAULT_TYPE default_cdrom = app_settings.INSTANCE_CDROM_ADD + input_device_buses = ['default', 'virtio', 'usb'] + default_input_device_bus = app_settings.INSTANCE_INPUT_DEFAULT_DEVICE dom_caps = conn.get_dom_capabilities(arch, machine) caps = conn.get_capabilities(arch) @@ -1554,7 +1556,8 @@ def create_instance(request, compute_id, arch, machine): console_pass=data["console_pass"], mac=data["mac"], qemu_ga=data["qemu_ga"], - add_cdrom=data["add_cdrom"] + add_cdrom=data["add_cdrom"], + add_input=data["add_input"], ) create_instance = Instance(compute_id=compute_id, name=data["name"], uuid=uuid) create_instance.save() diff --git a/vrtManager/create.py b/vrtManager/create.py index 6aaa1a9..e686efc 100644 --- a/vrtManager/create.py +++ b/vrtManager/create.py @@ -166,6 +166,7 @@ class wvmCreate(wvmConnect): mac=None, qemu_ga=True, add_cdrom="sata", + add_input="default" ): """ Create VM function @@ -324,14 +325,16 @@ class wvmCreate(wvmConnect): elif console_pass != "": console_pass = "passwd='" + console_pass + "'" - if "usb" in dom_caps["disk_bus"]: - xml += f"""""" - xml += f"""""" - xml += f"""""" - else: - xml += """""" - xml += """""" - xml += """""" + if add_input != "None": + xml += """""" + if add_input in dom_caps["disk_bus"]: + xml += f"""""" + xml += f"""""" + xml += f"""""" + else: + xml += """""" + xml += """""" + xml += """""" xml += f""" From 2ff188da45b4d90fccec4ae242ac989426e6fbc1 Mon Sep 17 00:00:00 2001 From: catborise Date: Thu, 8 Sep 2022 08:15:54 +0300 Subject: [PATCH 10/10] fix add-cdrom error while creating --- vrtManager/create.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/vrtManager/create.py b/vrtManager/create.py index e686efc..63a8f7a 100644 --- a/vrtManager/create.py +++ b/vrtManager/create.py @@ -249,7 +249,6 @@ class wvmCreate(wvmConnect): for volume in volumes: - disk_opts = "" if volume["cache_mode"] is not None and volume["cache_mode"] != "default": disk_opts += f"cache='{volume['cache_mode']}' " @@ -264,7 +263,7 @@ class wvmCreate(wvmConnect): stg_type = util.get_xml_path(stg.XMLDesc(0), "/pool/@type") if volume["device"] == "cdrom": - add_cdrom = None + add_cdrom = "None" if stg_type == "rbd": ceph_user, secret_uuid, ceph_hosts = get_rbd_storage_data(stg)