カスタム Analytics クエリ
Analytics API(アナリティクス API)
カスタム Analytics クエリ
selections、フィルター、集計を指定できる柔軟な Analytics クエリで、Autocomplete、Chat、Command、PCW データを対象とします。
POST
カスタム Analytics クエリ
概要
Request
「Analytics Read」権限を持つサービスキー
特定のグループのユーザーに結果を絞り込みます(オプション)
取得するデータを定義する query request オブジェクトの配列
クエリリクエストの構造
- data_source (必須): クエリ対象のデータソース
- selections (必須): 取得するフィールド selections の配列
- filters (任意): 適用するフィルターの配列
- aggregations (任意): グループ化に使用する集計の配列
Selections
- field (必須): 選択するフィールド名
- name (任意): フィールドのエイリアス
- aggregation_function (任意): 適用する集計関数
選択例
フィルター
- name (必須): フィルター対象とするフィールド名
- filter (必須): フィルター演算
- value (必須): 比較する値
フィルターの例
集計
aggregations パラメータは、指定した条件でデータをグループ化(集計)します。
- field (必須): グループ化の対象となるフィールド名
- name (必須): 集計対象フィールドに付与するエイリアス名
集約の例
利用可能なフィールド
ユーザーデータ
| フィールド名 | 説明 | 有効な集計 |
|---|---|---|
api_key | ユーザーのAPIキーのハッシュ | UNSPECIFIED, COUNT |
date | AutocompleteのUTC日付 | UNSPECIFIED, COUNT |
date UTC-x | タイムゾーンオフセット付きの日付(例: “date UTC-8” はPST) | UNSPECIFIED, COUNT |
hour | AutocompleteのUTC時 | UNSPECIFIED, COUNT |
language | プログラミング言語 | UNSPECIFIED, COUNT |
ide | 使用しているIDE | UNSPECIFIED, COUNT |
version | Windsurfのバージョン | UNSPECIFIED, COUNT |
num_acceptances | Autocompleteの受入回数 | SUM, MAX, MIN, AVG |
num_lines_accepted | 受入れられたコード行数 | SUM, MAX, MIN, AVG |
num_bytes_accepted | 受入れられたバイト数 | SUM, MAX, MIN, AVG |
distinct_users | 一意のユーザー数 | UNSPECIFIED, COUNT |
distinct_developer_days | 一意の(ユーザー、日)組 | UNSPECIFIED, COUNT |
distinct_developer_hours | 一意の(ユーザー、時)組 | UNSPECIFIED, COUNT |
Chat データ
Chat データは Cascade データとは分離されており、旧来の非エージェント型プラグインの利用状況を表します
| Field Name | Description | Valid Aggregations |
|---|---|---|
api_key | ユーザー API キーのハッシュ | UNSPECIFIED, COUNT |
model_id | Chat のモデル ID | UNSPECIFIED, COUNT |
date | Chat 応答の UTC 日付 | UNSPECIFIED, COUNT |
date UTC-x | タイムゾーンオフセット付きの日付 | UNSPECIFIED, COUNT |
ide | 使用中の IDE | UNSPECIFIED, COUNT |
version | Windsurf のバージョン | UNSPECIFIED, COUNT |
latest_intent_type | Chat のインテント種別(下記の Intent Types を参照) | UNSPECIFIED, COUNT |
num_chats_received | 受信したチャットメッセージ数 | SUM, MAX, MIN, AVG |
chat_accepted | チャットが承認されたか(サムズアップ) | SUM, COUNT |
chat_inserted_at_cursor | 「Insert」ボタンがクリックされたか | SUM, COUNT |
chat_applied | 「Apply Diff」ボタンがクリックされたか | SUM, COUNT |
chat_loc_used | Chat から使用されたコード行数 | SUM, MAX, MIN, AVG |
Chat のインテント種別
CHAT_INTENT_GENERIC- 通常の ChatCHAT_INTENT_FUNCTION_EXPLAIN- 関数の説明用コードレンズCHAT_INTENT_FUNCTION_DOCSTRING- 関数のドックストリング用コードレンズCHAT_INTENT_FUNCTION_REFACTOR- 関数のリファクタリング用コードレンズCHAT_INTENT_CODE_BLOCK_EXPLAIN- コードブロックの説明用コードレンズCHAT_INTENT_CODE_BLOCK_REFACTOR- コードブロックのリファクタリング用コードレンズCHAT_INTENT_PROBLEM_EXPLAIN- 問題説明用コードレンズCHAT_INTENT_FUNCTION_UNIT_TESTS- 関数のユニットテスト用コードレンズ
Command データ
accepted フィールドを使用して、受け入れられたコマンドのみに絞り込んでください。
| Field Name | Description | Valid Aggregations |
|---|---|---|
api_key | ユーザーの API キーのハッシュ | UNSPECIFIED, COUNT |
date | コマンドの UTC 日付 | UNSPECIFIED, COUNT |
timestamp | コマンドの UTC タイムスタンプ | UNSPECIFIED, COUNT |
language | プログラミング言語 | UNSPECIFIED, COUNT |
ide | 使用中の IDE | UNSPECIFIED, COUNT |
version | Windsurf のバージョン | UNSPECIFIED, COUNT |
command_source | Command のトリガー元(下記の Command Sources を参照) | UNSPECIFIED, COUNT |
provider_source | 生成モードまたは編集モード | UNSPECIFIED, COUNT |
lines_added | 追加されたコード行数 | SUM, MAX, MIN, AVG |
lines_removed | 削除されたコード行数 | SUM, MAX, MIN, AVG |
bytes_added | 追加されたバイト数 | SUM, MAX, MIN, AVG |
bytes_removed | 削除されたバイト数 | SUM, MAX, MIN, AVG |
selection_lines | 選択行数(生成時は 0) | SUM, MAX, MIN, AVG |
selection_bytes | 選択バイト数(生成時は 0) | SUM, MAX, MIN, AVG |
accepted | コマンドが受け入れられたかどうか | SUM, COUNT |
Command の発行元
COMMAND_REQUEST_SOURCE_LINE_HINT_CODE_LENSCOMMAND_REQUEST_SOURCE_DEFAULT- 一般的な Command の使い方COMMAND_REQUEST_SOURCE_RIGHT_CLICK_REFACTORCOMMAND_REQUEST_SOURCE_FUNCTION_CODE_LENSCOMMAND_REQUEST_SOURCE_FOLLOWUPCOMMAND_REQUEST_SOURCE_CLASS_CODE_LENSCOMMAND_REQUEST_SOURCE_PLANCOMMAND_REQUEST_SOURCE_SELECTION_HINT_CODE_LENS
プロバイダーのソース
PROVIDER_SOURCE_COMMAND_GENERATE- 生成モードPROVIDER_SOURCE_COMMAND_EDIT- 編集モード
PCW データ
| Field Name | Description | Valid Aggregations |
|---|---|---|
percent_code_written | codeium_bytes / (codeium_bytes + user_bytes) で算出 | UNSPECIFIED |
codeium_bytes | Codeium が生成した合計バイト数 | UNSPECIFIED |
user_bytes | ユーザーが作成した合計バイト数 | UNSPECIFIED |
total_bytes | codeium_bytes + user_bytes | UNSPECIFIED |
codeium_bytes_by_autocomplete | Autocomplete による Codeium のバイト数 | UNSPECIFIED |
codeium_bytes_by_command | Command による Codeium のバイト数 | UNSPECIFIED |
PCW フィルター
| フィールド名 | 説明 | 例 |
|---|---|---|
language | プログラミング言語 | KOTLIN, GO, JAVA |
ide | 使用している IDE | jetbrains, vscode |
version | Windsurf のバージョン | 1.28.0, 130.0 |
start_timestamp と end_timestamp を使用します。
例リクエスト
ユーザー データの例
Chat データの例
Command データの例
PCW データ例
レスポンス
返答例
ユーザーデータの応答
Chat データ レスポンス
Command データのレスポンス
PCW データ レスポンス
重要な注意事項
- PCW (Percent Code Written) は、日ごと・ユーザーごとの値のばらつきが大きいため、より有用なインサイトを得るには週単位で集計・分析することを推奨します
- すべての selection フィールドは、集計関数を持つかまったく持たないかのいずれかでなければなりません(混在させることはできません)
"distinct_*"パターンを持つフィールドは集計には使用できません- フィールドエイリアスは、すべての
selectionsおよび 集計 を通して一意でなければなりません - 集計関数が指定されていない場合、デフォルトは
UNSPECIFIEDになります