kshitijk4poor
5fb143169b
feat(dashboard): track real API call count per session
...
Adds schema v7 'api_call_count' column. run_agent.py increments it by 1
per LLM API call, web_server analytics SQL aggregates it, frontend uses
the real counter instead of summing sessions.
The 'API Calls' card on the analytics dashboard previously displayed
COUNT(*) from the sessions table — the number of conversations, not
LLM requests. Each session makes 10-90 API calls through the tool loop,
so the reported number was ~30x lower than real.
Salvaged from PR #10140 (@kshitijk4poor). The cache-token accuracy
portions of the original PR were deferred — per-provider analytics is
the better path there, since cache_write_tokens and actual_cost_usd
are only reliably available from a subset of providers (Anthropic
native, Codex Responses, OpenRouter with usage.include).
Tests:
- schema_version v7 assertion
- migration v2 -> v7 adds api_call_count column with default 0
- update_token_counts increments api_call_count by provided delta
- absolute=True sets api_call_count directly
- /api/analytics/usage exposes total_api_calls in totals
2026-04-22 05:51:58 -07:00
..
2026-02-26 03:20:08 +03:00
2026-04-20 22:21:21 -07:00
2026-04-07 17:19:07 -07:00
2026-04-07 17:19:07 -07:00
2026-04-22 02:59:58 -07:00
2026-04-20 23:20:33 -07:00
2026-04-20 20:53:51 -07:00
2026-04-21 14:31:48 -05:00
2026-04-07 17:19:07 -07:00
2026-04-07 17:19:07 -07:00
2026-04-18 19:19:46 -07:00
2026-04-21 01:52:49 -07:00
2026-04-21 20:35:16 -07:00
2026-04-14 01:43:45 -07:00
2026-04-08 13:46:30 -07:00
2026-04-20 00:47:39 -07:00
2026-04-20 00:47:40 -07:00
2026-04-07 17:59:42 -07:00
2026-03-18 03:17:37 -07:00
2026-03-18 03:22:58 -07:00
2026-04-09 16:24:53 -07:00
2026-04-12 16:40:37 -07:00
2026-04-11 01:52:58 -07:00
2026-04-17 21:35:30 -07:00
2026-03-09 21:36:29 -07:00
2026-04-19 12:39:58 -07:00
2026-04-20 04:51:44 -07:00
2026-04-20 05:11:39 -07:00
2026-04-14 10:45:42 -07:00
2026-04-21 14:23:45 -07:00
2026-04-07 17:19:07 -07:00
2026-04-17 19:03:26 -07:00
2026-04-19 12:40:08 -07:00
2026-04-20 23:20:33 -07:00
2026-04-12 16:36:11 -07:00
2026-04-10 03:44:43 -07:00
2026-04-19 05:19:22 -07:00
2026-04-12 01:44:18 -07:00
2026-04-17 18:46:30 -07:00
2026-04-16 06:48:33 -07:00
2026-04-20 22:14:29 -07:00
2026-04-20 22:14:29 -07:00
2026-04-17 05:08:07 -07:00
2026-04-14 23:13:11 -07:00
2026-04-15 15:05:32 -07:00
2026-04-22 05:51:44 -07:00
2026-04-13 04:35:37 -07:00
2026-04-09 16:24:53 -07:00
2026-03-14 12:11:23 -07:00
2026-04-17 19:27:58 -07:00
2026-04-10 21:15:47 -07:00
2026-04-17 19:24:30 -07:00
2026-04-20 23:20:33 -07:00
2026-04-20 20:53:51 -07:00
2026-04-21 21:30:10 -07:00
2026-03-29 21:54:36 -07:00
2026-04-11 17:23:36 -07:00
2026-03-30 17:34:43 -07:00
2026-04-16 21:57:10 -07:00
2026-03-17 03:48:44 -07:00
2026-04-16 06:48:33 -07:00
2026-04-17 04:19:36 -07:00
2026-04-17 06:33:21 -07:00
2026-04-22 02:59:58 -07:00
2026-04-16 01:16:14 -07:00
2026-04-19 11:07:29 -07:00
2026-04-19 11:23:00 -07:00
2026-04-08 19:58:16 -07:00
2026-04-22 02:59:58 -07:00
2026-04-21 20:35:16 -07:00
2026-04-20 22:14:03 -07:00
2026-04-13 04:33:52 -07:00
2026-04-16 12:36:49 -07:00
2026-04-07 17:19:07 -07:00
2026-04-16 07:17:45 -07:00
2026-04-21 01:56:55 -07:00
2026-04-21 05:19:43 -07:00
2026-04-10 14:46:57 -07:00
2026-03-16 06:07:45 -07:00
2026-03-14 10:35:14 -07:00
2026-04-17 01:05:09 -07:00
2026-04-21 21:30:10 -07:00
2026-04-17 01:05:09 -07:00
2026-04-20 05:11:39 -07:00
2026-04-01 11:20:33 -07:00
2026-04-17 18:58:29 -07:00
2026-04-20 04:52:50 -07:00
2026-04-09 14:20:16 -07:00
2026-04-21 06:06:16 -07:00
2026-03-08 17:42:50 -07:00
2026-03-25 18:06:04 -07:00
2026-03-31 11:41:12 -07:00
2026-04-19 00:28:25 -07:00
2026-04-09 16:24:53 -07:00
2026-04-10 21:15:59 -07:00
2026-04-10 03:44:43 -07:00
2026-04-10 02:57:39 -07:00
2026-04-20 14:56:04 -07:00
2026-04-16 20:43:41 -07:00
2026-04-16 12:36:49 -07:00
2026-04-03 10:10:53 -07:00
2026-04-11 15:38:43 -07:00
2026-03-17 01:59:07 -07:00
2026-03-28 14:32:23 -07:00
2026-03-11 00:50:39 -07:00
2026-04-16 06:35:31 -07:00
2026-04-16 12:36:49 -07:00
2026-04-09 16:24:53 -07:00
2026-04-17 01:05:09 -07:00
2026-03-30 11:17:15 -07:00
2026-04-10 02:57:39 -07:00
2026-04-20 00:52:50 -07:00
2026-04-13 16:32:04 -07:00
2026-03-29 20:05:59 -07:00
2026-04-20 20:52:50 -07:00
2026-03-26 13:39:41 -07:00
2026-04-15 10:23:15 -05:00
2026-04-16 19:14:05 -05:00
2026-04-10 00:32:20 -07:00
2026-04-19 19:38:02 -07:00
2026-04-19 22:43:09 -07:00
2026-04-17 19:35:12 -07:00
2026-04-17 21:29:24 -07:00
2026-04-19 22:15:49 -07:00
2026-04-21 06:26:35 -07:00
2026-04-22 05:51:58 -07:00
2026-03-28 14:33:35 -07:00
2026-04-20 23:20:33 -07:00