LN invoice: better handle unknown required featured bits in bolt11 invs
A user provided an invoice that requires feature bit 30. (That bit is not in the spec) To test: ``` lnbc1p324a66pp5tundykxx3q5kztsr8x00eknpn2uwe3394cnky3j9a0fswm568wnsdp9facx2mj5d9kk2um5v9khqueqv3hkuct5d9hkucqzpgxq9z0rgqsp5l73jgfgctzc92juer5rk2mqcrkj8teng53dr9vfxj4n8lulu4jmq9q8pqqqssq4gacn859tpzz99hkusnh7m93d5ncpx3t4zns8ynca7akmljpl5vh504qjz7dqwewqjh4md7xagaz5wg85knvxywrhp0sp2t09yta7lcq3qs6fy lntb1p324a66pp5tundykxx3q5kztsr8x00eknpn2uwe3394cnky3j9a0fswm568wnssp5l73jgfgctzc92juer5rk2mqcrkj8teng53dr9vfxj4n8lulu4jmqdp9facx2mj5d9kk2um5v9khqueqv3hkuct5d9hkuxq9z0rgq9q8pqqqssqdte0z9dy7ur7fagsk7r3mtfj6upq88xfylhufys87zqpamklcfgn2f3xeq3nlhvn3qy9tdgg42vq9eq99qz6rz6tzqezfhzuv6zsr5qp7cgel4 ```
This commit is contained in:
@@ -13,6 +13,8 @@ from electrum.invoices import (PR_UNPAID,PR_EXPIRED,PR_UNKNOWN,PR_PAID,PR_INFLIG
|
||||
from electrum.transaction import PartialTxOutput
|
||||
from electrum.lnaddr import lndecode
|
||||
from electrum import bitcoin
|
||||
from electrum import lnutil
|
||||
from electrum.lnaddr import LnInvoiceException
|
||||
|
||||
from .qewallet import QEWallet
|
||||
from .qetypes import QEAmount
|
||||
@@ -334,11 +336,21 @@ class QEInvoiceParser(QEInvoice):
|
||||
self._logger.debug(repr(e))
|
||||
|
||||
lninvoice = None
|
||||
try:
|
||||
maybe_lightning_invoice = maybe_extract_lightning_payment_identifier(maybe_lightning_invoice)
|
||||
lninvoice = Invoice.from_bech32(maybe_lightning_invoice)
|
||||
except InvoiceError as e:
|
||||
pass
|
||||
maybe_lightning_invoice = maybe_extract_lightning_payment_identifier(maybe_lightning_invoice)
|
||||
if maybe_lightning_invoice is not None:
|
||||
try:
|
||||
lninvoice = Invoice.from_bech32(maybe_lightning_invoice)
|
||||
except InvoiceError as e:
|
||||
e2 = e.__cause__
|
||||
if isinstance(e2, LnInvoiceException):
|
||||
self.validationError.emit('unknown', _("Error parsing Lightning invoice") + f":\n{e2}")
|
||||
self.clear()
|
||||
return
|
||||
if isinstance(e2, lnutil.IncompatibleOrInsaneFeatures):
|
||||
self.validationError.emit('unknown', _("Invoice requires unknown or incompatible Lightning feature") + f":\n{e2!r}")
|
||||
self.clear()
|
||||
return
|
||||
self._logger.exception(repr(e))
|
||||
|
||||
if not lninvoice and not self._bip21:
|
||||
self.validationError.emit('unknown',_('Unknown invoice'))
|
||||
|
||||
Reference in New Issue
Block a user