oh-my-claude-sisyphus 3.4.0 ā 3.4.2
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/README.md +71 -5
- package/commands/cancel-ecomode.md +71 -0
- package/commands/cancel.md +75 -0
- package/commands/pipeline.md +231 -0
- package/commands/planner.md +174 -0
- package/commands/swarm.md +280 -0
- package/dist/analytics/cost-estimator.d.ts +14 -0
- package/dist/analytics/cost-estimator.d.ts.map +1 -0
- package/dist/analytics/cost-estimator.js +70 -0
- package/dist/analytics/cost-estimator.js.map +1 -0
- package/dist/analytics/export.d.ts +7 -0
- package/dist/analytics/export.d.ts.map +1 -0
- package/dist/analytics/export.js +93 -0
- package/dist/analytics/export.js.map +1 -0
- package/dist/analytics/index.d.ts +14 -0
- package/dist/analytics/index.d.ts.map +1 -0
- package/dist/analytics/index.js +14 -0
- package/dist/analytics/index.js.map +1 -0
- package/dist/analytics/metrics-collector.d.ts +30 -0
- package/dist/analytics/metrics-collector.d.ts.map +1 -0
- package/dist/analytics/metrics-collector.js +96 -0
- package/dist/analytics/metrics-collector.js.map +1 -0
- package/dist/analytics/query-engine.d.ts +32 -0
- package/dist/analytics/query-engine.d.ts.map +1 -0
- package/dist/analytics/query-engine.js +151 -0
- package/dist/analytics/query-engine.js.map +1 -0
- package/dist/analytics/session-manager.d.ts +26 -0
- package/dist/analytics/session-manager.d.ts.map +1 -0
- package/dist/analytics/session-manager.js +201 -0
- package/dist/analytics/session-manager.js.map +1 -0
- package/dist/analytics/session-types.d.ts +37 -0
- package/dist/analytics/session-types.d.ts.map +1 -0
- package/dist/analytics/session-types.js +2 -0
- package/dist/analytics/session-types.js.map +1 -0
- package/dist/analytics/token-tracker.d.ts +24 -0
- package/dist/analytics/token-tracker.d.ts.map +1 -0
- package/dist/analytics/token-tracker.js +161 -0
- package/dist/analytics/token-tracker.js.map +1 -0
- package/dist/analytics/types.d.ts +37 -0
- package/dist/analytics/types.d.ts.map +1 -0
- package/dist/analytics/types.js +21 -0
- package/dist/analytics/types.js.map +1 -0
- package/dist/cli/analytics.d.ts +3 -0
- package/dist/cli/analytics.d.ts.map +1 -0
- package/dist/cli/analytics.js +74 -0
- package/dist/cli/analytics.js.map +1 -0
- package/dist/cli/commands/agents.d.ts +5 -0
- package/dist/cli/commands/agents.d.ts.map +1 -0
- package/dist/cli/commands/agents.js +29 -0
- package/dist/cli/commands/agents.js.map +1 -0
- package/dist/cli/commands/cleanup.d.ts +4 -0
- package/dist/cli/commands/cleanup.d.ts.map +1 -0
- package/dist/cli/commands/cleanup.js +17 -0
- package/dist/cli/commands/cleanup.js.map +1 -0
- package/dist/cli/commands/cost.d.ts +4 -0
- package/dist/cli/commands/cost.d.ts.map +1 -0
- package/dist/cli/commands/cost.js +53 -0
- package/dist/cli/commands/cost.js.map +1 -0
- package/dist/cli/commands/export.d.ts +5 -0
- package/dist/cli/commands/export.d.ts.map +1 -0
- package/dist/cli/commands/export.js +30 -0
- package/dist/cli/commands/export.js.map +1 -0
- package/dist/cli/commands/sessions.d.ts +5 -0
- package/dist/cli/commands/sessions.d.ts.map +1 -0
- package/dist/cli/commands/sessions.js +37 -0
- package/dist/cli/commands/sessions.js.map +1 -0
- package/dist/cli/commands/stats.d.ts +4 -0
- package/dist/cli/commands/stats.d.ts.map +1 -0
- package/dist/cli/commands/stats.js +43 -0
- package/dist/cli/commands/stats.js.map +1 -0
- package/dist/cli/utils/formatting.d.ts +22 -0
- package/dist/cli/utils/formatting.d.ts.map +1 -0
- package/dist/cli/utils/formatting.js +70 -0
- package/dist/cli/utils/formatting.js.map +1 -0
- package/dist/hud/analytics-display.d.ts +28 -0
- package/dist/hud/analytics-display.d.ts.map +1 -0
- package/dist/hud/analytics-display.js +105 -0
- package/dist/hud/analytics-display.js.map +1 -0
- package/dist/hud/background-cleanup.d.ts +28 -0
- package/dist/hud/background-cleanup.d.ts.map +1 -0
- package/dist/hud/background-cleanup.js +92 -0
- package/dist/hud/background-cleanup.js.map +1 -0
- package/dist/hud/index.js +4 -2
- package/dist/hud/index.js.map +1 -1
- package/dist/hud/render.d.ts +1 -1
- package/dist/hud/render.d.ts.map +1 -1
- package/dist/hud/render.js +32 -1
- package/dist/hud/render.js.map +1 -1
- package/dist/hud/state.d.ts +5 -0
- package/dist/hud/state.d.ts.map +1 -1
- package/dist/hud/state.js +13 -0
- package/dist/hud/state.js.map +1 -1
- package/dist/hud/types.d.ts +11 -1
- package/dist/hud/types.d.ts.map +1 -1
- package/dist/hud/types.js +19 -0
- package/dist/hud/types.js.map +1 -1
- package/docs/FULL-README.md +130 -16
- package/docs/MIGRATION.md +222 -1
- package/docs/SYNC-SYSTEM.md +528 -0
- package/package.json +8 -2
- package/scripts/sync-metadata.ts +363 -0
- package/skills/build-fix/SKILL.md +123 -0
- package/skills/code-review/SKILL.md +179 -0
- package/skills/security-review/SKILL.md +254 -0
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { readState, writeState, StateLocation } from '../features/state-manager/index.js';
|
|
2
|
+
import * as fs from 'fs/promises';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
const TOKEN_LOG_FILE = '.omc/state/token-tracking.jsonl';
|
|
5
|
+
const SESSION_STATS_FILE = '.omc/state/session-token-stats.json';
|
|
6
|
+
export class TokenTracker {
|
|
7
|
+
currentSessionId;
|
|
8
|
+
sessionStats;
|
|
9
|
+
constructor(sessionId) {
|
|
10
|
+
this.currentSessionId = sessionId || this.generateSessionId();
|
|
11
|
+
this.sessionStats = this.initializeSessionStats();
|
|
12
|
+
}
|
|
13
|
+
generateSessionId() {
|
|
14
|
+
return `session-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
15
|
+
}
|
|
16
|
+
initializeSessionStats() {
|
|
17
|
+
return {
|
|
18
|
+
sessionId: this.currentSessionId,
|
|
19
|
+
totalInputTokens: 0,
|
|
20
|
+
totalOutputTokens: 0,
|
|
21
|
+
totalCacheCreation: 0,
|
|
22
|
+
totalCacheRead: 0,
|
|
23
|
+
totalCost: 0,
|
|
24
|
+
byAgent: {},
|
|
25
|
+
byModel: {},
|
|
26
|
+
startTime: new Date().toISOString(),
|
|
27
|
+
lastUpdate: new Date().toISOString()
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
async recordTokenUsage(usage) {
|
|
31
|
+
const record = {
|
|
32
|
+
...usage,
|
|
33
|
+
sessionId: this.currentSessionId,
|
|
34
|
+
timestamp: new Date().toISOString()
|
|
35
|
+
};
|
|
36
|
+
// Append to JSONL log (append-only for performance)
|
|
37
|
+
await this.appendToLog(record);
|
|
38
|
+
// Update session stats
|
|
39
|
+
this.updateSessionStats(record);
|
|
40
|
+
// Persist session stats
|
|
41
|
+
await this.saveSessionStats();
|
|
42
|
+
}
|
|
43
|
+
async appendToLog(record) {
|
|
44
|
+
const logPath = path.resolve(process.cwd(), TOKEN_LOG_FILE);
|
|
45
|
+
const logDir = path.dirname(logPath);
|
|
46
|
+
await fs.mkdir(logDir, { recursive: true });
|
|
47
|
+
await fs.appendFile(logPath, JSON.stringify(record) + '\n', 'utf-8');
|
|
48
|
+
}
|
|
49
|
+
updateSessionStats(record) {
|
|
50
|
+
this.sessionStats.totalInputTokens += record.inputTokens;
|
|
51
|
+
this.sessionStats.totalOutputTokens += record.outputTokens;
|
|
52
|
+
this.sessionStats.totalCacheCreation += record.cacheCreationTokens;
|
|
53
|
+
this.sessionStats.totalCacheRead += record.cacheReadTokens;
|
|
54
|
+
this.sessionStats.lastUpdate = record.timestamp;
|
|
55
|
+
// Group by agent
|
|
56
|
+
if (record.agentName) {
|
|
57
|
+
if (!this.sessionStats.byAgent[record.agentName]) {
|
|
58
|
+
this.sessionStats.byAgent[record.agentName] = [];
|
|
59
|
+
}
|
|
60
|
+
this.sessionStats.byAgent[record.agentName].push(record);
|
|
61
|
+
}
|
|
62
|
+
// Group by model
|
|
63
|
+
if (!this.sessionStats.byModel[record.modelName]) {
|
|
64
|
+
this.sessionStats.byModel[record.modelName] = [];
|
|
65
|
+
}
|
|
66
|
+
this.sessionStats.byModel[record.modelName].push(record);
|
|
67
|
+
}
|
|
68
|
+
async saveSessionStats() {
|
|
69
|
+
writeState('session-token-stats', this.sessionStats, StateLocation.LOCAL);
|
|
70
|
+
}
|
|
71
|
+
async loadSessionStats(sessionId) {
|
|
72
|
+
const sid = sessionId || this.currentSessionId;
|
|
73
|
+
// Try to load from state
|
|
74
|
+
const result = readState('session-token-stats', StateLocation.LOCAL);
|
|
75
|
+
if (result.exists && result.data && result.data.sessionId === sid) {
|
|
76
|
+
this.sessionStats = result.data;
|
|
77
|
+
return result.data;
|
|
78
|
+
}
|
|
79
|
+
// Rebuild from JSONL log if needed
|
|
80
|
+
return this.rebuildStatsFromLog(sid);
|
|
81
|
+
}
|
|
82
|
+
async rebuildStatsFromLog(sessionId) {
|
|
83
|
+
const logPath = path.resolve(process.cwd(), TOKEN_LOG_FILE);
|
|
84
|
+
try {
|
|
85
|
+
const content = await fs.readFile(logPath, 'utf-8');
|
|
86
|
+
const lines = content.trim().split('\n');
|
|
87
|
+
const stats = this.initializeSessionStats();
|
|
88
|
+
stats.sessionId = sessionId;
|
|
89
|
+
for (const line of lines) {
|
|
90
|
+
const record = JSON.parse(line);
|
|
91
|
+
if (record.sessionId === sessionId) {
|
|
92
|
+
this.updateSessionStats(record);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return stats.totalInputTokens > 0 ? stats : null;
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
getSessionStats() {
|
|
102
|
+
return { ...this.sessionStats };
|
|
103
|
+
}
|
|
104
|
+
async getTopAgents(limit = 5) {
|
|
105
|
+
const { calculateCost } = await import('./cost-estimator.js');
|
|
106
|
+
const agentStats = Object.entries(this.sessionStats.byAgent).map(([agent, usages]) => {
|
|
107
|
+
const totalTokens = usages.reduce((sum, u) => sum + u.inputTokens + u.outputTokens, 0);
|
|
108
|
+
const totalCost = usages.reduce((sum, u) => {
|
|
109
|
+
const cost = calculateCost({
|
|
110
|
+
modelName: u.modelName,
|
|
111
|
+
inputTokens: u.inputTokens,
|
|
112
|
+
outputTokens: u.outputTokens,
|
|
113
|
+
cacheCreationTokens: u.cacheCreationTokens,
|
|
114
|
+
cacheReadTokens: u.cacheReadTokens
|
|
115
|
+
});
|
|
116
|
+
return sum + cost.totalCost;
|
|
117
|
+
}, 0);
|
|
118
|
+
return { agent, tokens: totalTokens, cost: totalCost };
|
|
119
|
+
});
|
|
120
|
+
return agentStats.sort((a, b) => b.cost - a.cost).slice(0, limit);
|
|
121
|
+
}
|
|
122
|
+
async cleanupOldLogs(retentionDays = 30) {
|
|
123
|
+
const logPath = path.resolve(process.cwd(), TOKEN_LOG_FILE);
|
|
124
|
+
const cutoffDate = new Date();
|
|
125
|
+
cutoffDate.setDate(cutoffDate.getDate() - retentionDays);
|
|
126
|
+
try {
|
|
127
|
+
const content = await fs.readFile(logPath, 'utf-8');
|
|
128
|
+
const lines = content.trim().split('\n');
|
|
129
|
+
let kept = 0;
|
|
130
|
+
let removed = 0;
|
|
131
|
+
const filteredLines = lines.filter(line => {
|
|
132
|
+
const record = JSON.parse(line);
|
|
133
|
+
const recordDate = new Date(record.timestamp);
|
|
134
|
+
if (recordDate >= cutoffDate) {
|
|
135
|
+
kept++;
|
|
136
|
+
return true;
|
|
137
|
+
}
|
|
138
|
+
removed++;
|
|
139
|
+
return false;
|
|
140
|
+
});
|
|
141
|
+
await fs.writeFile(logPath, filteredLines.join('\n') + '\n', 'utf-8');
|
|
142
|
+
return removed;
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
return 0;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
// Singleton instance for current session
|
|
150
|
+
let globalTracker = null;
|
|
151
|
+
export function getTokenTracker(sessionId) {
|
|
152
|
+
if (!globalTracker) {
|
|
153
|
+
globalTracker = new TokenTracker(sessionId);
|
|
154
|
+
}
|
|
155
|
+
return globalTracker;
|
|
156
|
+
}
|
|
157
|
+
export function resetTokenTracker(sessionId) {
|
|
158
|
+
globalTracker = new TokenTracker(sessionId);
|
|
159
|
+
return globalTracker;
|
|
160
|
+
}
|
|
161
|
+
//# sourceMappingURL=token-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-tracker.js","sourceRoot":"","sources":["../../src/analytics/token-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export interface TokenUsage {
|
|
2
|
+
timestamp: string;
|
|
3
|
+
sessionId: string;
|
|
4
|
+
agentName?: string;
|
|
5
|
+
modelName: string;
|
|
6
|
+
inputTokens: number;
|
|
7
|
+
outputTokens: number;
|
|
8
|
+
cacheCreationTokens: number;
|
|
9
|
+
cacheReadTokens: number;
|
|
10
|
+
}
|
|
11
|
+
export interface CostBreakdown {
|
|
12
|
+
inputCost: number;
|
|
13
|
+
outputCost: number;
|
|
14
|
+
cacheWriteCost: number;
|
|
15
|
+
cacheReadCost: number;
|
|
16
|
+
totalCost: number;
|
|
17
|
+
}
|
|
18
|
+
export interface SessionTokenStats {
|
|
19
|
+
sessionId: string;
|
|
20
|
+
totalInputTokens: number;
|
|
21
|
+
totalOutputTokens: number;
|
|
22
|
+
totalCacheCreation: number;
|
|
23
|
+
totalCacheRead: number;
|
|
24
|
+
totalCost: number;
|
|
25
|
+
byAgent: Record<string, TokenUsage[]>;
|
|
26
|
+
byModel: Record<string, TokenUsage[]>;
|
|
27
|
+
startTime: string;
|
|
28
|
+
lastUpdate: string;
|
|
29
|
+
}
|
|
30
|
+
export interface ModelPricing {
|
|
31
|
+
inputPerMillion: number;
|
|
32
|
+
outputPerMillion: number;
|
|
33
|
+
cacheWriteMarkup: number;
|
|
34
|
+
cacheReadDiscount: number;
|
|
35
|
+
}
|
|
36
|
+
export declare const PRICING: Record<string, ModelPricing>;
|
|
37
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/analytics/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,iBAAiB;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IACtC,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAmBhD,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export const PRICING = {
|
|
2
|
+
'claude-haiku-4': {
|
|
3
|
+
inputPerMillion: 0.80,
|
|
4
|
+
outputPerMillion: 4.00,
|
|
5
|
+
cacheWriteMarkup: 0.25,
|
|
6
|
+
cacheReadDiscount: 0.90
|
|
7
|
+
},
|
|
8
|
+
'claude-sonnet-4.5': {
|
|
9
|
+
inputPerMillion: 3.00,
|
|
10
|
+
outputPerMillion: 15.00,
|
|
11
|
+
cacheWriteMarkup: 0.25,
|
|
12
|
+
cacheReadDiscount: 0.90
|
|
13
|
+
},
|
|
14
|
+
'claude-opus-4.5': {
|
|
15
|
+
inputPerMillion: 15.00,
|
|
16
|
+
outputPerMillion: 75.00,
|
|
17
|
+
cacheWriteMarkup: 0.25,
|
|
18
|
+
cacheReadDiscount: 0.90
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/analytics/types.ts"],"names":[],"mappings":"AAuCA,MAAM,CAAC,MAAM,OAAO,GAAiC;IACnD,gBAAgB,EAAE;QAChB,eAAe,EAAE,IAAI;QACrB,gBAAgB,EAAE,IAAI;QACtB,gBAAgB,EAAE,IAAI;QACtB,iBAAiB,EAAE,IAAI;KACxB;IACD,mBAAmB,EAAE;QACnB,eAAe,EAAE,IAAI;QACrB,gBAAgB,EAAE,KAAK;QACvB,gBAAgB,EAAE,IAAI;QACtB,iBAAiB,EAAE,IAAI;KACxB;IACD,iBAAiB,EAAE;QACjB,eAAe,EAAE,KAAK;QACtB,gBAAgB,EAAE,KAAK;QACvB,gBAAgB,EAAE,IAAI;QACtB,iBAAiB,EAAE,IAAI;KACxB;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analytics.d.ts","sourceRoot":"","sources":["../../src/cli/analytics.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { program } from 'commander';
|
|
3
|
+
import { statsCommand } from './commands/stats.js';
|
|
4
|
+
import { costCommand } from './commands/cost.js';
|
|
5
|
+
import { sessionsCommand } from './commands/sessions.js';
|
|
6
|
+
import { agentsCommand } from './commands/agents.js';
|
|
7
|
+
import { exportCommand } from './commands/export.js';
|
|
8
|
+
import { cleanupCommand } from './commands/cleanup.js';
|
|
9
|
+
program
|
|
10
|
+
.name('omc-analytics')
|
|
11
|
+
.description('OMC Analytics CLI - Token tracking, cost reports, and session management')
|
|
12
|
+
.version('1.0.0');
|
|
13
|
+
// Stats command
|
|
14
|
+
program
|
|
15
|
+
.command('stats')
|
|
16
|
+
.description('Show current session statistics')
|
|
17
|
+
.option('--json', 'Output as JSON')
|
|
18
|
+
.action(statsCommand);
|
|
19
|
+
// Cost command
|
|
20
|
+
program
|
|
21
|
+
.command('cost [period]')
|
|
22
|
+
.description('Generate cost report (period: daily, weekly, monthly)')
|
|
23
|
+
.option('--json', 'Output as JSON')
|
|
24
|
+
.action((period = 'monthly', options) => {
|
|
25
|
+
if (!['daily', 'weekly', 'monthly'].includes(period)) {
|
|
26
|
+
console.error('Invalid period. Use: daily, weekly, or monthly');
|
|
27
|
+
process.exit(1);
|
|
28
|
+
}
|
|
29
|
+
costCommand(period, options);
|
|
30
|
+
});
|
|
31
|
+
// Sessions command
|
|
32
|
+
program
|
|
33
|
+
.command('sessions')
|
|
34
|
+
.description('View session history')
|
|
35
|
+
.option('--json', 'Output as JSON')
|
|
36
|
+
.option('--limit <number>', 'Limit number of sessions', '10')
|
|
37
|
+
.action(options => {
|
|
38
|
+
sessionsCommand({ ...options, limit: parseInt(options.limit) });
|
|
39
|
+
});
|
|
40
|
+
// Agents command
|
|
41
|
+
program
|
|
42
|
+
.command('agents')
|
|
43
|
+
.description('Show agent usage breakdown')
|
|
44
|
+
.option('--json', 'Output as JSON')
|
|
45
|
+
.option('--limit <number>', 'Limit number of agents', '10')
|
|
46
|
+
.action(options => {
|
|
47
|
+
agentsCommand({ ...options, limit: parseInt(options.limit) });
|
|
48
|
+
});
|
|
49
|
+
// Export command
|
|
50
|
+
program
|
|
51
|
+
.command('export <type> <format> <output>')
|
|
52
|
+
.description('Export data (type: cost, sessions, patterns; format: json, csv)')
|
|
53
|
+
.option('--period <period>', 'Period for cost report (daily, weekly, monthly)', 'monthly')
|
|
54
|
+
.action((type, format, output, options) => {
|
|
55
|
+
if (!['cost', 'sessions', 'patterns'].includes(type)) {
|
|
56
|
+
console.error('Invalid type. Use: cost, sessions, or patterns');
|
|
57
|
+
process.exit(1);
|
|
58
|
+
}
|
|
59
|
+
if (!['json', 'csv'].includes(format)) {
|
|
60
|
+
console.error('Invalid format. Use: json or csv');
|
|
61
|
+
process.exit(1);
|
|
62
|
+
}
|
|
63
|
+
exportCommand(type, format, output, options);
|
|
64
|
+
});
|
|
65
|
+
// Cleanup command
|
|
66
|
+
program
|
|
67
|
+
.command('cleanup')
|
|
68
|
+
.description('Clean up old logs and orphaned background tasks')
|
|
69
|
+
.option('--retention <days>', 'Retention period in days', '30')
|
|
70
|
+
.action(options => {
|
|
71
|
+
cleanupCommand({ ...options, retention: parseInt(options.retention) });
|
|
72
|
+
});
|
|
73
|
+
program.parse();
|
|
74
|
+
//# sourceMappingURL=analytics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analytics.js","sourceRoot":"","sources":["../../src/cli/analytics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/agents.ts"],"names":[],"mappings":"AAGA,wBAAsB,aAAa,CAAC,OAAO,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA+B9F"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { getTokenTracker } from '../../analytics/token-tracker.js';
|
|
2
|
+
import { colors, renderTable, formatCostWithColor, formatTokenCount } from '../utils/formatting.js';
|
|
3
|
+
export async function agentsCommand(options) {
|
|
4
|
+
const tracker = getTokenTracker();
|
|
5
|
+
const stats = tracker.getSessionStats();
|
|
6
|
+
const topAgents = await tracker.getTopAgents(options.limit || 10);
|
|
7
|
+
if (options.json) {
|
|
8
|
+
console.log(JSON.stringify({ topAgents, stats }, null, 2));
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
console.log(colors.bold('\nš¤ Agent Usage Breakdown\n'));
|
|
12
|
+
if (topAgents.length === 0) {
|
|
13
|
+
console.log(colors.gray('No agent usage recorded yet.\n'));
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const agentData = topAgents.map(agent => ({
|
|
17
|
+
agent: agent.agent,
|
|
18
|
+
tokens: formatTokenCount(agent.tokens),
|
|
19
|
+
cost: agent.cost
|
|
20
|
+
}));
|
|
21
|
+
const table = renderTable(agentData, [
|
|
22
|
+
{ header: 'Agent', field: 'agent', width: 35 },
|
|
23
|
+
{ header: 'Tokens', field: 'tokens', width: 12, align: 'right' },
|
|
24
|
+
{ header: 'Cost', field: 'cost', width: 12, align: 'right', format: (v) => formatCostWithColor(v) }
|
|
25
|
+
]);
|
|
26
|
+
console.log(table);
|
|
27
|
+
console.log('');
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=agents.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents.js","sourceRoot":"","sources":["../../../src/cli/commands/agents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAEpG,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAA2C;IAC7E,MAAM,OAAO,GAAG,eAAe,EAAE,CAAC;IAClC,MAAM,KAAK,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;IACxC,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IAElE,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC,CAAC;IAEzD,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC,CAAC;QAC3D,OAAO;IACT,CAAC;IAED,MAAM,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACxC,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,MAAM,EAAE,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC;QACtC,IAAI,EAAE,KAAK,CAAC,IAAI;KACjB,CAAC,CAAC,CAAC;IAEJ,MAAM,KAAK,GAAG,WAAW,CAAC,SAAS,EAAE;QACnC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE;QAC9C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE;QAChE,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;KAC5G,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACnB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanup.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/cleanup.ts"],"names":[],"mappings":"AAIA,wBAAsB,cAAc,CAAC,OAAO,EAAE;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAgBnF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { getQueryEngine } from '../../analytics/query-engine.js';
|
|
2
|
+
import { cleanupStaleBackgroundTasks } from '../../hud/background-cleanup.js';
|
|
3
|
+
import { colors } from '../utils/formatting.js';
|
|
4
|
+
export async function cleanupCommand(options) {
|
|
5
|
+
console.log(colors.bold('\nš§¹ Running Cleanup...\n'));
|
|
6
|
+
const retentionDays = options.retention || 30;
|
|
7
|
+
// Clean old token logs
|
|
8
|
+
const engine = getQueryEngine();
|
|
9
|
+
const { removedTokens, removedMetrics } = await engine.cleanupOldData(retentionDays);
|
|
10
|
+
// Clean stale background tasks
|
|
11
|
+
const removedTasks = await cleanupStaleBackgroundTasks();
|
|
12
|
+
console.log(`Removed ${removedTokens} old token logs (older than ${retentionDays} days)`);
|
|
13
|
+
console.log(`Removed ${removedMetrics} old metric events`);
|
|
14
|
+
console.log(`Removed ${removedTasks} stale background tasks`);
|
|
15
|
+
console.log(colors.green('\nā Cleanup complete\n'));
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=cleanup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanup.js","sourceRoot":"","sources":["../../../src/cli/commands/cleanup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,2BAA2B,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAA+B;IAClE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC;IAEtD,MAAM,aAAa,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;IAE9C,uBAAuB;IACvB,MAAM,MAAM,GAAG,cAAc,EAAE,CAAC;IAChC,MAAM,EAAE,aAAa,EAAE,cAAc,EAAE,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;IAErF,+BAA+B;IAC/B,MAAM,YAAY,GAAG,MAAM,2BAA2B,EAAE,CAAC;IAEzD,OAAO,CAAC,GAAG,CAAC,WAAW,aAAa,+BAA+B,aAAa,QAAQ,CAAC,CAAC;IAC1F,OAAO,CAAC,GAAG,CAAC,WAAW,cAAc,oBAAoB,CAAC,CAAC;IAC3D,OAAO,CAAC,GAAG,CAAC,WAAW,YAAY,yBAAyB,CAAC,CAAC;IAC9D,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,CAAC;AACtD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/cost.ts"],"names":[],"mappings":"AAGA,wBAAsB,WAAW,CAAC,MAAM,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS,EAAE,OAAO,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA4DpH"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getQueryEngine } from '../../analytics/query-engine.js';
|
|
2
|
+
import { colors, renderTable, formatCostWithColor } from '../utils/formatting.js';
|
|
3
|
+
export async function costCommand(period, options) {
|
|
4
|
+
const engine = getQueryEngine();
|
|
5
|
+
const report = await engine.getCostReport(period);
|
|
6
|
+
if (options.json) {
|
|
7
|
+
console.log(JSON.stringify(report, null, 2));
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
console.log(colors.bold(`\nšµ Cost Report (${period})\n`));
|
|
11
|
+
console.log(`Period: ${report.range.start.split('T')[0]} to ${report.range.end.split('T')[0]}`);
|
|
12
|
+
console.log(`Total Cost: ${formatCostWithColor(report.totalCost)}\n`);
|
|
13
|
+
// By agent
|
|
14
|
+
if (Object.keys(report.byAgent).length > 0) {
|
|
15
|
+
console.log(colors.bold('By Agent:'));
|
|
16
|
+
const agentData = Object.entries(report.byAgent)
|
|
17
|
+
.map(([agent, cost]) => ({ agent, cost }))
|
|
18
|
+
.sort((a, b) => b.cost - a.cost);
|
|
19
|
+
const agentTable = renderTable(agentData, [
|
|
20
|
+
{ header: 'Agent', field: 'agent', width: 30 },
|
|
21
|
+
{ header: 'Cost', field: 'cost', width: 12, align: 'right', format: (v) => formatCostWithColor(v) }
|
|
22
|
+
]);
|
|
23
|
+
console.log(agentTable);
|
|
24
|
+
console.log('');
|
|
25
|
+
}
|
|
26
|
+
// By model
|
|
27
|
+
if (Object.keys(report.byModel).length > 0) {
|
|
28
|
+
console.log(colors.bold('By Model:'));
|
|
29
|
+
const modelData = Object.entries(report.byModel)
|
|
30
|
+
.map(([model, cost]) => ({ model, cost }))
|
|
31
|
+
.sort((a, b) => b.cost - a.cost);
|
|
32
|
+
const modelTable = renderTable(modelData, [
|
|
33
|
+
{ header: 'Model', field: 'model', width: 30 },
|
|
34
|
+
{ header: 'Cost', field: 'cost', width: 12, align: 'right', format: (v) => formatCostWithColor(v) }
|
|
35
|
+
]);
|
|
36
|
+
console.log(modelTable);
|
|
37
|
+
console.log('');
|
|
38
|
+
}
|
|
39
|
+
// By day (for weekly/monthly)
|
|
40
|
+
if (report.byDay && Object.keys(report.byDay).length > 0 && period !== 'daily') {
|
|
41
|
+
console.log(colors.bold('By Day:'));
|
|
42
|
+
const dayData = Object.entries(report.byDay)
|
|
43
|
+
.map(([day, cost]) => ({ day, cost }))
|
|
44
|
+
.sort((a, b) => a.day.localeCompare(b.day));
|
|
45
|
+
const dayTable = renderTable(dayData, [
|
|
46
|
+
{ header: 'Date', field: 'day', width: 12 },
|
|
47
|
+
{ header: 'Cost', field: 'cost', width: 12, align: 'right', format: (v) => formatCostWithColor(v) }
|
|
48
|
+
]);
|
|
49
|
+
console.log(dayTable);
|
|
50
|
+
console.log('');
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=cost.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.js","sourceRoot":"","sources":["../../../src/cli/commands/cost.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAElF,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,MAAsC,EAAE,OAA2B;IACnG,MAAM,MAAM,GAAG,cAAc,EAAE,CAAC;IAChC,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IAElD,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,MAAM,KAAK,CAAC,CAAC,CAAC;IAC3D,OAAO,CAAC,GAAG,CAAC,WAAW,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAChG,OAAO,CAAC,GAAG,CAAC,eAAe,mBAAmB,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAEtE,WAAW;IACX,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QACtC,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC;aAC7C,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;aACzC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;QAEnC,MAAM,UAAU,GAAG,WAAW,CAAC,SAAS,EAAE;YACxC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE;YAC9C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;SAC5G,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAED,WAAW;IACX,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QACtC,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC;aAC7C,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;aACzC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;QAEnC,MAAM,UAAU,GAAG,WAAW,CAAC,SAAS,EAAE;YACxC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE;YAC9C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;SAC5G,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAED,8BAA8B;IAC9B,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;QAC/E,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;QACpC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;aACzC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;aACrC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAE9C,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,EAAE;YACpC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE;YAC3C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;SAC5G,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ExportFormat } from '../../analytics/export.js';
|
|
2
|
+
export declare function exportCommand(type: 'cost' | 'sessions' | 'patterns', format: ExportFormat, outputPath: string, options: {
|
|
3
|
+
period?: 'daily' | 'weekly' | 'monthly';
|
|
4
|
+
}): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=export.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/export.ts"],"names":[],"mappings":"AAEA,OAAO,EAA+D,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGtH,wBAAsB,aAAa,CACjC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,UAAU,EACtC,MAAM,EAAE,YAAY,EACpB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE;IAAE,MAAM,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS,CAAA;CAAE,GACnD,OAAO,CAAC,IAAI,CAAC,CAwBf"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { getQueryEngine } from '../../analytics/query-engine.js';
|
|
2
|
+
import { getSessionManager } from '../../analytics/session-manager.js';
|
|
3
|
+
import { exportCostReport, exportSessionHistory, exportUsagePatterns } from '../../analytics/export.js';
|
|
4
|
+
import { colors } from '../utils/formatting.js';
|
|
5
|
+
export async function exportCommand(type, format, outputPath, options) {
|
|
6
|
+
const engine = getQueryEngine();
|
|
7
|
+
const manager = getSessionManager();
|
|
8
|
+
console.log(colors.bold(`\nš¤ Exporting ${type} data to ${format.toUpperCase()}...\n`));
|
|
9
|
+
try {
|
|
10
|
+
if (type === 'cost') {
|
|
11
|
+
const period = options.period || 'monthly';
|
|
12
|
+
const report = await engine.getCostReport(period);
|
|
13
|
+
await exportCostReport(report, format, outputPath);
|
|
14
|
+
}
|
|
15
|
+
else if (type === 'sessions') {
|
|
16
|
+
const history = await manager.getHistory();
|
|
17
|
+
await exportSessionHistory(history, format, outputPath);
|
|
18
|
+
}
|
|
19
|
+
else if (type === 'patterns') {
|
|
20
|
+
const patterns = await engine.getUsagePatterns();
|
|
21
|
+
await exportUsagePatterns(patterns, format, outputPath);
|
|
22
|
+
}
|
|
23
|
+
console.log(colors.green(`ā Exported to ${outputPath}\n`));
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
console.error(colors.red(`ā Export failed: ${error.message}\n`));
|
|
27
|
+
process.exit(1);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=export.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../../src/cli/commands/export.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,mBAAmB,EAAgB,MAAM,2BAA2B,CAAC;AACtH,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,IAAsC,EACtC,MAAoB,EACpB,UAAkB,EAClB,OAAoD;IAEpD,MAAM,MAAM,GAAG,cAAc,EAAE,CAAC;IAChC,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;IAEpC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,IAAI,YAAY,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;IAExF,IAAI,CAAC;QACH,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,SAAS,CAAC;YAC3C,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAClD,MAAM,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QACrD,CAAC;aAAM,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;YAC/B,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;YAC3C,MAAM,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC1D,CAAC;aAAM,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;YAC/B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACjD,MAAM,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,UAAU,IAAI,CAAC,CAAC,CAAC;IAC7D,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,oBAAqB,KAAe,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC;QAC5E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/sessions.ts"],"names":[],"mappings":"AAGA,wBAAsB,eAAe,CAAC,OAAO,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAwChG"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { getSessionManager } from '../../analytics/session-manager.js';
|
|
2
|
+
import { colors, renderTable, formatDuration } from '../utils/formatting.js';
|
|
3
|
+
export async function sessionsCommand(options) {
|
|
4
|
+
const manager = getSessionManager();
|
|
5
|
+
const history = await manager.getHistory();
|
|
6
|
+
if (options.json) {
|
|
7
|
+
console.log(JSON.stringify(history, null, 2));
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
console.log(colors.bold('\nš Session History\n'));
|
|
11
|
+
console.log(`Total Sessions: ${history.totalSessions}`);
|
|
12
|
+
console.log(`Total Cost: ${colors.cyan(`$${history.totalCost.toFixed(4)}`)}`);
|
|
13
|
+
console.log(`Success Rate: ${(history.successRate * 100).toFixed(1)}%\n`);
|
|
14
|
+
const limit = options.limit || 10;
|
|
15
|
+
const sessions = history.sessions.slice(-limit).reverse();
|
|
16
|
+
if (sessions.length === 0) {
|
|
17
|
+
console.log(colors.gray('No sessions recorded yet.\n'));
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const sessionData = sessions.map(session => ({
|
|
21
|
+
id: session.id.slice(-8),
|
|
22
|
+
startTime: session.startTime.split('T')[0],
|
|
23
|
+
duration: session.duration ? formatDuration(session.duration) : 'ongoing',
|
|
24
|
+
status: session.status,
|
|
25
|
+
tags: session.tags.join(',')
|
|
26
|
+
}));
|
|
27
|
+
const table = renderTable(sessionData, [
|
|
28
|
+
{ header: 'ID', field: 'id', width: 10 },
|
|
29
|
+
{ header: 'Date', field: 'startTime', width: 12 },
|
|
30
|
+
{ header: 'Duration', field: 'duration', width: 12 },
|
|
31
|
+
{ header: 'Status', field: 'status', width: 12 },
|
|
32
|
+
{ header: 'Tags', field: 'tags', width: 25 }
|
|
33
|
+
]);
|
|
34
|
+
console.log(table);
|
|
35
|
+
console.log('');
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../../src/cli/commands/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAE7E,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAA2C;IAC/E,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;IACpC,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;IAE3C,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;IACnD,OAAO,CAAC,GAAG,CAAC,mBAAmB,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IACxD,OAAO,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC9E,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,OAAO,CAAC,WAAW,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAE1E,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;IAClC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;IAE1D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;QACxD,OAAO;IACT,CAAC;IAED,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3C,EAAE,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACxB,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1C,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;QACzE,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;KAC7B,CAAC,CAAC,CAAC;IAEJ,MAAM,KAAK,GAAG,WAAW,CAAC,WAAW,EAAE;QACrC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE;QACxC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,EAAE;QACjD,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE,EAAE;QACpD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE;QAChD,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE;KAC7C,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACnB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stats.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/stats.ts"],"names":[],"mappings":"AAIA,wBAAsB,YAAY,CAAC,OAAO,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA8C7E"}
|