Skip to main content

▶ Sieh dir zuerst den 402-Flow an

Interaktives Terminal-Demo — erlebe Request → 402 → Lightning-Zahlung → 200 OK, live in deinem Browser.

Option A — Vollständigen Server mit einem Befehl erstellen (am schnellsten)

npx create-l402-app my-api
Dies erstellt ein vollständiges Express + l402-kit Projekt: server.ts, .env.example, tsconfig.json und einen /premium-Endpunkt, der bereit ist, Lightning-Zahlungen zu akzeptieren.
my-api/
  src/server.ts      ← deine API mit l402-Middleware
  .env.example       ← Blink/OpenNode-Zugangsdaten-Vorlage
  package.json       ← npm install l402-kit + tsx
  tsconfig.json
  README.md
Dann:
cd my-api
cp .env.example .env   # füge deinen Blink API-Schlüssel hinzu
npm install
npm run dev
# ⚡ l402-kit server running on http://localhost:3000
# curl http://localhost:3000/premium  →  402 Payment Required

Option B — Zu einem bestehenden Projekt hinzufügen

1. Modus wählen

ManagedSoberano
Einrichtungszeit~2 Min.~5 Min.
Monatliche Kosten$0$0
Gebühr pro Transaktion0,3%0%
Was du brauchstEine Lightning-AdresseEin Blink / Alby / BTCPay-Konto
Verarbeitung von 10.000 sats30 sat Gebühr$0 Gebühr
Am besten fürSchnellen EinstiegVolumen / Produktion
Nicht sicher? Starte mit Managed — kein Node, kein Konto, nur eine Lightning-Adresse. Wechsle jederzeit mit einer Zeile Code zu Soberano, wenn du 0% Gebühren möchtest. Bereits bezahlte Token funktionieren nach dem Wechsel weiterhin. Lightning-Adresse erhalten (kostenlos, 2 Min.): Registriere dich unter dashboard.blink.sv — du erhältst yourname@blink.sv. Oder nutze Alby, Phoenix oder Wallet of Satoshi. Soberano-Einrichtung: Registriere dich unter dashboard.blink.svAPI Keys → Schlüssel erstellen → kopiere deine BTC Wallet ID von der Wallet-Seite. Setze BLINK_API_KEY und BLINK_WALLET_ID in deiner .env.

2. Installieren

npm install l402-kit

3. Zur API hinzufügen

Kein Lightning-Node erforderlich — nur deine Lightning-Adresse.
import express from "express";
import { l402, ManagedProvider } from "l402-kit";

const app = express();
const lightning = ManagedProvider.fromAddress("you@yourdomain.com");

app.get("/premium", l402({ priceSats: 100, lightning }), (_req, res) => {
  res.json({ data: "You paid 100 sats. Here is your data." });
});

app.listen(3000);
// 0.3% fee · no node setup · works immediately

4. Testen

curl http://localhost:3000/premium
Antwort:
{
  "error": "Payment Required",
  "price_sats": 100,
  "invoice": "lnbc1u1p...",
  "macaroon": "eyJoYXNo..."
}
Bezahle die Rechnung mit einer beliebigen Lightning-Wallet, dann:
curl http://localhost:3000/premium \
  -H "Authorization: L402 <macaroon>:<preimage>"
Antwort:
{ "data": "You paid 100 sats. Here is your data." }
Deine API akzeptiert jetzt Bitcoin-Zahlungen.

Testen ohne echte sats

Du benötigst keine Lightning-Wallet, um deine Integration zu testen. Verwende einen Mock-Provider — er generiert lokal gültige kryptografische Token-Paare, ohne Netzwerkaufrufe:
import { createHash, randomBytes } from "crypto";
import { l402 } from "l402-kit";
import type { LightningProvider, Invoice } from "l402-kit";

// Drop-in mock — generates real SHA256 hash/preimage pairs
function makeMockProvider(): LightningProvider & { preimage: string } {
  const preimage = randomBytes(32).toString("hex");
  const paymentHash = createHash("sha256").update(Buffer.from(preimage, "hex")).digest("hex");
  return {
    preimage, // use this in your test Authorization header
    async createInvoice(amountSats: number): Promise<Invoice> {
      const macaroon = Buffer.from(
        JSON.stringify({ hash: paymentHash, exp: Date.now() + 3_600_000 })
      ).toString("base64");
      return { paymentRequest: "lnbc_mock", paymentHash, macaroon, amountSats };
    },
    async checkPayment(): Promise<boolean> { return true; },
  };
}

// Usage in tests:
const mock = makeMockProvider();
app.get("/premium", l402({ priceSats: 10, lightning: mock }), handler);

// Step 1 — unauthenticated → 402
const res402 = await request(app).get("/premium");
// res402.body.macaroon  ← use this

// Step 2 — pay with mock preimage → 200
const res200 = await request(app)
  .get("/premium")
  .set("Authorization", `L402 ${res402.body.macaroon}:${mock.preimage}`);
// res200.status === 200 ✓
Für Tests mit echtem Geld in der Sandbox verwende OpenNodes testMode:
const lightning = new OpenNodeProvider(process.env.OPENNODE_KEY!, true); // testMode: no real sats
Vollständige Testanleitung → Testing