import hashlib from ecc.curve import secp256k1, Point from flask import Flask, request import os import asyncio from mint.ledger import Ledger from mint.migrations import m001_initial from lightning import WALLET # Ledger pubkey ledger = Ledger("supersecretprivatekey", "../data/mint") class MyFlaskApp(Flask): """ We overload the Flask class so we can run a startup script (migration). Stupid Flask. """ def __init__(self, *args, **kwargs): async def create_tasks_func(): await asyncio.wait([m001_initial(ledger.db)]) await ledger.load_used_proofs() error_message, balance = await WALLET.status() if error_message: print( f"The backend for {WALLET.__class__.__name__} isn't working properly: '{error_message}'", RuntimeWarning, ) print(f"Lightning balance: {balance} sat") print("Mint started.") loop = asyncio.get_event_loop() loop.run_until_complete(create_tasks_func()) loop.close() return super().__init__(*args, **kwargs) def run(self, *args, **options): super(MyFlaskApp, self).run(*args, **options) app = MyFlaskApp(__name__) @app.route("/keys") def keys(): return ledger.get_pubkeys() @app.route("/mint", methods=["POST"]) async def mint(): payload = request.json amounts = [] B_s = [] for k, v in payload.items(): amounts.append(v["amount"]) x = int(v["x"]) y = int(v["y"]) B_ = Point(x, y, secp256k1) B_s.append(B_) try: promises = await ledger.mint(B_s, amounts) return promises except Exception as exc: return {"error": str(exc)} @app.route("/split", methods=["POST"]) async def split(): proofs = request.json["proofs"] amount = request.json["amount"] output_data = request.json["output_data"] try: fst_promises, snd_promises = await ledger.split(proofs, amount, output_data) return {"fst": fst_promises, "snd": snd_promises} except Exception as exc: return {"error": str(exc)}