Refactored QubesVm.is_*vm() methods
This commit is contained in:
parent
4297c1284a
commit
053ca36ca8
@ -81,12 +81,6 @@ qubes_appmenu_remove_cmd = "/usr/lib/qubes/remove_appvm_appmenus.sh"
|
|||||||
# as "should be good for everyone"
|
# as "should be good for everyone"
|
||||||
swap_cow_sz = 1024*1024*1024
|
swap_cow_sz = 1024*1024*1024
|
||||||
|
|
||||||
VM_TEMPLATE = 'TempleteVM'
|
|
||||||
VM_APPVM = 'AppVM'
|
|
||||||
VM_NETVM = 'NetVM'
|
|
||||||
VM_FWVM = 'FirewallVM'
|
|
||||||
VM_DISPOSABLEVM = 'DisposableVM'
|
|
||||||
|
|
||||||
class XendSession(object):
|
class XendSession(object):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.get_xend_session_old_api()
|
self.get_xend_session_old_api()
|
||||||
@ -171,7 +165,7 @@ class QubesVm(object):
|
|||||||
Note that qid is not the same as Xen's domid!
|
Note that qid is not the same as Xen's domid!
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, qid, name, type,
|
def __init__(self, qid, name,
|
||||||
dir_path, conf_file = None,
|
dir_path, conf_file = None,
|
||||||
uses_default_netvm = True,
|
uses_default_netvm = True,
|
||||||
netvm_vm = None,
|
netvm_vm = None,
|
||||||
@ -196,7 +190,6 @@ class QubesVm(object):
|
|||||||
else:
|
else:
|
||||||
self.conf_file = dir_path + "/" + conf_file
|
self.conf_file = dir_path + "/" + conf_file
|
||||||
|
|
||||||
self.__type = type
|
|
||||||
self.uses_default_netvm = uses_default_netvm
|
self.uses_default_netvm = uses_default_netvm
|
||||||
self.netvm_vm = netvm_vm
|
self.netvm_vm = netvm_vm
|
||||||
|
|
||||||
@ -217,10 +210,6 @@ class QubesVm(object):
|
|||||||
def qid(self):
|
def qid(self):
|
||||||
return self.__qid
|
return self.__qid
|
||||||
|
|
||||||
@property
|
|
||||||
def type(self):
|
|
||||||
return self.__type
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def ip(self):
|
def ip(self):
|
||||||
if self.netvm_vm is not None:
|
if self.netvm_vm is not None:
|
||||||
@ -271,34 +260,19 @@ class QubesVm(object):
|
|||||||
self.updateable = False
|
self.updateable = False
|
||||||
|
|
||||||
def is_templete(self):
|
def is_templete(self):
|
||||||
if self.type == VM_TEMPLATE:
|
return isinstance(self, QubesTemplateVm)
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def is_appvm(self):
|
def is_appvm(self):
|
||||||
if self.type == VM_APPVM:
|
return isinstance(self, QubesAppVm)
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def is_netvm(self):
|
def is_netvm(self):
|
||||||
if self.type == VM_NETVM or self.type == VM_FWVM:
|
return isinstance(self, QubesNetVm)
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def is_fwvm(self):
|
def is_fwvm(self):
|
||||||
if self.type == VM_FWVM:
|
return isinstance(self, QubesFirewallVm)
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def is_disposablevm(self):
|
def is_disposablevm(self):
|
||||||
if self.type == VM_DISPOSABLEVM:
|
return isinstance(self, QubesDisposableVm)
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def add_to_xen_storage(self):
|
def add_to_xen_storage(self):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
@ -625,7 +599,7 @@ class QubesTemplateVm(QubesVm):
|
|||||||
private_img = kwargs.pop("private_img") if "private_img" in kwargs else None
|
private_img = kwargs.pop("private_img") if "private_img" in kwargs else None
|
||||||
appvms_conf_file = kwargs.pop("appvms_conf_file") if "appvms_conf_file" in kwargs else None
|
appvms_conf_file = kwargs.pop("appvms_conf_file") if "appvms_conf_file" in kwargs else None
|
||||||
|
|
||||||
super(QubesTemplateVm, self).__init__(type=VM_TEMPLATE, label = default_template_label, **kwargs)
|
super(QubesTemplateVm, self).__init__(label = default_template_label, **kwargs)
|
||||||
|
|
||||||
dir_path = kwargs["dir_path"]
|
dir_path = kwargs["dir_path"]
|
||||||
|
|
||||||
@ -653,6 +627,10 @@ class QubesTemplateVm(QubesVm):
|
|||||||
self.appmenus_templates_dir = self.dir_path + "/" + default_appmenus_templates_subdir
|
self.appmenus_templates_dir = self.dir_path + "/" + default_appmenus_templates_subdir
|
||||||
self.appvms = QubesVmCollection()
|
self.appvms = QubesVmCollection()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def type(self):
|
||||||
|
return "TempleteVM"
|
||||||
|
|
||||||
def set_updateable(self):
|
def set_updateable(self):
|
||||||
if self.is_updateable():
|
if self.is_updateable():
|
||||||
return
|
return
|
||||||
@ -896,10 +874,12 @@ class QubesNetVm(QubesServiceVm):
|
|||||||
|
|
||||||
if "label" not in kwargs or kwargs["label"] is None:
|
if "label" not in kwargs or kwargs["label"] is None:
|
||||||
kwargs["label"] = default_servicevm_label
|
kwargs["label"] = default_servicevm_label
|
||||||
if "type" not in kwargs or kwargs["type"] is None:
|
|
||||||
kwargs["type"] = VM_NETVM
|
|
||||||
super(QubesNetVm, self).__init__(installed_by_rpm=True, **kwargs)
|
super(QubesNetVm, self).__init__(installed_by_rpm=True, **kwargs)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def type(self):
|
||||||
|
return "NetVM"
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def gateway(self):
|
def gateway(self):
|
||||||
return self.__gateway
|
return self.__gateway
|
||||||
@ -943,7 +923,11 @@ class QubesFirewallVm(QubesNetVm):
|
|||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
self.netvm_vm = kwargs.pop("netvm_vm") if "netvm_vm" in kwargs else None
|
self.netvm_vm = kwargs.pop("netvm_vm") if "netvm_vm" in kwargs else None
|
||||||
|
|
||||||
super(QubesFirewallVm, self).__init__(type=VM_FWVM, **kwargs)
|
super(QubesFirewallVm, self).__init__(**kwargs)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def type(self):
|
||||||
|
return "FirewallVM"
|
||||||
|
|
||||||
def create_xml_element(self):
|
def create_xml_element(self):
|
||||||
element = xml.etree.ElementTree.Element(
|
element = xml.etree.ElementTree.Element(
|
||||||
@ -1041,7 +1025,7 @@ class QubesDisposableVm(QubesVm):
|
|||||||
|
|
||||||
template_vm = kwargs.pop("template_vm")
|
template_vm = kwargs.pop("template_vm")
|
||||||
|
|
||||||
super(QubesDisposableVm, self).__init__(type=VM_DISPOSABLEVM, dir_path=None, **kwargs)
|
super(QubesDisposableVm, self).__init__(dir_path=None, **kwargs)
|
||||||
qid = kwargs["qid"]
|
qid = kwargs["qid"]
|
||||||
|
|
||||||
assert template_vm is not None, "Missing template_vm for DisposableVM!"
|
assert template_vm is not None, "Missing template_vm for DisposableVM!"
|
||||||
@ -1053,6 +1037,10 @@ class QubesDisposableVm(QubesVm):
|
|||||||
self.template_vm = template_vm
|
self.template_vm = template_vm
|
||||||
template_vm.appvms[qid] = self
|
template_vm.appvms[qid] = self
|
||||||
|
|
||||||
|
@property
|
||||||
|
def type(self):
|
||||||
|
return "DisposableVM"
|
||||||
|
|
||||||
def create_xml_element(self):
|
def create_xml_element(self):
|
||||||
element = xml.etree.ElementTree.Element(
|
element = xml.etree.ElementTree.Element(
|
||||||
"QubesDisposableVm",
|
"QubesDisposableVm",
|
||||||
@ -1082,7 +1070,7 @@ class QubesAppVm(QubesVm):
|
|||||||
template_vm = kwargs.pop("template_vm")
|
template_vm = kwargs.pop("template_vm")
|
||||||
|
|
||||||
|
|
||||||
super(QubesAppVm, self).__init__(type=VM_APPVM, **kwargs)
|
super(QubesAppVm, self).__init__(**kwargs)
|
||||||
qid = kwargs["qid"]
|
qid = kwargs["qid"]
|
||||||
dir_path = kwargs["dir_path"]
|
dir_path = kwargs["dir_path"]
|
||||||
|
|
||||||
@ -1106,6 +1094,10 @@ class QubesAppVm(QubesVm):
|
|||||||
self.swapcow_img = dir_path + "/" + default_swapcow_img
|
self.swapcow_img = dir_path + "/" + default_swapcow_img
|
||||||
|
|
||||||
|
|
||||||
|
@property
|
||||||
|
def type(self):
|
||||||
|
return "AppVM"
|
||||||
|
|
||||||
def set_updateable(self):
|
def set_updateable(self):
|
||||||
if self.is_updateable():
|
if self.is_updateable():
|
||||||
return
|
return
|
||||||
|
Loading…
Reference in New Issue
Block a user