agent-recorder 0.0.1 → 0.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +2 -2
- package/vendor/node_modules/@agent-recorder/core/db/migrations.d.ts +2 -2
- package/vendor/node_modules/@agent-recorder/core/db/migrations.d.ts.map +1 -1
- package/vendor/node_modules/@agent-recorder/core/db/migrations.js +14 -6
- package/vendor/node_modules/@agent-recorder/core/db/migrations.js.map +1 -1
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics 2.js +0 -205
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.d 2.ts +0 -50
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.test 2.js +0 -253
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/analytics/session-analytics.test.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/configure 2.js +0 -144
- package/vendor/node_modules/@agent-recorder/cli/commands/configure.d 2.ts +0 -17
- package/vendor/node_modules/@agent-recorder/cli/commands/configure.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/configure.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/diagnose 2.js +0 -141
- package/vendor/node_modules/@agent-recorder/cli/commands/diagnose.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/commands/diagnose.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/diagnose.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/doctor 2.js +0 -253
- package/vendor/node_modules/@agent-recorder/cli/commands/doctor.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/commands/doctor.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/doctor.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/export 2.js +0 -56
- package/vendor/node_modules/@agent-recorder/cli/commands/export.d 2.ts +0 -12
- package/vendor/node_modules/@agent-recorder/cli/commands/export.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/export.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/install 2.js +0 -77
- package/vendor/node_modules/@agent-recorder/cli/commands/install.d 2.ts +0 -13
- package/vendor/node_modules/@agent-recorder/cli/commands/install.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/install.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/logs 2.js +0 -40
- package/vendor/node_modules/@agent-recorder/cli/commands/logs.d 2.ts +0 -8
- package/vendor/node_modules/@agent-recorder/cli/commands/logs.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/logs.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/mock-mcp 2.js +0 -188
- package/vendor/node_modules/@agent-recorder/cli/commands/mock-mcp.d 2.ts +0 -10
- package/vendor/node_modules/@agent-recorder/cli/commands/mock-mcp.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/mock-mcp.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/restart 2.js +0 -67
- package/vendor/node_modules/@agent-recorder/cli/commands/restart.d 2.ts +0 -9
- package/vendor/node_modules/@agent-recorder/cli/commands/restart.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/restart.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/sessions 2.js +0 -333
- package/vendor/node_modules/@agent-recorder/cli/commands/sessions.d 2.ts +0 -52
- package/vendor/node_modules/@agent-recorder/cli/commands/sessions.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/sessions.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/start 2.js +0 -174
- package/vendor/node_modules/@agent-recorder/cli/commands/start.d 2.ts +0 -10
- package/vendor/node_modules/@agent-recorder/cli/commands/start.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/start.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/status 2.js +0 -104
- package/vendor/node_modules/@agent-recorder/cli/commands/status.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/commands/status.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/status.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/stop 2.js +0 -89
- package/vendor/node_modules/@agent-recorder/cli/commands/stop.d 2.ts +0 -8
- package/vendor/node_modules/@agent-recorder/cli/commands/stop.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/stop.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/tui 2.js +0 -14
- package/vendor/node_modules/@agent-recorder/cli/commands/tui.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/commands/tui.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/commands/tui.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths 2.js +0 -117
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.d 2.ts +0 -55
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.test 2.js +0 -152
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/config/claude-paths.test.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/index 2.js +0 -194
- package/vendor/node_modules/@agent-recorder/cli/index.d 2.ts +0 -10
- package/vendor/node_modules/@agent-recorder/cli/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/package 2.json +0 -17
- package/vendor/node_modules/@agent-recorder/cli/tui/App 2.js +0 -84
- package/vendor/node_modules/@agent-recorder/cli/tui/App.d 2.ts +0 -6
- package/vendor/node_modules/@agent-recorder/cli/tui/App.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/App.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/api 2.js +0 -105
- package/vendor/node_modules/@agent-recorder/cli/tui/api.d 2.ts +0 -31
- package/vendor/node_modules/@agent-recorder/cli/tui/api.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/api.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/EventInspectPanel 2.js +0 -45
- package/vendor/node_modules/@agent-recorder/cli/tui/components/EventInspectPanel.d 2.ts +0 -11
- package/vendor/node_modules/@agent-recorder/cli/tui/components/EventInspectPanel.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/EventInspectPanel.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Header 2.js +0 -13
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Header.d 2.ts +0 -17
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Header.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Header.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Spinner 2.js +0 -21
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Spinner.d 2.ts +0 -12
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Spinner.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Spinner.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/StatusBadge 2.js +0 -50
- package/vendor/node_modules/@agent-recorder/cli/tui/components/StatusBadge.d 2.ts +0 -16
- package/vendor/node_modules/@agent-recorder/cli/tui/components/StatusBadge.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/StatusBadge.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Table 2.js +0 -20
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Table.d 2.ts +0 -21
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Table.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/Table.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/index 2.js +0 -8
- package/vendor/node_modules/@agent-recorder/cli/tui/components/index.d 2.ts +0 -8
- package/vendor/node_modules/@agent-recorder/cli/tui/components/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/components/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/hooks/useEventStream 2.js +0 -75
- package/vendor/node_modules/@agent-recorder/cli/tui/hooks/useEventStream.d 2.ts +0 -22
- package/vendor/node_modules/@agent-recorder/cli/tui/hooks/useEventStream.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/hooks/useEventStream.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionDetailScreen 2.js +0 -190
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionDetailScreen.d 2.ts +0 -13
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionDetailScreen.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionDetailScreen.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionsScreen 2.js +0 -166
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionsScreen.d 2.ts +0 -10
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionsScreen.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/SessionsScreen.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/index 2.js +0 -6
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/index.d 2.ts +0 -6
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/cli/tui/screens/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/config 2.js +0 -44
- package/vendor/node_modules/@agent-recorder/core/config.d 2.ts +0 -25
- package/vendor/node_modules/@agent-recorder/core/config.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/db/connection.d 2.ts +0 -15
- package/vendor/node_modules/@agent-recorder/core/migrations/001_initial 2.sql +0 -40
- package/vendor/node_modules/@agent-recorder/core/migrations/002_session_sequences 2.sql +0 -8
- package/vendor/node_modules/@agent-recorder/core/migrations/003_add_tool_columns 2.sql +0 -9
- package/vendor/node_modules/@agent-recorder/core/migrations/004_add_cancelled_status 2.sql +0 -23
- package/vendor/node_modules/@agent-recorder/core/migrations/005_add_error_category 2.sql +0 -6
- package/vendor/node_modules/@agent-recorder/core/package 2.json +0 -18
- package/vendor/node_modules/@agent-recorder/core/types/events.d 2.ts +0 -69
- package/vendor/node_modules/@agent-recorder/core/types/index 2.js +0 -2
- package/vendor/node_modules/@agent-recorder/core/types/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/types/session 2.js +0 -6
- package/vendor/node_modules/@agent-recorder/core/types/session.d 2.ts +0 -22
- package/vendor/node_modules/@agent-recorder/core/types/session.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/types/session.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/error-category 2.js +0 -58
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.d 2.ts +0 -22
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/error-category.test.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/index 2.js +0 -6
- package/vendor/node_modules/@agent-recorder/core/utils/index.d 2.ts +0 -6
- package/vendor/node_modules/@agent-recorder/core/utils/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/redact.d 2.ts +0 -19
- package/vendor/node_modules/@agent-recorder/core/utils/redact.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/core/utils/redact.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/index 2.js +0 -128
- package/vendor/node_modules/@agent-recorder/service/index.d 2.ts +0 -36
- package/vendor/node_modules/@agent-recorder/service/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/index 2.js +0 -7
- package/vendor/node_modules/@agent-recorder/service/mcp/index.d 2.ts +0 -7
- package/vendor/node_modules/@agent-recorder/service/mcp/index.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/index.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy 2.js +0 -223
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.d 2.ts +0 -26
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/proxy.test.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/recorder 2.js +0 -62
- package/vendor/node_modules/@agent-recorder/service/mcp/recorder.d 2.ts +0 -31
- package/vendor/node_modules/@agent-recorder/service/mcp/recorder.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/recorder.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/types 2.js +0 -15
- package/vendor/node_modules/@agent-recorder/service/mcp/types.d 2.ts +0 -40
- package/vendor/node_modules/@agent-recorder/service/mcp/types.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/mcp/types.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/package 2.json +0 -15
- package/vendor/node_modules/@agent-recorder/service/routes/events 2.js +0 -71
- package/vendor/node_modules/@agent-recorder/service/routes/events.d 2.ts +0 -11
- package/vendor/node_modules/@agent-recorder/service/routes/events.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/routes/events.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/routes/health 2.js +0 -18
- package/vendor/node_modules/@agent-recorder/service/routes/health.d 2.ts +0 -6
- package/vendor/node_modules/@agent-recorder/service/routes/health.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/routes/health.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/routes/sessions 2.js +0 -80
- package/vendor/node_modules/@agent-recorder/service/routes/sessions.d 2.ts +0 -12
- package/vendor/node_modules/@agent-recorder/service/routes/sessions.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/routes/sessions.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/server 2.js +0 -36
- package/vendor/node_modules/@agent-recorder/service/server.d 2.ts +0 -19
- package/vendor/node_modules/@agent-recorder/service/server.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/server.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/server.test 2.js +0 -296
- package/vendor/node_modules/@agent-recorder/service/server.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/service/server.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/session-manager 2.js +0 -22
- package/vendor/node_modules/@agent-recorder/service/session-manager.d 2.ts +0 -16
- package/vendor/node_modules/@agent-recorder/service/session-manager.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/session-manager.js 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/session-manager.test 2.js +0 -61
- package/vendor/node_modules/@agent-recorder/service/session-manager.test.d 2.ts +0 -5
- package/vendor/node_modules/@agent-recorder/service/session-manager.test.d.ts 2.map +0 -1
- package/vendor/node_modules/@agent-recorder/service/session-manager.test.js 2.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "agent-recorder",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.8",
|
|
4
4
|
"description": "Local-first flight recorder for Claude Code",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
},
|
|
36
36
|
"repository": {
|
|
37
37
|
"type": "git",
|
|
38
|
-
"url": "https://github.com/
|
|
38
|
+
"url": "git+https://github.com/EdytaKucharska/agent_recorder.git"
|
|
39
39
|
},
|
|
40
40
|
"keywords": [
|
|
41
41
|
"claude",
|
|
@@ -10,8 +10,8 @@ import type Database from "better-sqlite3";
|
|
|
10
10
|
export declare function runMigrations(db: Database.Database, migrationsDir: string): void;
|
|
11
11
|
/**
|
|
12
12
|
* Gets the default migrations directory path.
|
|
13
|
-
*
|
|
14
|
-
*
|
|
13
|
+
* In vendored build: db/migrations.js → ../migrations
|
|
14
|
+
* In dev build: dist/db/migrations.js → ../../migrations
|
|
15
15
|
*/
|
|
16
16
|
export declare function getDefaultMigrationsDir(): string;
|
|
17
17
|
//# sourceMappingURL=migrations.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.d.ts","sourceRoot":"","sources":["../../src/db/migrations.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAK3C;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,aAAa,EAAE,MAAM,GACpB,IAAI,CAsCN;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,IAAI,MAAM,
|
|
1
|
+
{"version":3,"file":"migrations.d.ts","sourceRoot":"","sources":["../../src/db/migrations.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAK3C;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,aAAa,EAAE,MAAM,GACpB,IAAI,CAsCN;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,IAAI,MAAM,CAgBhD"}
|
|
@@ -42,15 +42,23 @@ export function runMigrations(db, migrationsDir) {
|
|
|
42
42
|
}
|
|
43
43
|
/**
|
|
44
44
|
* Gets the default migrations directory path.
|
|
45
|
-
*
|
|
46
|
-
*
|
|
45
|
+
* In vendored build: db/migrations.js → ../migrations
|
|
46
|
+
* In dev build: dist/db/migrations.js → ../../migrations
|
|
47
47
|
*/
|
|
48
48
|
export function getDefaultMigrationsDir() {
|
|
49
|
-
// ESM-compatible __dirname equivalent
|
|
50
49
|
const __filename = fileURLToPath(import.meta.url);
|
|
51
50
|
const __dirname = dirname(__filename);
|
|
52
|
-
//
|
|
53
|
-
|
|
54
|
-
|
|
51
|
+
// Try vendored path first (one level up from db/)
|
|
52
|
+
const vendorPath = join(__dirname, "..", "migrations");
|
|
53
|
+
// Fall back to dev path (two levels up from dist/db/)
|
|
54
|
+
const devPath = join(__dirname, "..", "..", "migrations");
|
|
55
|
+
// Check which path exists
|
|
56
|
+
try {
|
|
57
|
+
readdirSync(vendorPath);
|
|
58
|
+
return vendorPath;
|
|
59
|
+
}
|
|
60
|
+
catch {
|
|
61
|
+
return devPath;
|
|
62
|
+
}
|
|
55
63
|
}
|
|
56
64
|
//# sourceMappingURL=migrations.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.js","sourceRoot":"","sources":["../../src/db/migrations.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,EAAqB,EACrB,aAAqB;IAErB,oDAAoD;IACpD,EAAE,CAAC,IAAI,CAAC;;;;;GAKP,CAAC,CAAC;IAEH,iCAAiC;IACjC,MAAM,OAAO,GAAG,IAAI,GAAG,CACrB,EAAE;SACC,OAAO,CAAC,kCAAkC,CAAC;SAC3C,GAAG,EAAE;SACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAE,GAA4B,CAAC,QAAQ,CAAC,CACxD,CAAC;IAEF,sCAAsC;IACtC,MAAM,KAAK,GAAG,WAAW,CAAC,aAAa,CAAC;SACrC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACjC,IAAI,EAAE,CAAC;IAEV,2BAA2B;IAC3B,KAAK,MAAM,QAAQ,IAAI,KAAK,EAAE,CAAC;QAC7B,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,SAAS;QACX,CAAC;QAED,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;QAEjE,iCAAiC;QACjC,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;YAClB,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACb,EAAE,CAAC,OAAO,CAAC,+CAA+C,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC5E,CAAC,CAAC,EAAE,CAAC;QAEL,OAAO,CAAC,GAAG,CAAC,sBAAsB,QAAQ,EAAE,CAAC,CAAC;IAChD,CAAC;AACH,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,uBAAuB;IACrC,
|
|
1
|
+
{"version":3,"file":"migrations.js","sourceRoot":"","sources":["../../src/db/migrations.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,EAAqB,EACrB,aAAqB;IAErB,oDAAoD;IACpD,EAAE,CAAC,IAAI,CAAC;;;;;GAKP,CAAC,CAAC;IAEH,iCAAiC;IACjC,MAAM,OAAO,GAAG,IAAI,GAAG,CACrB,EAAE;SACC,OAAO,CAAC,kCAAkC,CAAC;SAC3C,GAAG,EAAE;SACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAE,GAA4B,CAAC,QAAQ,CAAC,CACxD,CAAC;IAEF,sCAAsC;IACtC,MAAM,KAAK,GAAG,WAAW,CAAC,aAAa,CAAC;SACrC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACjC,IAAI,EAAE,CAAC;IAEV,2BAA2B;IAC3B,KAAK,MAAM,QAAQ,IAAI,KAAK,EAAE,CAAC;QAC7B,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,SAAS;QACX,CAAC;QAED,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC;QAEjE,iCAAiC;QACjC,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;YAClB,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACb,EAAE,CAAC,OAAO,CAAC,+CAA+C,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC5E,CAAC,CAAC,EAAE,CAAC;QAEL,OAAO,CAAC,GAAG,CAAC,sBAAsB,QAAQ,EAAE,CAAC,CAAC;IAChD,CAAC;AACH,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,uBAAuB;IACrC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClD,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAEtC,kDAAkD;IAClD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;IACvD,sDAAsD;IACtD,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;IAE1D,0BAA0B;IAC1B,IAAI,CAAC;QACH,WAAW,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,UAAU,CAAC;IACpB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC;IACjB,CAAC;AACH,CAAC"}
|
|
@@ -1,205 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Session analytics - pure functions for computing session metrics.
|
|
3
|
-
* These functions work on BaseEvent[] arrays fetched from the API.
|
|
4
|
-
* No side effects, no I/O - just computation.
|
|
5
|
-
*/
|
|
6
|
-
/**
|
|
7
|
-
* Compute session summary from events.
|
|
8
|
-
*/
|
|
9
|
-
export function computeSessionSummary(events, slowestCount = 10) {
|
|
10
|
-
const byStatus = {};
|
|
11
|
-
const byEventType = {};
|
|
12
|
-
const byToolName = {};
|
|
13
|
-
const byErrorCategory = {};
|
|
14
|
-
let successCount = 0;
|
|
15
|
-
let errorCount = 0;
|
|
16
|
-
let timeoutCount = 0;
|
|
17
|
-
let totalDurationMs = 0;
|
|
18
|
-
let durationCount = 0;
|
|
19
|
-
// Collect durations for slowest calls
|
|
20
|
-
const durations = [];
|
|
21
|
-
for (const event of events) {
|
|
22
|
-
// Count by status
|
|
23
|
-
byStatus[event.status] = (byStatus[event.status] ?? 0) + 1;
|
|
24
|
-
// Count by event type
|
|
25
|
-
byEventType[event.eventType] = (byEventType[event.eventType] ?? 0) + 1;
|
|
26
|
-
// Count by tool name
|
|
27
|
-
if (event.toolName) {
|
|
28
|
-
byToolName[event.toolName] = (byToolName[event.toolName] ?? 0) + 1;
|
|
29
|
-
}
|
|
30
|
-
// Count by error category
|
|
31
|
-
if (event.errorCategory) {
|
|
32
|
-
byErrorCategory[event.errorCategory] =
|
|
33
|
-
(byErrorCategory[event.errorCategory] ?? 0) + 1;
|
|
34
|
-
}
|
|
35
|
-
// Count success/error/timeout
|
|
36
|
-
if (event.status === "success") {
|
|
37
|
-
successCount++;
|
|
38
|
-
}
|
|
39
|
-
else if (event.status === "error") {
|
|
40
|
-
errorCount++;
|
|
41
|
-
}
|
|
42
|
-
else if (event.status === "timeout") {
|
|
43
|
-
timeoutCount++;
|
|
44
|
-
}
|
|
45
|
-
// Compute duration if both timestamps present
|
|
46
|
-
if (event.startedAt && event.endedAt) {
|
|
47
|
-
const duration = new Date(event.endedAt).getTime() - new Date(event.startedAt).getTime();
|
|
48
|
-
totalDurationMs += duration;
|
|
49
|
-
durationCount++;
|
|
50
|
-
durations.push({
|
|
51
|
-
sequence: event.sequence,
|
|
52
|
-
toolName: event.toolName,
|
|
53
|
-
durationMs: duration,
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
// Top tools by count
|
|
58
|
-
const topTools = Object.entries(byToolName)
|
|
59
|
-
.sort(([, a], [, b]) => b - a)
|
|
60
|
-
.slice(0, 5)
|
|
61
|
-
.map(([name, count]) => ({ name, count }));
|
|
62
|
-
// Top errors by count
|
|
63
|
-
const topErrors = Object.entries(byErrorCategory)
|
|
64
|
-
.sort(([, a], [, b]) => b - a)
|
|
65
|
-
.slice(0, 5)
|
|
66
|
-
.map(([category, count]) => ({
|
|
67
|
-
category: category,
|
|
68
|
-
count,
|
|
69
|
-
}));
|
|
70
|
-
// Slowest calls
|
|
71
|
-
const slowestCalls = durations
|
|
72
|
-
.sort((a, b) => b.durationMs - a.durationMs)
|
|
73
|
-
.slice(0, slowestCount);
|
|
74
|
-
return {
|
|
75
|
-
totalEvents: events.length,
|
|
76
|
-
byStatus,
|
|
77
|
-
byEventType,
|
|
78
|
-
byToolName,
|
|
79
|
-
byErrorCategory,
|
|
80
|
-
successCount,
|
|
81
|
-
errorCount,
|
|
82
|
-
timeoutCount,
|
|
83
|
-
errorRate: events.length > 0 ? (errorCount + timeoutCount) / events.length : 0,
|
|
84
|
-
avgDurationMs: durationCount > 0 ? Math.round(totalDurationMs / durationCount) : null,
|
|
85
|
-
totalDurationMs,
|
|
86
|
-
topTools,
|
|
87
|
-
topErrors,
|
|
88
|
-
slowestCalls,
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Format summary as human-readable text.
|
|
93
|
-
*/
|
|
94
|
-
export function formatSummaryText(summary) {
|
|
95
|
-
const lines = [];
|
|
96
|
-
lines.push("Session Summary");
|
|
97
|
-
lines.push("=".repeat(50));
|
|
98
|
-
lines.push(`Total Events: ${summary.totalEvents}`);
|
|
99
|
-
lines.push(`Error Rate: ${(summary.errorRate * 100).toFixed(1)}% (${summary.errorCount} errors, ${summary.timeoutCount} timeouts)`);
|
|
100
|
-
lines.push(`Avg Duration: ${summary.avgDurationMs !== null ? `${summary.avgDurationMs}ms` : "N/A"}`);
|
|
101
|
-
lines.push(`Total Duration: ${summary.totalDurationMs}ms`);
|
|
102
|
-
lines.push("");
|
|
103
|
-
// By status
|
|
104
|
-
lines.push("By Status:");
|
|
105
|
-
for (const [status, count] of Object.entries(summary.byStatus)) {
|
|
106
|
-
lines.push(` ${status}: ${count}`);
|
|
107
|
-
}
|
|
108
|
-
lines.push("");
|
|
109
|
-
// Top tools
|
|
110
|
-
if (summary.topTools.length > 0) {
|
|
111
|
-
lines.push("Top Tools:");
|
|
112
|
-
for (const { name, count } of summary.topTools) {
|
|
113
|
-
lines.push(` ${name}: ${count}`);
|
|
114
|
-
}
|
|
115
|
-
lines.push("");
|
|
116
|
-
}
|
|
117
|
-
// Error categories
|
|
118
|
-
if (summary.topErrors.length > 0) {
|
|
119
|
-
lines.push("Error Categories:");
|
|
120
|
-
for (const { category, count } of summary.topErrors) {
|
|
121
|
-
lines.push(` ${category}: ${count}`);
|
|
122
|
-
}
|
|
123
|
-
lines.push("");
|
|
124
|
-
}
|
|
125
|
-
// Slowest calls
|
|
126
|
-
if (summary.slowestCalls.length > 0) {
|
|
127
|
-
lines.push("Slowest Calls:");
|
|
128
|
-
for (const { sequence, toolName, durationMs } of summary.slowestCalls.slice(0, 5)) {
|
|
129
|
-
lines.push(` [${sequence}] ${toolName ?? "-"}: ${durationMs}ms`);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
return lines.join("\n");
|
|
133
|
-
}
|
|
134
|
-
/**
|
|
135
|
-
* Format a concise one-line safe summary (no content).
|
|
136
|
-
*/
|
|
137
|
-
export function formatConciseSummary(events, summary) {
|
|
138
|
-
const parts = [];
|
|
139
|
-
// Total events with top tools
|
|
140
|
-
const toolBreakdown = summary.topTools
|
|
141
|
-
.slice(0, 3)
|
|
142
|
-
.map((t) => `${t.name}(${t.count})`)
|
|
143
|
-
.join(", ");
|
|
144
|
-
parts.push(`${summary.totalEvents} tool calls across ${toolBreakdown}${summary.topTools.length > 3 ? "..." : ""}`);
|
|
145
|
-
// Errors
|
|
146
|
-
if (summary.errorCount > 0 || summary.timeoutCount > 0) {
|
|
147
|
-
const errorDetails = summary.topErrors
|
|
148
|
-
.map((e) => `${e.category}`)
|
|
149
|
-
.join(", ");
|
|
150
|
-
parts.push(`${summary.errorCount + summary.timeoutCount} error(s): ${errorDetails || "unknown"}`);
|
|
151
|
-
}
|
|
152
|
-
// Slowest call
|
|
153
|
-
if (summary.slowestCalls.length > 0) {
|
|
154
|
-
const slowest = summary.slowestCalls[0];
|
|
155
|
-
parts.push(`Slowest: ${slowest.toolName ?? "unknown"} (${slowest.durationMs}ms)`);
|
|
156
|
-
}
|
|
157
|
-
// Total wall time
|
|
158
|
-
if (summary.totalDurationMs > 0) {
|
|
159
|
-
const wallTime = (summary.totalDurationMs / 1000).toFixed(1);
|
|
160
|
-
parts.push(`Total time: ${wallTime}s`);
|
|
161
|
-
}
|
|
162
|
-
return parts.join("\n");
|
|
163
|
-
}
|
|
164
|
-
/**
|
|
165
|
-
* Format stats output for CLI.
|
|
166
|
-
*/
|
|
167
|
-
export function formatStatsText(summary) {
|
|
168
|
-
const lines = [];
|
|
169
|
-
lines.push("Session Statistics");
|
|
170
|
-
lines.push("=".repeat(50));
|
|
171
|
-
lines.push("");
|
|
172
|
-
// Counts by tool
|
|
173
|
-
lines.push("Tool Call Counts (sorted by frequency):");
|
|
174
|
-
const sortedTools = Object.entries(summary.byToolName).sort(([, a], [, b]) => b - a);
|
|
175
|
-
for (const [name, count] of sortedTools) {
|
|
176
|
-
lines.push(` ${name.padEnd(30)} ${count}`);
|
|
177
|
-
}
|
|
178
|
-
lines.push("");
|
|
179
|
-
// Slowest calls
|
|
180
|
-
if (summary.slowestCalls.length > 0) {
|
|
181
|
-
lines.push("Slowest Calls (top 10):");
|
|
182
|
-
for (const { sequence, toolName, durationMs } of summary.slowestCalls) {
|
|
183
|
-
lines.push(` [${String(sequence).padStart(4)}] ${(toolName ?? "-").padEnd(30)} ${durationMs}ms`);
|
|
184
|
-
}
|
|
185
|
-
lines.push("");
|
|
186
|
-
}
|
|
187
|
-
// Error counts by tool
|
|
188
|
-
if (summary.topErrors.length > 0) {
|
|
189
|
-
lines.push("Error Categories:");
|
|
190
|
-
for (const { category, count } of summary.topErrors) {
|
|
191
|
-
lines.push(` ${category.padEnd(30)} ${count}`);
|
|
192
|
-
}
|
|
193
|
-
lines.push("");
|
|
194
|
-
}
|
|
195
|
-
// Summary stats
|
|
196
|
-
lines.push("Summary:");
|
|
197
|
-
lines.push(` Total Events: ${summary.totalEvents}`);
|
|
198
|
-
lines.push(` Success: ${summary.successCount}`);
|
|
199
|
-
lines.push(` Errors: ${summary.errorCount}`);
|
|
200
|
-
lines.push(` Timeouts: ${summary.timeoutCount}`);
|
|
201
|
-
lines.push(` Avg Duration: ${summary.avgDurationMs !== null ? `${summary.avgDurationMs}ms` : "N/A"}`);
|
|
202
|
-
lines.push(` Total Duration: ${summary.totalDurationMs}ms`);
|
|
203
|
-
return lines.join("\n");
|
|
204
|
-
}
|
|
205
|
-
//# sourceMappingURL=session-analytics.js.map
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Session analytics - pure functions for computing session metrics.
|
|
3
|
-
* These functions work on BaseEvent[] arrays fetched from the API.
|
|
4
|
-
* No side effects, no I/O - just computation.
|
|
5
|
-
*/
|
|
6
|
-
import type { BaseEvent, ErrorCategory } from "@agent-recorder/core";
|
|
7
|
-
/** Session summary computed from events */
|
|
8
|
-
export interface SessionSummary {
|
|
9
|
-
totalEvents: number;
|
|
10
|
-
byStatus: Record<string, number>;
|
|
11
|
-
byEventType: Record<string, number>;
|
|
12
|
-
byToolName: Record<string, number>;
|
|
13
|
-
byErrorCategory: Record<string, number>;
|
|
14
|
-
successCount: number;
|
|
15
|
-
errorCount: number;
|
|
16
|
-
timeoutCount: number;
|
|
17
|
-
errorRate: number;
|
|
18
|
-
avgDurationMs: number | null;
|
|
19
|
-
totalDurationMs: number;
|
|
20
|
-
topTools: Array<{
|
|
21
|
-
name: string;
|
|
22
|
-
count: number;
|
|
23
|
-
}>;
|
|
24
|
-
topErrors: Array<{
|
|
25
|
-
category: ErrorCategory;
|
|
26
|
-
count: number;
|
|
27
|
-
}>;
|
|
28
|
-
slowestCalls: Array<{
|
|
29
|
-
sequence: number;
|
|
30
|
-
toolName: string | null;
|
|
31
|
-
durationMs: number;
|
|
32
|
-
}>;
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Compute session summary from events.
|
|
36
|
-
*/
|
|
37
|
-
export declare function computeSessionSummary(events: BaseEvent[], slowestCount?: number): SessionSummary;
|
|
38
|
-
/**
|
|
39
|
-
* Format summary as human-readable text.
|
|
40
|
-
*/
|
|
41
|
-
export declare function formatSummaryText(summary: SessionSummary): string;
|
|
42
|
-
/**
|
|
43
|
-
* Format a concise one-line safe summary (no content).
|
|
44
|
-
*/
|
|
45
|
-
export declare function formatConciseSummary(events: BaseEvent[], summary: SessionSummary): string;
|
|
46
|
-
/**
|
|
47
|
-
* Format stats output for CLI.
|
|
48
|
-
*/
|
|
49
|
-
export declare function formatStatsText(summary: SessionSummary): string;
|
|
50
|
-
//# sourceMappingURL=session-analytics.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session-analytics.d.ts","sourceRoot":"","sources":["../../src/analytics/session-analytics.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErE,2CAA2C;AAC3C,MAAM,WAAW,cAAc;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACjD,SAAS,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,aAAa,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC7D,YAAY,EAAE,KAAK,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC,CAAC;CACJ;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,SAAS,EAAE,EACnB,YAAY,SAAK,GAChB,cAAc,CAkGhB;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,cAAc,GAAG,MAAM,CAoDjE;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,SAAS,EAAE,EACnB,OAAO,EAAE,cAAc,GACtB,MAAM,CAqCR;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,cAAc,GAAG,MAAM,CAiD/D"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session-analytics.js","sourceRoot":"","sources":["../../src/analytics/session-analytics.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,253 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for session analytics pure functions.
|
|
3
|
-
*/
|
|
4
|
-
import { describe, it, expect } from "vitest";
|
|
5
|
-
import { computeSessionSummary, formatSummaryText, formatStatsText, formatConciseSummary, } from "./session-analytics.js";
|
|
6
|
-
/** Create a mock event for testing */
|
|
7
|
-
function mockEvent(overrides = {}) {
|
|
8
|
-
return {
|
|
9
|
-
id: "test-id",
|
|
10
|
-
sessionId: "session-1",
|
|
11
|
-
parentEventId: null,
|
|
12
|
-
sequence: 1,
|
|
13
|
-
eventType: "tool_call",
|
|
14
|
-
agentRole: "assistant",
|
|
15
|
-
agentName: "claude-code",
|
|
16
|
-
skillName: null,
|
|
17
|
-
toolName: "read_file",
|
|
18
|
-
mcpMethod: "tools/call",
|
|
19
|
-
startedAt: "2024-01-01T00:00:00.000Z",
|
|
20
|
-
endedAt: "2024-01-01T00:00:01.000Z",
|
|
21
|
-
status: "success",
|
|
22
|
-
inputJson: "{}",
|
|
23
|
-
outputJson: "{}",
|
|
24
|
-
errorCategory: null,
|
|
25
|
-
createdAt: "2024-01-01T00:00:00.000Z",
|
|
26
|
-
...overrides,
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
describe("computeSessionSummary", () => {
|
|
30
|
-
it("computes correct total events", () => {
|
|
31
|
-
const events = [
|
|
32
|
-
mockEvent({ sequence: 1 }),
|
|
33
|
-
mockEvent({ sequence: 2 }),
|
|
34
|
-
mockEvent({ sequence: 3 }),
|
|
35
|
-
];
|
|
36
|
-
const summary = computeSessionSummary(events);
|
|
37
|
-
expect(summary.totalEvents).toBe(3);
|
|
38
|
-
});
|
|
39
|
-
it("counts events by status", () => {
|
|
40
|
-
const events = [
|
|
41
|
-
mockEvent({ sequence: 1, status: "success" }),
|
|
42
|
-
mockEvent({ sequence: 2, status: "success" }),
|
|
43
|
-
mockEvent({
|
|
44
|
-
sequence: 3,
|
|
45
|
-
status: "error",
|
|
46
|
-
errorCategory: "jsonrpc_error",
|
|
47
|
-
}),
|
|
48
|
-
mockEvent({
|
|
49
|
-
sequence: 4,
|
|
50
|
-
status: "timeout",
|
|
51
|
-
errorCategory: "downstream_timeout",
|
|
52
|
-
}),
|
|
53
|
-
];
|
|
54
|
-
const summary = computeSessionSummary(events);
|
|
55
|
-
expect(summary.byStatus["success"]).toBe(2);
|
|
56
|
-
expect(summary.byStatus["error"]).toBe(1);
|
|
57
|
-
expect(summary.byStatus["timeout"]).toBe(1);
|
|
58
|
-
expect(summary.successCount).toBe(2);
|
|
59
|
-
expect(summary.errorCount).toBe(1);
|
|
60
|
-
expect(summary.timeoutCount).toBe(1);
|
|
61
|
-
});
|
|
62
|
-
it("counts events by tool name", () => {
|
|
63
|
-
const events = [
|
|
64
|
-
mockEvent({ sequence: 1, toolName: "read_file" }),
|
|
65
|
-
mockEvent({ sequence: 2, toolName: "write_file" }),
|
|
66
|
-
mockEvent({ sequence: 3, toolName: "read_file" }),
|
|
67
|
-
];
|
|
68
|
-
const summary = computeSessionSummary(events);
|
|
69
|
-
expect(summary.byToolName["read_file"]).toBe(2);
|
|
70
|
-
expect(summary.byToolName["write_file"]).toBe(1);
|
|
71
|
-
});
|
|
72
|
-
it("computes error rate correctly", () => {
|
|
73
|
-
const events = [
|
|
74
|
-
mockEvent({ sequence: 1, status: "success" }),
|
|
75
|
-
mockEvent({
|
|
76
|
-
sequence: 2,
|
|
77
|
-
status: "error",
|
|
78
|
-
errorCategory: "jsonrpc_error",
|
|
79
|
-
}),
|
|
80
|
-
mockEvent({
|
|
81
|
-
sequence: 3,
|
|
82
|
-
status: "timeout",
|
|
83
|
-
errorCategory: "downstream_timeout",
|
|
84
|
-
}),
|
|
85
|
-
mockEvent({ sequence: 4, status: "success" }),
|
|
86
|
-
];
|
|
87
|
-
const summary = computeSessionSummary(events);
|
|
88
|
-
expect(summary.errorRate).toBe(0.5); // 2 errors out of 4
|
|
89
|
-
});
|
|
90
|
-
it("computes average duration", () => {
|
|
91
|
-
const events = [
|
|
92
|
-
mockEvent({
|
|
93
|
-
sequence: 1,
|
|
94
|
-
startedAt: "2024-01-01T00:00:00.000Z",
|
|
95
|
-
endedAt: "2024-01-01T00:00:01.000Z", // 1000ms
|
|
96
|
-
}),
|
|
97
|
-
mockEvent({
|
|
98
|
-
sequence: 2,
|
|
99
|
-
startedAt: "2024-01-01T00:00:02.000Z",
|
|
100
|
-
endedAt: "2024-01-01T00:00:05.000Z", // 3000ms
|
|
101
|
-
}),
|
|
102
|
-
];
|
|
103
|
-
const summary = computeSessionSummary(events);
|
|
104
|
-
expect(summary.avgDurationMs).toBe(2000);
|
|
105
|
-
expect(summary.totalDurationMs).toBe(4000);
|
|
106
|
-
});
|
|
107
|
-
it("handles events with no end time", () => {
|
|
108
|
-
const events = [
|
|
109
|
-
mockEvent({
|
|
110
|
-
sequence: 1,
|
|
111
|
-
status: "running",
|
|
112
|
-
startedAt: "2024-01-01T00:00:00.000Z",
|
|
113
|
-
endedAt: null,
|
|
114
|
-
}),
|
|
115
|
-
];
|
|
116
|
-
const summary = computeSessionSummary(events);
|
|
117
|
-
expect(summary.avgDurationMs).toBeNull();
|
|
118
|
-
expect(summary.totalDurationMs).toBe(0);
|
|
119
|
-
});
|
|
120
|
-
it("counts error categories", () => {
|
|
121
|
-
const events = [
|
|
122
|
-
mockEvent({
|
|
123
|
-
sequence: 1,
|
|
124
|
-
status: "error",
|
|
125
|
-
errorCategory: "jsonrpc_error",
|
|
126
|
-
}),
|
|
127
|
-
mockEvent({
|
|
128
|
-
sequence: 2,
|
|
129
|
-
status: "timeout",
|
|
130
|
-
errorCategory: "downstream_timeout",
|
|
131
|
-
}),
|
|
132
|
-
mockEvent({
|
|
133
|
-
sequence: 3,
|
|
134
|
-
status: "error",
|
|
135
|
-
errorCategory: "jsonrpc_error",
|
|
136
|
-
}),
|
|
137
|
-
];
|
|
138
|
-
const summary = computeSessionSummary(events);
|
|
139
|
-
expect(summary.byErrorCategory["jsonrpc_error"]).toBe(2);
|
|
140
|
-
expect(summary.byErrorCategory["downstream_timeout"]).toBe(1);
|
|
141
|
-
});
|
|
142
|
-
it("computes top tools sorted by count", () => {
|
|
143
|
-
const events = [
|
|
144
|
-
mockEvent({ sequence: 1, toolName: "read_file" }),
|
|
145
|
-
mockEvent({ sequence: 2, toolName: "read_file" }),
|
|
146
|
-
mockEvent({ sequence: 3, toolName: "read_file" }),
|
|
147
|
-
mockEvent({ sequence: 4, toolName: "write_file" }),
|
|
148
|
-
mockEvent({ sequence: 5, toolName: "write_file" }),
|
|
149
|
-
mockEvent({ sequence: 6, toolName: "bash" }),
|
|
150
|
-
];
|
|
151
|
-
const summary = computeSessionSummary(events);
|
|
152
|
-
expect(summary.topTools).toHaveLength(3);
|
|
153
|
-
expect(summary.topTools[0]).toEqual({ name: "read_file", count: 3 });
|
|
154
|
-
expect(summary.topTools[1]).toEqual({ name: "write_file", count: 2 });
|
|
155
|
-
expect(summary.topTools[2]).toEqual({ name: "bash", count: 1 });
|
|
156
|
-
});
|
|
157
|
-
it("computes slowest calls", () => {
|
|
158
|
-
const events = [
|
|
159
|
-
mockEvent({
|
|
160
|
-
sequence: 1,
|
|
161
|
-
toolName: "fast_tool",
|
|
162
|
-
startedAt: "2024-01-01T00:00:00.000Z",
|
|
163
|
-
endedAt: "2024-01-01T00:00:00.100Z", // 100ms
|
|
164
|
-
}),
|
|
165
|
-
mockEvent({
|
|
166
|
-
sequence: 2,
|
|
167
|
-
toolName: "slow_tool",
|
|
168
|
-
startedAt: "2024-01-01T00:00:01.000Z",
|
|
169
|
-
endedAt: "2024-01-01T00:00:06.000Z", // 5000ms
|
|
170
|
-
}),
|
|
171
|
-
mockEvent({
|
|
172
|
-
sequence: 3,
|
|
173
|
-
toolName: "medium_tool",
|
|
174
|
-
startedAt: "2024-01-01T00:00:07.000Z",
|
|
175
|
-
endedAt: "2024-01-01T00:00:08.000Z", // 1000ms
|
|
176
|
-
}),
|
|
177
|
-
];
|
|
178
|
-
const summary = computeSessionSummary(events);
|
|
179
|
-
expect(summary.slowestCalls).toHaveLength(3);
|
|
180
|
-
expect(summary.slowestCalls[0]).toEqual({
|
|
181
|
-
sequence: 2,
|
|
182
|
-
toolName: "slow_tool",
|
|
183
|
-
durationMs: 5000,
|
|
184
|
-
});
|
|
185
|
-
expect(summary.slowestCalls[1]).toEqual({
|
|
186
|
-
sequence: 3,
|
|
187
|
-
toolName: "medium_tool",
|
|
188
|
-
durationMs: 1000,
|
|
189
|
-
});
|
|
190
|
-
});
|
|
191
|
-
it("handles empty events array", () => {
|
|
192
|
-
const summary = computeSessionSummary([]);
|
|
193
|
-
expect(summary.totalEvents).toBe(0);
|
|
194
|
-
expect(summary.errorRate).toBe(0);
|
|
195
|
-
expect(summary.avgDurationMs).toBeNull();
|
|
196
|
-
expect(summary.topTools).toHaveLength(0);
|
|
197
|
-
expect(summary.slowestCalls).toHaveLength(0);
|
|
198
|
-
});
|
|
199
|
-
});
|
|
200
|
-
describe("formatSummaryText", () => {
|
|
201
|
-
it("formats summary as text", () => {
|
|
202
|
-
const events = [
|
|
203
|
-
mockEvent({ sequence: 1, toolName: "read_file", status: "success" }),
|
|
204
|
-
];
|
|
205
|
-
const summary = computeSessionSummary(events);
|
|
206
|
-
const text = formatSummaryText(summary);
|
|
207
|
-
expect(text).toContain("Session Summary");
|
|
208
|
-
expect(text).toContain("Total Events: 1");
|
|
209
|
-
expect(text).toContain("read_file: 1");
|
|
210
|
-
expect(text).toContain("success: 1");
|
|
211
|
-
});
|
|
212
|
-
it("includes error categories when present", () => {
|
|
213
|
-
const events = [
|
|
214
|
-
mockEvent({
|
|
215
|
-
sequence: 1,
|
|
216
|
-
status: "error",
|
|
217
|
-
errorCategory: "jsonrpc_error",
|
|
218
|
-
}),
|
|
219
|
-
];
|
|
220
|
-
const summary = computeSessionSummary(events);
|
|
221
|
-
const text = formatSummaryText(summary);
|
|
222
|
-
expect(text).toContain("Error Categories:");
|
|
223
|
-
expect(text).toContain("jsonrpc_error: 1");
|
|
224
|
-
});
|
|
225
|
-
});
|
|
226
|
-
describe("formatStatsText", () => {
|
|
227
|
-
it("formats stats output", () => {
|
|
228
|
-
const events = [
|
|
229
|
-
mockEvent({ sequence: 1, toolName: "read_file" }),
|
|
230
|
-
mockEvent({ sequence: 2, toolName: "read_file" }),
|
|
231
|
-
];
|
|
232
|
-
const summary = computeSessionSummary(events);
|
|
233
|
-
const text = formatStatsText(summary);
|
|
234
|
-
expect(text).toContain("Session Statistics");
|
|
235
|
-
expect(text).toContain("Tool Call Counts");
|
|
236
|
-
expect(text).toContain("read_file");
|
|
237
|
-
expect(text).toContain("Summary:");
|
|
238
|
-
expect(text).toContain("Total Events:");
|
|
239
|
-
});
|
|
240
|
-
});
|
|
241
|
-
describe("formatConciseSummary", () => {
|
|
242
|
-
it("formats concise one-liner summary", () => {
|
|
243
|
-
const events = [
|
|
244
|
-
mockEvent({ sequence: 1, toolName: "read_file" }),
|
|
245
|
-
mockEvent({ sequence: 2, toolName: "write_file" }),
|
|
246
|
-
];
|
|
247
|
-
const summary = computeSessionSummary(events);
|
|
248
|
-
const text = formatConciseSummary(events, summary);
|
|
249
|
-
expect(text).toContain("2 tool calls");
|
|
250
|
-
expect(text).toContain("read_file");
|
|
251
|
-
});
|
|
252
|
-
});
|
|
253
|
-
//# sourceMappingURL=session-analytics.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session-analytics.test.d.ts","sourceRoot":"","sources":["../../src/analytics/session-analytics.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session-analytics.test.js","sourceRoot":"","sources":["../../src/analytics/session-analytics.test.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EACL,qBAAqB,EACrB,iBAAiB,EACjB,eAAe,EACf,oBAAoB,GACrB,MAAM,wBAAwB,CAAC;AAGhC,sCAAsC;AACtC,SAAS,SAAS,CAAC,YAAgC,EAAE;IACnD,OAAO;QACL,EAAE,EAAE,SAAS;QACb,SAAS,EAAE,WAAW;QACtB,aAAa,EAAE,IAAI;QACnB,QAAQ,EAAE,CAAC;QACX,SAAS,EAAE,WAAW;QACtB,SAAS,EAAE,WAAW;QACtB,SAAS,EAAE,aAAa;QACxB,SAAS,EAAE,IAAI;QACf,QAAQ,EAAE,WAAW;QACrB,SAAS,EAAE,YAAY;QACvB,SAAS,EAAE,0BAA0B;QACrC,OAAO,EAAE,0BAA0B;QACnC,MAAM,EAAE,SAAS;QACjB,SAAS,EAAE,IAAI;QACf,UAAU,EAAE,IAAI;QAChB,aAAa,EAAE,IAAI;QACnB,SAAS,EAAE,0BAA0B;QACrC,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;YAC1B,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;YAC1B,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;SAC3B,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAC7C,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAC7C,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,aAAa,EAAE,eAAe;aAC/B,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,SAAS;gBACjB,aAAa,EAAE,oBAAoB;aACpC,CAAC;SACH,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC;YAClD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;SAClD,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAC7C,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,aAAa,EAAE,eAAe;aAC/B,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,SAAS;gBACjB,aAAa,EAAE,oBAAoB;aACpC,CAAC;YACF,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SAC9C,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,oBAAoB;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,0BAA0B,EAAE,SAAS;aAC/C,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,0BAA0B,EAAE,SAAS;aAC/C,CAAC;SACH,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,SAAS;gBACjB,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,IAAI;aACd,CAAC;SACH,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,QAAQ,EAAE,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,aAAa,EAAE,eAAe;aAC/B,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,SAAS;gBACjB,aAAa,EAAE,oBAAoB;aACpC,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,aAAa,EAAE,eAAe;aAC/B,CAAC;SACH,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC;YAClD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC;YAClD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;SAC7C,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QACtE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,QAAQ,EAAE,WAAW;gBACrB,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,0BAA0B,EAAE,QAAQ;aAC9C,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,QAAQ,EAAE,WAAW;gBACrB,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,0BAA0B,EAAE,SAAS;aAC/C,CAAC;YACF,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,QAAQ,EAAE,aAAa;gBACvB,SAAS,EAAE,0BAA0B;gBACrC,OAAO,EAAE,0BAA0B,EAAE,SAAS;aAC/C,CAAC;SACH,CAAC;QAEF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YACtC,QAAQ,EAAE,CAAC;YACX,QAAQ,EAAE,WAAW;YACrB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YACtC,QAAQ,EAAE,CAAC;YACX,QAAQ,EAAE,aAAa;YACvB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,OAAO,GAAG,qBAAqB,CAAC,EAAE,CAAC,CAAC;QAE1C,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,QAAQ,EAAE,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SACrE,CAAC;QACF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAExC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QAC1C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QAC1C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,MAAM,MAAM,GAAG;YACb,SAAS,CAAC;gBACR,QAAQ,EAAE,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,aAAa,EAAE,eAAe;aAC/B,CAAC;SACH,CAAC;QACF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAExC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;QAC5C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;SAClD,CAAC;QACF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAEtC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;QAC7C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QAC3C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACpC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACnC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,MAAM,GAAG;YACb,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;YACjD,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC;SACnD,CAAC;QACF,MAAM,OAAO,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,oBAAoB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEnD,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|