Handle GuiVM properties
This commit is contained in:
parent
a52cb6bb91
commit
27aad9bd38
@ -716,6 +716,9 @@ class Qubes(qubes.PropertyHolder):
|
|||||||
|
|
||||||
Methods and attributes:
|
Methods and attributes:
|
||||||
"""
|
"""
|
||||||
|
default_guivm = qubes.VMProperty('default_guivm', load_stage=3,
|
||||||
|
default=None, allow_none=True,
|
||||||
|
doc='Default GuiVM for VMs.')
|
||||||
|
|
||||||
default_netvm = qubes.VMProperty('default_netvm', load_stage=3,
|
default_netvm = qubes.VMProperty('default_netvm', load_stage=3,
|
||||||
default=None, allow_none=True,
|
default=None, allow_none=True,
|
||||||
@ -963,6 +966,7 @@ class Qubes(qubes.PropertyHolder):
|
|||||||
|
|
||||||
# stage 5: misc fixups
|
# stage 5: misc fixups
|
||||||
|
|
||||||
|
self.property_require('default_guivm', allow_none=True)
|
||||||
self.property_require('default_netvm', allow_none=True)
|
self.property_require('default_netvm', allow_none=True)
|
||||||
self.property_require('default_template', allow_none=True)
|
self.property_require('default_template', allow_none=True)
|
||||||
self.property_require('clockvm', allow_none=True)
|
self.property_require('clockvm', allow_none=True)
|
||||||
@ -1420,6 +1424,7 @@ class Qubes(qubes.PropertyHolder):
|
|||||||
def on_domain_deleted(self, event, vm):
|
def on_domain_deleted(self, event, vm):
|
||||||
# pylint: disable=unused-argument
|
# pylint: disable=unused-argument
|
||||||
for propname in (
|
for propname in (
|
||||||
|
'default_guivm'
|
||||||
'default_netvm',
|
'default_netvm',
|
||||||
'default_fw_netvm',
|
'default_fw_netvm',
|
||||||
'clockvm',
|
'clockvm',
|
||||||
|
@ -34,6 +34,18 @@ class GUI(qubes.ext.Extension):
|
|||||||
if vm.features.get('gui-seamless', False)
|
if vm.features.get('gui-seamless', False)
|
||||||
else 'FULLSCREEN'))
|
else 'FULLSCREEN'))
|
||||||
|
|
||||||
|
@qubes.ext.handler('property-set:guivm')
|
||||||
|
def on_property_set(self, subject, event, name, newvalue, oldvalue=None):
|
||||||
|
# Clean other 'guivm-XXX' tags.
|
||||||
|
# gui-daemon can connect to only one domain
|
||||||
|
tags_list = list(subject.tags)
|
||||||
|
for tag in tags_list:
|
||||||
|
if 'guivm-' in tag:
|
||||||
|
subject.tags.remove(tag)
|
||||||
|
|
||||||
|
guivm = 'guivm-' + newvalue.name
|
||||||
|
subject.tags.add(guivm)
|
||||||
|
|
||||||
@qubes.ext.handler('domain-qdb-create')
|
@qubes.ext.handler('domain-qdb-create')
|
||||||
def on_domain_qdb_create(self, vm, event):
|
def on_domain_qdb_create(self, vm, event):
|
||||||
# pylint: disable=unused-argument,no-self-use
|
# pylint: disable=unused-argument,no-self-use
|
||||||
@ -45,3 +57,12 @@ class GUI(qubes.ext.Extension):
|
|||||||
feature))
|
feature))
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
# Add GuiVM Xen ID for gui-daemon
|
||||||
|
try:
|
||||||
|
if vm.guivm is not None:
|
||||||
|
if str(vm.name) != str(vm.guivm.name):
|
||||||
|
vm.untrusted_qdb.write('/qubes-gui-domain-xid',
|
||||||
|
str(vm.guivm.xid))
|
||||||
|
except AttributeError:
|
||||||
|
vm.untrusted_qdb.write('/qubes-gui-domain-xid', '')
|
||||||
|
@ -518,6 +518,9 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
|
|||||||
#
|
#
|
||||||
# properties loaded from XML
|
# properties loaded from XML
|
||||||
#
|
#
|
||||||
|
guivm = qubes.VMProperty('guivm', load_stage=4, allow_none=True,
|
||||||
|
default=(lambda self: self.app.default_guivm),
|
||||||
|
doc='VM used for Gui')
|
||||||
|
|
||||||
virt_mode = qubes.property(
|
virt_mode = qubes.property(
|
||||||
'virt_mode',
|
'virt_mode',
|
||||||
|
Loading…
Reference in New Issue
Block a user