Merge remote-tracking branch 'qubesos/pr/74'

* qubesos/pr/74:
  Apply changes in global settings only when actual changes occurred
  Fix pylint's critique
  Fixed minor error in previous fix
  Replaced single check vm updates checkbox
  Restored check-dom0-updates functionality in Global Settings
  De-uglify kernel selection in Global Settings
  De-uglify default template in Global Settings
  Allow setting default NetVM to None in Global Settings
  Fixed error in setting Clockvm to None in Global Settings
  Fixed error in setting Updatevm to None in Global Settings
This commit is contained in:
Marek Marczykowski-Górecki 2018-03-14 21:32:45 +01:00
commit 6fe0668b22
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
2 changed files with 129 additions and 128 deletions

View File

@ -27,15 +27,16 @@ import traceback
from PyQt4 import QtCore, QtGui # pylint: disable=import-error from PyQt4 import QtCore, QtGui # pylint: disable=import-error
from qubesadmin import Qubes from qubesadmin import Qubes
from qubesadmin.utils import parse_size, updates_vms_status from qubesadmin.utils import parse_size
from . import ui_globalsettingsdlg # pylint: disable=no-name-in-module from . import ui_globalsettingsdlg # pylint: disable=no-name-in-module
from . import utils
from configparser import ConfigParser from configparser import ConfigParser
qmemman_config_path = '/etc/qubes/qmemman.conf' qmemman_config_path = '/etc/qubes/qmemman.conf'
# pylint: disable=too-many-instance-attributes
class GlobalSettingsWindow(ui_globalsettingsdlg.Ui_GlobalSettings, class GlobalSettingsWindow(ui_globalsettingsdlg.Ui_GlobalSettings,
QtGui.QDialog): QtGui.QDialog):
@ -59,126 +60,77 @@ class GlobalSettingsWindow(ui_globalsettingsdlg.Ui_GlobalSettings,
self.__init_updates__() self.__init_updates__()
def __init_system_defaults__(self): def __init_system_defaults__(self):
# updatevm and clockvm # set up updatevm choice
all_vms = [vm for vm in self.qvm_collection.domains self.update_vm_vmlist, self.update_vm_idx = utils.prepare_vm_choice(
if (not vm.features.get('internal', False)) and vm.qid != 0] self.update_vm_combo, self.qvm_collection, 'updatevm',
None, allow_none=True
)
self.updatevm_idx = -1 # set up clockvm choice
self.clock_vm_vmlist, self.clock_vm_idx = utils.prepare_vm_choice(
self.clock_vm_combo, self.qvm_collection, 'clockvm',
None, allow_none=True
)
current_update_vm = self.qvm_collection.updatevm # set up default netvm
for (i, vm) in enumerate(all_vms): self.default_netvm_vmlist, self.default_netvm_idx = \
text = vm.name utils.prepare_vm_choice(
if vm is current_update_vm: self.default_netvm_combo,
self.updatevm_idx = i self.qvm_collection, 'default_netvm',
text += self.tr(" (current)") None,
self.update_vm_combo.insertItem(i, text) filter_function=(lambda vm: vm.provides_network),
self.update_vm_combo.insertItem(len(all_vms), "none") allow_none=True)
if current_update_vm is None:
self.updatevm_idx = len(all_vms)
self.update_vm_combo.setCurrentIndex(self.updatevm_idx)
# clockvm # default template
self.clockvm_idx = -1 self.default_template_vmlist, self.default_template_idx = \
utils.prepare_vm_choice(
current_clock_vm = self.qvm_collection.clockvm self.default_template_combo,
for (i, vm) in enumerate(all_vms): self.qvm_collection, 'default_template',
text = vm.name None,
if vm is current_clock_vm: filter_function=(lambda vm: vm.klass == 'TemplateVM')
self.clockvm_idx = i )
text += self.tr(" (current)")
self.clock_vm_combo.insertItem(i, text)
self.clock_vm_combo.insertItem(len(all_vms), "none")
if current_clock_vm is None:
self.clockvm_idx = len(all_vms)
self.clock_vm_combo.setCurrentIndex(self.clockvm_idx)
# default netvm
netvms = [vm for vm in all_vms
if getattr(vm, 'provides_network', False)]
self.netvm_idx = -1
current_netvm = self.qvm_collection.default_netvm
for (i, vm) in enumerate(netvms):
text = vm.name
if vm is current_netvm:
self.netvm_idx = i
text += self.tr(" (current)")
self.default_netvm_combo.insertItem(i, text)
if current_netvm is not None:
self.default_netvm_combo.setCurrentIndex(self.netvm_idx)
#default template
templates = [vm for vm in all_vms if vm.klass == 'TemplateVM']
self.template_idx = -1
current_template = self.qvm_collection.default_template
for (i, vm) in enumerate(templates):
text = vm.name
if vm is current_template:
self.template_idx = i
text += self.tr(" (current)")
self.default_template_combo.insertItem(i, text)
if current_template is not None:
self.default_template_combo.setCurrentIndex(self.template_idx)
def __apply_system_defaults__(self): def __apply_system_defaults__(self):
#upatevm # upatevm
if self.update_vm_combo.currentIndex() != self.updatevm_idx: if self.qvm_collection.updatevm != \
updatevm_name = str(self.update_vm_combo.currentText()) self.update_vm_vmlist[self.update_vm_combo.currentIndex()]:
updatevm_name = updatevm_name.split(' ')[0] self.qvm_collection.updatevm = \
updatevm = self.qvm_collection.domains[updatevm_name] self.update_vm_vmlist[self.update_vm_combo.currentIndex()]
self.qvm_collection.updatevm = updatevm # clockvm
if self.qvm_collection.clockvm !=\
self.clock_vm_vmlist[self.clock_vm_combo.currentIndex()]:
self.qvm_collection.clockvm = \
self.clock_vm_vmlist[self.clock_vm_combo.currentIndex()]
#clockvm # default netvm
if self.clock_vm_combo.currentIndex() != self.clockvm_idx: if self.qvm_collection.default_netvm !=\
clockvm_name = str(self.clock_vm_combo.currentText()) self.default_netvm_vmlist[
clockvm_name = clockvm_name.split(' ')[0] self.default_netvm_combo.currentIndex()]:
clockvm = self.qvm_collection.domains[clockvm_name] self.qvm_collection.default_netvm = \
self.default_netvm_vmlist[
self.qvm_collection.clockvm = clockvm self.default_netvm_combo.currentIndex()]
#default netvm
if self.default_netvm_combo.currentIndex() != self.netvm_idx:
name = str(self.default_netvm_combo.currentText())
name = name.split(' ')[0]
vm = self.qvm_collection.domains[name]
self.qvm_collection.default_netvm = vm
#default template
if self.default_template_combo.currentIndex() != self.template_idx:
name = str(self.default_template_combo.currentText())
name = name.split(' ')[0]
vm = self.qvm_collection.domains[name]
self.qvm_collection.default_template = vm
# default template
if self.qvm_collection.default_template != \
self.default_template_vmlist[
self.default_template_combo.currentIndex()]:
self.qvm_collection.default_template = \
self.default_template_vmlist[
self.default_template_combo.currentIndex()]
def __init_kernel_defaults__(self): def __init_kernel_defaults__(self):
kernel_list = [] self.kernels_list, self.kernels_idx = utils.prepare_kernel_choice(
# TODO system_path["qubes_kernels_base_dir"] self.default_kernel_combo, self.qvm_collection, 'default_kernel',
# idea: qubes.pools['linux-kernel'].volumes None,
for k in os.listdir('/var/lib/qubes/vm-kernels'): allow_none=True
kernel_list.append(k) )
self.kernel_idx = 0
for (i, k) in enumerate(kernel_list):
text = k
if k == self.qvm_collection.default_kernel:
text += self.tr(" (current)")
self.kernel_idx = i
self.default_kernel_combo.insertItem(i, text)
self.default_kernel_combo.setCurrentIndex(self.kernel_idx)
def __apply_kernel_defaults__(self): def __apply_kernel_defaults__(self):
if self.default_kernel_combo.currentIndex() != self.kernel_idx: if self.qvm_collection.default_kernel != \
kernel = str(self.default_kernel_combo.currentText()) self.kernels_list[self.default_kernel_combo.currentIndex()]:
kernel = kernel.split(' ')[0] self.qvm_collection.default_kernel = \
self.kernels_list[self.default_kernel_combo.currentIndex()]
self.qvm_collection.default_kernel = kernel
def __init_mem_defaults__(self): def __init_mem_defaults__(self):
#qmemman settings #qmemman settings
@ -260,27 +212,62 @@ class GlobalSettingsWindow(ui_globalsettingsdlg.Ui_GlobalSettings,
qmemman_config_file.writelines(config_lines) qmemman_config_file.writelines(config_lines)
qmemman_config_file.close() qmemman_config_file.close()
def __init_updates__(self): def __init_updates__(self):
self.updates_val = False
# TODO updates_dom0_status(self.qvm_collection) # TODO: remove workaround when it is no longer needed
self.updates_dom0_val = True self.dom0_updates_file_path = '/var/lib/qubes/updates/disable-updates'
try:
self.updates_dom0_val = self.qvm_collection.check_updates_dom0
except AttributeError:
self.updates_dom0_val =\
not os.path.isfile(self.dom0_updates_file_path)
self.updates_dom0.setChecked(self.updates_dom0_val) self.updates_dom0.setChecked(self.updates_dom0_val)
updates_vms = updates_vms_status(self.qvm_collection)
if updates_vms is None: self.updates_vm.setChecked(self.qvm_collection.check_updates_vm)
self.updates_vm.setCheckState(QtCore.Qt.PartiallyChecked) self.enable_updates_all.clicked.connect(self.__enable_updates_all)
else: self.disable_updates_all.clicked.connect(self.__disable_updates_all)
self.updates_vm.setCheckState(updates_vms)
def __enable_updates_all(self):
reply = QtGui.QMessageBox.question(
self, self.tr("Change state of all qubes"),
self.tr("Are you sure you want to set all qubes to check "
"for updates?"),
QtGui.QMessageBox.Yes | QtGui.QMessageBox.Cancel)
if reply == QtGui.QMessageBox.Cancel:
return
self.__set_updates_all(True)
def __disable_updates_all(self):
reply = QtGui.QMessageBox.question(
self, self.tr("Change state of all qubes"),
self.tr("Are you sure you want to set all qubes to not check "
"for updates?"),
QtGui.QMessageBox.Yes | QtGui.QMessageBox.Cancel)
if reply == QtGui.QMessageBox.Cancel:
return
self.__set_updates_all(False)
def __set_updates_all(self, state):
for vm in self.qvm_collection.domains:
vm.features['check-updates'] = state
def __apply_updates__(self): def __apply_updates__(self):
if self.updates_dom0.isChecked() != self.updates_dom0_val: if self.updates_dom0.isChecked() != self.updates_dom0_val:
# TODO updates_dom0_toggle( # TODO: remove workaround when it is no longer needed
# self.qvm_collection, self.updates_dom0.isChecked()) try:
raise NotImplementedError('Toggle dom0 updates not implemented') self.qvm_collection.check_updates_dom0 = \
if self.updates_vm.checkState() != QtCore.Qt.PartiallyChecked: self.updates_dom0.isChecked()
for vm in self.qvm_collection.domains: except AttributeError:
vm.features['check-updates'] = \ if self.updates_dom0.isChecked():
bool(self.updates_vm.checkState()) os.remove(self.dom0_updates_file_path)
else:
open(self.dom0_updates_file_path, 'a').close()
self.qvm_collection.check_updates_vm = self.updates_vm.isChecked()
def reject(self): def reject(self):
self.done(0) self.done(0)

View File

@ -6,8 +6,8 @@
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>678</width> <width>651</width>
<height>331</height> <height>386</height>
</rect> </rect>
</property> </property>
<property name="windowTitle"> <property name="windowTitle">
@ -195,6 +195,13 @@
<string>Updates</string> <string>Updates</string>
</property> </property>
<layout class="QGridLayout" name="gridLayout_3"> <layout class="QGridLayout" name="gridLayout_3">
<item row="1" column="1">
<widget class="QPushButton" name="disable_updates_all">
<property name="text">
<string>Disable checking for updates for all VMs</string>
</property>
</widget>
</item>
<item row="0" column="0"> <item row="0" column="0">
<widget class="QCheckBox" name="updates_dom0"> <widget class="QCheckBox" name="updates_dom0">
<property name="text"> <property name="text">
@ -215,6 +222,13 @@
</property> </property>
</widget> </widget>
</item> </item>
<item row="2" column="1">
<widget class="QPushButton" name="enable_updates_all">
<property name="text">
<string>Enable checking for updates for all VMs</string>
</property>
</widget>
</item>
</layout> </layout>
</widget> </widget>
</item> </item>