搜尋閱讀車身和零件
目的:搜尋同步元數據,然後按需取得全文和部分內容。
使用者介面流程
- 使用者按主題/寄件者搜尋。
- 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