Cari Baca Tubuh Dan Bagiannya
Tujuan: mencari metadata yang disinkronkan, lalu mengambil konten seluruh isi dan sebagian sesuai permintaan.
Aliran UI
- Pencarian pengguna berdasarkan subjek/pengirim.
- UI memanggil
/api/accounts/:account_id/emails/search. - Pengguna membuka pesan.
- UI memanggil
/bodyuntuk pesan yang diuraikan secara lengkap. - UI memanggil
/partslalu/parts/:part_id/contentuntuk pratinjau atau unduhan bagian yang dipilih.
Alur Perpustakaan Klien
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);
}
}
Alur 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}"
Kasus Konflik yang Diharapkan
409 email_part_content_hash_mismatch409 email_part_metadata_out_of_sync
Skrip Validasi
scripts/provider_parts_content_flow.sh