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

# Benutzerdefinierte Analytics-Abfrage

> Flexible Analytics-Abfrage mit benutzerdefinierten selections, Filtern und aggregations für Autocomplete-, Chat-, Command- und PCW-Daten.

<div id="overview">
  ## Übersicht
</div>

Die Custom Analytics-API bietet flexible Abfragemöglichkeiten für Autocomplete-, Chat- und Command-Daten mit anpassbaren selections, Filtern, aggregations und Sortierungen.

<div id="request">
  ## Anfrage
</div>

<ParamField body="service_key" type="string" required>
  Ihr Service Key mit Berechtigungen „Analytics Read“
</ParamField>

<ParamField body="group_name" type="string">
  Ergebnisse auf Benutzer in einer bestimmten Gruppe einschränken (optional)
</ParamField>

<ParamField body="query_requests" type="array" required>
  Array von Query-Request-Objekten, die die abzurufenden Daten definieren

  <Expandable title="Query Request Object">
    <ParamField body="data_source" type="string" required>
      Abzufragende Datenquelle. Optionen:

      * `QUERY_DATA_SOURCE_USER_DATA` - Autocomplete-Daten
      * `QUERY_DATA_SOURCE_CHAT_DATA` - Chat-Daten
      * `QUERY_DATA_SOURCE_COMMAND_DATA` - Command-Daten
      * `QUERY_DATA_SOURCE_PCW_DATA` - Percent-Code-Written-Daten
    </ParamField>

    <ParamField body="selections" type="array" required>
      Array der abzurufenden Feldauswahlen

      <Expandable title="Selection Object">
        <ParamField body="field" type="string" required>
          Name des auszuwählenden Felds (siehe Abschnitt „Available Fields“)
        </ParamField>

        <ParamField body="name" type="string">
          Alias für das Feld. Wenn nicht angegeben, lautet der Standardwert `{aggregation_function}_{field_name}` (kleingeschrieben)
        </ParamField>

        <ParamField body="aggregation_function" type="string">
          Anzuwendende Aggregationsfunktion:

          * `QUERY_AGGREGATION_UNSPECIFIED` (Standard)
          * `QUERY_AGGREGATION_COUNT`
          * `QUERY_AGGREGATION_SUM`
          * `QUERY_AGGREGATION_AVG`
          * `QUERY_AGGREGATION_MAX`
          * `QUERY_AGGREGATION_MIN`
        </ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="filters" type="array">
      Array der anzuwendenden Filter

      <Expandable title="Filter Object">
        <ParamField body="name" type="string" required>
          Name des zu filternden Felds
        </ParamField>

        <ParamField body="filter" type="string" required>
          Filteroperation:

          * `QUERY_FILTER_EQUAL`
          * `QUERY_FILTER_NOT_EQUAL`
          * `QUERY_FILTER_GREATER_THAN`
          * `QUERY_FILTER_LESS_THAN`
          * `QUERY_FILTER_GE` (größer oder gleich)
          * `QUERY_FILTER_LE` (kleiner oder gleich)
        </ParamField>

        <ParamField body="value" type="string" required>
          Zu vergleichender Wert
        </ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="aggregations" type="array">
      Array von Aggregationen für die Gruppierung

      <Expandable title="Aggregation Object">
        <ParamField body="field" type="string" required>
          Feldname, nach dem gruppiert werden soll
        </ParamField>

        <ParamField body="name" type="string" required>
          Alias für das Aggregationsfeld
        </ParamField>
      </Expandable>
    </ParamField>
  </Expandable>
</ParamField>

<div id="query-request-structure">
  ## Struktur der Query-Anfrage
</div>

Jedes Query-Request-Objekt enthält:

* **data\_source** (erforderlich): Abzufragende Datenquelle
* **selections** (erforderlich): Array von Feldselections, die abgerufen werden sollen
* **filters** (optional): Array von Filtern, die angewendet werden sollen
* **aggregations** (optional): Array von Aggregationen zur Gruppierung

<div id="selections">
  ## Selections
</div>

Selections legen fest, welche Felder abgerufen werden und wie sie aggregiert werden.

* **field** (erforderlich): Name des auszuwählenden Felds
* **name** (optional): Alias für das Feld
* **aggregation\_function** (optional): Anzuwendende Aggregationsfunktion

<div id="selection-example">
  ### Beispielauswahl
