> ## Documentation Index
> Fetch the complete documentation index at: https://x-preview-mintlify-d5730eee.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Faça sua primeira solicitação

> Faça sua primeira solicitação à X Enterprise API, incluindo configuração de autenticação, seleção de endpoint, comandos cURL de exemplo e dicas para tratamento de respostas.

export const Button = ({href, children}) => {
  return <div className="not-prose group">
    <a href={href}>
      <button className="flex items-center space-x-2.5 py-1 px-4 bg-primary-dark dark:bg-white text-white dark:text-gray-950 rounded-full group-hover:opacity-[0.9] font-medium">
        <span>
          {children}
        </span>
        <svg width="3" height="24" viewBox="0 -9 3 24" class="h-6 rotate-0 overflow-visible"><path d="M0 0L3 3L0 6" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path></svg>
      </button>
    </a>
  </div>;
};

Este guia orienta você a fazer sua primeira solicitação à X API. Você precisará de uma [conta de desenvolvedor com credenciais de app](/x-api/getting-started/getting-access) antes de começar.

***

## Início rápido com cURL

A maneira mais rápida de testar a API é com cURL. Vamos consultar um usuário:

```bash theme={null}
curl "https://api.x.com/2/users/by/username/xdevelopers" \
  -H "Authorization: Bearer $BEARER_TOKEN"
```

Substitua `$BEARER_TOKEN` pelo seu Bearer Token real. Você receberá uma resposta como esta:

```json theme={null}
{
  "data": {
    "id": "2244994945",
    "name": "X Developers",
    "username": "xdevelopers"
  }
}
```

***

## Guia passo a passo

<Steps>
  <Step title="Obtenha seu Bearer Token">
    No [Developer Console](https://console.x.com), navegue até o seu app e copie o Bearer Token.
  </Step>

  <Step title="Escolha um endpoint">
    Comece com um destes endpoints amigáveis para iniciantes:

    | Endpoint                                          | O que faz                                      |
    | :------------------------------------------------ | :--------------------------------------------- |
    | [User lookup](/x-api/users/lookup/introduction)   | Obtenha o perfil de usuário por username ou ID |
    | [Post lookup](/x-api/posts/lookup/introduction)   | Obtenha um post por ID                         |
    | [Recent search](/x-api/posts/search/introduction) | Pesquise posts dos últimos 7 dias              |
  </Step>

  <Step title="Faça a solicitação">
    Use cURL, Postman ou seu cliente HTTP preferido:

    ```bash theme={null}
    # Look up a user by username
    curl "https://api.x.com/2/users/by/username/xdevelopers" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Step>

  <Step title="Faça o parse da resposta">
    As respostas são em JSON. Os dados principais ficam no campo `data`:

    ```json theme={null}
    {
      "data": {
        "id": "2244994945",
        "name": "X Developers",
        "username": "xdevelopers"
      }
    }
    ```
  </Step>
</Steps>

***

## Solicite mais dados com fields

Por padrão, os endpoints retornam campos mínimos. Use o parâmetro `fields` para solicitar dados adicionais:

```bash theme={null}
curl "https://api.x.com/2/users/by/username/xdevelopers?user.fields=created_at,description,public_metrics" \
  -H "Authorization: Bearer $BEARER_TOKEN"
```

Resposta:

```json theme={null}
{
  "data": {
    "id": "2244994945",
    "name": "X Developers",
    "username": "xdevelopers",
    "created_at": "2013-12-14T04:35:55.000Z",
    "description": "The voice of the X Developer Platform",
    "public_metrics": {
      "followers_count": 570842,
      "following_count": 2048,
      "tweet_count": 14052,
      "listed_count": 1672
    }
  }
}
```

[Saiba mais sobre fields →](/x-api/fundamentals/fields)

***

## Mais exemplos

<Tabs>
  <Tab title="Consultar um post">
    ```bash theme={null}
    curl "https://api.x.com/2/tweets/1460323737035677698?tweet.fields=created_at,public_metrics" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>

  <Tab title="Pesquisar posts recentes">
    ```bash theme={null}
    curl "https://api.x.com/2/tweets/search/recent?query=from:xdevelopers&tweet.fields=created_at" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>

  <Tab title="Obter posts de um usuário">
    ```bash theme={null}
    curl "https://api.x.com/2/users/2244994945/tweets?max_results=5" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>
</Tabs>

***

## Usando código em vez de cURL

<Tabs>
  <Tab title="Python">
    ```python theme={null}
    import requests

    bearer_token = "YOUR_BEARER_TOKEN"
    url = "https://api.x.com/2/users/by/username/xdevelopers"

    headers = {"Authorization": f"Bearer {bearer_token}"}
    response = requests.get(url, headers=headers)

    print(response.json())
    ```
  </Tab>

  <Tab title="JavaScript">
    ```javascript theme={null}
    const bearerToken = "YOUR_BEARER_TOKEN";
    const url = "https://api.x.com/2/users/by/username/xdevelopers";

    fetch(url, {
      headers: { Authorization: `Bearer ${bearerToken}` }
    })
      .then(res => res.json())
      .then(data => console.log(data));
    ```
  </Tab>

  <Tab title="SDKs oficiais">
    Para uso em produção, recomendamos os SDKs oficiais:

    * [Python SDK](/xdks/python/overview)
    * [TypeScript SDK](/xdks/typescript/overview)

    Eles cuidam de autenticação, paginação e limites de taxa automaticamente.
  </Tab>
</Tabs>

***

## Ferramentas para testes

<CardGroup cols={3}>
  <Card title="Postman" icon="server" href="/tutorials/postman-getting-started">
    Teste visual da API com a nossa coleção.
  </Card>

  <Card title="Código de exemplo" icon="github" href="https://github.com/xdevplatform/Twitter-API-v2-sample-code">
    Exemplos em múltiplas linguagens.
  </Card>

  <Card title="Referência da API" icon="code" href="/x-api/posts/lookup/introduction">
    Documentação completa de endpoints.
  </Card>
</CardGroup>

***

## Solução de problemas

<Accordion title="401 Unauthorized">
  * Verifique se o seu Bearer Token está correto
  * Garanta que o token não foi regenerado
  * Verifique o formato do cabeçalho `Authorization`: `Bearer YOUR_TOKEN`
</Accordion>

<Accordion title="403 Forbidden">
  * Seu app pode não ter acesso a este endpoint
  * Alguns endpoints exigem autenticação user-context (OAuth 1.0a ou 2.0)
  * Verifique as permissões do seu app no Developer Console
</Accordion>

<Accordion title="429 Too Many Requests">
  * Você atingiu um limite de taxa
  * Verifique o cabeçalho `x-rate-limit-reset` para saber quando tentar novamente
  * Implemente exponential backoff no seu código
</Accordion>

[Referência completa de erros →](/x-api/fundamentals/response-codes-and-errors)

***

## Próximas etapas

<CardGroup cols={2}>
  <Card title="Aprenda sobre autenticação" icon="key" href="/resources/fundamentals/authentication/overview">
    Entenda o OAuth para solicitações user-context.
  </Card>

  <Card title="Explore endpoints" icon="compass" href="/x-api/posts/search/introduction">
    Descubra o que você pode construir.
  </Card>

  <Card title="Use um SDK" icon="cube" href="/tools-and-libraries">
    Desenvolvimento mais rápido com bibliotecas oficiais.
  </Card>

  <Card title="Construa algo" icon="hammer" href="/x-api/what-to-build">
    Ideias para o que criar.
  </Card>
</CardGroup>
