core: use vm.absolute_path to parse paths in qubes.xml

This makes easier to handle some corner cases. One of them is having
entry without `dir_path` defined. This may happen when migrating from R2
(using backup+restore or in-place) while some DisposableVM was running
(even if not included in the backup itself).

Fixes qubesos/qubes-issues#1124
Reported by @doncohen, thanks @wyory for providing more details.
This commit is contained in:
Marek Marczykowski-Górecki 2015-09-04 00:19:40 +02:00
parent 226a144285
commit 76bddaa280
2 changed files with 9 additions and 4 deletions

View File

@ -376,8 +376,13 @@ class QubesVm(object):
def absolute_path(self, arg, default): def absolute_path(self, arg, default):
if arg is not None and os.path.isabs(arg): if arg is not None and os.path.isabs(arg):
return arg return arg
else: elif self.dir_path is not None:
return os.path.join(self.dir_path, (arg if arg is not None else default)) return os.path.join(self.dir_path, (arg if arg is not None else default))
else:
# cannot provide any meaningful value without dir_path; this is
# only to import some older format of `qubes.xml` (for example
# during migration from older release)
return None
def _absolute_path_gen(self, default): def _absolute_path_gen(self, default):
return lambda value: self.absolute_path(value, default) return lambda value: self.absolute_path(value, default)

View File

@ -55,12 +55,12 @@ class QubesVmStorage(object):
else: else:
self.root_img_size = defaults['root_img_size'] self.root_img_size = defaults['root_img_size']
self.private_img = os.path.join(self.vmdir, vm_files["private_img"]) self.private_img = vm.absolute_path(vm_files["private_img"], None)
if self.vm.template: if self.vm.template:
self.root_img = self.vm.template.root_img self.root_img = self.vm.template.root_img
else: else:
self.root_img = os.path.join(self.vmdir, vm_files["root_img"]) self.root_img = vm.absolute_path(vm_files["root_img"], None)
self.volatile_img = os.path.join(self.vmdir, vm_files["volatile_img"]) self.volatile_img = vm.absolute_path(vm_files["volatile_img"], None)
# For now compute this path still in QubesVm # For now compute this path still in QubesVm
self.modules_img = modules_img self.modules_img = modules_img