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