> ## Documentation Index
> Fetch the complete documentation index at: https://docs.pilotstatus.com.br/llms.txt
> Use this file to discover all available pages before exploring further.

# Listar conversas

> Lista as conversas do número vinculado, ordenadas pela última atividade (lastMessageAt desc). Paginação por page/pageSize. Filtre por período com startDate/endDate (ISO 8601, sobre lastMessageAt). O modo de privacidade do número (PII) afeta a resposta: RELAY_ONLY retorna [] + notice:"PII_RELAY_ONLY"; STORE_X_DAYS limita à janela max(startDate, agora − retentionDays). Requer key escopada a número. Identidade do contato: `from` é o telefone E.164 (com `+`) quando conhecido — pode ser null para contatos que usam username do WhatsApp; `userId` é o BSUID durável (id estável do contato) e `username` o handle público quando visível.

**Requer uma chave com escopo de número.**



## OpenAPI

````yaml openapi.pt.json GET /v1/conversations
openapi: 3.1.0
info:
  title: API Pilot Status
  version: 1.0.0
  license:
    name: Pilot Status Terms of Service
    url: https://pilotstatus.com.br/terms
  description: >-
    API REST pública do Pilot Status. Autentique com o header `x-api-key:
    ps_...` (ou `x-api-key-id`). Base URL: https://pilotstatus.com.br
servers:
  - url: https://pilotstatus.com.br
security:
  - apiKey: []
  - apiKeyId: []
paths:
  /v1/conversations:
    get:
      tags:
        - Conversations
      summary: Listar conversas
      description: >-
        Lista as conversas do número vinculado, ordenadas pela última atividade
        (lastMessageAt desc). Paginação por page/pageSize. Filtre por período
        com startDate/endDate (ISO 8601, sobre lastMessageAt). O modo de
        privacidade do número (PII) afeta a resposta: RELAY_ONLY retorna [] +
        notice:"PII_RELAY_ONLY"; STORE_X_DAYS limita à janela max(startDate,
        agora − retentionDays). Requer key escopada a número. Identidade do
        contato: `from` é o telefone E.164 (com `+`) quando conhecido — pode ser
        null para contatos que usam username do WhatsApp; `userId` é o BSUID
        durável (id estável do contato) e `username` o handle público quando
        visível.


        **Requer uma chave com escopo de número.**
      operationId: get_conversations
      parameters:
        - name: startDate
          in: query
          required: false
          description: Início do período (filtra por lastMessageAt). Deve ser ≤ endDate.
          schema:
            type: string
            description: (string (ISO 8601))
          example: '2026-06-01T00:00:00Z'
        - name: endDate
          in: query
          required: false
          description: Fim do período (filtra por lastMessageAt).
          schema:
            type: string
            description: (string (ISO 8601))
          example: '2026-06-27T23:59:59Z'
        - name: page
          in: query
          required: false
          description: Página (padrão 1).
          schema:
            type: string
            description: (integer (≥1))
          example: '1'
        - name: pageSize
          in: query
          required: false
          description: Itens por página (padrão 30, máx 100).
          schema:
            type: string
            description: (integer (1–100))
          example: '30'
      responses:
        '200':
          description: Listar conversas
          content:
            application/json:
              example:
                conversations:
                  - id: conv_01HZX...
                    from: '+5511988887777'
                    fromName: Ana
                    userId: BR.13491208655302741918
                    username: ana
                    type: DIRECT
                    unreadCount: 2
                    lastMessageAt: '2026-06-27T10:00:00.000Z'
                    lastMessagePreview: Olá! Sua entrega chegou.
                total: 1
                page: 1
                pageSize: 30
                totalPages: 1
        '400':
          description: Range de datas inválido
          content:
            application/json:
              example:
                error: startDate must be before or equal to endDate
                code: INVALID_DATE_RANGE
        '401':
          description: Header `x-api-key` / `x-api-key-id` ausente ou inválido
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                  code:
                    type: string
              example:
                error: Unauthorized
        '403':
          description: Chave com escopo de tenant usada em endpoint com escopo de número
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                  code:
                    type: string
              example:
                error: Tenant-scoped keys cannot call number endpoints
                code: TENANT_SCOPE_NOT_ALLOWED
        '429':
          description: Limite de taxa excedido
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                  code:
                    type: string
              example:
                error: Too many requests
components:
  securitySchemes:
    apiKey:
      type: apiKey
      in: header
      name: x-api-key
      description: Sua chave de API ps_
    apiKeyId:
      type: apiKey
      in: header
      name: x-api-key-id
      description: Id da chave de API (alternativa ao x-api-key)

````