Integrate http_server (previously in electrum-merchant)
Use submodule to fetch HTML and CSS files
This commit is contained in:
@@ -40,13 +40,11 @@ from electrum.bitcoin import COIN
|
||||
from electrum.lnaddr import lndecode
|
||||
import electrum.constants as constants
|
||||
|
||||
from .util import MyTreeView, pr_icons, read_QIcon
|
||||
from .util import MyTreeView, pr_icons, read_QIcon, webopen
|
||||
|
||||
REQUEST_TYPE_BITCOIN = 0
|
||||
REQUEST_TYPE_LN = 1
|
||||
|
||||
ROLE_REQUEST_TYPE = Qt.UserRole
|
||||
ROLE_RHASH_OR_ADDR = Qt.UserRole + 1
|
||||
ROLE_KEY = Qt.UserRole + 1
|
||||
|
||||
class RequestList(MyTreeView):
|
||||
|
||||
@@ -76,7 +74,7 @@ class RequestList(MyTreeView):
|
||||
def select_key(self, key):
|
||||
for i in range(self.model().rowCount()):
|
||||
item = self.model().index(i, self.Columns.DATE)
|
||||
row_key = item.data(ROLE_RHASH_OR_ADDR)
|
||||
row_key = item.data(ROLE_KEY)
|
||||
if key == row_key:
|
||||
self.selectionModel().setCurrentIndex(item, QItemSelectionModel.SelectCurrent | QItemSelectionModel.Rows)
|
||||
break
|
||||
@@ -85,12 +83,12 @@ class RequestList(MyTreeView):
|
||||
# TODO use siblingAtColumn when min Qt version is >=5.11
|
||||
item = self.model().itemFromIndex(idx.sibling(idx.row(), self.Columns.DATE))
|
||||
request_type = item.data(ROLE_REQUEST_TYPE)
|
||||
key = item.data(ROLE_RHASH_OR_ADDR)
|
||||
is_lightning = request_type == REQUEST_TYPE_LN
|
||||
req = self.wallet.get_request(key, is_lightning)
|
||||
key = item.data(ROLE_KEY)
|
||||
req = self.wallet.get_request(key)
|
||||
if req is None:
|
||||
self.update()
|
||||
return
|
||||
is_lightning = request_type == PR_TYPE_LN
|
||||
text = req.get('invoice') if is_lightning else req.get('URI')
|
||||
self.parent.receive_address_e.setText(text)
|
||||
|
||||
@@ -101,9 +99,9 @@ class RequestList(MyTreeView):
|
||||
date_idx = idx.sibling(idx.row(), self.Columns.DATE)
|
||||
date_item = m.itemFromIndex(date_idx)
|
||||
status_item = m.itemFromIndex(idx)
|
||||
key = date_item.data(ROLE_RHASH_OR_ADDR)
|
||||
is_lightning = date_item.data(ROLE_REQUEST_TYPE) == REQUEST_TYPE_LN
|
||||
req = self.wallet.get_request(key, is_lightning)
|
||||
key = date_item.data(ROLE_KEY)
|
||||
is_lightning = date_item.data(ROLE_REQUEST_TYPE) == PR_TYPE_LN
|
||||
req = self.wallet.get_request(key)
|
||||
if req:
|
||||
status = req['status']
|
||||
status_str = get_request_status(req)
|
||||
@@ -121,7 +119,7 @@ class RequestList(MyTreeView):
|
||||
if status == PR_PAID:
|
||||
continue
|
||||
is_lightning = req['type'] == PR_TYPE_LN
|
||||
request_type = REQUEST_TYPE_LN if is_lightning else REQUEST_TYPE_BITCOIN
|
||||
request_type = req['type']
|
||||
timestamp = req.get('time', 0)
|
||||
amount = req.get('amount')
|
||||
message = req['message'] if is_lightning else req['memo']
|
||||
@@ -133,18 +131,17 @@ class RequestList(MyTreeView):
|
||||
self.set_editability(items)
|
||||
items[self.Columns.DATE].setData(request_type, ROLE_REQUEST_TYPE)
|
||||
items[self.Columns.STATUS].setIcon(read_QIcon(pr_icons.get(status)))
|
||||
if request_type == REQUEST_TYPE_LN:
|
||||
items[self.Columns.DATE].setData(req['rhash'], ROLE_RHASH_OR_ADDR)
|
||||
if request_type == PR_TYPE_LN:
|
||||
items[self.Columns.DATE].setData(req['rhash'], ROLE_KEY)
|
||||
items[self.Columns.DATE].setIcon(read_QIcon("lightning.png"))
|
||||
items[self.Columns.DATE].setData(REQUEST_TYPE_LN, ROLE_REQUEST_TYPE)
|
||||
else:
|
||||
elif request_type == PR_TYPE_ADDRESS:
|
||||
address = req['address']
|
||||
if address not in domain:
|
||||
continue
|
||||
expiration = req.get('exp', None)
|
||||
signature = req.get('sig')
|
||||
requestor = req.get('name', '')
|
||||
items[self.Columns.DATE].setData(address, ROLE_RHASH_OR_ADDR)
|
||||
items[self.Columns.DATE].setData(address, ROLE_KEY)
|
||||
if signature is not None:
|
||||
items[self.Columns.DATE].setIcon(read_QIcon("seal.png"))
|
||||
items[self.Columns.DATE].setToolTip(f'signed by {requestor}')
|
||||
@@ -167,13 +164,9 @@ class RequestList(MyTreeView):
|
||||
item = self.model().itemFromIndex(idx.sibling(idx.row(), self.Columns.DATE))
|
||||
if not item:
|
||||
return
|
||||
addr = item.data(ROLE_RHASH_OR_ADDR)
|
||||
key = item.data(ROLE_KEY)
|
||||
request_type = item.data(ROLE_REQUEST_TYPE)
|
||||
assert request_type in [REQUEST_TYPE_BITCOIN, REQUEST_TYPE_LN]
|
||||
if request_type == REQUEST_TYPE_BITCOIN:
|
||||
req = self.wallet.receive_requests.get(addr)
|
||||
elif request_type == REQUEST_TYPE_LN:
|
||||
req = self.wallet.lnworker.invoices[addr][0]
|
||||
req = self.wallet.get_request(key)
|
||||
if req is None:
|
||||
self.update()
|
||||
return
|
||||
@@ -184,19 +177,15 @@ class RequestList(MyTreeView):
|
||||
if column == self.Columns.AMOUNT:
|
||||
column_data = column_data.strip()
|
||||
menu.addAction(_("Copy {}").format(column_title), lambda: self.parent.do_copy(column_title, column_data))
|
||||
if request_type == REQUEST_TYPE_BITCOIN:
|
||||
self.create_menu_bitcoin_payreq(menu, addr)
|
||||
elif request_type == REQUEST_TYPE_LN:
|
||||
self.create_menu_ln_payreq(menu, addr, req)
|
||||
|
||||
#menu.addAction(_("Copy Address"), lambda: self.parent.do_copy('Address', addr))
|
||||
menu.addAction(_("Copy Request"), lambda: self.parent.do_copy('URI', self.wallet.get_request_URI(addr)))
|
||||
if 'http_url' in req:
|
||||
menu.addAction(_("View in web browser"), lambda: webopen(req['http_url']))
|
||||
|
||||
# do bip70 only for browser access
|
||||
# so, each request should have an ID, regardless
|
||||
#menu.addAction(_("Save as BIP70 file"), lambda: self.parent.export_payment_request(addr))
|
||||
menu.addAction(_("Delete"), lambda: self.parent.delete_request(key))
|
||||
run_hook('receive_list_menu', menu, key)
|
||||
menu.exec_(self.viewport().mapToGlobal(position))
|
||||
|
||||
def create_menu_bitcoin_payreq(self, menu, addr):
|
||||
menu.addAction(_("Copy Address"), lambda: self.parent.do_copy('Address', addr))
|
||||
menu.addAction(_("Copy URI"), lambda: self.parent.do_copy('URI', self.wallet.get_request_URI(addr)))
|
||||
menu.addAction(_("Save as BIP70 file"), lambda: self.parent.export_payment_request(addr))
|
||||
menu.addAction(_("Delete"), lambda: self.parent.delete_payment_request(addr))
|
||||
run_hook('receive_list_menu', menu, addr)
|
||||
|
||||
def create_menu_ln_payreq(self, menu, payreq_key, req):
|
||||
menu.addAction(_("Copy Lightning invoice"), lambda: self.parent.do_copy('Lightning invoice', req))
|
||||
menu.addAction(_("Delete"), lambda: self.parent.delete_lightning_payreq(payreq_key))
|
||||
|
||||
Reference in New Issue
Block a user