Skip to main content

▶ Veja o fluxo 402 primeiro

Demo interativo no terminal — veja requisição → 402 → Lightning pay → 200 OK, ao vivo no seu navegador.

Opção A — Crie um servidor completo com um comando (mais rápido)

npx create-l402-app my-api
Isso cria um projeto completo Express + l402-kit: server.ts, .env.example, tsconfig.json, e um endpoint /premium pronto para aceitar pagamentos Lightning.
my-api/
  src/server.ts      ← sua API com middleware l402
  .env.example       ← template de credenciais Blink/OpenNode
  package.json       ← npm install l402-kit + tsx
  tsconfig.json
  README.md
Em seguida:
cd my-api
cp .env.example .env   # adicione sua chave de API Blink
npm install
npm run dev
# ⚡ l402-kit server running on http://localhost:3000
# curl http://localhost:3000/premium  →  402 Payment Required

Opção B — Adicionar a um projeto existente

1. Escolha seu modo

ManagedSoberano
Tempo de configuração~2 min~5 min
Custo mensal$0$0
Taxa por transação0,3%0%
O que você precisaUm endereço LightningUma conta Blink / Alby / BTCPay
Processando 10.000 satsTaxa de 30 satTaxa de $0
Ideal paraComeçar rapidamenteVolume / produção
Não tem certeza? Comece com Managed — sem nó, sem conta, apenas um endereço Lightning. Mude para Soberano em uma linha de código quando quiser taxas de 0%. Tokens já pagos continuam funcionando após a mudança. Obtenha um endereço Lightning (grátis, 2 min): Cadastre-se em dashboard.blink.sv — você receberá seunome@blink.sv. Ou use Alby, Phoenix, ou Wallet of Satoshi. Configuração Soberano: Cadastre-se em dashboard.blink.svAPI Keys → crie uma chave → copie seu BTC Wallet ID da página da carteira. Defina BLINK_API_KEY e BLINK_WALLET_ID no seu .env.

2. Instalar

npm install l402-kit

3. Adicionar à sua API

Nenhum nó Lightning necessário — apenas seu endereço Lightning.
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. Testar

curl http://localhost:3000/premium
Resposta:
{
  "error": "Payment Required",
  "price_sats": 100,
  "invoice": "lnbc1u1p...",
  "macaroon": "eyJoYXNo..."
}
Pague a fatura com qualquer carteira Lightning e então:
curl http://localhost:3000/premium \
  -H "Authorization: L402 <macaroon>:<preimage>"
Resposta:
{ "data": "You paid 100 sats. Here is your data." }
Sua API agora aceita pagamentos em Bitcoin.

Testar sem sats reais

Você não precisa de uma carteira Lightning para testar sua integração. Use um provedor mock — ele gera pares de tokens criptográficos válidos localmente, sem chamadas de rede:
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 ✓
Para testes com dinheiro real no sandbox, use o modo de teste da OpenNode:
const lightning = new OpenNodeProvider(process.env.OPENNODE_KEY!, true); // testMode: no real sats
Guia completo de testes → Testes