Implemented NetVM selection via drop-down in AppVM creation dialog.
This commit is contained in:
parent
e9f1bb3880
commit
ba0cced495
300
newappvmdlg.ui
300
newappvmdlg.ui
@ -17,149 +17,173 @@
|
|||||||
<iconset>
|
<iconset>
|
||||||
<normaloff>:/qubes.png</normaloff>:/qubes.png</iconset>
|
<normaloff>:/qubes.png</normaloff>:/qubes.png</iconset>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<widget class="QFrame" name="hvmtemplatewarningbox">
|
||||||
<item>
|
<property name="geometry">
|
||||||
<layout class="QGridLayout" name="gridLayout">
|
<rect>
|
||||||
<item row="0" column="3">
|
<x>9</x>
|
||||||
<widget class="QComboBox" name="vmlabel">
|
<y>117</y>
|
||||||
<property name="frame">
|
<width>481</width>
|
||||||
<bool>true</bool>
|
<height>56</height>
|
||||||
</property>
|
</rect>
|
||||||
</widget>
|
</property>
|
||||||
</item>
|
<property name="frameShape">
|
||||||
<item row="1" column="1" colspan="2">
|
<enum>QFrame::NoFrame</enum>
|
||||||
<widget class="QComboBox" name="template_name"/>
|
</property>
|
||||||
</item>
|
<property name="frameShadow">
|
||||||
<item row="1" column="0">
|
<enum>QFrame::Raised</enum>
|
||||||
<widget class="QLabel" name="label_2">
|
</property>
|
||||||
<property name="text">
|
<widget class="QLabel" name="hvmtemplatewarning">
|
||||||
<string>Use this template:</string>
|
<property name="enabled">
|
||||||
</property>
|
<bool>true</bool>
|
||||||
<property name="buddy">
|
</property>
|
||||||
<cstring>template_name</cstring>
|
<property name="geometry">
|
||||||
</property>
|
<rect>
|
||||||
</widget>
|
<x>0</x>
|
||||||
</item>
|
<y>0</y>
|
||||||
<item row="2" column="2">
|
<width>471</width>
|
||||||
<widget class="QRadioButton" name="proxyvm_radio">
|
<height>61</height>
|
||||||
<property name="text">
|
</rect>
|
||||||
<string>ProxyVM</string>
|
</property>
|
||||||
</property>
|
<property name="text">
|
||||||
</widget>
|
<string><html><head/><body><p><span style=" font-weight:600; color:#ff0000;">Make sure that the license of the OS installed in a template VM grants you permission to run multiple instances of an installed system.</span></p></body></html></string>
|
||||||
</item>
|
</property>
|
||||||
<item row="2" column="1">
|
<property name="alignment">
|
||||||
<widget class="QRadioButton" name="netvm_radio">
|
<set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set>
|
||||||
<property name="text">
|
</property>
|
||||||
<string>NetVM</string>
|
<property name="wordWrap">
|
||||||
</property>
|
<bool>true</bool>
|
||||||
</widget>
|
</property>
|
||||||
</item>
|
</widget>
|
||||||
<item row="0" column="1" colspan="2">
|
</widget>
|
||||||
<widget class="QLineEdit" name="vmname">
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
<property name="text">
|
<property name="geometry">
|
||||||
<string>my-new-vm</string>
|
<rect>
|
||||||
</property>
|
<x>330</x>
|
||||||
</widget>
|
<y>180</y>
|
||||||
</item>
|
<width>160</width>
|
||||||
<item row="2" column="0">
|
<height>27</height>
|
||||||
<widget class="QRadioButton" name="appvm_radio">
|
</rect>
|
||||||
<property name="text">
|
</property>
|
||||||
<string>AppVM</string>
|
<property name="orientation">
|
||||||
</property>
|
<enum>Qt::Horizontal</enum>
|
||||||
<property name="checked">
|
</property>
|
||||||
<bool>true</bool>
|
<property name="standardButtons">
|
||||||
</property>
|
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||||
</widget>
|
</property>
|
||||||
</item>
|
</widget>
|
||||||
<item row="2" column="3">
|
<widget class="QWidget" name="">
|
||||||
<widget class="QRadioButton" name="hvm_radio">
|
<property name="geometry">
|
||||||
<property name="enabled">
|
<rect>
|
||||||
<bool>false</bool>
|
<x>14</x>
|
||||||
</property>
|
<y>14</y>
|
||||||
<property name="text">
|
<width>471</width>
|
||||||
<string>HVM</string>
|
<height>103</height>
|
||||||
</property>
|
</rect>
|
||||||
</widget>
|
</property>
|
||||||
</item>
|
<layout class="QGridLayout" name="gridLayout">
|
||||||
<item row="0" column="0">
|
<item row="0" column="0" colspan="2">
|
||||||
<widget class="QLabel" name="label">
|
<widget class="QLabel" name="label">
|
||||||
<property name="text">
|
|
||||||
<string>Name & label:</string>
|
|
||||||
</property>
|
|
||||||
<property name="buddy">
|
|
||||||
<cstring>vmname</cstring>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="1" column="3">
|
|
||||||
<widget class="QCheckBox" name="standalone">
|
|
||||||
<property name="text">
|
|
||||||
<string>Standalone</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="3" column="3">
|
|
||||||
<widget class="QRadioButton" name="hvmtpl_radio">
|
|
||||||
<property name="enabled">
|
|
||||||
<bool>false</bool>
|
|
||||||
</property>
|
|
||||||
<property name="text">
|
|
||||||
<string>HVM template</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="3" column="0">
|
|
||||||
<widget class="QCheckBox" name="allow_networking">
|
|
||||||
<property name="text">
|
|
||||||
<string>Allow networking</string>
|
|
||||||
</property>
|
|
||||||
<property name="checked">
|
|
||||||
<bool>true</bool>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<widget class="QFrame" name="hvmtemplatewarningbox">
|
|
||||||
<property name="frameShape">
|
|
||||||
<enum>QFrame::NoFrame</enum>
|
|
||||||
</property>
|
|
||||||
<property name="frameShadow">
|
|
||||||
<enum>QFrame::Raised</enum>
|
|
||||||
</property>
|
|
||||||
<widget class="QLabel" name="hvmtemplatewarning">
|
|
||||||
<property name="enabled">
|
|
||||||
<bool>true</bool>
|
|
||||||
</property>
|
|
||||||
<property name="geometry">
|
|
||||||
<rect>
|
|
||||||
<x>0</x>
|
|
||||||
<y>0</y>
|
|
||||||
<width>482</width>
|
|
||||||
<height>51</height>
|
|
||||||
</rect>
|
|
||||||
</property>
|
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string><html><head/><body><p><span style=" font-weight:600; color:#ff0000;">Make sure that the license of the OS installed in a template VM grants you permission to run multiple instances of an installed system.</span></p></body></html></string>
|
<string>Name and label:</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="wordWrap">
|
<property name="buddy">
|
||||||
|
<cstring>vmname</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="0" column="2" colspan="3">
|
||||||
|
<widget class="QLineEdit" name="vmname">
|
||||||
|
<property name="text">
|
||||||
|
<string>my-new-vm</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="0" column="5">
|
||||||
|
<widget class="QComboBox" name="vmlabel">
|
||||||
|
<property name="frame">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</widget>
|
</item>
|
||||||
</item>
|
<item row="1" column="0" colspan="2">
|
||||||
<item>
|
<widget class="QLabel" name="label_2">
|
||||||
<widget class="QDialogButtonBox" name="buttonBox">
|
<property name="text">
|
||||||
<property name="orientation">
|
<string>Use this template:</string>
|
||||||
<enum>Qt::Horizontal</enum>
|
</property>
|
||||||
</property>
|
<property name="buddy">
|
||||||
<property name="standardButtons">
|
<cstring>template_name</cstring>
|
||||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
</property>
|
||||||
</property>
|
</widget>
|
||||||
</widget>
|
</item>
|
||||||
</item>
|
<item row="1" column="2" colspan="3">
|
||||||
</layout>
|
<widget class="QComboBox" name="template_name"/>
|
||||||
|
</item>
|
||||||
|
<item row="1" column="5">
|
||||||
|
<widget class="QCheckBox" name="standalone">
|
||||||
|
<property name="text">
|
||||||
|
<string>Standalone</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="0">
|
||||||
|
<widget class="QRadioButton" name="appvm_radio">
|
||||||
|
<property name="text">
|
||||||
|
<string>AppVM</string>
|
||||||
|
</property>
|
||||||
|
<property name="checked">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="1" colspan="2">
|
||||||
|
<widget class="QRadioButton" name="netvm_radio">
|
||||||
|
<property name="text">
|
||||||
|
<string>NetVM</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="3">
|
||||||
|
<widget class="QRadioButton" name="proxyvm_radio">
|
||||||
|
<property name="text">
|
||||||
|
<string>ProxyVM</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="4">
|
||||||
|
<widget class="QRadioButton" name="hvm_radio">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>HVM</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="5">
|
||||||
|
<widget class="QRadioButton" name="hvmtpl_radio">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>HVM template</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="3" column="0" colspan="2">
|
||||||
|
<widget class="QCheckBox" name="allow_networking">
|
||||||
|
<property name="text">
|
||||||
|
<string>Allow networking:</string>
|
||||||
|
</property>
|
||||||
|
<property name="checked">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="3" column="2" colspan="3">
|
||||||
|
<widget class="QComboBox" name="netvm_name"/>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
<tabstops>
|
<tabstops>
|
||||||
<tabstop>vmname</tabstop>
|
<tabstop>vmname</tabstop>
|
||||||
|
@ -72,6 +72,7 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
self.vmlabel.setItemIcon (i, QIcon(label.icon_path))
|
self.vmlabel.setItemIcon (i, QIcon(label.icon_path))
|
||||||
|
|
||||||
self.fill_template_list()
|
self.fill_template_list()
|
||||||
|
self.fill_netvm_list()
|
||||||
|
|
||||||
self.vmname.setValidator(QRegExpValidator(QRegExp("[a-zA-Z0-9-]*", Qt.CaseInsensitive), None))
|
self.vmname.setValidator(QRegExpValidator(QRegExp("[a-zA-Z0-9-]*", Qt.CaseInsensitive), None))
|
||||||
self.vmname.selectAll()
|
self.vmname.selectAll()
|
||||||
@ -103,24 +104,60 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
self.template_name.insertItem(i, vm.name)
|
self.template_name.insertItem(i, vm.name)
|
||||||
self.template_name.setCurrentIndex(default_index)
|
self.template_name.setCurrentIndex(default_index)
|
||||||
|
|
||||||
|
def fill_netvm_list(self):
|
||||||
|
def filter_netvm(vm):
|
||||||
|
if vm.internal:
|
||||||
|
return False
|
||||||
|
if vm.is_netvm():
|
||||||
|
return True
|
||||||
|
if vm.is_proxyvm():
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
self.netvm_list = filter(filter_netvm, self.qvm_collection.values())
|
||||||
|
|
||||||
|
self.netvm_name.clear()
|
||||||
|
default_index = 0
|
||||||
|
for (i, vm) in enumerate(self.netvm_list):
|
||||||
|
if vm is self.qvm_collection.get_default_netvm():
|
||||||
|
default_index = i
|
||||||
|
self.netvm_name.insertItem(i, vm.name + " (default)")
|
||||||
|
else:
|
||||||
|
self.netvm_name.insertItem(i, vm.name)
|
||||||
|
self.netvm_name.setCurrentIndex(default_index)
|
||||||
|
|
||||||
|
def on_allow_networking_toggled(self, checked):
|
||||||
|
if checked:
|
||||||
|
self.fill_netvm_list()
|
||||||
|
self.netvm_name.setEnabled(True)
|
||||||
|
else:
|
||||||
|
self.netvm_name.clear()
|
||||||
|
self.netvm_name.setEnabled(False)
|
||||||
|
|
||||||
def on_appvm_radio_toggled(self, checked):
|
def on_appvm_radio_toggled(self, checked):
|
||||||
if checked:
|
if checked:
|
||||||
self.template_name.setEnabled(True)
|
self.template_name.setEnabled(True)
|
||||||
self.allow_networking.setEnabled(True)
|
self.allow_networking.setEnabled(True)
|
||||||
|
self.netvm_name.setEnabled(self.allow_networking.isChecked())
|
||||||
|
|
||||||
def on_netvm_radio_toggled(self, checked):
|
def on_netvm_radio_toggled(self, checked):
|
||||||
if checked:
|
if checked:
|
||||||
self.template_name.setEnabled(True)
|
self.template_name.setEnabled(True)
|
||||||
|
self.allow_networking.setChecked(True)
|
||||||
self.allow_networking.setEnabled(False)
|
self.allow_networking.setEnabled(False)
|
||||||
|
self.netvm_name.setEnabled(False)
|
||||||
|
|
||||||
def on_proxyvm_radio_toggled(self, checked):
|
def on_proxyvm_radio_toggled(self, checked):
|
||||||
if checked:
|
if checked:
|
||||||
self.template_name.setEnabled(True)
|
self.template_name.setEnabled(True)
|
||||||
self.allow_networking.setEnabled(True)
|
self.allow_networking.setEnabled(True)
|
||||||
|
self.netvm_name.setEnabled(self.allow_networking.isChecked())
|
||||||
|
|
||||||
def on_hvm_radio_toggled(self, checked):
|
def on_hvm_radio_toggled(self, checked):
|
||||||
if self.hvm_radio.isChecked() or self.hvmtpl_radio.isChecked():
|
if self.hvm_radio.isChecked() or self.hvmtpl_radio.isChecked():
|
||||||
self.standalone.setChecked(True)
|
self.standalone.setChecked(True)
|
||||||
self.allow_networking.setEnabled(True)
|
self.allow_networking.setEnabled(True)
|
||||||
|
self.netvm_name.setEnabled(self.allow_networking.isChecked())
|
||||||
self.standalone.setEnabled(self.hvm_radio.isChecked())
|
self.standalone.setEnabled(self.hvm_radio.isChecked())
|
||||||
else:
|
else:
|
||||||
self.standalone.setChecked(False)
|
self.standalone.setChecked(False)
|
||||||
@ -157,6 +194,10 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
if self.template_name.isEnabled():
|
if self.template_name.isEnabled():
|
||||||
template_vm = self.template_vm_list[self.template_name.currentIndex()]
|
template_vm = self.template_vm_list[self.template_name.currentIndex()]
|
||||||
|
|
||||||
|
netvm = None
|
||||||
|
if self.netvm_name.isEnabled():
|
||||||
|
netvm = self.netvm_list[self.netvm_name.currentIndex()]
|
||||||
|
|
||||||
standalone = self.standalone.isChecked()
|
standalone = self.standalone.isChecked()
|
||||||
|
|
||||||
allow_networking = None
|
allow_networking = None
|
||||||
@ -181,7 +222,7 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
|
|
||||||
vmclass = "Qubes" + vmtype.replace("VM", "Vm")
|
vmclass = "Qubes" + vmtype.replace("VM", "Vm")
|
||||||
thread_monitor = ThreadMonitor()
|
thread_monitor = ThreadMonitor()
|
||||||
thread = threading.Thread (target=self.do_create_vm, args=(vmclass, vmname, label, template_vm, standalone, allow_networking, thread_monitor))
|
thread = threading.Thread (target=self.do_create_vm, args=(vmclass, vmname, label, template_vm, netvm, standalone, allow_networking, thread_monitor))
|
||||||
thread.daemon = True
|
thread.daemon = True
|
||||||
thread.start()
|
thread.start()
|
||||||
|
|
||||||
@ -205,7 +246,7 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
def do_create_vm (self, vmclass, vmname, label, template_vm, standalone, allow_networking, thread_monitor):
|
def do_create_vm (self, vmclass, vmname, label, template_vm, netvm, standalone, allow_networking, thread_monitor):
|
||||||
vm = None
|
vm = None
|
||||||
try:
|
try:
|
||||||
self.qvm_collection.lock_db_for_writing()
|
self.qvm_collection.lock_db_for_writing()
|
||||||
@ -220,6 +261,13 @@ class NewVmDlg (QDialog, Ui_NewVMDlg):
|
|||||||
if allow_networking == False:
|
if allow_networking == False:
|
||||||
vm.uses_default_netvm = False
|
vm.uses_default_netvm = False
|
||||||
vm.netvm = None
|
vm.netvm = None
|
||||||
|
else:
|
||||||
|
vm.netvm = netvm
|
||||||
|
if vm.netvm == self.qvm_collection.get_default_netvm():
|
||||||
|
vm.uses_default_netvm = True
|
||||||
|
else:
|
||||||
|
vm.uses_default_netvm = False
|
||||||
|
|
||||||
self.qvm_collection.save()
|
self.qvm_collection.save()
|
||||||
|
|
||||||
except Exception as ex:
|
except Exception as ex:
|
||||||
|
Loading…
Reference in New Issue
Block a user