SDKs
Node.js / TypeScript
Padrões idiomáticos de Node.js para a Thunderbit Open API
A API da Thunderbit funciona com o fetch nativo (Node 18+) — sem necessidade de SDK. Para HTTP/2 e pooling de conexões em escala, troque para undici ou axios.
Configurar
const API = "https://openapi.thunderbit.com/openapi/v1";
const H = {
"Authorization": `Bearer ${process.env.THUNDERBIT_API_KEY}`,
"Content-Type": "application/json",
};Distill de uma página
const r = await fetch(`${API}/distill`, {
method: "POST",
headers: H,
body: JSON.stringify({ url: "https://thunderbit.com/playground" }),
});
const { data } = await r.json();
console.log(data.markdown);Extract de dados estruturados
type Product = { name: string; price: number; currency?: string };
const r = await fetch(`${API}/extract`, {
method: "POST",
headers: H,
body: JSON.stringify({
url: "https://example.com/product/iphone-15-pro",
schema: {
type: "object",
properties: {
name: { type: "string" },
price: { type: "number" },
},
required: ["name", "price"],
},
}),
});
const { data } = await r.json() as { data: Product };Batch + Webhook (TypeScript)
const job = await fetch(`${API}/batch/distill`, {
method: "POST",
headers: H,
body: JSON.stringify({
urls: ["https://example.com/page1", "https://example.com/page2"],
webhook: {
url: "https://your-server.com/webhook",
secret: process.env.WEBHOOK_SECRET,
},
}),
}).then(r => r.json());Verifique a assinatura do Webhook no seu handler — veja Webhooks.
Um SDK Node.js oficial está em desenvolvimento — volte em breve.