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

# Weryfikacja e-maila

> Sprawdź poprawność i dostarczalność pojedynczego adresu e-mail, w tym wykrywanie catch-all, dzięki API Email Verifier

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

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

Uruchom weryfikację pojedynczego e-maila, aby sprawdzić jego dostarczalność. Uwierzytelniaj każde żądanie za pomocą [klucza API](/pl/authentication) w nagłówku `x-api-key`. W przypadku operacji wsadowych użyj endpointu [Weryfikacja e-maili zbiorczo](/pl/api-reference/email-verifier/verify-bulk).

<Info>
  Enrow wykonuje **deterministyczne weryfikacje**, które weryfikują nawet adresy catch-all. Oznacza to, że nie ma potrzeby późniejszego przepuszczania wyników przez debouncer.
</Info>

## Request Body

<ParamField body="email" type="string" required>
  E-mail do zweryfikowania
</ParamField>

<ParamField body="custom" type="object">
  Niestandardowe parametry, które zostaną zwrócone w odpowiedzi GET oraz w powiadomieniu webhook.

  <Expandable title="custom object">
    <ParamField body="your_custom_key_name" type="string" default="your_custom_property">
      Twoje niestandardowe dane
    </ParamField>
  </Expandable>
</ParamField>

<ParamField body="settings" type="object">
  Ustawienia związane z tą weryfikacją.

  <Expandable title="settings properties">
    <ParamField body="webhook" type="string">
      Adres URL, który zostanie powiadomiony za pomocą żądania HTTP POST po zakończeniu pojedynczej weryfikacji. Zobacz [Jak działają webhooki](/pl/how-webhooks-work).
    </ParamField>
  </Expandable>
</ParamField>

## Response

### 200 — Weryfikacja zainicjowana

<ResponseField name="message" type="string">
  Komunikat potwierdzający
</ResponseField>

<ResponseField name="id" type="string">
  Unikalny identyfikator tej weryfikacji. Użyj go, aby pobrać wyniki za pomocą [endpointu GET](/pl/api-reference/email-verifier/get-single-verification).
</ResponseField>

<ResponseField name="credits_used" type="number">
  Liczba zużytych kredytów (0.25). Zobacz [Kredyty i rozliczenia](/pl/credits-billing), aby poznać koszty poszczególnych endpointów.
</ResponseField>

<ResponseField name="credits" type="object">
  Podział kredytów

  <Expandable title="credits properties">
    <ResponseField name="amount" type="number">
      Zużyte kredyty
    </ResponseField>

    <ResponseField name="source" type="string">
      Źródło kredytów: `sub`, `paygo` lub `mixed`
    </ResponseField>

    <ResponseField name="split" type="object">
      Podział pomiędzy kredyty z subskrypcji a kredyty pay-as-you-go (`fromSub`, `fromPaygo`)
    </ResponseField>
  </Expandable>
</ResponseField>

### Odpowiedzi błędów

| 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>
  W przypadku niewystarczającej liczby kredytów (**402**) treść odpowiedzi to `{ "reason": "...", "success": false }`. Zobacz [Obsługa błędów](/pl/error-handling), aby poznać pełną listę kodów statusu i formatów odpowiedzi.
</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 Pomyślna odpowiedź 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 Odpowiedź błędu theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Kolejne kroki

<CardGroup cols={2}>
  <Card title="Pobierz wynik" icon="inbox" href="/pl/api-reference/email-verifier/get-single-verification">
    Pobierz wynik weryfikacji za pomocą `id`.
  </Card>

  <Card title="Weryfikuj e-maile zbiorczo" icon="layer-group" href="/pl/api-reference/email-verifier/verify-bulk">
    Zweryfikuj wiele adresów e-mail w jednym żądaniu.
  </Card>

  <Card title="Uwierzytelnianie" icon="key" href="/pl/authentication">
    Jak przekazać klucz API w nagłówku x-api-key.
  </Card>

  <Card title="Webhooki" icon="bell" href="/pl/how-webhooks-work">
    Otrzymuj automatyczne powiadomienia o zakończeniu weryfikacji.
  </Card>
</CardGroup>
