搜索阅读车身和零件
目的:搜索同步元数据,然后按需获取全文和部分内容。
用户界面流程
- 用户按主题/发件人搜索。
- UI 调用
/api/accounts/:account_id/emails/search。 - 用户打开消息。
- UI 调用
/body来获取完整解析的消息。 - 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