diff --git a/src/vorta/views/repo_add_dialog.py b/src/vorta/views/repo_add_dialog.py index dbb88a299e..2f23d094a1 100644 --- a/src/vorta/views/repo_add_dialog.py +++ b/src/vorta/views/repo_add_dialog.py @@ -1,3 +1,4 @@ +import logging import re from PyQt5 import QtCore, uic from PyQt5.QtWidgets import QAction, QApplication, QDialogButtonBox, QLineEdit @@ -9,6 +10,8 @@ from vorta.utils import borg_compat, choose_file_dialog, get_asset, get_private_keys, validate_passwords from vorta.views.utils import get_colored_icon +logger = logging.getLogger(__name__) + uifile = get_asset('UI/repoadd.ui') AddRepoUI, AddRepoBase = uic.loadUiType(uifile) @@ -27,7 +30,7 @@ def __init__(self, parent=None): self.saveButton = self.buttonBox.button(QDialogButtonBox.StandardButton.Ok) self.saveButton.setText(self.tr("Add")) - self.buttonBox.rejected.connect(self.close) + self.buttonBox.rejected.connect(self.cancel_job) self.buttonBox.accepted.connect(self.run) self.chooseLocalFolderButton.clicked.connect(self.choose_local_backup_folder) self.useRemoteRepoButton.clicked.connect(self.use_remote_repo_action) @@ -211,6 +214,24 @@ def password_listener(self): self.passwordLabel.setText(translate('utils', msg)) return not bool(msg) + def cancel_job(self): + self.close() + try: + if self.job: + self.job.cancel() + logger.debug(f"Cancelled adding repo {self.values['repo_url']}") + except Exception as e: + logger.error(e) + + # def cancel_queued_job(self): + # self.close() + # try: + # if self.job or self.job.repo_id() in self.job_manager.jobs: + # self.job.cancel() + # logger.debug(f"Cancelled adding repo {self.values['repo_url']}") + # except: + # pass + class ExistingRepoWindow(AddRepoWindow): def __init__(self): @@ -242,10 +263,10 @@ def run(self): params = BorgInfoRepoJob.prepare(self.values) if params['ok']: self.saveButton.setEnabled(False) - thread = BorgInfoRepoJob(params['cmd'], params) - thread.updated.connect(self._set_status) - thread.result.connect(self.run_result) - self.thread = thread # Needs to be connected to self for tests to work. - self.thread.run() + job = BorgInfoRepoJob(params['cmd'], params, params['repo_id']) + job.updated.connect(self._set_status) + job.result.connect(self.run_result) + self.job = job # Needs to be connected to self for tests to work. + QApplication.instance().jobs_manager.add_job(job) else: self._set_status(params['message'])