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

# Buscar teléfono

> Encuentra un único número de teléfono a partir de una URL de LinkedIn o de un nombre y empresa con la API de Phone Finder

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

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

Ejecuta una búsqueda asíncrona para encontrar un número de teléfono y el país asociado. Autentica cada solicitud con tu [clave de API](/es/authentication) en la cabecera `x-api-key`.

La búsqueda debe contener una de las siguientes opciones:

* La URL del **perfil de LinkedIn** de una persona (p. ej., `https://www.linkedin.com/in/michael-scott/`)
* La combinación de información individual: `firstname` + `lastname` + (`company_name` o `company_domain`)

La **URL de LinkedIn siempre prevalecerá** sobre la información individual si ambas están presentes, ya que es la mejor manera de distinguir a una sola persona y evitar problemas relacionados con homónimos.

## Cuerpo de la solicitud

**Opción 1 (Recomendada):**

<ParamField body="linkedin_url" type="string">
  URL del perfil de LinkedIn de la persona.

  **Nota**: Tiene prioridad sobre la información individual si se proporcionan ambas.
</ParamField>

**Opción 2:**

<ParamField body="firstname" type="string">
  Nombre de la persona
</ParamField>

<ParamField body="lastname" type="string">
  Apellido de la persona
</ParamField>

<ParamField body="company_domain" type="string">
  Dominio de la empresa (p. ej., `"dundermifflin.com"`)
</ParamField>

<ParamField body="company_name" type="string">
  Nombre de la empresa (alternativa a `company_domain`)
</ParamField>

**Adicional:**

<ParamField body="custom" type="string">
  Un valor personalizado que puedes usar para referenciar un ID interno. Estará presente en los resultados.
</ParamField>

<ParamField body="settings" type="object">
  Configuración relacionada con esta búsqueda.

  <Expandable title="propiedades de settings">
    <ParamField body="webhook" type="string">
      Una URL que será notificada mediante una solicitud HTTP POST una vez que finalice la búsqueda. Consulta [Cómo funcionan los webhooks](/es/how-webhooks-work).
    </ParamField>
  </Expandable>
</ParamField>

## Respuesta

### 201 — Búsqueda individual creada

<ResponseField name="message" type="string">
  Mensaje de confirmación
</ResponseField>

<ResponseField name="id" type="string">
  Identificador único de esta búsqueda. Úsalo para recuperar los resultados a través del [endpoint GET](/es/api-reference/phone/get-single-result).
</ResponseField>

<ResponseField name="credits_used" type="number">
  Número de créditos consumidos (50 de forma predeterminada; puede variar según el plan). Consulta [Créditos y facturación](/es/credits-billing) para conocer los costes por endpoint.
</ResponseField>

<ResponseField name="credits" type="object">
  Desglose de créditos

  <Expandable title="propiedades de credits">
    <ResponseField name="amount" type="number">
      Créditos consumidos
    </ResponseField>

    <ResponseField name="source" type="string">
      Origen de los créditos: `sub` (suscripción), `paygo` (pago por uso) o `mixed`
    </ResponseField>

    <ResponseField name="split" type="object">
      Desglose entre créditos de suscripción y de pago por uso (`fromSub`, `fromPaygo`)
    </ResponseField>
  </Expandable>
</ResponseField>

### Respuestas de error

| Code    | Message                                                       |
| ------- | ------------------------------------------------------------- |
| **400** | `Invalid linkedin_url format`                                 |
| **401** | `No apikey found in the x-api-key headers`                    |
| **401** | `This apikey is not valid`                                    |
| **401** | `This account is not allowed to use the phone search feature` |
| **402** | `Insufficient credits`                                        |

En caso de créditos insuficientes (**402**), el cuerpo de la respuesta es `{ "reason": "...", "success": false }`. Consulta [Gestión de errores](/es/error-handling) para ver la lista completa de códigos de estado y formatos de respuesta.

<RequestExample>
  ```bash cURL — URL de LinkedIn theme={null}
  curl --request POST \
    --url https://api.enrow.io/phone/single \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: YOUR_API_KEY' \
    --data '{
      "linkedin_url": "https://www.linkedin.com/in/michael-scott/",
      "custom": "#u84hde941Jdx"
    }'
  ```

  ```javascript Node.js theme={null}
  const response = await fetch('https://api.enrow.io/phone/single', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
      'x-api-key': process.env.ENROW_API_KEY
    },
    body: JSON.stringify({
      linkedin_url: 'https://www.linkedin.com/in/michael-scott/',
      custom: '#u84hde941Jdx'
    })
  });

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

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

  url = "https://api.enrow.io/phone/single"
  headers = {
      "Content-Type": "application/json",
      "x-api-key": os.getenv("ENROW_API_KEY")
  }
  payload = {
      "linkedin_url": "https://www.linkedin.com/in/michael-scott/",
      "custom": "#u84hde941Jdx"
  }

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

<ResponseExample>
  ```json Respuesta de éxito theme={null}
  {
    "credits_used": 40,
    "id": "94cbc13b-7d77-4f41-83f0-60106daa7182",
    "message": "Single search operating",
    "credits": {
      "amount": 40,
      "source": "sub",
      "split": { "fromPaygo": 0, "fromSub": 40 }
    }
  }
  ```

  ```json Respuesta de error theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Próximos pasos

<CardGroup cols={2}>
  <Card title="Obtener el resultado" icon="inbox" href="/es/api-reference/phone/get-single-result">
    Recupera el número de teléfono encontrado usando el `id` de la búsqueda.
  </Card>

  <Card title="Buscar teléfonos en lote" icon="layer-group" href="/es/api-reference/phone/find-bulk">
    Ejecuta varias búsquedas de teléfono en una sola solicitud.
  </Card>

  <Card title="Autenticación" icon="key" href="/es/authentication">
    Cómo pasar tu clave de API en la cabecera x-api-key.
  </Card>

  <Card title="Webhooks" icon="bell" href="/es/how-webhooks-work">
    Recibe notificaciones automáticas cuando se complete una búsqueda.
  </Card>
</CardGroup>
