> ## 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.

# Vérifier un e-mail

> Validez et vérifiez la délivrabilité d'une adresse e-mail unique, y compris la détection des catch-all, avec l'API Email Verifier

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

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

Lancez une vérification d'e-mail unique pour contrôler sa délivrabilité. Authentifiez chaque requête avec votre [clé API](/fr/authentication) dans l'en-tête `x-api-key`. Pour les opérations par lot, utilisez l'endpoint [Vérifier des e-mails en masse](/fr/api-reference/email-verifier/verify-bulk).

<Info>
  Enrow effectue des **vérifications déterministes** qui valident même les e-mails catch-all. Cela signifie qu'il n'est pas nécessaire de faire repasser ensuite les résultats par un debouncer.
</Info>

## Corps de la requête

<ParamField body="email" type="string" required>
  L'e-mail à vérifier
</ParamField>

<ParamField body="custom" type="object">
  Paramètres personnalisés qui seront renvoyés dans la réponse GET et dans la notification webhook.

  <Expandable title="objet custom">
    <ParamField body="your_custom_key_name" type="string" default="your_custom_property">
      Vos données personnalisées
    </ParamField>
  </Expandable>
</ParamField>

<ParamField body="settings" type="object">
  Paramètres liés à cette vérification.

  <Expandable title="propriétés settings">
    <ParamField body="webhook" type="string">
      Une URL qui sera notifiée via une requête HTTP POST une fois la vérification unique terminée. Voir [Comment fonctionnent les webhooks](/fr/how-webhooks-work).
    </ParamField>
  </Expandable>
</ParamField>

## Réponse

### 200 — Vérification initiée

<ResponseField name="message" type="string">
  Message de confirmation
</ResponseField>

<ResponseField name="id" type="string">
  Identifiant unique de cette vérification. Utilisez-le pour récupérer les résultats via l'[endpoint GET](/fr/api-reference/email-verifier/get-single-verification).
</ResponseField>

<ResponseField name="credits_used" type="number">
  Nombre de crédits consommés (0.25). Voir [Crédits et facturation](/fr/credits-billing) pour connaître les coûts par endpoint.
</ResponseField>

<ResponseField name="credits" type="object">
  Détail des crédits

  <Expandable title="propriétés credits">
    <ResponseField name="amount" type="number">
      Crédits consommés
    </ResponseField>

    <ResponseField name="source" type="string">
      Source des crédits : `sub`, `paygo` ou `mixed`
    </ResponseField>

    <ResponseField name="split" type="object">
      Répartition entre les crédits d'abonnement et les crédits à l'usage (`fromSub`, `fromPaygo`)
    </ResponseField>
  </Expandable>
</ResponseField>

### Réponses d'erreur

| Code    | Message                                    |
| ------- | ------------------------------------------ |
| **400** | `invalid email format`                     |
| **400** | `invalid JSON input`                       |
| **401** | `No apikey found in the x-api-key headers` |
| **401** | `This apikey is not valid`                 |
| **402** | `Insufficient credits`                     |

<Note>
  En cas de crédits insuffisants (**402**), le corps de la réponse est `{ "reason": "...", "success": false }`. Voir [Gestion des erreurs](/fr/error-handling) pour la liste complète des codes de statut et des formats de réponse.
</Note>

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.enrow.io/email/verify/single \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "email": "pam.beesly@dundermifflin.com"
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/email/verify/single', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      email: 'pam.beesly@dundermifflin.com'
    })
  });

  const data = await response.json();
  console.log(data.id);
  ```

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

  url = "https://api.enrow.io/email/verify/single"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "email": "pam.beesly@dundermifflin.com"
  }

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

<ResponseExample>
  ```json Réponse de succès theme={null}
  {
    "message": "Single verification operating",
    "id": "0cf517bc-16e8-45bc-b967-ab9116b3c804",
    "credits_used": 0.25,
    "credits": {
      "amount": 0.25,
      "source": "sub",
      "split": { "fromPaygo": 0, "fromSub": 0.25 }
    }
  }
  ```

  ```json Réponse d'erreur theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Étapes suivantes

<CardGroup cols={2}>
  <Card title="Obtenir le résultat" icon="inbox" href="/fr/api-reference/email-verifier/get-single-verification">
    Récupérez le résultat de la vérification à l'aide de l'`id`.
  </Card>

  <Card title="Vérifier des e-mails en masse" icon="layer-group" href="/fr/api-reference/email-verifier/verify-bulk">
    Vérifiez plusieurs adresses e-mail en une seule requête.
  </Card>

  <Card title="Authentification" icon="key" href="/fr/authentication">
    Comment transmettre votre clé API dans l'en-tête x-api-key.
  </Card>

  <Card title="Webhooks" icon="bell" href="/fr/how-webhooks-work">
    Soyez notifié automatiquement lorsqu'une vérification se termine.
  </Card>
</CardGroup>
