Reduce duplicated code in create_xml_entries

This commit is contained in:
Marek Marczykowski 2011-03-16 19:42:01 -04:00
parent 4e68c4cde9
commit bef1ea4c92

View File

@ -640,6 +640,34 @@ class QubesVm(object):
shutil.rmtree (self.dir_path) shutil.rmtree (self.dir_path)
def get_xml_attrs(self):
attrs = {}
attrs["qid"] = str(self.qid)
attrs["name"] = self.name
attrs["dir_path"] = self.dir_path
attrs["conf_file"] = self.conf_file
attrs["root_img"] = self.root_img
attrs["rootcow_img"] = self.rootcow_img
attrs["private_img"] = self.private_img
attrs["uses_default_netvm"] = str(self.uses_default_netvm)
attrs["netvm_qid"] = str(self.netvm_vm.qid) if self.netvm_vm is not None else "none"
attrs["installed_by_rpm"] = str(self.installed_by_rpm)
attrs["updateable"] = str(self.updateable)
attrs["label"] = self.label.name
attrs["memory"] = str(self.memory)
attrs["vcpus"] = str(self.vcpus)
return attrs
def create_xml_element(self):
# Compatibility hack (Qubes*VM in type vs Qubes*Vm in XML)...
rx_type = re.compile (r"VM")
attrs = self.get_xml_attrs()
element = xml.etree.ElementTree.Element(
"Qubes" + rx_type.sub("Vm", self.type),
**attrs)
return element
class QubesTemplateVm(QubesVm): class QubesTemplateVm(QubesVm):
""" """
@ -854,25 +882,12 @@ class QubesTemplateVm(QubesVm):
f_cow.close () f_cow.close ()
f_root.close() f_root.close()
def create_xml_element(self): def get_xml_attrs(self):
element = xml.etree.ElementTree.Element( attrs = super(QubesTemplateVm, self).get_xml_attrs()
"QubesTemplateVm", attrs["appvms_conf_file"] = self.appvms_conf_file
qid=str(self.qid), attrs["netvms_conf_file"] = self.netvms_conf_file
name=self.name, attrs["standalonevms_conf_file"] = self.standalonevms_conf_file
dir_path=self.dir_path, return attrs
conf_file=self.conf_file,
appvms_conf_file=self.appvms_conf_file,
netvms_conf_file=self.netvms_conf_file,
standalonevms_conf_file=self.standalonevms_conf_file,
root_img=self.root_img,
rootcow_img=self.rootcow_img,
private_img=self.private_img,
uses_default_netvm=str(self.uses_default_netvm),
netvm_qid=str(self.netvm_vm.qid) if self.netvm_vm is not None else "none",
installed_by_rpm=str(self.installed_by_rpm),
updateable=str(self.updateable),
)
return element
class QubesCowVm(QubesVm): class QubesCowVm(QubesVm):
""" """
@ -1055,6 +1070,11 @@ class QubesCowVm(QubesVm):
subprocess.check_call ([qubes_appmenu_remove_cmd, self.name]) subprocess.check_call ([qubes_appmenu_remove_cmd, self.name])
shutil.rmtree (self.dir_path) shutil.rmtree (self.dir_path)
def get_xml_attrs(self):
attrs = super(QubesCowVm, self).get_xml_attrs()
attrs["template_qid"] = str(self.template_vm.qid) if self.template_vm is not None else "none"
return attrs
class QubesNetVm(QubesCowVm): class QubesNetVm(QubesCowVm):
""" """
A class that represents a NetVM. A child of QubesCowVM. A class that represents a NetVM. A child of QubesCowVM.
@ -1145,24 +1165,12 @@ class QubesNetVm(QubesCowVm):
self.__external_ip_allowed_xids.discard(int(xid)) self.__external_ip_allowed_xids.discard(int(xid))
self.update_external_ip_permissions() self.update_external_ip_permissions()
def create_xml_element(self): def get_xml_attrs(self):
element = xml.etree.ElementTree.Element( attrs = super(QubesNetVm, self).get_xml_attrs()
"QubesNetVm", attrs.pop("netvm_qid")
qid=str(self.qid), attrs.pop("uses_default_netvm")
netid=str(self.netid), attrs["netid"] = str(self.netid)
name=self.name, return attrs
dir_path=self.dir_path,
conf_file=self.conf_file,
template_qid=str(self.template_vm.qid) if self.template_vm is not None else "none",
updateable=str(self.updateable),
root_img=self.root_img,
private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm),
label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
)
return element
class QubesProxyVm(QubesNetVm): class QubesProxyVm(QubesNetVm):
""" """
@ -1292,25 +1300,10 @@ class QubesProxyVm(QubesNetVm):
"/local/domain/{0}/qubes_iptables".format(self.get_xid()), "/local/domain/{0}/qubes_iptables".format(self.get_xid()),
iptables]) iptables])
def create_xml_element(self): def get_xml_attrs(self):
element = xml.etree.ElementTree.Element( attrs = super(QubesProxyVm, self).get_xml_attrs()
"QubesProxyVm", attrs["netvm_qid"] = str(self.netvm_vm.qid) if self.netvm_vm is not None else "none"
qid=str(self.qid), return attrs
netid=str(self.netid),
name=self.name,
dir_path=self.dir_path,
conf_file=self.conf_file,
template_qid=str(self.template_vm.qid) if self.template_vm is not None else "none",
updateable=str(self.updateable),
netvm_qid=str(self.netvm_vm.qid) if self.netvm_vm is not None else "none",
root_img=self.root_img,
private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm),
label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
)
return element
class QubesDom0NetVm(QubesNetVm): class QubesDom0NetVm(QubesNetVm):
def __init__(self): def __init__(self):
@ -1410,14 +1403,13 @@ class QubesDisposableVm(QubesVm):
def type(self): def type(self):
return "DisposableVM" return "DisposableVM"
def create_xml_element(self): def get_xml_attrs(self):
element = xml.etree.ElementTree.Element( attrs = {}
"QubesDisposableVm", attrs["qid"] = str(self.qid)
qid=str(self.qid), attrs["name"] = self.name
name=self.name, attrs["template_qid"] = str(self.template_vm.qid)
template_qid=str(self.template_vm.qid), attrs["label"] = self.label.name
label=self.label.name) return attrs
return element
def verify_files(self): def verify_files(self):
return True return True
@ -1537,26 +1529,6 @@ class QubesAppVm(QubesCowVm):
return conf return conf
def create_xml_element(self):
element = xml.etree.ElementTree.Element(
"QubesAppVm",
qid=str(self.qid),
name=self.name,
dir_path=self.dir_path,
conf_file=self.conf_file,
template_qid=str(self.template_vm.qid) if self.template_vm is not None else "none",
uses_default_netvm=str(self.uses_default_netvm),
netvm_qid=str(self.netvm_vm.qid) if self.netvm_vm is not None else "none",
root_img=self.root_img,
private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm),
updateable=str(self.updateable),
label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
)
return element
def start(self, debug_console = False, verbose = False, preparing_dvm = False): def start(self, debug_console = False, verbose = False, preparing_dvm = False):
if dry_run: if dry_run:
return return