> ## Documentation Index
> Fetch the complete documentation index at: https://docs.enrow.io/llms.txt
> Use this file to discover all available pages before exploring further.

# Verificar emails

> Valida un lote de direcciones de email en una sola solicitud (hasta 5.000) y comprueba la entregabilidad con Email Verifier

<Badge color="green">POST</Badge>

```
https://api.enrow.io/email/verify/bulk
```

Ejecuta varias verificaciones de email en una sola solicitud. Hasta 5.000 verificaciones por lote. Autentica cada solicitud con tu [clave de API](/es/authentication) en el encabezado `x-api-key`. Para verificar una sola dirección en su lugar, usa el endpoint [Verify Single Email](/es/api-reference/email-verifier/verify-single).

<Info>
  Enrow realiza **verificaciones deterministas** que verifican incluso los emails catch-all. No se necesita ningún debouncer.
</Info>

## Cuerpo de la solicitud

<ParamField body="verifications" type="array of strings" required>
  Array de direcciones de email a verificar.
</ParamField>

<ParamField body="custom" type="object">
  Parámetros personalizados que se devolverán en la respuesta GET y en la notificación del webhook.

  <Expandable title="custom object">
    <ParamField body="your_custom_key_name" type="string" default="your_custom_property">
      Tus datos personalizados
    </ParamField>
  </Expandable>
</ParamField>

<ParamField body="settings" type="object">
  Ajustes relacionados con esta verificación en lote.

  <Expandable title="settings properties">
    <ParamField body="webhook" type="string">
      Una URL que será notificada mediante una solicitud HTTP POST una vez que finalice la verificación en lote. Consulta [Cómo funcionan los webhooks](/es/how-webhooks-work).
    </ParamField>
  </Expandable>
</ParamField>

## Respuesta

### 201 — Verificación en lote iniciada

<ResponseField name="message" type="string">
  Mensaje de confirmación
</ResponseField>

<ResponseField name="id" type="string">
  Identificador único de este lote. Úsalo para recuperar los resultados a través del [endpoint GET](/es/api-reference/email-verifier/get-bulk-verifications).
</ResponseField>

<ResponseField name="credits_used" type="number">
  Total de créditos consumidos. Consulta [Créditos y facturación](/es/credits-billing) para conocer los costes por endpoint.
</ResponseField>

<ResponseField name="estimated_duration" type="number">
  Tiempo de procesamiento estimado en minutos (no garantizado)
</ResponseField>

<ResponseField name="credits" type="object">
  Desglose de créditos

  <Expandable title="credits properties">
    <ResponseField name="amount" type="number">
      Créditos consumidos
    </ResponseField>

    <ResponseField name="source" type="string">
      Origen de los créditos: `sub` (suscripción), `paygo` (pago por uso) o `mixed`
    </ResponseField>

    <ResponseField name="split" type="object">
      Desglose entre créditos de suscripción y de pago por uso (`fromSub`, `fromPaygo`)
    </ResponseField>
  </Expandable>
</ResponseField>

### Respuestas de error

| Code    | Message                                                         |
| ------- | --------------------------------------------------------------- |
| **400** | `Missing payload`                                               |
| **400** | `At least 1 verification must be present in the payload`        |
| **400** | `Too many verifications. Limit is currently at 5000 per batch.` |
| **401** | `No apikey found in the x-api-key headers`                      |
| **401** | `This apikey is not valid`                                      |
| **402** | `Insufficient credits`                                          |

<Note>
  En caso de créditos insuficientes, el endpoint en lote devuelve **402** con el cuerpo `{ "message": "..." }`. Consulta [Gestión de errores](/es/error-handling) para ver la lista completa de códigos de estado y formatos de respuesta.
</Note>

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.enrow.io/email/verify/bulk \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "verifications": [
        "pam.beesly@dundermifflin.com",
        "angela.martin@dundermifflin.com",
        "stanley.hudson@dundermifflin.com"
      ],
      "settings": {
        "webhook": "https://your-app.com/webhooks/enrow/verify"
      }
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/email/verify/bulk', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      verifications: [
        'pam.beesly@dundermifflin.com',
        'angela.martin@dundermifflin.com',
        'stanley.hudson@dundermifflin.com'
      ],
      settings: {
        webhook: 'https://your-app.com/webhooks/enrow/verify'
      }
    })
  });

  const data = await response.json();
  console.log(`Batch ID: ${data.id}`);
  ```

  ```python Python theme={null}
  import requests
  import os

  url = "https://api.enrow.io/email/verify/bulk"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "verifications": [
          "pam.beesly@dundermifflin.com",
          "angela.martin@dundermifflin.com",
          "stanley.hudson@dundermifflin.com"
      ],
      "settings": {
          "webhook": "https://your-app.com/webhooks/enrow/verify"
      }
  }

  response = requests.post(url, json=payload, headers=headers)
  print(response.json())
  ```
</RequestExample>

<ResponseExample>
  ```json Respuesta de éxito theme={null}
  {
    "message": "Bulk verification operating",
    "id": "0cf517bc-16e8-45bc-b967-ab9116b3c804",
    "credits_used": 0.75,
    "estimated_duration": 1
  }
  ```

  ```json Respuesta de error theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Próximos pasos

<CardGroup cols={2}>
  <Card title="Obtener los resultados" icon="inbox" href="/es/api-reference/email-verifier/get-bulk-verifications">
    Recupera los resultados de verificación usando el `id` del lote.
  </Card>

  <Card title="Verificar un solo email" icon="circle-check" href="/es/api-reference/email-verifier/verify-single">
    Comprueba si una dirección de email es válida y entregable.
  </Card>

  <Card title="Créditos y facturación" icon="coins" href="/es/credits-billing">
    Consulta cómo se consumen los créditos en cada endpoint.
  </Card>

  <Card title="Webhooks" icon="bell" href="/es/how-webhooks-work">
    Recibe una notificación automática cuando un lote se complete.
  </Card>
</CardGroup>