</div>

```json theme={null}
{
  "field": "num_acceptances",
  "name": "total_acceptances",
  "aggregation_function": "QUERY_AGGREGATION_SUM"
}
```

<div id="filters">
  ## Filter
</div>

Filter schränken Daten auf Elemente ein, die bestimmte Kriterien erfüllen.

* **name** (erforderlich): Feldname, nach dem gefiltert werden soll
* **filter** (erforderlich): Filteroperation
* **value** (erforderlich): Wert, mit dem verglichen werden soll

<div id="filter-example">
  ### Beispiel für einen Filter
</div>

```json theme={null}
{
  "name": "language",
  "filter": "QUERY_FILTER_EQUAL",
  "value": "PYTHON"
}
```

<div id="aggregations">
  ## Aggregations
</div>

Aggregationen fassen Daten anhand angegebener Kriterien zusammen.

* **field** (erforderlich): Feldname, nach dem gruppiert werden soll
* **name** (erforderlich): Alias für das Aggregationsfeld

<div id="aggregation-example">
  ### Beispiel für Aggregation
</div>

```json theme={null}
{
  "field": "ide",
  "name": "ide_type"
}
```

<div id="available-fields">
  ## Verfügbare Felder
</div>

<div id="user-data">
  ### Benutzerdaten
</div>

Alle Benutzerdaten werden pro Benutzer und pro Stunde aggregiert.

| Feldname                   | Beschreibung                                           | Gültige Aggregationen |
| -------------------------- | ------------------------------------------------------ | --------------------- |
| `api_key`                  | Hash des Benutzer-API-Schlüssels                       | UNSPECIFIED, COUNT    |
| `date`                     | UTC-Datum der Autocomplete-Vorschläge                  | UNSPECIFIED, COUNT    |
| `date UTC-x`               | Datum mit Zeitzonenoffset (z. B. „date UTC-8“ für PST) | UNSPECIFIED, COUNT    |
| `hour`                     | UTC-Stunde der Autocomplete-Vorschläge                 | UNSPECIFIED, COUNT    |
| `language`                 | Programmiersprache                                     | UNSPECIFIED, COUNT    |
| `ide`                      | Verwendetes IDE                                        | UNSPECIFIED, COUNT    |
| `version`                  | Windsurf-Version                                       | UNSPECIFIED, COUNT    |
| `num_acceptances`          | Anzahl der Autocomplete-Annahmen                       | SUM, MAX, MIN, AVG    |
| `num_lines_accepted`       | Akzeptierte Codezeilen                                 | SUM, MAX, MIN, AVG    |
| `num_bytes_accepted`       | Akzeptierte Bytes                                      | SUM, MAX, MIN, AVG    |
| `distinct_users`           | Eindeutige Benutzer                                    | UNSPECIFIED, COUNT    |
| `distinct_developer_days`  | Eindeutige (Benutzer, Tag)-Tupel                       | UNSPECIFIED, COUNT    |
| `distinct_developer_hours` | Eindeutige (Benutzer, Stunde)-Tupel                    | UNSPECIFIED, COUNT    |

<div id="chat-data">
  ### Chat-Daten
</div>

Alle Chat-Daten beziehen sich auf Antworten des Chat-AI-Modells, nicht auf Benutzerfragen.

| Field Name                | Description                                     | Valid Aggregations |
| ------------------------- | ----------------------------------------------- | ------------------ |
| `api_key`                 | Hash des Benutzer-API-Schlüssels                | UNSPECIFIED, COUNT |
| `model_id`                | Chat-AI-Modell-ID                               | UNSPECIFIED, COUNT |
| `date`                    | UTC-Datum der Chat-Antwort                      | UNSPECIFIED, COUNT |
| `date UTC-x`              | Datum mit Zeitzonen-Offset                      | UNSPECIFIED, COUNT |
| `ide`                     | Verwendetes IDE                                 | UNSPECIFIED, COUNT |
| `version`                 | Windsurf-Version                                | UNSPECIFIED, COUNT |
| `latest_intent_type`      | Chat-Intent-Typ (siehe Intent-Typen unten)      | UNSPECIFIED, COUNT |
| `num_chats_received`      | Anzahl empfangener Chat-Nachrichten             | SUM, MAX, MIN, AVG |
| `chat_accepted`           | Ob der Chat angenommen wurde (Daumen hoch)      | SUM, COUNT         |
| `chat_inserted_at_cursor` | Ob die Schaltfläche „Insert“ geklickt wurde     | SUM, COUNT         |
| `chat_applied`            | Ob die Schaltfläche „Apply Diff“ geklickt wurde | SUM, COUNT         |
| `chat_loc_used`           | Aus dem Chat verwendete Codezeilen              | SUM, MAX, MIN, AVG |

