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
- El usuario busca por asunto/remitente.
- La interfaz de usuario llama a
/api/accounts/:account_id/emails/search. - El usuario abre un mensaje.
- La interfaz de usuario llama a
/bodypara obtener el mensaje analizado completo. - La interfaz de usuario llama a
/partsy luego a/parts/:part_id/contentpara 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_mismatch409 email_part_metadata_out_of_sync
Script de validación
scripts/provider_parts_content_flow.sh