Browse Source

more label sync wip

283
Maran 12 years ago
parent
commit
2973f5d2c3
  1. 1
      lib/simple_config.py
  2. 25
      plugins/labels.py

1
lib/simple_config.py

@ -151,7 +151,6 @@ a SimpleConfig instance then reads the wallet file.
except ConfigParser.NoSectionError: except ConfigParser.NoSectionError:
pass pass
def init_path(self, path): def init_path(self, path):
"""Set the path of the wallet.""" """Set the path of the wallet."""

25
plugins/labels.py

@ -14,9 +14,16 @@ import PyQt4.QtCore as QtCore
import PyQt4.QtGui as QtGui import PyQt4.QtGui as QtGui
target_host = 'labelectrum.herokuapp.com' target_host = 'labelectrum.herokuapp.com'
auth_token = 'naFniLDwQpHzoMkpwB8H'
def init(gui): def init(gui):
"""If you want to give this a spin create a account at the target_host url and put it in your user dir config
file with the label_api_key."""
global auth_token
auth_token = gui.config.get("label_api_key")
if not auth_token:
return
cloud_wallet = CloudWallet(gui.wallet) cloud_wallet = CloudWallet(gui.wallet)
gui.set_hook('create_settings_tab', add_settings_tab) gui.set_hook('create_settings_tab', add_settings_tab)
gui.set_hook('label_changed', label_changed) gui.set_hook('label_changed', label_changed)
@ -32,7 +39,8 @@ def label_changed(gui,item,label):
bundle = {"label": {"external_id": hashed, "text": label}} bundle = {"label": {"external_id": hashed, "text": label}}
params = json.dumps(bundle) params = json.dumps(bundle)
connection = httplib.HTTPConnection(target_host) connection = httplib.HTTPConnection(target_host)
connection.request("POST", ("/api/wallets/%s/labels.json?auth_token=%s" % (wallet_id(gui.wallet), auth_token)), params, {'Content-Type': 'application/json'}) wallet = wallet_id(gui.wallet)
connection.request("POST", ("/api/wallets/%s/labels.json?auth_token=%s" % (wallet, auth_token)), params, {'Content-Type': 'application/json'})
response = connection.getresponse() response = connection.getresponse()
if response.reason == httplib.responses[httplib.NOT_FOUND]: if response.reason == httplib.responses[httplib.NOT_FOUND]:
@ -43,7 +51,7 @@ def add_settings_tab(gui, tabs):
cloud_tab = QWidget() cloud_tab = QWidget()
layout = QGridLayout(cloud_tab) layout = QGridLayout(cloud_tab)
layout.addWidget(QLabel("API Key: "),0,0) layout.addWidget(QLabel("API Key: "),0,0)
layout.addWidget(QLineEdit("jEnsNBb5fAR5rYSBNYnR"), 0,2) layout.addWidget(QLineEdit(auth_token), 0,2)
layout.addWidget(QLabel("Label sync options: "),1,0) layout.addWidget(QLabel("Label sync options: "),1,0)
@ -64,14 +72,14 @@ def full_push(wallet):
def full_pull(wallet): def full_pull(wallet):
cloud_wallet = CloudWallet(wallet) cloud_wallet = CloudWallet(wallet)
cloud_wallet.full_pull() cloud_wallet.full_pull(True)
print "Labels pulled, please restart your client" print "Labels pulled, please restart your client"
def show(): def show():
print 'showing' print 'showing'
def get_info(): def get_info():
return 'Label sync', "Syncs your labels with LabElectrum. Labels are not encrypted, transactions and addresses are however." return 'Label sync', "Syncs your labels with LabElectrum. Labels are not encrypted, transactions and addresses are however. This code might increase the load of your wallet with a few micoseconds as it will sync labels on each startup."
def is_enabled(): def is_enabled():
return True return True
@ -94,14 +102,13 @@ class CloudWallet():
self.addresses = addresses self.addresses = addresses
def full_pull(self): def full_pull(self, force = False):
global target_host, auth_token global target_host, auth_token
connection = httplib.HTTPConnection(target_host) connection = httplib.HTTPConnection(target_host)
connection.request("GET", ("/api/wallets/%s/labels.json?auth_token=%s" % (self.mpk, auth_token)),"", {'Content-Type': 'application/json'}) connection.request("GET", ("/api/wallets/%s/labels.json?auth_token=%s" % (self.mpk, auth_token)),"", {'Content-Type': 'application/json'})
response = connection.getresponse() response = connection.getresponse()
if response.reason == httplib.responses[httplib.NOT_FOUND]: if response.reason == httplib.responses[httplib.NOT_FOUND]:
return return
try: try:
response = json.loads(response.read()) response = json.loads(response.read())
except ValueError as e: except ValueError as e:
@ -111,12 +118,12 @@ class CloudWallet():
for key in self.addresses: for key in self.addresses:
target_hashed = hashlib.sha256(key).digest().encode('hex') target_hashed = hashlib.sha256(key).digest().encode('hex')
if label["external_id"] == target_hashed: if label["external_id"] == target_hashed:
if not self.labels.get(key): if force or not self.labels.get(key):
self.labels[key] = label["text"] self.labels[key] = label["text"]
for key, value in self.transactions.iteritems(): for key, value in self.transactions.iteritems():
target_hashed = hashlib.sha256(key).digest().encode('hex') target_hashed = hashlib.sha256(key).digest().encode('hex')
if label["external_id"] == target_hashed: if label["external_id"] == target_hashed:
if not self.labels.get(key): if force or not self.labels.get(key):
self.labels[key] = label["text"] self.labels[key] = label["text"]
def full_push(self): def full_push(self):

Loading…
Cancel
Save