<div id="chat-intent-types">
  #### Chat-Intent-Typen
</div>

* `CHAT_INTENT_GENERIC` - Regulärer Chat
* `CHAT_INTENT_FUNCTION_EXPLAIN` - CodeLens: Funktions­erklärung
* `CHAT_INTENT_FUNCTION_DOCSTRING` - CodeLens: Funktions-Docstring
* `CHAT_INTENT_FUNCTION_REFACTOR` - CodeLens: Funktions-Refactoring
* `CHAT_INTENT_CODE_BLOCK_EXPLAIN` - CodeLens: Erklärung des Codeblocks
* `CHAT_INTENT_CODE_BLOCK_REFACTOR` - CodeLens: Refactoring des Codeblocks
* `CHAT_INTENT_PROBLEM_EXPLAIN` - CodeLens: Problemerklärung
* `CHAT_INTENT_FUNCTION_UNIT_TESTS` - CodeLens: Unit-Tests für die Funktion

<div id="command-data">
  ### Command-Daten
</div>

Command-Daten umfassen alle Befehle, einschließlich abgelehnter. Verwenden Sie das Feld `accepted`, um nur akzeptierte Befehle zu filtern.

| Feldname          | Beschreibung                                             | Gültige aggregations |
| ----------------- | -------------------------------------------------------- | -------------------- |
| `api_key`         | Hash des Benutzer-API-Schlüssels                         | UNSPECIFIED, COUNT   |
| `date`            | UTC-Datum des Befehls                                    | UNSPECIFIED, COUNT   |
| `timestamp`       | UTC-Zeitstempel des Befehls                              | UNSPECIFIED, COUNT   |
| `language`        | Programmiersprache                                       | UNSPECIFIED, COUNT   |
| `ide`             | Verwendetes IDE                                          | UNSPECIFIED, COUNT   |
| `version`         | Windsurf-Version                                         | UNSPECIFIED, COUNT   |
| `command_source`  | Auslöserquelle von Command (siehe Command Sources unten) | UNSPECIFIED, COUNT   |
| `provider_source` | Generierungs- oder Bearbeitungsmodus                     | UNSPECIFIED, COUNT   |
| `lines_added`     | Hinzugefügte Codezeilen                                  | SUM, MAX, MIN, AVG   |
| `lines_removed`   | Entfernte Codezeilen                                     | SUM, MAX, MIN, AVG   |
| `bytes_added`     | Hinzugefügte Bytes                                       | SUM, MAX, MIN, AVG   |
| `bytes_removed`   | Entfernte Bytes                                          | SUM, MAX, MIN, AVG   |
| `selection_lines` | Ausgewählte Zeilen (0 bei Generierungen)                 | SUM, MAX, MIN, AVG   |
| `selection_bytes` | Ausgewählte Bytes (0 bei Generierungen)                  | SUM, MAX, MIN, AVG   |
| `accepted`        | Ob der Befehl akzeptiert wurde                           | SUM, COUNT           |

<div id="command-sources">
  #### Command-Quellen
</div>

* `COMMAND_REQUEST_SOURCE_LINE_HINT_CODE_LENS`
* `COMMAND_REQUEST_SOURCE_DEFAULT` - Typische Command-Verwendung
* `COMMAND_REQUEST_SOURCE_RIGHT_CLICK_REFACTOR`
* `COMMAND_REQUEST_SOURCE_FUNCTION_CODE_LENS`
* `COMMAND_REQUEST_SOURCE_FOLLOWUP`
* `COMMAND_REQUEST_SOURCE_CLASS_CODE_LENS`
* `COMMAND_REQUEST_SOURCE_PLAN`
* `COMMAND_REQUEST_SOURCE_SELECTION_HINT_CODE_LENS`

<div id="provider-sources">
  #### Anbieterdatenquellen
</div>

* `PROVIDER_SOURCE_COMMAND_GENERATE` - Generierungsmodus
* `PROVIDER_SOURCE_COMMAND_EDIT` - Bearbeitungsmodus

