mirror of
https://github.com/lnbits/lnbits-legend.git
synced 2024-11-19 18:11:30 +01:00
works
This commit is contained in:
parent
228717195b
commit
a147a07bab
1
Pipfile
1
Pipfile
@ -29,6 +29,7 @@ uvicorn = {extras = ["standard"], version = "*"}
|
||||
sse-starlette = "*"
|
||||
jinja2 = "3.0.1"
|
||||
pyngrok = "*"
|
||||
secp256k1 = "*"
|
||||
|
||||
[dev-packages]
|
||||
black = "==20.8b1"
|
||||
|
840
Pipfile.lock
generated
840
Pipfile.lock
generated
File diff suppressed because it is too large
Load Diff
@ -2,11 +2,14 @@ import bitstring # type: ignore
|
||||
import re
|
||||
import hashlib
|
||||
from typing import List, NamedTuple, Optional
|
||||
from bech32 import bech32_decode, CHARSET # type: ignore
|
||||
from bech32 import bech32_encode, bech32_decode, CHARSET
|
||||
from ecdsa import SECP256k1, VerifyingKey # type: ignore
|
||||
from ecdsa.util import sigdecode_string # type: ignore
|
||||
from binascii import unhexlify
|
||||
|
||||
import time
|
||||
from decimal import Decimal
|
||||
import embit
|
||||
import secp256k1
|
||||
|
||||
class Route(NamedTuple):
|
||||
pubkey: str
|
||||
@ -138,23 +141,23 @@ def encode(options):
|
||||
|
||||
if options.fallback:
|
||||
addr.tags.append(("f", options.fallback))
|
||||
|
||||
for r in options.route:
|
||||
splits = r.split("/")
|
||||
route = []
|
||||
while len(splits) >= 5:
|
||||
route.append(
|
||||
(
|
||||
unhexlify(splits[0]),
|
||||
unhexlify(splits[1]),
|
||||
int(splits[2]),
|
||||
int(splits[3]),
|
||||
int(splits[4]),
|
||||
if options.route:
|
||||
for r in options.route:
|
||||
splits = r.split("/")
|
||||
route = []
|
||||
while len(splits) >= 5:
|
||||
route.append(
|
||||
(
|
||||
unhexlify(splits[0]),
|
||||
unhexlify(splits[1]),
|
||||
int(splits[2]),
|
||||
int(splits[3]),
|
||||
int(splits[4]),
|
||||
)
|
||||
)
|
||||
)
|
||||
splits = splits[5:]
|
||||
assert len(splits) == 0
|
||||
addr.tags.append(("r", route))
|
||||
splits = splits[5:]
|
||||
assert len(splits) == 0
|
||||
addr.tags.append(("r", route))
|
||||
return lnencode(addr, options.privkey)
|
||||
|
||||
|
||||
@ -171,7 +174,7 @@ def lnencode(addr, privkey):
|
||||
else:
|
||||
amount = addr.currency if addr.currency else ""
|
||||
|
||||
hrp = "ln" + amount
|
||||
hrp = "ln" + amount + "0n"
|
||||
|
||||
# Start with the timestamp
|
||||
data = bitstring.pack("uint:35", addr.date)
|
||||
@ -264,6 +267,19 @@ class LnAddr(object):
|
||||
)
|
||||
|
||||
|
||||
def shorten_amount(amount):
|
||||
""" Given an amount in bitcoin, shorten it
|
||||
"""
|
||||
# Convert to pico initially
|
||||
amount = int(amount * 10**12)
|
||||
units = ['p', 'n', 'u', 'm', '']
|
||||
for unit in units:
|
||||
if amount % 1000 == 0:
|
||||
amount //= 1000
|
||||
else:
|
||||
break
|
||||
return str(amount) + unit
|
||||
|
||||
def _unshorten_amount(amount: str) -> int:
|
||||
"""Given a shortened amount, return millisatoshis"""
|
||||
# BOLT #11:
|
||||
@ -294,6 +310,24 @@ def _pull_tagged(stream):
|
||||
return (CHARSET[tag], stream.read(length * 5), stream)
|
||||
|
||||
|
||||
def is_p2pkh(currency, prefix):
|
||||
return prefix == base58_prefix_map[currency][0]
|
||||
|
||||
def is_p2sh(currency, prefix):
|
||||
return prefix == base58_prefix_map[currency][1]
|
||||
|
||||
# Tagged field containing BitArray
|
||||
def tagged(char, l):
|
||||
# Tagged fields need to be zero-padded to 5 bits.
|
||||
while l.len % 5 != 0:
|
||||
l.append('0b0')
|
||||
return bitstring.pack("uint:5, uint:5, uint:5",
|
||||
CHARSET.find(char),
|
||||
(l.len / 5) / 32, (l.len / 5) % 32) + l
|
||||
|
||||
def tagged_bytes(char, l):
|
||||
return tagged(char, bitstring.BitArray(l))
|
||||
|
||||
def _trim_to_bytes(barr):
|
||||
# Adds a byte if necessary.
|
||||
b = barr.tobytes()
|
||||
@ -315,3 +349,11 @@ def _u5_to_bitarray(arr: List[int]) -> bitstring.BitArray:
|
||||
for a in arr:
|
||||
ret += bitstring.pack("uint:5", a)
|
||||
return ret
|
||||
|
||||
def bitarray_to_u5(barr):
|
||||
assert barr.len % 5 == 0
|
||||
ret = []
|
||||
s = bitstring.ConstBitStream(barr)
|
||||
while s.pos != s.len:
|
||||
ret.append(s.read(5).uint)
|
||||
return ret
|
@ -4,6 +4,9 @@ import httpx
|
||||
from os import getenv
|
||||
from datetime import datetime, timedelta
|
||||
from typing import Optional, Dict, AsyncGenerator
|
||||
import random
|
||||
import string
|
||||
from lnbits.helpers import urlsafe_short_hash
|
||||
import hashlib
|
||||
from ..bolt11 import encode
|
||||
from .base import (
|
||||
@ -15,43 +18,48 @@ from .base import (
|
||||
)
|
||||
|
||||
class FakeWallet(Wallet):
|
||||
"""https://github.com/lnbits/lnbits"""
|
||||
|
||||
def __init__(self):
|
||||
self.amount = 0
|
||||
self.timestamp = 0
|
||||
self.currency = "bc"
|
||||
self.paymenthash = ""
|
||||
self.privkey = getenv("FAKE_WALLET_KEY")
|
||||
self.memo = ""
|
||||
self.description_hashed = ""
|
||||
self.description = ""
|
||||
self.fallback = None
|
||||
self.expires = None
|
||||
self.route = None
|
||||
async def status(self) -> StatusResponse:
|
||||
print(
|
||||
"The FakeWallet backend is for using LNbits as a centralised, stand-alone payment system."
|
||||
)
|
||||
return StatusResponse(None, 21000000000)
|
||||
|
||||
async def create_invoice(
|
||||
self,
|
||||
amount: int,
|
||||
memo: Optional[str] = None,
|
||||
description_hash: Optional[bytes] = None,
|
||||
) -> InvoiceResponse:
|
||||
class options:
|
||||
def __init__(self, amount, timestamp, payments_hash, privkey, memo, ):
|
||||
self.name = name
|
||||
self.age = age
|
||||
async def status(self) -> StatusResponse:
|
||||
|
||||
randomHash = hashlib.sha256(b"some random data").hexdigest()
|
||||
options = {
|
||||
"amount": amount,
|
||||
"timestamp": datetime.now().timestamp(),
|
||||
"payments_hash": randomHash,
|
||||
"privkey": "v3qrevqrevm39qin0vq3r0ivmrewvmq3rimq03ig",
|
||||
"memo": "",
|
||||
"description_hashed": "",
|
||||
}
|
||||
print(self.privkey)
|
||||
self.amount = amount
|
||||
self.timestamp = datetime.now().timestamp()
|
||||
if description_hash:
|
||||
options.description_hashed = description_hash
|
||||
self.tags_set = {"h"}
|
||||
self.description_hashed = description_hash
|
||||
else:
|
||||
options.memo = memo
|
||||
payment_request = encode(options)
|
||||
self.tags_set = {"d"}
|
||||
self.memo = memo
|
||||
self.description = memo
|
||||
letters = string.ascii_lowercase
|
||||
randomHash = hashlib.sha256(str(random.getrandbits(256)).encode('utf-8')).hexdigest()
|
||||
self.paymenthash = randomHash
|
||||
payment_request = encode(self)
|
||||
print(payment_request)
|
||||
checking_id = randomHash
|
||||
|
||||
return InvoiceResponse(ok, checking_id, payment_request)
|
||||
return InvoiceResponse(True, checking_id, payment_request)
|
||||
|
||||
|
||||
async def pay_invoice(self, bolt11: str) -> PaymentResponse:
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user