diff --git a/qubesmanager/backup.py b/qubesmanager/backup.py index b89b1cb..f8ccd0b 100644 --- a/qubesmanager/backup.py +++ b/qubesmanager/backup.py @@ -30,21 +30,23 @@ from qubesadmin import Qubes, events, exc from qubesadmin import utils as admin_utils from qubes.storage.file import get_disk_usage -from PyQt4 import QtCore, QtGui # pylint: disable=import-error +from PyQt4 import QtCore # pylint: disable=import-error +from PyQt4 import QtGui # pylint: disable=import-error +from . import ui_backupdlg +from . import multiselectwidget -from .ui_backupdlg import * -from .multiselectwidget import * - -from .backup_utils import * +from . import backup_utils from . import utils import grp import pwd import sys import os -from .thread_monitor import * +from . import thread_monitor +import threading import time -class BackupVMsWindow(Ui_Backup, QWizard): + +class BackupVMsWindow(ui_backupdlg.Ui_Backup, multiselectwidget.QtGui.QWizard): __pyqtSignals__ = ("backup_progress(int)",) @@ -67,21 +69,21 @@ class BackupVMsWindow(Ui_Backup, QWizard): self.progress_status.text = self.tr("Backup in progress...") self.dir_line_edit.setReadOnly(False) - self.select_vms_widget = MultiSelectWidget(self) + self.select_vms_widget = multiselectwidget.MultiSelectWidget(self) self.verticalLayout.insertWidget(1, self.select_vms_widget) - self.connect(self, SIGNAL("currentIdChanged(int)"), + self.connect(self, QtCore.SIGNAL("currentIdChanged(int)"), self.current_page_changed) self.connect(self.select_vms_widget, - SIGNAL("items_removed(PyQt_PyObject)"), + QtCore.SIGNAL("items_removed(PyQt_PyObject)"), self.vms_removed) self.connect(self.select_vms_widget, - SIGNAL("items_added(PyQt_PyObject)"), + QtCore.SIGNAL("items_added(PyQt_PyObject)"), self.vms_added) - self.connect(self, SIGNAL("backup_progress(int)"), + self.connect(self, QtCore.SIGNAL("backup_progress(int)"), self.progress_bar.setValue) self.dir_line_edit.connect(self.dir_line_edit, - SIGNAL("textChanged(QString)"), + QtCore.SIGNAL("textChanged(QString)"), self.backup_location_changed) self.select_vms_page.isComplete = self.has_selected_vms @@ -90,15 +92,15 @@ class BackupVMsWindow(Ui_Backup, QWizard): # this causes to run isComplete() twice, I don't know why self.select_vms_page.connect( self.select_vms_widget, - SIGNAL("selected_changed()"), - SIGNAL("completeChanged()")) + QtCore.SIGNAL("selected_changed()"), + QtCore.SIGNAL("completeChanged()")) self.passphrase_line_edit.connect( self.passphrase_line_edit, - SIGNAL("textChanged(QString)"), + QtCore.SIGNAL("textChanged(QString)"), self.backup_location_changed) self.passphrase_line_edit_verify.connect( self.passphrase_line_edit_verify, - SIGNAL("textChanged(QString)"), + QtCore.SIGNAL("textChanged(QString)"), self.backup_location_changed) self.total_size = 0 @@ -123,7 +125,7 @@ class BackupVMsWindow(Ui_Backup, QWizard): def load_settings(self): try: - profile_data = load_backup_profile() + profile_data = backup_utils.load_backup_profile() except Exception as ex: # TODO: fix just for file not found return if not profile_data: @@ -157,9 +159,9 @@ class BackupVMsWindow(Ui_Backup, QWizard): 'include': [vm.name for vm in self.selected_vms], 'passphrase_text': self.passphrase_line_edit.text()} # TODO: add compression when it is added - write_backup_profile(settings) + backup_utils.write_backup_profile(settings) - class VmListItem(QListWidgetItem): + class VmListItem(QtGui.QListWidgetItem): def __init__(self, vm): self.vm = vm if vm.qid == 0: @@ -205,9 +207,9 @@ class BackupVMsWindow(Ui_Backup, QWizard): self.total_size_label.setText( admin_utils.size_to_human(self.total_size)) - @pyqtSlot(name='on_select_path_button_clicked') + @QtCore.pyqtSlot(name='on_select_path_button_clicked') def select_path_button_clicked(self): - select_path_button_clicked(self) + backup_utils.select_path_button_clicked(self) def validateCurrentPage(self): if self.currentPage() is self.select_vms_page: @@ -220,26 +222,26 @@ class BackupVMsWindow(Ui_Backup, QWizard): elif self.currentPage() is self.select_dir_page: backup_location = str(self.dir_line_edit.text()) if not backup_location: - QMessageBox.information( + QtGui.QMessageBox.information( None, self.tr("Wait!"), self.tr("Enter backup target location first.")) return False if self.appvm_combobox.currentIndex() == 0 \ and not os.path.isdir(backup_location): - QMessageBox.information( + QtGui.QMessageBox.information( None, self.tr("Wait!"), self.tr("Selected directory do not exists or " "not a directory (%s).") % backup_location) return False if not len(self.passphrase_line_edit.text()): - QMessageBox.information( + QtGui.QMessageBox.information( None, self.tr("Wait!"), self.tr("Enter passphrase for backup " "encryption/verification first.")) return False if self.passphrase_line_edit.text() !=\ self.passphrase_line_edit_verify.text(): - QMessageBox.information( + QtGui.QMessageBox.information( None, self.tr("Wait!"), self.tr("Enter the same passphrase in both fields.")) return False @@ -250,7 +252,7 @@ class BackupVMsWindow(Ui_Backup, QWizard): # self.func_output.append(s) def update_progress_bar(self, value): - self.emit(SIGNAL("backup_progress(int)"), value) + self.emit(QtCore.SIGNAL("backup_progress(int)"), value) def __do_backup__(self, thread_monitor): msg = [] @@ -301,9 +303,10 @@ class BackupVMsWindow(Ui_Backup, QWizard): self.showFileDialog.setChecked(self.showFileDialog.isEnabled() and str(self.dir_line_edit.text()) .count("media/") > 0) - self.thread_monitor = ThreadMonitor() - thread = threading.Thread(target=self.__do_backup__, - args=(self.thread_monitor,)) + self.thread_monitor = thread_monitor.ThreadMonitor() + thread = threading.Thread( + target=self.__do_backup__, + args=(self.thread_monitor,)) thread.daemon = True thread.start() @@ -315,17 +318,17 @@ class BackupVMsWindow(Ui_Backup, QWizard): if self.canceled: self.progress_status.setText(self.tr("Backup aborted.")) if self.tmpdir_to_remove: - if QMessageBox.warning( + if QtGui.QMessageBox.warning( None, self.tr("Backup aborted"), self.tr( "Do you want to remove temporary files " "from %s?") % self.tmpdir_to_remove, - QMessageBox.Yes, QMessageBox.No) == \ - QMessageBox.Yes: + QtGui.QMessageBox.Yes, + QtGui.QMessageBox.No) == QtGui.QMessageBox.Yes: shutil.rmtree(self.tmpdir_to_remove) else: self.progress_status.setText(self.tr("Backup error.")) - QMessageBox.warning( + QtGui.QMessageBox.warning( self, self.tr("Backup error!"), self.tr("ERROR: {}").format( self.thread_monitor.error_msg)) @@ -368,7 +371,7 @@ class BackupVMsWindow(Ui_Backup, QWizard): return len(self.dir_line_edit.text()) > 0 def backup_location_changed(self, new_dir=None): - self.select_dir_page.emit(SIGNAL("completeChanged()")) + self.select_dir_page.emit(QtCore.SIGNAL("completeChanged()")) # Bases on the original code by: diff --git a/qubesmanager/backup_utils.py b/qubesmanager/backup_utils.py index 102b5be..083c4da 100644 --- a/qubesmanager/backup_utils.py +++ b/qubesmanager/backup_utils.py @@ -20,8 +20,8 @@ # # import re -from PyQt4.QtCore import * -from PyQt4.QtGui import * +from PyQt4 import QtGui +from PyQt4 import QtCore import subprocess from . import utils @@ -63,7 +63,7 @@ def enable_dir_line_edit(dialog, boolean): def select_path_button_clicked(dialog, select_file=False): backup_location = str(dialog.dir_line_edit.text()) - file_dialog = QFileDialog() + file_dialog = QtGui.QFileDialog() file_dialog.setReadOnly(True) new_path = None @@ -77,7 +77,7 @@ def select_path_button_clicked(dialog, select_file=False): "qubes.SelectFile" if select_file else "qubes.SelectDirectory") except subprocess.CalledProcessError as ex: - QMessageBox.warning( + QtGui.QMessageBox.warning( None, dialog.tr("Nothing selected!"), dialog.tr("No file or directory selected.")) @@ -87,7 +87,7 @@ def select_path_button_clicked(dialog, select_file=False): dialog.dir_line_edit.setText(new_path) if new_path and len(backup_location) > 0: - dialog.select_dir_page.emit(SIGNAL("completeChanged()")) + dialog.select_dir_page.emit(QtCore.SIGNAL("completeChanged()")) def load_backup_profile(): diff --git a/qubesmanager/restore.py b/qubesmanager/restore.py index f7f44b8..46e56f5 100644 --- a/qubesmanager/restore.py +++ b/qubesmanager/restore.py @@ -24,30 +24,29 @@ import sys import os import shutil -from PyQt4.QtCore import * -from PyQt4.QtGui import * -from .thread_monitor import * +from PyQt4 import QtCore +from PyQt4 import QtGui +from . import thread_monitor +import threading import time import os.path import traceback -import qubesmanager.resources_rc import signal from qubes import backup -from .ui_restoredlg import * -from .multiselectwidget import * +from . import ui_restoredlg +from . import multiselectwidget -from .backup_utils import * +from . import backup_utils from multiprocessing import Queue, Event from multiprocessing.queues import Empty -from qubesadmin import Qubes, events, exc -from qubesadmin import utils as admin_utils +from qubesadmin import Qubes, exc from qubesadmin.backup import restore -class RestoreVMsWindow(Ui_Restore, QWizard): +class RestoreVMsWindow(ui_restoredlg.Ui_Restore, QtGui.QWizard): __pyqtSignals__ = ("restore_progress(int)", "backup_progress(int)") @@ -69,20 +68,20 @@ class RestoreVMsWindow(Ui_Restore, QWizard): self.setupUi(self) - self.select_vms_widget = MultiSelectWidget(self) + self.select_vms_widget = multiselectwidget.MultiSelectWidget(self) self.select_vms_layout.insertWidget(1, self.select_vms_widget) self.connect(self, - SIGNAL("currentIdChanged(int)"), self.current_page_changed) + QtCore.SIGNAL("currentIdChanged(int)"), self.current_page_changed) self.connect(self, - SIGNAL("restore_progress(QString)"), + QtCore.SIGNAL("restore_progress(QString)"), self.commit_text_edit.append) self.connect(self, - SIGNAL("backup_progress(int)"), self.progress_bar.setValue) + QtCore.SIGNAL("backup_progress(int)"), self.progress_bar.setValue) self.dir_line_edit.connect(self.dir_line_edit, - SIGNAL("textChanged(QString)"), + QtCore.SIGNAL("textChanged(QString)"), self.backup_location_changed) - self.connect(self.verify_only, SIGNAL("stateChanged(int)"), + self.connect(self.verify_only, QtCore.SIGNAL("stateChanged(int)"), self.on_verify_only_toogled) self.select_dir_page.isComplete = self.has_selected_dir @@ -92,15 +91,15 @@ class RestoreVMsWindow(Ui_Restore, QWizard): # this causes to run isComplete() twice, I don't know why self.select_vms_page.connect( self.select_vms_widget, - SIGNAL("selected_changed()"), - SIGNAL("completeChanged()")) + QtCore.SIGNAL("selected_changed()"), + QtCore.SIGNAL("completeChanged()")) - fill_appvms_list(self) + backup_utils.fill_appvms_list(self) # self.__init_restore_options__() - @pyqtSlot(name='on_select_path_button_clicked') + @QtCore.pyqtSlot(name='on_select_path_button_clicked') def select_path_button_clicked(self): - select_path_button_clicked(self, True) + backup_utils.select_path_button_clicked(self, True) def on_ignore_missing_toggled(self, checked): self.restore_options['use-default-template'] = checked @@ -158,22 +157,22 @@ class RestoreVMsWindow(Ui_Restore, QWizard): continue self.select_vms_widget.available_list.addItem(vmname) except exc.QubesException as ex: - QMessageBox.warning(None, self.tr("Restore error!"), str(ex)) + QtGui.QMessageBox.warning(None, self.tr("Restore error!"), str(ex)) def gather_output(self, s): self.func_output.append(s) def restore_error_output(self, s): self.error_detected.set() - self.feedback_queue.put((SIGNAL("restore_progress(QString)"), + self.feedback_queue.put((QtCore.SIGNAL("restore_progress(QString)"), u'{0}'.format(s))) def restore_output(self, s): - self.feedback_queue.put((SIGNAL("restore_progress(QString)"), + self.feedback_queue.put((QtCore.SIGNAL("restore_progress(QString)"), u'{0}'.format(s))) def update_progress_bar(self, value): - self.feedback_queue.put((SIGNAL("backup_progress(int)"), value)) + self.feedback_queue.put((QtCore.SIGNAL("backup_progress(int)"), value)) def __do_restore__(self, thread_monitor): err_msg = [] @@ -192,17 +191,17 @@ class RestoreVMsWindow(Ui_Restore, QWizard): "investigate them and/or clean them up")) if self.canceled: - self.emit(SIGNAL("restore_progress(QString)"), + self.emit(QtCore.SIGNAL("restore_progress(QString)"), '{0}' .format(self.tr("Restore aborted!"))) elif len(err_msg) > 0 or self.error_detected.is_set(): if len(err_msg) > 0: thread_monitor.set_error_msg('\n'.join(err_msg)) - self.emit(SIGNAL("restore_progress(QString)"), + self.emit(QtCore.SIGNAL("restore_progress(QString)"), '{0}' .format(self.tr("Finished with errors!"))) else: - self.emit(SIGNAL("restore_progress(QString)"), + self.emit(QtCore.SIGNAL("restore_progress(QString)"), '{0}' .format(self.tr("Finished successfully!"))) @@ -234,7 +233,7 @@ class RestoreVMsWindow(Ui_Restore, QWizard): self.confirm_text_edit.setFontFamily("Monospace") self.confirm_text_edit.setText(self.func_output) - self.confirm_page.emit(SIGNAL("completeChanged()")) + self.confirm_page.emit(QtCore.SIGNAL("completeChanged()")) elif self.currentPage() is self.commit_page: self.button(self.FinishButton).setDisabled(True) @@ -243,8 +242,8 @@ class RestoreVMsWindow(Ui_Restore, QWizard): and str(self.dir_line_edit.text()) .count("media/") > 0) - self.thread_monitor = ThreadMonitor() - thread = threading.Thread (target= self.__do_restore__ , args=(self.thread_monitor,)) + self.thread_monitor = thread_monitor.ThreadMonitor() + thread = threading.Thread (target= self.__do_restore__, args=(self.thread_monitor,)) thread.daemon = True thread.start() @@ -260,19 +259,23 @@ class RestoreVMsWindow(Ui_Restore, QWizard): if not self.thread_monitor.success: if self.canceled: if self.tmpdir_to_remove and \ - QMessageBox.warning(None, self.tr("Restore aborted"), + QtGui.QMessageBox.warning( + None, + self.tr("Restore aborted"), self.tr("Do you want to remove temporary files " "from %s?") % self.tmpdir_to_remove, - QMessageBox.Yes, QMessageBox.No) == \ - QMessageBox.Yes: + QtGui.QMessageBox.Yes, + QtGui.QMessageBox.No) == QtGui.QMessageBox.Yes: shutil.rmtree(self.tmpdir_to_remove) else: - QMessageBox.warning(None, - self.tr("Backup error!"), self.tr("ERROR: {0}") - .format(self.thread_monitor.error_msg)) + QtGui.QMessageBox.warning( + None, + self.tr("Backup error!"), + self.tr("ERROR: {0}").format( + self.thread_monitor.error_msg)) if self.showFileDialog.isChecked(): # TODO: this is not working - self.emit(SIGNAL("restore_progress(QString)"), + self.emit(QtCore.SIGNAL("restore_progress(QString)"), '{0}'.format( self.tr( "Please unmount your backup volume and cancel" @@ -281,7 +284,7 @@ class RestoreVMsWindow(Ui_Restore, QWizard): self.target_appvm.run("QUBESRPC %s dom0" % "qubes.SelectDirectory") else: - file_dialog = QFileDialog() + file_dialog = QtGui.QFileDialog() file_dialog.setReadOnly(True) file_dialog.getExistingDirectory( self, self.tr("Detach backup device"), @@ -304,7 +307,7 @@ class RestoreVMsWindow(Ui_Restore, QWizard): def reject(self): # TODO: probably not working too if self.currentPage() is self.commit_page: if self.backup_restore.canceled: - self.emit(SIGNAL("restore_progress(QString)"), + self.emit(QtCore.SIGNAL("restore_progress(QString)"), '{0}' .format(self.tr("Aborting the operation..."))) self.button(self.CancelButton).setDisabled(True) @@ -328,7 +331,7 @@ class RestoreVMsWindow(Ui_Restore, QWizard): return self.select_vms_widget.selected_list.count() > 0 def backup_location_changed(self, new_dir=None): - self.select_dir_page.emit(SIGNAL("completeChanged()")) + self.select_dir_page.emit(QtCore.SIGNAL("completeChanged()")) # Bases on the original code by: @@ -340,18 +343,18 @@ def handle_exception(exc_type, exc_value, exc_traceback): filename = os.path.basename(filename) error = "%s: %s" % (exc_type.__name__, exc_value) - QMessageBox.critical(None, "Houston, we have a problem...", + QtGui.QMessageBox.critical(None, "Houston, we have a problem...", "Whoops. A critical error has occured. " "This is most likely a bug " "in Qubes Restore VMs application.

" "%s" % error + "at line %d of file %s.

" - % (line, filename)) + % (line, filename)) def main(): - qtapp = QApplication(sys.argv) + qtapp = QtGui.QApplication(sys.argv) qtapp.setOrganizationName("The Qubes Project") qtapp.setOrganizationDomain("http://qubes-os.org") qtapp.setApplicationName("Qubes Restore VMs")