SDKs
.NET / C#
Padrões idiomáticos de .NET para a Thunderbit Open API
Use o HttpClient built-in + System.Text.Json. async/await em todo lugar. Compatível com .NET 6+.
Configurar
using System.Net.Http.Json;
using System.Text.Json;
const string Api = "https://openapi.thunderbit.com/openapi/v1";
var client = new HttpClient
{
BaseAddress = new Uri(Api + "/"),
Timeout = TimeSpan.FromSeconds(60),
};
client.DefaultRequestHeaders.Authorization =
new("Bearer", Environment.GetEnvironmentVariable("THUNDERBIT_API_KEY"));Distill de uma página
var res = await client.PostAsJsonAsync("distill", new {
url = "https://thunderbit.com/playground"
});
res.EnsureSuccessStatusCode();
var json = await res.Content.ReadFromJsonAsync<JsonElement>();
Console.WriteLine(json.GetProperty("data").GetProperty("markdown").GetString());Extract de dados estruturados
record Product(string Name, decimal Price, string? Currency);
var res = await client.PostAsJsonAsync("extract", new {
url = "https://example.com/product/iphone-15-pro",
schema = new {
type = "object",
properties = new {
name = new { type = "string" },
price = new { type = "number" },
},
required = new[] { "name", "price" },
}
});
var body = await res.Content.ReadFromJsonAsync<JsonElement>();
var product = body.GetProperty("data").Deserialize<Product>(
new JsonSerializerOptions { PropertyNamingPolicy = JsonNamingPolicy.CamelCase });Batch + Webhook
var job = await client.PostAsJsonAsync("batch/distill", new {
urls = new[] { "https://example.com/page1", "https://example.com/page2" },
webhook = new {
url = "https://your-server.com/webhook",
secret = Environment.GetEnvironmentVariable("WEBHOOK_SECRET"),
}
});
var body = await job.Content.ReadFromJsonAsync<JsonElement>();
var jobId = body.GetProperty("data").GetProperty("id").GetString();Verifique a assinatura do Webhook no seu handler — veja Webhooks.
Um SDK .NET oficial está em desenvolvimento — volte em breve.