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:
commit
6fe0668b22
@ -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)
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user