You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

134 lines
4.1 KiB

import threading
from PyQt6.QtCore import pyqtSignal, pyqtSlot
from electrum.i18n import _
from electrum.plugin import hook
from electrum.gui.qml.qewallet import QEWallet
from electrum.gui.common_qt.plugins import PluginQObject
from .labels import LabelsPlugin
class Plugin(LabelsPlugin):
class QSignalObject(PluginQObject):
labelsChanged = pyqtSignal()
uploadSuccess = pyqtSignal()
uploadFailed = pyqtSignal()
downloadSuccess = pyqtSignal()
downloadFailed = pyqtSignal()
_name = _('LabelSync Plugin')
def __init__(self, plugin, parent):
super().__init__(plugin, parent)
@pyqtSlot(result=str)
def settingsComponent(self): return '../../../plugins/labels/Labels.qml'
@pyqtSlot()
def upload(self):
assert self.plugin
self._busy = True
self.busyChanged.emit()
self.plugin.push_async()
def upload_finished(self, result):
if result:
self.uploadSuccess.emit()
else:
self.uploadFailed.emit()
self._busy = False
self.busyChanged.emit()
@pyqtSlot()
def download(self):
assert self.plugin
self._busy = True
self.busyChanged.emit()
self.plugin.pull_async()
def download_finished(self, result):
if result:
self.downloadSuccess.emit()
else:
self.downloadFailed.emit()
self._busy = False
self.busyChanged.emit()
def __init__(self, *args):
LabelsPlugin.__init__(self, *args)
self._app = None
self.so = None
@hook
def load_wallet(self, wallet):
self.logger.debug(f'plugin enabled for wallet "{str(wallet)}"')
self.start_wallet(wallet)
def push_async(self):
if not self._app.daemon.currentWallet:
self.logger.error('No current wallet')
self.so.download_finished(False)
return
wallet = self._app.daemon.currentWallet.wallet
def push_thread(_wallet):
try:
self.push(_wallet)
self.so.upload_finished(True)
self._app.appController.userNotify.emit(_('Labels uploaded'))
except Exception as e:
self.logger.error(repr(e))
self.so.upload_finished(False)
self._app.appController.userNotify.emit(repr(e))
threading.Thread(target=push_thread, args=[wallet]).start()
def pull_async(self):
if not self._app.daemon.currentWallet:
self.logger.error('No current wallet')
self.so.download_finished(False)
return
wallet = self._app.daemon.currentWallet.wallet
def pull_thread(_wallet):
try:
self.pull(_wallet, True)
self.so.download_finished(True)
self._app.appController.userNotify.emit(_('Labels downloaded'))
except Exception as e:
self.logger.error(repr(e))
self.so.download_finished(False)
self._app.appController.userNotify.emit(repr(e))
threading.Thread(target=pull_thread, args=[wallet]).start()
def on_pulled(self, wallet):
self.logger.info('on pulled')
_wallet = QEWallet.getInstanceFor(wallet)
self.logger.debug('wallet ' + ('found' if _wallet else 'not found'))
if _wallet:
_wallet.labelsUpdated.emit()
@hook
def init_qml(self, app):
self.logger.debug(f'init_qml hook called, gui={str(type(app))}')
self.logger.debug(f'app={self._app!r}, so={self.so!r}')
self._app = app
# important: QSignalObject needs to be parented, as keeping a ref
# in the plugin is not enough to avoid gc
self.so = Plugin.QSignalObject(self, self._app)
# If the user just enabled the plugin, the 'load_wallet' hook would not
# get called for already loaded wallets, hence we call it manually for those:
for wallet_name, wallet in app.daemon.daemon._wallets.items():
self.load_wallet(wallet)