From bb754b68c3e356df8c516e8ae0b0e1750e7e171c Mon Sep 17 00:00:00 2001 From: Bahtiar `kalkin-` Gadimov Date: Sun, 6 Dec 2015 18:28:27 +0100 Subject: [PATCH 1/3] Add pool support to qvm-clone --- qvm-tools/qvm-clone | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/qvm-tools/qvm-clone b/qvm-tools/qvm-clone index e2eba3b3..5f617098 100755 --- a/qvm-tools/qvm-clone +++ b/qvm-tools/qvm-clone @@ -38,6 +38,8 @@ def main(): help="Specify path to the template directory") parser.add_option ("--force-root", action="store_true", dest="force_root", default=False, help="Force to run, even with root privileges") + parser.add_option ("-P", "--pool", dest="pool_name", + help="Specify in to which storage pool to clone") (options, args) = parser.parse_args () if (len (args) != 2): @@ -45,6 +47,7 @@ def main(): srcname = args[0] dstname = args[1] + if hasattr(os, "geteuid") and os.geteuid() == 0: if not options.force_root: print >> sys.stderr, "*** Running this tool as root is strongly discouraged, this will lead you in permissions problems." @@ -61,6 +64,11 @@ def main(): print >> sys.stderr, "ERROR: A VM with the name '{0}' does not exist in the system.".format(srcname) exit(1) + if options.pool_name is None: + pool_name = src_vm.pool_name + else: + pool_name = options.pool_name + if qvm_collection.get_vm_by_name(dstname) is not None: print >> sys.stderr, "ERROR: A VM with the name '{0}' already exists in the system.".format(dstname) exit(1) @@ -70,7 +78,7 @@ def main(): exit(1) dst_vm = qvm_collection.add_new_vm(src_vm.__class__.__name__, - name=dstname, template=src_vm.template, + name=dstname, template=src_vm.template, pool_name=pool_name, dir_path=options.dir_path, installed_by_rpm=False) try: From 65f00d839352248d44d13e63d9ca3b17b7a008f1 Mon Sep 17 00:00:00 2001 From: Bahtiar `kalkin-` Gadimov Date: Mon, 7 Dec 2015 10:59:44 +0100 Subject: [PATCH 2/3] Remove unnecessary imports from qvm-clone --- qvm-tools/qvm-clone | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/qvm-tools/qvm-clone b/qvm-tools/qvm-clone index 5f617098..42749c94 100755 --- a/qvm-tools/qvm-clone +++ b/qvm-tools/qvm-clone @@ -17,16 +17,15 @@ # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software -# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -# -# +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, +# USA. + +import os +import sys +from optparse import OptionParser from qubes.qubes import QubesVmCollection -from qubes.qubes import QubesAppVm, QubesTemplateVm, QubesHVm -from qubes.qubes import QubesException -from optparse import OptionParser; -import sys -import os + def main(): usage = "usage: %prog [options] \n"\ From 8d3616689eb2b87e2ffa765faeba3dbede730326 Mon Sep 17 00:00:00 2001 From: Bahtiar `kalkin-` Gadimov Date: Mon, 7 Dec 2015 11:03:51 +0100 Subject: [PATCH 3/3] PEP8 qvm-tools/qvm-clone --- qvm-tools/qvm-clone | 54 +++++++++++++++++++++++++++------------------ 1 file changed, 32 insertions(+), 22 deletions(-) diff --git a/qvm-tools/qvm-clone b/qvm-tools/qvm-clone index 42749c94..5ec22c5c 100755 --- a/qvm-tools/qvm-clone +++ b/qvm-tools/qvm-clone @@ -30,26 +30,30 @@ from qubes.qubes import QubesVmCollection def main(): usage = "usage: %prog [options] \n"\ "Clones an existing VM by copying all its disk files" - - parser = OptionParser (usage) - parser.add_option ("-q", "--quiet", action="store_false", dest="verbose", default=True) - parser.add_option ("-p", "--path", dest="dir_path", - help="Specify path to the template directory") - parser.add_option ("--force-root", action="store_true", dest="force_root", default=False, - help="Force to run, even with root privileges") - parser.add_option ("-P", "--pool", dest="pool_name", - help="Specify in to which storage pool to clone") - (options, args) = parser.parse_args () - if (len (args) != 2): - parser.error ("You must specify at least the src and dst TemplateVM names!") + parser = OptionParser(usage) + parser.add_option("-q", "--quiet", action="store_false", dest="verbose", + default=True) + parser.add_option("-p", "--path", dest="dir_path", + help="Specify path to the template directory") + parser.add_option("--force-root", action="store_true", dest="force_root", + default=False, + help="Force to run, even with root privileges") + parser.add_option("-P", "--pool", dest="pool_name", + help="Specify in to which storage pool to clone") + + (options, args) = parser.parse_args() + if (len(args) != 2): + parser.error( + "You must specify at least the src and dst TemplateVM names!") srcname = args[0] dstname = args[1] - if hasattr(os, "geteuid") and os.geteuid() == 0: if not options.force_root: - print >> sys.stderr, "*** Running this tool as root is strongly discouraged, this will lead you in permissions problems." + print >> sys.stderr, "*** Running this tool as root is" + \ + " strongly discouraged, this will lead you in permissions" + \ + "problems." print >> sys.stderr, "Retry as unprivileged user." print >> sys.stderr, "... or use --force-root to continue anyway." exit(1) @@ -59,8 +63,10 @@ def main(): qvm_collection.load() src_vm = qvm_collection.get_vm_by_name(srcname) - if src_vm is None: - print >> sys.stderr, "ERROR: A VM with the name '{0}' does not exist in the system.".format(srcname) + if src_vm is None: + print >> sys.stderr, \ + "ERROR: A VM with the name '{0}' does not exist in the system." \ + .format(srcname) exit(1) if options.pool_name is None: @@ -69,7 +75,9 @@ def main(): pool_name = options.pool_name if qvm_collection.get_vm_by_name(dstname) is not None: - print >> sys.stderr, "ERROR: A VM with the name '{0}' already exists in the system.".format(dstname) + print >> sys.stderr, \ + "ERROR: A VM with the name '{0}' already exists in the system." \ + .format(dstname) exit(1) if src_vm.is_disposablevm(): @@ -77,19 +85,21 @@ def main(): exit(1) dst_vm = qvm_collection.add_new_vm(src_vm.__class__.__name__, - name=dstname, template=src_vm.template, pool_name=pool_name, - dir_path=options.dir_path, installed_by_rpm=False) + name=dstname, template=src_vm.template, + pool_name=pool_name, + dir_path=options.dir_path, + installed_by_rpm=False) try: dst_vm.clone_attrs(src_vm) - dst_vm.clone_disk_files (src_vm=src_vm, verbose=options.verbose) + dst_vm.clone_disk_files(src_vm=src_vm, verbose=options.verbose) except (IOError, OSError) as err: print >> sys.stderr, "ERROR: {0}".format(err) qvm_collection.pop(dst_vm.qid) dst_vm.remove_from_disk() - exit (1) + exit(1) qvm_collection.save() qvm_collection.unlock_db() - + main()