跳转到主要内容
Olostep 的 API 是围绕对象设计的。理解这种设计有助于您构建更有效的集成。此设计灵感来自 Stripe 的 API 哲学

一切皆为对象

Olostep 中的每个资源都是一个具有唯一标识符的对象。无论您通过 API、SDK 还是仪表板创建它,您都会得到一个可以引用、更新和查询的对象。
资源对象 ID 格式示例
Scrapescrape_*scrape_abc123
Batchbatch_*batch_xyz789
Crawlcrawl_*crawl_def456
Mapmap_*map_ghi012
Answeranswer_*answer_jkl345
Filefile_*file_mno678
Scheduleschedule_*schedule_pqr901

对象可以有生命周期

一些 Olostep 对象通过 status 字段跟踪状态。这种状态机模式让您确切知道每个资源在其生命周期中的位置。

批次

批次有两个级别的状态:批次本身和单个项目 批次状态:
in_progress → completed
状态描述
in_progress正在抓取 URL
completed处理完成
批次级别的失败极为罕见。 批次几乎总是完成的——即使某些 URL 失败,批次本身也会达到 completed 状态。在极少数情况下,基础设施出现灾难性故障(例如,在丰富过程中 LLM 服务中断),批次可能会失败。这影响不到 0.01% 的批次。
项目状态: 批次中的每个 URL 都作为一个单独的项目进行跟踪,并具有自己的状态:
状态描述
successURL 抓取成功
failed无法抓取 URL
项目可能因以下原因失败:
  • URL 被阻止或返回错误
  • 解析器输出缺失
  • 网络/获取错误
失败的项目包含一个 error 对象,其中包含解释失败的 codemessage。批次仍然会完成——在处理结果时检查每个项目的状态。

爬网

in_progress → completed
状态描述
in_progress正在主动发现和处理 URL
completed爬网完成
爬网总是会完成。 即使爬网找到 0 个 URL(由于 robots.txt 阻止或起始 URL 无效),爬网状态也将为 completed。检查 pages_count 字段以验证结果。

检索模式

许多对象生成的内容可以稍后检索。retrieve_id 模式让您可以在不重新处理的情况下获取内容。
# 使用 retrieve_id 获取内容
curl "https://api.olostep.com/v1/retrieve?retrieve_id=6h89o8u1kt" \
  -H "Authorization: Bearer <your_token>"
此模式用于:
  • 批次项目 — 每个处理过的 URL 都会获得一个 retrieve_id
  • 爬网页面 — 每个爬网页面都会获得一个 retrieve_id
/v1/retrieve 端点接受 formats 参数以指定要返回的内容类型(htmlmarkdownjsontext)。

Webhooks:事件驱动的更新

与其轮询状态变化,不如配置 webhooks 以在对象状态改变时接收事件。
{
  "event": "batch.completed",
  "data": {
    "id": "batch_xyz789",
    "status": "completed",
    "items_total": 100,
    "items_completed": 100
  }
}

元数据:您的数据与我们的数据并存

使用 metadata 将自定义键值对附加到对象。这使您可以将 Olostep 资源链接到您的内部系统。
{
  "items": [{"url": "https://example.com"}],
  "metadata": {
    "order_id": "12345",
    "customer": "acme-corp"
  }
}

总结

概念描述
对象每个资源都有一个唯一 ID 并且可以查询
生命周期通过 status 字段跟踪进度
检索使用 retrieve_id 稍后获取内容
Webhooks在状态变化时收到通知
元数据将您自己的数据附加到任何对象