<div id="pcw-data">
  ### PCW-Daten
</div>

Prozentual geschriebener Code mit separater Erfassung der Beiträge von Autocomplete und Command.

| Feldname                        | Beschreibung                                                  | Gültige Aggregationen |
| ------------------------------- | ------------------------------------------------------------- | --------------------- |
| `percent_code_written`          | Berechnet als codeium\_bytes / (codeium\_bytes + user\_bytes) | UNSPECIFIED           |
| `codeium_bytes`                 | Summe der von Codeium generierten Bytes                       | UNSPECIFIED           |
| `user_bytes`                    | Summe der vom Benutzer geschriebenen Bytes                    | UNSPECIFIED           |
| `total_bytes`                   | codeium\_bytes + user\_bytes                                  | UNSPECIFIED           |
| `codeium_bytes_by_autocomplete` | Codeium-Bytes durch Autocomplete                              | UNSPECIFIED           |
| `codeium_bytes_by_command`      | Codeium-Bytes durch Command                                   | UNSPECIFIED           |

<div id="pcw-filters">
  #### PCW-Filter
</div>

| Feldname   | Beschreibung       | Beispiele         |
| ---------- | ------------------ | ----------------- |
| `language` | Programmiersprache | KOTLIN, GO, JAVA  |
| `ide`      | Verwendete IDE     | jetbrains, vscode |
| `version`  | Windsurf-Version   | 1.28.0, 130.0     |

Für Datumsfilter in PCW-Abfragen verwenden Sie `start_timestamp` und `end_timestamp` im Hauptanforderungstext der Anfrage.

<div id="example-requests">
  ## Beispielanfragen
</div>

<div id="user-data-example">
  ### Beispiel für Nutzerdaten
</div>

```bash theme={null}
curl -X POST --header "Content-Type: application/json" \
--data '{
  "service_key": "your_service_key_here",
  "query_requests": [
    {
      "data_source": "QUERY_DATA_SOURCE_USER_DATA",
      "selections": [
        {
          "field": "num_acceptances",
          "name": "total_acceptances",
          "aggregation_function": "QUERY_AGGREGATION_SUM"
        },
        {
          "field": "num_lines_accepted",
          "name": "total_lines",
          "aggregation_function": "QUERY_AGGREGATION_SUM"
        }
      ],
      "filters": [
        {
          "name": "date",
          "filter": "QUERY_FILTER_GE",
          "value": "2024-01-01"
        },
        {
          "name": "date",
          "filter": "QUERY_FILTER_LE",
          "value": "2024-02-01"
        }
      ]
    }
  ]
}' \
https://server.codeium.com/api/v1/Analytics
```

<div id="chat-data-example">
  ### Beispiel für Chat-Daten
</div>

```bash theme={null}
curl -X POST --header "Content-Type: application/json" \
--data '{
  "service_key": "your_service_key_here",
  "query_requests": [
    {
      "data_source": "QUERY_DATA_SOURCE_CHAT_DATA",
      "selections": [
        {
          "field": "chat_loc_used",
          "name": "lines_used",
          "aggregation_function": "QUERY_AGGREGATION_SUM"
        }
      ],
      "filters": [
        {
          "name": "latest_intent_type",
          "filter": "QUERY_FILTER_EQUAL",
          "value": "CHAT_INTENT_FUNCTION_DOCSTRING"
        }
      ],
      "aggregations": [
        {
          "field": "ide",
          "name": "ide_type"
        }
      ]
    }
  ]
}' \
https://server.codeium.com/api/v1/Analytics
```

<div id="command-data-example">
  ### Beispiel für Command-Daten
</div>

```bash theme={null}
curl -X POST --header "Content-Type: application/json" \
--data '{
  "service_key": "ihr_service_schlüssel_hier",
  "query_requests": [
    {
      "data_source": "QUERY_DATA_SOURCE_COMMAND_DATA",
      "selections": [
        {
          "field": "lines_added",
          "name": "total_lines_added",
          "aggregation_function": "QUERY_AGGREGATION_SUM"
        },
        {
          "field": "lines_removed",
          "name": "total_lines_removed",
          "aggregation_function": "QUERY_AGGREGATION_SUM"
        }
      ],
      "filters": [
        {
          "name": "provider_source",
          "filter": "QUERY_FILTER_EQUAL",
          "value": "PROVIDER_SOURCE_COMMAND_EDIT"
        },
        {
          "name": "accepted",
          "filter": "QUERY_FILTER_EQUAL",
          "value": "true"
        }
      ],
      "aggregations": [
        {
          "field": "language",
          "name": "programming_language"
        }
      ]
    }
  ]
}' \
https://server.codeium.com/api/v1/Analytics
```

