IM
ZH-CN
文档首页
菜单
指南

搜索阅读车身和零件

搜索同步元数据,然后按需获取全文和部分内容。

inbox-manager client-flow

搜索阅读车身和零件

目的:搜索同步元数据,然后按需获取全文和部分内容。

用户界面流程

  1. 用户按主题/发件人搜索。
  2. UI 调用/api/accounts/:account_id/emails/search
  3. 用户打开消息。
  4. UI 调用 /body 来获取完整解析的消息。
  5. UI 调用/parts,然后调用/parts/:part_id/content 来预览或下载选定的部分。

客户端库流程

const results = await api.emails.search(accountId, {
  query: "invoice",
  limit: 20,
});
const emailId = results.data[0]?.id;
if (emailId) {
  const body = await api.emails.getBody(accountId, emailId);
  const parts = await api.emails.listParts(accountId, emailId);
  const firstPart = parts.data[0];
  if (firstPart) {
    await api.emails.getPartContent(accountId, emailId, firstPart.id);
  }
}

HTTP/curl 流程

API_BASE_URL="https://api.inbox-manager.com"

curl -sS -X POST "${API_BASE_URL}/api/accounts/${ACCOUNT_ID}/emails/search" \
  -H "authorization: Bearer ${BEARER_TOKEN}" \
  -H "content-type: application/json" \
  --data '{"query":"invoice","limit":20,"offset":0}'

curl -sS "${API_BASE_URL}/api/accounts/${ACCOUNT_ID}/emails/${EMAIL_ID}/body" \
  -H "authorization: Bearer ${BEARER_TOKEN}"

curl -sS "${API_BASE_URL}/api/accounts/${ACCOUNT_ID}/emails/${EMAIL_ID}/parts" \
  -H "authorization: Bearer ${BEARER_TOKEN}"

curl -sS "${API_BASE_URL}/api/accounts/${ACCOUNT_ID}/emails/${EMAIL_ID}/parts/${PART_ID}/content" \
  -H "authorization: Bearer ${BEARER_TOKEN}"

预期的冲突案例

-409 email_part_content_hash_mismatch

  • 409 email_part_metadata_out_of_sync

验证脚本

-scripts/provider_parts_content_flow.sh