electrum

Electrum Bitcoin wallet
git clone https://git.parazyd.org/electrum
Log | Files | Refs | Submodules

commit 51560b9ecd1b42d5ee8a8318616e7241da4f7572
parent e8b97e5326df188422529ccd12a0ff64bea1c3d0
Author: Maran <maran.hidskes@gmail.com>
Date:   Sun, 10 Mar 2013 17:44:02 +0100

Implement buttons and move to prod server

Diffstat:
Mgui/gui_classic.py | 1-
Mplugins/labels.py | 36++++++++++++++++++++++++++++--------
2 files changed, 28 insertions(+), 9 deletions(-)

diff --git a/gui/gui_classic.py b/gui/gui_classic.py @@ -554,7 +554,6 @@ class ElectrumWindow(QMainWindow): def address_label_changed(self, item, column, l, column_addr, column_label): - if column == column_label: addr = unicode( item.text(column_addr) ) text = unicode( item.text(column_label) ) diff --git a/plugins/labels.py b/plugins/labels.py @@ -13,8 +13,8 @@ from PyQt4.QtCore import * import PyQt4.QtCore as QtCore import PyQt4.QtGui as QtGui -target_host = 'localhost:3000' -auth_token = 'jEnsNBb5fAR5rYSBNYnR' +target_host = 'labelectrum.herokuapp.com' +auth_token = 'naFniLDwQpHzoMkpwB8H' def init(gui): cloud_wallet = CloudWallet(gui.wallet) @@ -25,7 +25,6 @@ def init(gui): def wallet_id(wallet): return hashlib.sha256(str(wallet.get_master_public_key())).digest().encode('hex') - def label_changed(gui,item,label): print "Label changed! Item: %s Label: %s label" % ( item, label) global auth_token, target_host @@ -44,14 +43,30 @@ def add_settings_tab(gui, tabs): cloud_tab = QWidget() layout = QGridLayout(cloud_tab) layout.addWidget(QLabel("API Key: "),0,0) - layout.addWidget(QLineEdit(), 0,2) + layout.addWidget(QLineEdit("jEnsNBb5fAR5rYSBNYnR"), 0,2) layout.addWidget(QLabel("Label sync options: "),1,0) - layout.addWidget(QPushButton("Force upload"), 1,1) - layout.addWidget(QPushButton("Force download"), 1,2) + + upload = QPushButton("Force upload") + upload.clicked.connect(lambda: full_push(gui.wallet)) + layout.addWidget(upload, 1,1) + + download = QPushButton("Force download") + download.clicked.connect(lambda: full_pull(gui.wallet)) + layout.addWidget(download, 1,2) tabs.addTab(cloud_tab, "Label cloud") +def full_push(wallet): + cloud_wallet = CloudWallet(wallet) + cloud_wallet.full_push() + print "Labels pushed" + +def full_pull(wallet): + cloud_wallet = CloudWallet(wallet) + cloud_wallet.full_pull() + print "Labels pulled, please restart your client" + def show(): print 'showing' @@ -64,7 +79,7 @@ def is_enabled(): def toggle(gui): return is_enabled() - +# This can probably be refactored into plain top level methods instead of a class class CloudWallet(): def __init__(self, wallet): self.mpk = hashlib.sha256(str(wallet.get_master_public_key())).digest().encode('hex') @@ -87,7 +102,11 @@ class CloudWallet(): if response.reason == httplib.responses[httplib.NOT_FOUND]: return - response = json.loads(response.read()) + try: + response = json.loads(response.read()) + except ValueError as e: + return + for label in response: for key in self.addresses: target_hashed = hashlib.sha256(key).digest().encode('hex') @@ -116,3 +135,4 @@ class CloudWallet(): if response.reason == httplib.responses[httplib.NOT_FOUND]: return response = json.loads(response.read()) + print response