From 0b8fc21db7ab820a9426122b5d0a9537e47f011e Mon Sep 17 00:00:00 2001 From: Tomasz Machalski Date: Mon, 31 Mar 2014 21:02:21 +0200 Subject: [PATCH 1/2] Added Bitcurex and Bitmarket exchanges --- plugins/exchange_rate.py | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/plugins/exchange_rate.py b/plugins/exchange_rate.py index 4658ae12b..b7aa73a0b 100644 --- a/plugins/exchange_rate.py +++ b/plugins/exchange_rate.py @@ -16,6 +16,8 @@ from electrum_gui.qt.amountedit import AmountEdit EXCHANGES = ["BitcoinAverage", "BitcoinVenezuela", + "Bitcurex", + "Bitmarket", "BitPay", "Blockchain", "BTCChina", @@ -37,7 +39,7 @@ class Exchanger(threading.Thread): self.query_rates = threading.Event() self.use_exchange = self.parent.config.get('use_exchange', "Blockchain") self.parent.exchanges = EXCHANGES - self.parent.currencies = ["EUR","GBP","USD"] + self.parent.currencies = ["EUR","GBP","USD","PLN"] self.parent.win.emit(SIGNAL("refresh_exchanges_combo()")) self.parent.win.emit(SIGNAL("refresh_currencies_combo()")) self.is_running = False @@ -81,6 +83,8 @@ class Exchanger(threading.Thread): update_rates = { "BitcoinAverage": self.update_ba, "BitcoinVenezuela": self.update_bv, + "Bitcurex": self.update_bx, + "Bitmarket": self.update_bm, "BitPay": self.update_bp, "Blockchain": self.update_bc, "BTCChina": self.update_CNY, @@ -149,6 +153,36 @@ class Exchanger(threading.Thread): pass self.parent.set_currencies(quote_currencies) + def update_bm(self): + try: + jsonresp = self.get_json('www.bitmarket.pl', "/json/BTCPLN/ticker.json") + except Exception: + return + quote_currencies = {"PLN": 0.0} + pln_price = jsonresp["last"] + try: + quote_currencies["PLN"] = decimal.Decimal(str(pln_price)) + with self.lock: + self.quote_currencies = quote_currencies + except KeyError: + pass + self.parent.set_currencies(quote_currencies) + + def update_bx(self): + try: + jsonresp = self.get_json('pln.bitcurex.com', "/data/ticker.json") + except Exception: + return + quote_currencies = {"PLN": 0.0} + pln_price = jsonresp["last"] + try: + quote_currencies["PLN"] = decimal.Decimal(str(pln_price)) + with self.lock: + self.quote_currencies = quote_currencies + except KeyError: + pass + self.parent.set_currencies(quote_currencies) + def update_CNY(self): try: jsonresp = self.get_json('data.btcchina.com', "/data/ticker") From b099930174a3a220930f837e18c3bb314947efca Mon Sep 17 00:00:00 2001 From: Michael Wozniak Date: Mon, 31 Mar 2014 21:52:31 -0400 Subject: [PATCH 2/2] Update create current unix time update method to create current unix time to be windows compatible fix issue #640 --- plugins/exchange_rate.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/exchange_rate.py b/plugins/exchange_rate.py index 4658ae12b..2a0c22a95 100644 --- a/plugins/exchange_rate.py +++ b/plugins/exchange_rate.py @@ -6,6 +6,7 @@ import decimal import httplib import json import threading +import time import re from decimal import Decimal from electrum.plugins import BasePlugin @@ -421,7 +422,7 @@ class Plugin(BasePlugin): newtx = self.wallet.get_tx_history() v = newtx[[x[0] for x in newtx].index(str(item.data(0, Qt.UserRole).toPyObject()))][3] - tx_info = {'timestamp':int(datetime.datetime.now().strftime("%s")), 'value': v } + tx_info = {'timestamp':int(time.time()), 'value': v } pass tx_time = int(tx_info['timestamp']) if cur_exchange == "CoinDesk":