URI: 
       tmore label sync wip - electrum - Electrum Bitcoin wallet
  HTML git clone https://git.parazyd.org/electrum
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
       ---
   DIR commit 2973f5d2c3ec7de9cc638886f5614c6494116d00
   DIR parent 08cedc452de43308ab88f196f880f1a0c758929a
  HTML Author: Maran <maran.hidskes@gmail.com>
       Date:   Sun, 10 Mar 2013 18:14:21 +0100
       
       more label sync wip
       
       Diffstat:
         M lib/simple_config.py                |       1 -
         M plugins/labels.py                   |      25 ++++++++++++++++---------
       
       2 files changed, 16 insertions(+), 10 deletions(-)
       ---
   DIR diff --git a/lib/simple_config.py b/lib/simple_config.py
       t@@ -151,7 +151,6 @@ a SimpleConfig instance then reads the wallet file.
                    except ConfigParser.NoSectionError:
                        pass
        
       -
            def init_path(self, path):
                """Set the path of the wallet."""
        
   DIR diff --git a/plugins/labels.py b/plugins/labels.py
       t@@ -14,9 +14,16 @@ import PyQt4.QtCore as QtCore
        import PyQt4.QtGui as QtGui
        
        target_host = 'labelectrum.herokuapp.com'
       -auth_token = 'naFniLDwQpHzoMkpwB8H'
        
        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)
            gui.set_hook('create_settings_tab', add_settings_tab)
            gui.set_hook('label_changed', label_changed)
       t@@ -32,7 +39,8 @@ def label_changed(gui,item,label):
            bundle = {"label": {"external_id": hashed, "text": label}}
            params = json.dumps(bundle)
            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()
            if response.reason == httplib.responses[httplib.NOT_FOUND]:
       t@@ -43,7 +51,7 @@ def add_settings_tab(gui, tabs):
              cloud_tab = QWidget()
              layout = QGridLayout(cloud_tab)
              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)
        
       t@@ -64,14 +72,14 @@ def full_push(wallet):
        
        def full_pull(wallet):
            cloud_wallet = CloudWallet(wallet)
       -    cloud_wallet.full_pull()
       +    cloud_wallet.full_pull(True)
            print "Labels pulled, please restart your client"
        
        def show():
            print 'showing'
        
        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():
            return True
       t@@ -94,14 +102,13 @@ class CloudWallet():
                self.addresses = addresses
        
        
       -    def full_pull(self):
       +    def full_pull(self, force = False):
                global target_host, auth_token
                connection = httplib.HTTPConnection(target_host)
                connection.request("GET", ("/api/wallets/%s/labels.json?auth_token=%s" % (self.mpk, auth_token)),"", {'Content-Type': 'application/json'})
                response = connection.getresponse()
                if response.reason == httplib.responses[httplib.NOT_FOUND]:
                    return
       -
                try:
                    response = json.loads(response.read())
                except ValueError as e:
       t@@ -111,12 +118,12 @@ class CloudWallet():
                    for key in self.addresses:
                        target_hashed = hashlib.sha256(key).digest().encode('hex')
                        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"] 
                    for key, value in self.transactions.iteritems():
                        target_hashed = hashlib.sha256(key).digest().encode('hex')
                        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"] 
        
            def full_push(self):