2021-11-17 17:53:32 +01:00
|
|
|
import hashlib
|
2023-02-01 16:54:07 +01:00
|
|
|
import json
|
2022-06-27 00:11:46 +02:00
|
|
|
import random
|
2022-08-03 14:10:32 +02:00
|
|
|
import secrets
|
2022-06-27 00:11:46 +02:00
|
|
|
import string
|
2023-02-01 16:54:07 +01:00
|
|
|
from subprocess import PIPE, Popen, run
|
2022-08-03 14:10:32 +02:00
|
|
|
|
2021-11-17 17:53:32 +01:00
|
|
|
from lnbits.core.crud import create_payment
|
2023-06-15 12:36:28 +02:00
|
|
|
from lnbits.settings import get_wallet_class, set_wallet_class
|
2021-11-17 17:53:32 +01:00
|
|
|
|
2022-06-01 14:53:05 +02:00
|
|
|
|
2021-11-17 17:53:32 +01:00
|
|
|
async def credit_wallet(wallet_id: str, amount: int):
|
|
|
|
preimage = secrets.token_hex(32)
|
|
|
|
m = hashlib.sha256()
|
|
|
|
m.update(f"{preimage}".encode())
|
|
|
|
payment_hash = m.hexdigest()
|
|
|
|
await create_payment(
|
|
|
|
wallet_id=wallet_id,
|
|
|
|
payment_request="",
|
|
|
|
payment_hash=payment_hash,
|
|
|
|
checking_id=payment_hash,
|
|
|
|
preimage=preimage,
|
2022-06-27 00:11:46 +02:00
|
|
|
memo=f"funding_test_{get_random_string(5)}",
|
2022-06-01 14:53:05 +02:00
|
|
|
amount=amount, # msat
|
|
|
|
pending=False, # not pending, so it will increase the wallet's balance
|
2021-11-17 17:53:32 +01:00
|
|
|
)
|
2022-06-27 00:11:46 +02:00
|
|
|
|
|
|
|
|
2023-02-01 16:54:07 +01:00
|
|
|
def get_random_string(N: int = 10):
|
2022-06-27 00:11:46 +02:00
|
|
|
return "".join(
|
|
|
|
random.SystemRandom().choice(string.ascii_uppercase + string.digits)
|
2023-01-24 12:04:19 +01:00
|
|
|
for _ in range(N)
|
2022-06-27 00:11:46 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
async def get_random_invoice_data():
|
|
|
|
return {"out": False, "amount": 10, "memo": f"test_memo_{get_random_string(10)}"}
|
Boltz.exchange Extension (#922)
* initial commit and still draft, ready for review
* forgot to uncomment this line
* fee estimation and blockheight
* resolve conversation with michael, to use mempool websockets instead of boltz status event
* Update lnbits/extensions/boltz/boltz.py
Co-authored-by: michael1011 <me@michael1011.at>
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* fix docker hosts for development
* add api endpoints to _api_docs
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* more blackformatting and refactoring create_swap()
* fix variable bug
* check if swap is already refunded
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* raise exception in mempool fails
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* black formatting
* add some logging with loguru, and remove function duplication
* cleanup readme
* updates/suggestions from calle
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* remove unused comments
* Update API Endpoints
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* un-factor get_boltz_pairs
* added a explaination for the onchain tx
* remove unused template file
* rename api endpoints
* fix isort and prettier
* more verbose logging!!
* add boltz to mock_data.zip
* new mockdata
* remove comment
* better readme
* fix mempool urls
* change /refund /check /status to post requests
* first step in tests2
* add first tests
* change refund,check,status to post requests
* next try on tests
* overall code improvements
* just testing tests
* throw http exceptions in views_api
* require admincheck for refund,check,status and added fastapi documentation for those
* added more tests
* black
* many code improvements
* adding tests
* temp fix test
* fix race condition when pay_invoice fails
* test are working
* add boltz env variables
* add startup check, bugfixes, improvements
* improve on status checking
* remove check_invoice_status
* more fixes and tests
* testing testing testing
* make tests run again inside regtest
* fix bad error :O
* fix postgres boolean bug and add swap test
* Update README.md
Update README.md
Update README.md
Update README.md
* some mypy
* blacked
* the missing commit?
* fix api_docs readme link
* better refunding error catching
fix
* check swaps now also shows pending reverse swap, ui improvements, tooltips
* add backend check for boltz limits
fixup
* many improvements, startup check for swaps working, reverse needs more testing
* little last fixes
* remove unused logic
* fastapi documentation
fixup
* formatting and remove unused tests
* fix test
* fix swapstatus model
* Update lnbits/extensions/boltz/tasks.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* Update lnbits/extensions/boltz/views_api.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* balance check msg, format
* fix mypy data override
* fix swapstatus, remove can refund column
* Update lnbits/extensions/boltz/README.md
Co-authored-by: michael1011 <me@michael1011.at>
* empty lines
* fix error message when swap is not found
* remove preimage_hash from database
* fix api_docs html
fix api_docs html
* catch boltz network exceptions better
* formatting
* check for timeout on swap at get request
Co-authored-by: michael1011 <me@michael1011.at>
Co-authored-by: fusion44 <some.fusion@gmail.com>
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
2022-08-30 12:51:17 +02:00
|
|
|
|
|
|
|
|
2023-06-15 12:36:28 +02:00
|
|
|
set_wallet_class()
|
2022-10-05 11:15:11 +02:00
|
|
|
WALLET = get_wallet_class()
|
|
|
|
is_fake: bool = WALLET.__class__.__name__ == "FakeWallet"
|
Boltz.exchange Extension (#922)
* initial commit and still draft, ready for review
* forgot to uncomment this line
* fee estimation and blockheight
* resolve conversation with michael, to use mempool websockets instead of boltz status event
* Update lnbits/extensions/boltz/boltz.py
Co-authored-by: michael1011 <me@michael1011.at>
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* fix docker hosts for development
* add api endpoints to _api_docs
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* more blackformatting and refactoring create_swap()
* fix variable bug
* check if swap is already refunded
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* raise exception in mempool fails
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* black formatting
* add some logging with loguru, and remove function duplication
* cleanup readme
* updates/suggestions from calle
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* remove unused comments
* Update API Endpoints
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* un-factor get_boltz_pairs
* added a explaination for the onchain tx
* remove unused template file
* rename api endpoints
* fix isort and prettier
* more verbose logging!!
* add boltz to mock_data.zip
* new mockdata
* remove comment
* better readme
* fix mempool urls
* change /refund /check /status to post requests
* first step in tests2
* add first tests
* change refund,check,status to post requests
* next try on tests
* overall code improvements
* just testing tests
* throw http exceptions in views_api
* require admincheck for refund,check,status and added fastapi documentation for those
* added more tests
* black
* many code improvements
* adding tests
* temp fix test
* fix race condition when pay_invoice fails
* test are working
* add boltz env variables
* add startup check, bugfixes, improvements
* improve on status checking
* remove check_invoice_status
* more fixes and tests
* testing testing testing
* make tests run again inside regtest
* fix bad error :O
* fix postgres boolean bug and add swap test
* Update README.md
Update README.md
Update README.md
Update README.md
* some mypy
* blacked
* the missing commit?
* fix api_docs readme link
* better refunding error catching
fix
* check swaps now also shows pending reverse swap, ui improvements, tooltips
* add backend check for boltz limits
fixup
* many improvements, startup check for swaps working, reverse needs more testing
* little last fixes
* remove unused logic
* fastapi documentation
fixup
* formatting and remove unused tests
* fix test
* fix swapstatus model
* Update lnbits/extensions/boltz/tasks.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* Update lnbits/extensions/boltz/views_api.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* balance check msg, format
* fix mypy data override
* fix swapstatus, remove can refund column
* Update lnbits/extensions/boltz/README.md
Co-authored-by: michael1011 <me@michael1011.at>
* empty lines
* fix error message when swap is not found
* remove preimage_hash from database
* fix api_docs html
fix api_docs html
* catch boltz network exceptions better
* formatting
* check for timeout on swap at get request
Co-authored-by: michael1011 <me@michael1011.at>
Co-authored-by: fusion44 <some.fusion@gmail.com>
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
2022-08-30 12:51:17 +02:00
|
|
|
is_regtest: bool = not is_fake
|
2023-02-01 16:54:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
docker_bitcoin_rpc = "lnbits"
|
|
|
|
docker_prefix = "lnbits-legend"
|
2023-02-01 17:19:56 +01:00
|
|
|
docker_cmd = "docker exec"
|
2023-02-01 16:54:07 +01:00
|
|
|
|
2023-06-15 12:36:28 +02:00
|
|
|
docker_lightning = f"{docker_cmd} {docker_prefix}-lnd-1-1"
|
|
|
|
docker_lightning_cli = f"{docker_lightning} lncli --network regtest --rpcserver=lnd-1"
|
2023-02-01 16:54:07 +01:00
|
|
|
|
|
|
|
docker_bitcoin = f"{docker_cmd} {docker_prefix}-bitcoind-1-1"
|
|
|
|
docker_bitcoin_cli = f"{docker_bitcoin} bitcoin-cli -rpcuser={docker_bitcoin_rpc} -rpcpassword={docker_bitcoin_rpc} -regtest"
|
|
|
|
|
|
|
|
|
|
|
|
def run_cmd(cmd: str) -> str:
|
|
|
|
return run(cmd, shell=True, capture_output=True).stdout.decode("UTF-8").strip()
|
|
|
|
|
|
|
|
|
|
|
|
def run_cmd_json(cmd: str) -> dict:
|
|
|
|
return json.loads(run_cmd(cmd))
|
|
|
|
|
|
|
|
|
2023-06-15 12:36:28 +02:00
|
|
|
def get_real_invoice(sats: int) -> dict:
|
2023-06-19 12:12:00 +02:00
|
|
|
return run_cmd_json(f"{docker_lightning_cli} addinvoice {sats}")
|
2023-02-01 16:54:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
def pay_real_invoice(invoice: str) -> Popen:
|
|
|
|
return Popen(
|
2023-06-19 12:12:00 +02:00
|
|
|
f"{docker_lightning_cli} payinvoice --force {invoice}",
|
2023-06-15 12:36:28 +02:00
|
|
|
shell=True,
|
|
|
|
stdin=PIPE,
|
|
|
|
stdout=PIPE,
|
2023-02-01 16:54:07 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def mine_blocks(blocks: int = 1) -> str:
|
|
|
|
return run_cmd(f"{docker_bitcoin_cli} -generate {blocks}")
|
|
|
|
|
|
|
|
|
|
|
|
def create_onchain_address(address_type: str = "bech32") -> str:
|
|
|
|
return run_cmd(f"{docker_bitcoin_cli} getnewaddress {address_type}")
|
|
|
|
|
|
|
|
|
|
|
|
def pay_onchain(address: str, sats: int) -> str:
|
|
|
|
btc = sats * 0.00000001
|
|
|
|
return run_cmd(f"{docker_bitcoin_cli} sendtoaddress {address} {btc}")
|