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

# Manejo de errores

> Mensajes de error comunes y consejos de depuración para Analytics API, incluidos los errores de autenticación, estructura de consultas y limitación de frecuencia.

<div id="overview">
  ## Descripción general
</div>

La Analytics API devuelve mensajes de error detallados para ayudar a depurar consultas no válidas. Esta página aborda escenarios de error comunes y cómo resolverlos.

<div id="error-response-format">
  ## Formato de respuesta de error
</div>

Cuando se produce un error, la API devuelve una respuesta de error con un mensaje descriptivo:

```json theme={null}
{
  "error": "Mensaje de error que describe qué salió mal"
}
```

<div id="common-errors">
  ## Errores comunes
</div>

<div id="authentication-errors">
  ### Errores de autenticación
</div>

<AccordionGroup>
  <Accordion title="Invalid service key">
    **Error:** `Invalid service key`

    **Cause:** La clave de servicio proporcionada no es válida o ha sido revocada.

    **Solution:**

    * Verifica que tu clave de servicio sea correcta
    * Comprueba que la clave de servicio no haya sido revocada
    * Genera una nueva clave de servicio si es necesario
  </Accordion>

  <Accordion title="Insufficient permissions">
    **Error:** `Insufficient permissions`

    **Cause:** La clave de servicio no tiene los permisos necesarios para el endpoint que estás utilizando.

    **Solution:**

    * Actualiza los permisos de la clave de servicio en la configuración del equipo
    * Consulta la [introducción a la API](/es/windsurf/accounts/api-reference/api-introduction#required-permissions) para ver el permiso específico que requiere cada endpoint
  </Accordion>
</AccordionGroup>

<div id="query-structure-errors">
  ### Errores en la estructura de la consulta
</div>

<AccordionGroup>
  <Accordion title="Faltan selections">
    **Error:** `at least one field or aggregation is required`

    **Causa:** La solicitud de consulta no contiene ninguna selections ni aggregations.

    **Solución:** Agrega al menos una selección a tu solicitud de consulta:

    ```json theme={null}
    "selections": [
      {
        "field": "num_acceptances",
        "aggregation_function": "QUERY_AGGREGATION_SUM"
      }
    ]
    ```
  </Accordion>

  <Accordion title="data source no válido">
    **Error:** `invalid query table: QUERY_DATA_SOURCE_UNSPECIFIED`

    **Causa:** Probablemente haya un error tipográfico en el campo `data_source`.

    **Solución:** Verifica la ortografía de tu data source. Opciones válidas:

    * `QUERY_DATA_SOURCE_USER_DATA`
    * `QUERY_DATA_SOURCE_CHAT_DATA`
    * `QUERY_DATA_SOURCE_COMMAND_DATA`
    * `QUERY_DATA_SOURCE_PCW_DATA`
  </Accordion>

  <Accordion title="Funciones de agregación mixtas">
    **Error:** `all selection fields should have an aggregation function, or none of them should`

    **Causa:** Algunas selections tienen funciones de agregación y otras no.

    **Solución:** Agrega funciones de agregación a todas las selections o elimínalas de todas:

    **Inválido:**

    ```json theme={null}
    "selections": [
      {
        "field": "num_acceptances",
        "aggregation_function": "QUERY_AGGREGATION_SUM"
      },
      {
        "field": "num_lines_accepted",
        "aggregation_function": "QUERY_AGGREGATION_UNSPECIFIED"
      }
    ]
    ```

    **Válido:**

    ```json theme={null}
    "selections": [
      {
        "field": "num_acceptances",
        "aggregation_function": "QUERY_AGGREGATION_SUM"
      },
      {
        "field": "num_lines_accepted",
        "aggregation_function": "QUERY_AGGREGATION_SUM"
      }
    ]
    ```
  </Accordion>
</AccordionGroup>

<div id="field-and-aggregation-errors">
  ### Errores de campos y agregaciones
</div>

<AccordionGroup>
  <Accordion title="Función de agregación no válida">
    **Error:** `invalid aggregation function for string type field ide: QUERY_AGGREGATION_SUM`

    **Causa:** La función de agregación no es compatible con el tipo de campo especificado.

    **Solución:** Consulta la sección [Available Fields](/es/windsurf/accounts/api-reference/custom-analytics#available-fields) para ver qué funciones de agregación son válidas para cada campo. Los campos de tipo string normalmente solo admiten `COUNT` y `UNSPECIFIED`.
  </Accordion>

  <Accordion title="Agregación de campos distintivos">
    **Error:** `tried to aggregate on a distinct field: distinct_developer_days. Consider aggregating on the non-distinct fields instead: [api_key date]`

    **Causa:** Los campos con el patrón "distinct\_\*" no se pueden usar en la sección de aggregations.

    **Solución:** Usa los campos alternativos sugeridos para la agregación:

    **Inválido:**

    ```json theme={null}
    "aggregations": [
      {
        "field": "distinct_developer_days",
        "name": "distinct_developer_days"
      }
    ]
    ```

    **Válido:**

    ```json theme={null}
    "aggregations": [
      {
        "field": "api_key",
        "name": "api_key"
      },
      {
        "field": "date",
        "name": "date"
      }
    ]
    ```
  </Accordion>

  <Accordion title="Aliases de campo duplicados">
    **Error:** `duplicate field alias for selection/aggregation: num_acceptances`

    **Causa:** Varias selections o aggregations tienen el mismo nombre.

    **Solución:** Asegúrate de que todos los aliases de campos sean únicos. Recuerda que, si no se especifica un nombre, el valor predeterminado es `{aggregation_function}_{field_name}`.
  </Accordion>
</AccordionGroup>

<div id="data-filtering-errors">
  ### Errores de filtrado de datos
</div>

<AccordionGroup>
  <Accordion title="Invalid group name">
    **Error:** `invalid group name: GroupName`

    **Causa:** El nombre del grupo especificado no existe en tu organización.

    **Solución:**

    * Verifica la escritura del nombre del grupo
    * Comprueba que el grupo exista en la configuración de tu equipo
    * Usa el nombre exacto del grupo tal como aparece en el panel de tu equipo
  </Accordion>

  <Accordion title="Invalid timestamp format">
    **Error:** `invalid timestamp format`

    **Causa:** La marca de tiempo no está en el formato RFC 3339 correcto.

    **Solución:** Usa el formato correcto de marca de tiempo:

    ```
    2023-01-01T00:00:00Z
    ```

    **Ejemplos válidos:**

    * `2024-01-01T00:00:00Z`
    * `2024-12-31T23:59:59Z`
    * `2024-06-15T12:30:45Z`
  </Accordion>

  <Accordion title="Conflicting filters">
    **Error:** `Cannot use both group_name and emails parameters`

    **Causa:** Se proporcionaron los parámetros `group_name` y `emails` en una solicitud de Cascade Analytics.

    **Solución:** Usa `group_name` O `emails`, pero no ambos:

    **Inválido:**

    ```json theme={null}
    {
      "group_name": "engineering",
      "emails": ["user@example.com"]
    }
    ```

    **Válido:**

    ```json theme={null}
    {
      "group_name": "engineering"
    }
    ```

    **O:**

    ```json theme={null}
    {
      "emails": ["user@example.com", "user2@example.com"]
    }
    ```
  </Accordion>
</AccordionGroup>

<div id="rate-limiting">
  ## Limitación de tasa
</div>

<AccordionGroup>
  <Accordion title="Se superó el límite de tasa">
    **Error:** `429 Too Many Requests`

    **Causa:** Superaste el límite de tasa de la API.

    **Solución:**

    * Espera antes de realizar más solicitudes
    * Implementa retroceso exponencial (exponential backoff) en tu cliente
    * Considera agrupar varias consultas en una sola solicitud cuando sea posible
    * Ponte en contacto con soporte si necesitas límites de tasa más altos
  </Accordion>
</AccordionGroup>

<div id="debugging-tips">
  ## Consejos para depurar
</div>

<div id="1-start-simple">
  ### 1. Comienza de forma sencilla
</div>

Empieza con consultas básicas y ve añadiendo complejidad gradualmente:

```json theme={null}
{
  "service_key": "your_key",
  "query_requests": [
    {
      "data_source": "QUERY_DATA_SOURCE_USER_DATA",
      "selections": [
        {
          "field": "num_acceptances",
          "aggregation_function": "QUERY_AGGREGATION_COUNT"
        }
      ]
    }
  ]
}
```

<div id="2-validate-field-names">
  ### 2. Validar nombres de campos
</div>

Vuelve a comprobar los nombres de los campos con la documentación de [Available Fields](/es/windsurf/accounts/api-reference/custom-analytics#available-fields).

<div id="3-check-aggregation-compatibility">
  ### 3. Verifica la compatibilidad de agregación
</div>

Asegúrate de que tus funciones de agregación sean compatibles con los tipos de campo que estás seleccionando.

<div id="4-test-filters-separately">
  ### 4. Prueba los filtros por separado
</div>

Si tu consulta no devuelve los resultados esperados, prueba a eliminar los filtros uno por uno para aislar el problema.

<div id="5-use-proper-json-formatting">
  ### 5. Usa un formato JSON adecuado
</div>

Asegúrate de que tu JSON esté bien formateado y que todas las cadenas estén correctamente entrecomilladas.

<div id="getting-help">
  ## Obtén ayuda
</div>

Si sigues teniendo problemas:

1. **Revisa el mensaje de error con atención** - La mayoría de los errores incluyen indicaciones específicas para solucionarlos
2. **Revisa los ejemplos** - Compara la estructura de tu consulta con los ejemplos que funcionan en la documentación
3. **Contacta al soporte** - Ponte en contacto con [Windsurf Support](https://windsurf.com/support) y envía tu mensaje de error y la consulta específicos

<div id="api-version-notes">
  ## Notas de la versión de la API
</div>

El manejo de errores y la validación se han mejorado en la versión 1.10.0 de la API y posteriores. Si estás usando una versión anterior, considera actualizar para obtener mensajes de error más detallados.
