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

# Wyszukiwanie zbiorcze

> Znajdź firmowe adresy e-mail zbiorczo na podstawie imion, nazwisk i firm — do 5000 wyszukiwań na partię dzięki Enrow Email Finder

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

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

Uruchom wiele wyszukiwań e-maili w jednym żądaniu. Do 5000 wyszukiwań na partię. Uwierzytelniaj każde żądanie za pomocą [klucza API](/pl/authentication) w nagłówku `x-api-key`. Aby znaleźć pojedynczy e-mail, użyj punktu końcowego [Find Single Email](/pl/api-reference/email-finder/find-single).

<Info>
  Enrow przeprowadza **deterministyczne weryfikacje**, które weryfikują nawet adresy typu catch-all. Nie jest potrzebny żaden debouncer.
</Info>

## Request Body

<ParamField body="searches" type="array of objects" required>
  Dane wyszukiwań, dla których mają zostać znalezione odpowiadające e-maile.

  <Expandable title="właściwości obiektu search">
    <ParamField body="fullname" type="string" required>
      Imię i nazwisko użytkownika
    </ParamField>

    <ParamField body="company_domain" type="string">
      Domena firmy lub adres URL strony internetowej. Wymagane jest podanie `company_domain` lub `company_name`.
    </ParamField>

    <ParamField body="company_name" type="string">
      Nazwa firmy użytkownika. Wymagane jest podanie `company_domain` lub `company_name`.
    </ParamField>

    <ParamField body="custom" type="string | object">
      Niestandardowa wartość, której możesz użyć do powiązania z wewnętrznym identyfikatorem (na przykład). Będzie obecna w wynikach.
    </ParamField>
  </Expandable>
</ParamField>

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

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

<ParamField body="settings" type="object">
  Ustawienia dotyczące całego wyszukiwania zbiorczego.

  <Expandable title="właściwości settings">
    <ParamField body="country_code" type="string" default="US">
      2-znakowy kod reprezentujący kraj wyszukiwań (kod ISO 3166 Alpha-2). Istotny przy użyciu `company_name`.
    </ParamField>

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

    <ParamField body="retrieve_gender" type="boolean" default="false">
      Pobierz powiązaną płeć, gdy e-mail zostanie znaleziony.
    </ParamField>

    <ParamField body="retrieve_company_info" type="boolean" default="false">
      Pobierz powiązane informacje o firmie. Działa tylko wtedy, gdy `country_code` ma wartość `FR`.
    </ParamField>
  </Expandable>
</ParamField>

## Response

### 201 — Wyszukiwanie zbiorcze rozpoczęte

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

<ResponseField name="id" type="string">
  Unikalny identyfikator tej partii. Użyj go, aby pobrać wyniki przez [punkt końcowy GET](/pl/api-reference/email-finder/get-bulk-results).
</ResponseField>

<ResponseField name="credits_used" type="number">
  Łączna liczba zużytych kredytów. Zobacz [Kredyty i rozliczenia](/pl/credits-billing), aby poznać koszty poszczególnych punktów końcowych.
</ResponseField>

<ResponseField name="estimated_duration" type="number">
  Szacowany czas przetwarzania w minutach (niegwarantowany)
</ResponseField>

### Error Responses

| Code    | Message                                                    |
| ------- | ---------------------------------------------------------- |
| **400** | `Missing payload`                                          |
| **400** | `Missing searches payload`                                 |
| **400** | `Too many searches. Limit is currently at 5000 per batch.` |
| **400** | `Error while parsing payload`                              |
| **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 punkt końcowy zbiorczy zwraca HTTP **402** z treścią w postaci `{ "message": "..." }`. 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/find/bulk \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "searches": [
        {
          "fullname": "Dwight Schrute",
          "company_domain": "dundermifflin.com",
          "custom": "lead_001"
        },
        {
          "fullname": "Jim Halpert",
          "company_domain": "dundermifflin.com",
          "custom": "lead_002"
        },
        {
          "fullname": "Ryan Howard",
          "company_domain": "dundermifflin.com",
          "custom": "lead_003"
        }
      ],
      "settings": {
        "webhook": "https://your-app.com/webhooks/enrow",
        "retrieve_gender": true
      }
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/email/find/bulk', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      searches: [
        { fullname: 'Dwight Schrute', company_domain: 'dundermifflin.com', custom: 'lead_001' },
        { fullname: 'Jim Halpert', company_domain: 'dundermifflin.com', custom: 'lead_002' },
        { fullname: 'Ryan Howard', company_domain: 'dundermifflin.com', custom: 'lead_003' }
      ],
      settings: {
        webhook: 'https://your-app.com/webhooks/enrow',
        retrieve_gender: true
      }
    })
  });

  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/find/bulk"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "searches": [
          {"fullname": "Dwight Schrute", "company_domain": "dundermifflin.com", "custom": "lead_001"},
          {"fullname": "Jim Halpert", "company_domain": "dundermifflin.com", "custom": "lead_002"},
          {"fullname": "Ryan Howard", "company_domain": "dundermifflin.com", "custom": "lead_003"}
      ],
      "settings": {
          "webhook": "https://your-app.com/webhooks/enrow",
          "retrieve_gender": True
      }
  }

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

<ResponseExample>
  ```json Pomyślna odpowiedź theme={null}
  {
    "message": "Bulk search operating",
    "id": "0cf517bc-16e8-45bc-b967-ab9116b3c804",
    "credits_used": 3,
    "estimated_duration": 1
  }
  ```

  ```json Odpowiedź z błędem theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Następne kroki

<CardGroup cols={2}>
  <Card title="Pobierz wyniki zbiorcze" icon="layer-group" href="/pl/api-reference/email-finder/get-bulk-results">
    Pobierz znalezione e-maile, używając `id` partii.
  </Card>

  <Card title="Znajdź pojedynczy e-mail" icon="envelope" href="/pl/api-reference/email-finder/find-single">
    Uruchom pojedyncze wyszukiwanie e-maila na podstawie imienia, nazwiska i firmy.
  </Card>

  <Card title="Webhooki" icon="bell" href="/pl/how-webhooks-work">
    Otrzymuj automatyczne powiadomienia, gdy partia zostanie ukończona.
  </Card>

  <Card title="Kredyty i rozliczenia" icon="coins" href="/pl/credits-billing">
    Zobacz, jak zużywane są kredyty dla każdego punktu końcowego.
  </Card>
</CardGroup>
