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

# Znajdź adres e-mail

> Znajdź pojedynczy służbowy adres e-mail na podstawie imienia i nazwiska oraz domeny lub nazwy firmy

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

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

Uruchom pojedyncze wyszukiwanie e-maila, aby znaleźć służbowy adres e-mail. Uwierzytelniaj każde żądanie za pomocą swojego [klucza API](/pl/authentication) w nagłówku `x-api-key`. Do operacji wsadowych użyj endpointu [Find Bulk Emails](/pl/api-reference/email-finder/find-bulk) (do 5000 wyszukiwań na partię).

<Info>
  Enrow przeprowadza **deterministyczne weryfikacje**, które weryfikują nawet adresy catch-all. Oznacza to, że nie trzeba później przepuszczać znalezionych adresów przez debouncer.
</Info>

## Request Body

<ParamField body="fullname" type="string" required>
  Imię i nazwisko osoby, dla której ma zostać znaleziony e-mail
</ParamField>

<ParamField body="company_domain" type="string">
  Domena firmy, akceptowanych jest wiele formatów (`"dundermifflin.com"`, `"https://www.dundermifflin.com"`...)

  **Uwaga**: Wymagany jest co najmniej jeden z parametrów: `company_domain` lub `company_name`.
</ParamField>

<ParamField body="company_name" type="string">
  Nazwa firmy (`"Apple"`, `"Air France"`, ...)

  **Uwaga**: Wymagany jest co najmniej jeden z parametrów: `company_domain` lub `company_name`.
</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">
  Zestaw ustawień związanych z tym wyszukiwaniem

  <Expandable title="settings properties">
    <ParamField body="webhook" type="string">
      Adres URL, który zostanie powiadomiony za pomocą żądania HTTP POST po zakończeniu pojedynczego wyszukiwania. Zobacz [How Webhooks Work](/pl/how-webhooks-work).
    </ParamField>

    <ParamField body="country_code" type="string" default="US">
      Kod kraju ISO 3166 Alpha-2 powiązany z wyszukiwaniem. Istotny przy korzystaniu z nazwy firmy — pomaga rozróżnić homonimy poprzez wyszukiwanie w zlokalizowanej wersji Google.
    </ParamField>

    <ParamField body="retrieve_gender" type="boolean" default="false">
      Pozwala uzyskać płeć (`male`/`female`) osoby.
    </ParamField>

    <ParamField body="retrieve_company_info" type="boolean" default="false">
      Zwraca dodatkowe informacje o firmie w wyniku. Obecnie działa tylko wtedy, gdy `country_code` ma wartość `FR`.
    </ParamField>
  </Expandable>
</ParamField>

## Response

### 200 — Wyszukiwanie zainicjowane

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

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

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

### Error Responses

| Code    | Message                                                                                     |
| ------- | ------------------------------------------------------------------------------------------- |
| **400** | `invalid JSON input`                                                                        |
| **400** | `both company_domain and company_name are absent, input payload needs at least one of them` |
| **400** | `missing fullname`                                                                          |
| **401** | `No apikey found in the x-api-key headers`                                                  |
| **401** | `This apikey is not valid`                                                                  |
| **402** | `Insufficient credits`                                                                      |

<Note>
  Odpowiedzi o niewystarczającej liczbie kredytów (`402`) na endpointach pojedynczych zwracają `{ "reason": "...", "success": false }`; wszystkie pozostałe błędy zwracają `{ "message": "..." }`.
</Note>

Zobacz [Error handling](/pl/error-handling), aby poznać pełną listę kodów statusu i formatów odpowiedzi.

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.enrow.io/email/find/single \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "fullname": "Dwight Schrute",
      "company_domain": "dundermifflin.com",
      "settings": {
        "retrieve_gender": true
      }
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/email/find/single', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      fullname: 'Dwight Schrute',
      company_domain: 'dundermifflin.com',
      settings: {
        retrieve_gender: true
      }
    })
  });

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

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

  url = "https://api.enrow.io/email/find/single"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "fullname": "Dwight Schrute",
      "company_domain": "dundermifflin.com",
      "settings": {
          "retrieve_gender": True
      }
  }

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

<ResponseExample>
  ```json Success Response theme={null}
  {
    "message": "Single search operating",
    "id": "0cf517bc-16e8-45bc-b967-ab9116b3c804",
    "credits_used": 1
  }
  ```

  ```json Error Response theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Następne kroki

<CardGroup cols={2}>
  <Card title="Pobierz wynik" icon="inbox" href="/pl/api-reference/email-finder/get-single-result">
    Pobierz znaleziony e-mail przy użyciu `id` wyszukiwania.
  </Card>

  <Card title="Znajdź adresy e-mail zbiorczo" icon="layer-group" href="/pl/api-reference/email-finder/find-bulk">
    Uruchom do 5000 wyszukiwań e-maili 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 po zakończeniu wyszukiwania.
  </Card>
</CardGroup>
