qvm-prefs: add an option to get a single VM property

Could be useful for scripts
This commit is contained in:
Marek Marczykowski-Górecki 2015-05-15 03:07:03 +02:00
parent dadcfc334d
commit 8aaef404de
2 changed files with 42 additions and 11 deletions

View File

@ -11,6 +11,7 @@ qvm-prefs - list/set various per-VM properties
SYNOPSIS SYNOPSIS
======== ========
| qvm-prefs -l [options] <vm-name> | qvm-prefs -l [options] <vm-name>
| qvm-prefs -g [options] <vm-name> <property>
| qvm-prefs -s [options] <vm-name> <property> [...] | qvm-prefs -s [options] <vm-name> <property> [...]
@ -20,6 +21,8 @@ OPTIONS
Show this help message and exit Show this help message and exit
-l, --list -l, --list
List properties of a specified VM List properties of a specified VM
-g, --get
Get a single property of a specified VM
-s, --set -s, --set
Set properties of a specified VM Set properties of a specified VM

View File

@ -109,6 +109,28 @@ def do_list(vm):
print fmt.format ("internal", vm.internal) print fmt.format ("internal", vm.internal)
def do_get(vms, vm, prop):
if prop == 'config':
prop = 'conf_file'
elif prop == 'dir':
prop = 'dir_path'
elif prop == 'last_backup':
prop = 'backup_timestamp'
if not hasattr(vm, prop):
print >>sys.stderr, "VM '{}' has no attribute '{}'".format(vm.name,
prop)
return
if getattr(vm, prop, None) is None:
# not set or set to None
return
if prop in ['template', 'netvm', 'dispvm_netvm']:
print getattr(vm, prop).name
else:
print str(getattr(vm, prop))
def set_label(vms, vm, args): def set_label(vms, vm, args):
if len (args) != 1: if len (args) != 1:
print >> sys.stderr, "Missing label name argument!" print >> sys.stderr, "Missing label name argument!"
@ -495,14 +517,20 @@ def do_set(vms, vm, property, args):
def main(): def main():
usage = "usage: %prog -l [options] <vm-name>\n"\ usage = "usage: %prog -l [options] <vm-name>\n"\
"usage: %prog -g [options] <vm-name> <property>\n"\
"usage: %prog -s [options] <vm-name> <property> [...]\n"\ "usage: %prog -s [options] <vm-name> <property> [...]\n"\
"List/set various per-VM properties." "List/set various per-VM properties."
parser = OptionParser (usage) parser = OptionParser (usage)
parser.add_option ("-l", "--list", action="store_true", dest="do_list", default=False) parser.add_option("-l", "--list", action="store_true", dest="do_list",
parser.add_option ("-s", "--set", action="store_true", dest="do_set", default=False) default=False)
parser.add_option ("--force-root", action="store_true", dest="force_root", default=False, parser.add_option("-s", "--set", action="store_true", dest="do_set",
help="Force to run, even with root privileges") default=False)
parser.add_option ("-g", "--gry", action="store_true", dest="do_get",
default=False)
parser.add_option("--force-root", action="store_true", dest="force_root",
default=False,
help="Force to run, even with root privileges")
(options, args) = parser.parse_args () (options, args) = parser.parse_args ()
if (len (args) < 1): if (len (args) < 1):
@ -517,11 +545,10 @@ def main():
print >> sys.stderr, "... or use --force-root to continue anyway." print >> sys.stderr, "... or use --force-root to continue anyway."
exit(1) exit(1)
if options.do_list and options.do_set: if options.do_list + options.do_set + options.do_get > 1:
print >> sys.stderr, "You cannot provide -l and -s at the same time!" print >> sys.stderr, "You can provide at most one of -l, -g and -s at " \
exit (1) "the same time!"
exit(1)
if options.do_set: if options.do_set:
qvm_collection = QubesVmCollection() qvm_collection = QubesVmCollection()
@ -555,7 +582,8 @@ def main():
qvm_collection.unlock_db() qvm_collection.unlock_db()
exit(1) exit(1)
elif options.do_get or len(args) == 2:
do_get(qvm_collection, vm, args[1])
else: else:
# do_list # do_list
do_list(vm) do_list(vm)