IM
ES
Inicio de documentación
Menú
Guías

Buscar Leer cuerpo y piezas

busque metadatos sincronizados y luego obtenga contenido completo y parcial a pedido.

inbox-manager client-flow

Buscar Leer cuerpo y piezas

Propósito: buscar metadatos sincronizados y luego recuperar el contenido completo y parcial a pedido.

Flujo de interfaz de usuario

  1. El usuario busca por asunto/remitente.
  2. La interfaz de usuario llama a /api/accounts/:account_id/emails/search.
  3. El usuario abre un mensaje.
  4. La interfaz de usuario llama a /body para obtener el mensaje analizado completo.
  5. La interfaz de usuario llama a /parts y luego a /parts/:part_id/content para obtener vistas previas o descargas de piezas seleccionadas.

Flujo de la biblioteca del cliente

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);
  }
}

Flujo 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}"

Casos de conflicto esperados

  • 409 email_part_content_hash_mismatch
  • 409 email_part_metadata_out_of_sync

Script de validación

  • scripts/provider_parts_content_flow.sh