Browse Source

create common class for qt hardware plugins

283
ThomasV 8 years ago
parent
commit
ae779694df
  1. 28
      plugins/hw_wallet/qt.py
  2. 41
      plugins/ledger/qt.py
  3. 22
      plugins/trezor/qt_generic.py

28
plugins/hw_wallet/qt.py

@ -168,3 +168,31 @@ class QtHandlerBase(QObject, PrintError):
def win_yes_no_question(self, msg): def win_yes_no_question(self, msg):
self.ok = self.win.question(msg) self.ok = self.win.question(msg)
self.done.set() self.done.set()
from electrum.plugins import hook
from electrum_gui.qt.main_window import StatusBarButton
class QtPluginBase(object):
@hook
def load_wallet(self, wallet, window):
for keystore in wallet.get_keystores():
if type(keystore) != self.keystore_class:
continue
tooltip = self.device + '\n' + (keystore.label or 'unnamed')
cb = partial(self.show_settings_dialog, window, keystore)
button = StatusBarButton(QIcon(self.icon_unpaired), tooltip, cb)
button.icon_paired = self.icon_paired
button.icon_unpaired = self.icon_unpaired
window.statusBar().addPermanentWidget(button)
handler = self.create_handler(window)
handler.button = button
keystore.handler = handler
keystore.thread = TaskThread(window, window.on_error)
# Trigger a pairing
keystore.thread.add(partial(self.get_client, keystore))
def show_settings_dialog(self, window, keystore):
pass

41
plugins/ledger/qt.py

@ -3,46 +3,25 @@ import threading
from PyQt4.Qt import (QDialog, QInputDialog, QLineEdit, from PyQt4.Qt import (QDialog, QInputDialog, QLineEdit,
QVBoxLayout, QLabel, SIGNAL) QVBoxLayout, QLabel, SIGNAL)
import PyQt4.QtCore as QtCore import PyQt4.QtCore as QtCore
from electrum_gui.qt.main_window import StatusBarButton
from electrum.i18n import _ from electrum.i18n import _
from electrum.plugins import hook from .ledger import LedgerPlugin
from .ledger import LedgerPlugin, Ledger_KeyStore from ..hw_wallet.qt import QtHandlerBase, QtPluginBase
from ..hw_wallet.qt import QtHandlerBase
from electrum_gui.qt.util import * from electrum_gui.qt.util import *
class Plugin(LedgerPlugin):
class Plugin(LedgerPlugin, QtPluginBase):
icon_unpaired = ":icons/ledger_unpaired.png" icon_unpaired = ":icons/ledger_unpaired.png"
icon_paired = ":icons/ledger.png" icon_paired = ":icons/ledger.png"
@hook def create_handler(self, window):
def load_wallet(self, wallet, window): return Ledger_Handler(window)
for keystore in wallet.get_keystores():
if type(keystore) != self.keystore_class:
continue class Ledger_Handler(QtHandlerBase):
tooltip = self.device
cb = partial(self.show_settings_dialog, window, keystore)
button = StatusBarButton(QIcon(self.icon_unpaired), tooltip, cb)
button.icon_paired = self.icon_paired
button.icon_unpaired = self.icon_unpaired
window.statusBar().addPermanentWidget(button)
handler = BTChipQTHandler(window)
handler.button = button
keystore.handler = handler
keystore.thread = TaskThread(window, window.on_error)
# Trigger a pairing
keystore.thread.add(partial(self.get_client, keystore))
def create_handler(self, wizard):
return BTChipQTHandler(wizard)
def show_settings_dialog(self, window, keystore):
pass
class BTChipQTHandler(QtHandlerBase):
def __init__(self, win): def __init__(self, win):
super(BTChipQTHandler, self).__init__(win, 'Ledger') super(Ledger_Handler, self).__init__(win, 'Ledger')
def word_dialog(self, msg): def word_dialog(self, msg):
response = QInputDialog.getText(self.top_level_window(), "Ledger Wallet Authentication", msg, QLineEdit.Password) response = QInputDialog.getText(self.top_level_window(), "Ledger Wallet Authentication", msg, QLineEdit.Password)

22
plugins/trezor/qt_generic.py

@ -7,7 +7,7 @@ from PyQt4.Qt import QVBoxLayout, QLabel, SIGNAL
from electrum_gui.qt.main_window import StatusBarButton from electrum_gui.qt.main_window import StatusBarButton
from electrum_gui.qt.util import * from electrum_gui.qt.util import *
from .plugin import TIM_NEW, TIM_RECOVER, TIM_MNEMONIC from .plugin import TIM_NEW, TIM_RECOVER, TIM_MNEMONIC
from ..hw_wallet.qt import QtHandlerBase from ..hw_wallet.qt import QtHandlerBase, QtPluginBase
from electrum.i18n import _ from electrum.i18n import _
from electrum.plugins import hook, DeviceMgr from electrum.plugins import hook, DeviceMgr
@ -178,7 +178,7 @@ class QtHandler(QtHandlerBase):
class QtPlugin(object): class QtPlugin(QtPluginBase):
# Derived classes must provide the following class-static variables: # Derived classes must provide the following class-static variables:
# icon_file # icon_file
# pin_matrix_widget_class # pin_matrix_widget_class
@ -186,24 +186,6 @@ class QtPlugin(object):
def create_handler(self, window): def create_handler(self, window):
return QtHandler(window, self.pin_matrix_widget_class(), self.device) return QtHandler(window, self.pin_matrix_widget_class(), self.device)
@hook
def load_wallet(self, wallet, window):
for keystore in wallet.get_keystores():
if type(keystore) != self.keystore_class:
continue
tooltip = self.device + ' ' + (keystore.label or '')
cb = partial(self.show_settings_dialog, window, keystore)
button = StatusBarButton(QIcon(self.icon_unpaired), tooltip, cb)
button.icon_paired = self.icon_paired
button.icon_unpaired = self.icon_unpaired
window.statusBar().addPermanentWidget(button)
handler = self.create_handler(window)
handler.button = button
keystore.handler = handler
keystore.thread = TaskThread(window, window.on_error)
# Trigger a pairing
keystore.thread.add(partial(self.get_client, keystore))
@hook @hook
def receive_menu(self, menu, addrs, wallet): def receive_menu(self, menu, addrs, wallet):
if type(wallet) is not Standard_Wallet: if type(wallet) is not Standard_Wallet:

Loading…
Cancel
Save