> ## 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ź telefony zbiorczo

> Znajdź wiele numerów telefonów w jednej partii (do 3000 wyszukiwań) na podstawie adresów URL LinkedIn lub imienia i nazwy firmy, z powiadomieniami webhook

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

```
https://api.enrow.io/phone/bulk
```

Uruchom wiele wyszukiwań telefonów w jednym żądaniu. Do 3000 wyszukiwań na partię. Uwierzytelniaj każde żądanie za pomocą [klucza API](/pl/authentication) w nagłówku `x-api-key`. Aby znaleźć pojedynczy numer telefonu, użyj punktu końcowego [Znajdź telefon](/pl/api-reference/phone/find-single).

Każde wyszukiwanie musi zawierać jedno z poniższych:

* Adres URL **profilu LinkedIn** osoby (np. `https://www.linkedin.com/in/michael-scott/`)
* Kombinację informacji indywidualnych: `firstname` + `lastname` + (`company_name` lub `company_domain`)

**Adres URL LinkedIn ma zawsze pierwszeństwo** przed informacjami indywidualnymi, jeśli oba są obecne.

## Treść żądania

<ParamField body="searches" type="array of objects" required>
  Dane wyszukiwań, dla których należy znaleźć odpowiadające numery telefonów.

  <Expandable title="właściwości obiektu search">
    **Opcja 1 (zalecana):**

    <ParamField body="linkedin_url" type="string">
      Adres URL profilu LinkedIn
    </ParamField>

    **Opcja 2:**

    <ParamField body="firstname" type="string">
      Imię
    </ParamField>

    <ParamField body="lastname" type="string">
      Nazwisko
    </ParamField>

    <ParamField body="company_domain" type="string">
      Domena firmy
    </ParamField>

    <ParamField body="company_name" type="string">
      Nazwa firmy (alternatywa dla `company_domain`)
    </ParamField>

    **Dodatkowe:**

    <ParamField body="custom" type="string">
      Wartość niestandardowa służąca do odwołania się do wewnętrznego identyfikatora. Będzie obecna w wynikach.
    </ParamField>
  </Expandable>
</ParamField>

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

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

  <Expandable title="właściwości settings">
    <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>
  </Expandable>
</ParamField>

## Odpowiedź

### 201 — Utworzono wyszukiwanie zbiorcze

<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/phone/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 dla poszczególnych punktów końcowych.
</ResponseField>

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

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

  <Expandable title="właściwości credits">
    <ResponseField name="amount" type="number">
      Zużyte kredyty
    </ResponseField>

    <ResponseField name="source" type="string">
      Źródło kredytów: `sub` (subskrypcja) lub `paygo` (pay-as-you-go)
    </ResponseField>

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

### Odpowiedzi błędów

| Kod     | Komunikat                                                     |
| ------- | ------------------------------------------------------------- |
| **400** | `At least 1 phone search must be present in the payload`      |
| **400** | `Missing payload`                                             |
| **400** | `Too many searches. Limit is currently at 3000 per batch.`    |
| **401** | `This apikey is not valid`                                    |
| **401** | `This account is not allowed to use the phone search feature` |
| **402** | `Insufficient credits`                                        |

<Note>
  Gdy kredyty są niewystarczające, 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/phone/bulk \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "searches": [
        {
          "linkedin_url": "https://www.linkedin.com/in/michael-scott"
        },
        {
          "linkedin_url": "https://www.linkedin.com/in/dwight-schrute"
        }
      ],
      "settings": {
        "webhook": "https://your-app.com/webhooks/enrow/phone"
      }
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/phone/bulk', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      searches: [
        { linkedin_url: 'https://www.linkedin.com/in/michael-scott' },
        { linkedin_url: 'https://www.linkedin.com/in/dwight-schrute' }
      ],
      settings: {
        webhook: 'https://your-app.com/webhooks/enrow/phone'
      }
    })
  });

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

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

  url = "https://api.enrow.io/phone/bulk"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "searches": [
          {"linkedin_url": "https://www.linkedin.com/in/michael-scott"},
          {"linkedin_url": "https://www.linkedin.com/in/dwight-schrute"}
      ],
      "settings": {
          "webhook": "https://your-app.com/webhooks/enrow/phone"
      }
  }

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

<ResponseExample>
  ```json Odpowiedź pomyślna theme={null}
  {
    "credits_used": 80,
    "estimated_duration": 1,
    "id": "e3b61122-d6a6-4ea7-b331-9b734682a76a",
    "message": "Bulk search operating",
    "credits": {
      "amount": 80,
      "source": "sub",
      "split": {
        "fromPaygo": 0,
        "fromSub": 80
      }
    }
  }
  ```

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

## Następne kroki

<CardGroup cols={2}>
  <Card title="Pobierz wyniki zbiorcze" icon="inbox" href="/pl/api-reference/phone/get-bulk-results">
    Pobierz znalezione numery telefonów za pomocą identyfikatora partii `id`.
  </Card>

  <Card title="Znajdź pojedynczy telefon" icon="phone" href="/pl/api-reference/phone/find-single">
    Uruchom pojedyncze wyszukiwanie telefonu na podstawie adresu URL LinkedIn lub imienia i nazwy firmy.
  </Card>

  <Card title="Webhooki" icon="bell" href="/pl/how-webhooks-work">
    Otrzymuj automatyczne powiadomienia po zakończeniu wyszukiwania zbiorczego.
  </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>
