qvm-prefs: add an option to get a single VM property
Could be useful for scripts
This commit is contained in:
parent
dadcfc334d
commit
8aaef404de
@ -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
|
||||||
|
|
||||||
|
@ -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,8 +582,9 @@ def main():
|
|||||||
qvm_collection.unlock_db()
|
qvm_collection.unlock_db()
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
|
elif options.do_get or len(args) == 2:
|
||||||
else:
|
do_get(qvm_collection, vm, args[1])
|
||||||
|
else:
|
||||||
# do_list
|
# do_list
|
||||||
do_list(vm)
|
do_list(vm)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user