<div id="pcw-data-example">
  ### Beispiel für PCW-Daten
</div>

```bash theme={null}
curl -X POST --header "Content-Type: application/json" \
--data '{
  "service_key": "your_service_key_here",
  "start_timestamp": "2024-01-01T00:00:00Z",
  "end_timestamp": "2024-12-22T00:00:00Z",
  "query_requests": [
    {
      "data_source": "QUERY_DATA_SOURCE_PCW_DATA",
      "selections": [
        {
          "field": "percent_code_written",
          "name": "pcw"
        },
        {
          "field": "codeium_bytes",
          "name": "ai_bytes"
        },
        {
          "field": "total_bytes",
          "name": "total"
        },
        {
          "field": "codeium_bytes_by_autocomplete",
          "name": "autocomplete_bytes"
        },
        {
          "field": "codeium_bytes_by_command",
          "name": "command_bytes"
        }
      ],
      "filters": [
        {
          "filter": "QUERY_FILTER_EQUAL",
          "name": "language",
          "value": "GO"
        }
      ]
    }
  ]
}' \
https://server.codeium.com/api/v1/Analytics
```

<div id="response">
  ## Antwort
</div>

<ResponseField name="queryResults" type="array">
  Array mit Abfrageergebnissen, eines für jede Abfrage

  <ResponseField name="responseItems" type="array">
    Array mit Ergebniseinträgen

    <ResponseField name="item" type="object">
      Objekt, das die ausgewählten Felder und ihre Werte enthält
    </ResponseField>
  </ResponseField>
</ResponseField>

<div id="example-responses">
  ### Beispielantworten
</div>

<div id="user-data-response">
  #### Antwort mit Benutzerdaten
</div>

```json theme={null}
{
  "queryResults": [
    {
      "responseItems": [
        {
          "item": {
            "total_acceptances": "125",
            "total_lines": "863"
          }
        }
      ]
    }
  ]
}
```

<div id="chat-data-response">
  #### Antwort mit Chatdaten
</div>

```json theme={null}
{
  "queryResults": [
    {
      "responseItems": [
        {
          "item": {
            "lines_used": "74",
            "ide_type": "jetbrains"
          }
        },
        {
          "item": {
            "lines_used": "41",
            "ide_type": "vscode"
          }
        }
      ]
    }
  ]
}
```

<div id="command-data-response">
  #### Command-Datenantwort
</div>

```json theme={null}
{
  "queryResults": [
    {
      "responseItems": [
        {
          "item": {
            "programming_language": "PYTHON",
            "total_lines_added": "21",
            "total_lines_removed": "5"
          }
        },
        {
          "item": {
            "programming_language": "GO",
            "total_lines_added": "31",
            "total_lines_removed": "27"
          }
        }
      ]
    }
  ]
}
```

<div id="pcw-data-response">
  #### PCW-Datenrückgabe
</div>

```json theme={null}
{
  "queryResults": [
    {
      "responseItems": [
        {
          "item": {
            "ai_bytes": "6018",
            "autocomplete_bytes": "4593",
            "command_bytes": "1425",
            "pcw": "0.61",
            "total": "9900"
          }
        }
      ]
    }
  ]
}
```

<div id="important-notes">
  ## Wichtige Hinweise
</div>

* PCW (Percent Code Written) weist innerhalb einzelner Tage oder Nutzer eine hohe Varianz auf – für aussagekräftigere Erkenntnisse über mehrere Wochen aggregieren
* Alle Auswahlfelder müssen entweder Aggregationsfunktionen haben oder keines darf eine haben (Mischformen sind nicht zulässig)
* Felder mit dem Muster "distinct\_\*" können nicht in aggregations verwendet werden
* Feldaliase müssen über alle selections und aggregations hinweg eindeutig sein
* Wenn keine Aggregationsfunktion angegeben ist, wird standardmäßig UNSPECIFIED verwendet
