IM
ID
Beranda dokumentasi
Menu
Panduan

Cari Baca Tubuh Dan Bagiannya

cari metadata yang disinkronkan, lalu ambil konten lengkap dan sebagian sesuai permintaan.

inbox-manager client-flow

Cari Baca Tubuh Dan Bagiannya

Tujuan: mencari metadata yang disinkronkan, lalu mengambil konten seluruh isi dan sebagian sesuai permintaan.

Aliran UI

  1. Pencarian pengguna berdasarkan subjek/pengirim.
  2. UI memanggil /api/accounts/:account_id/emails/search.
  3. Pengguna membuka pesan.
  4. UI memanggil /body untuk pesan yang diuraikan secara lengkap.
  5. UI memanggil /parts lalu /parts/:part_id/content untuk 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_mismatch
  • 409 email_part_metadata_out_of_sync

Skrip Validasi

  • scripts/provider_parts_content_flow.sh