claudedesk 1.0.0

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.
Files changed (182) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +431 -0
  3. package/config/repos.example.json +128 -0
  4. package/config/settings.example.json +64 -0
  5. package/config/skills/code-review.md +76 -0
  6. package/config/skills/full-check.md +26 -0
  7. package/config/skills/lint-fix.md +23 -0
  8. package/dist/api/agent-routes.d.ts +2 -0
  9. package/dist/api/agent-routes.d.ts.map +1 -0
  10. package/dist/api/agent-routes.js +251 -0
  11. package/dist/api/agent-routes.js.map +1 -0
  12. package/dist/api/app-routes.d.ts +2 -0
  13. package/dist/api/app-routes.d.ts.map +1 -0
  14. package/dist/api/app-routes.js +150 -0
  15. package/dist/api/app-routes.js.map +1 -0
  16. package/dist/api/docker-routes.d.ts +2 -0
  17. package/dist/api/docker-routes.d.ts.map +1 -0
  18. package/dist/api/docker-routes.js +167 -0
  19. package/dist/api/docker-routes.js.map +1 -0
  20. package/dist/api/middleware.d.ts +6 -0
  21. package/dist/api/middleware.d.ts.map +1 -0
  22. package/dist/api/middleware.js +293 -0
  23. package/dist/api/middleware.js.map +1 -0
  24. package/dist/api/pin-auth.d.ts +65 -0
  25. package/dist/api/pin-auth.d.ts.map +1 -0
  26. package/dist/api/pin-auth.js +218 -0
  27. package/dist/api/pin-auth.js.map +1 -0
  28. package/dist/api/routes.d.ts +2 -0
  29. package/dist/api/routes.d.ts.map +1 -0
  30. package/dist/api/routes.js +473 -0
  31. package/dist/api/routes.js.map +1 -0
  32. package/dist/api/settings-routes.d.ts +2 -0
  33. package/dist/api/settings-routes.d.ts.map +1 -0
  34. package/dist/api/settings-routes.js +570 -0
  35. package/dist/api/settings-routes.js.map +1 -0
  36. package/dist/api/skill-routes.d.ts +2 -0
  37. package/dist/api/skill-routes.d.ts.map +1 -0
  38. package/dist/api/skill-routes.js +88 -0
  39. package/dist/api/skill-routes.js.map +1 -0
  40. package/dist/api/terminal-routes.d.ts +2 -0
  41. package/dist/api/terminal-routes.d.ts.map +1 -0
  42. package/dist/api/terminal-routes.js +3524 -0
  43. package/dist/api/terminal-routes.js.map +1 -0
  44. package/dist/api/tunnel-routes.d.ts +2 -0
  45. package/dist/api/tunnel-routes.d.ts.map +1 -0
  46. package/dist/api/tunnel-routes.js +196 -0
  47. package/dist/api/tunnel-routes.js.map +1 -0
  48. package/dist/api/workspace-routes.d.ts +3 -0
  49. package/dist/api/workspace-routes.d.ts.map +1 -0
  50. package/dist/api/workspace-routes.js +649 -0
  51. package/dist/api/workspace-routes.js.map +1 -0
  52. package/dist/cli.d.ts +3 -0
  53. package/dist/cli.d.ts.map +1 -0
  54. package/dist/cli.js +276 -0
  55. package/dist/cli.js.map +1 -0
  56. package/dist/client/assets/index-B4r0njGe.js +780 -0
  57. package/dist/client/assets/index-CY_9MyE0.css +1 -0
  58. package/dist/client/favicon.svg +5 -0
  59. package/dist/client/icons/icon-192.svg +5 -0
  60. package/dist/client/icons/icon-512.svg +5 -0
  61. package/dist/client/icons/logo-with-message.png +0 -0
  62. package/dist/client/icons/logo.png +0 -0
  63. package/dist/client/index.html +25 -0
  64. package/dist/client/manifest.json +62 -0
  65. package/dist/client/sw.js +243 -0
  66. package/dist/config/agent-usage.d.ts +34 -0
  67. package/dist/config/agent-usage.d.ts.map +1 -0
  68. package/dist/config/agent-usage.js +87 -0
  69. package/dist/config/agent-usage.js.map +1 -0
  70. package/dist/config/repos.d.ts +34 -0
  71. package/dist/config/repos.d.ts.map +1 -0
  72. package/dist/config/repos.js +412 -0
  73. package/dist/config/repos.js.map +1 -0
  74. package/dist/config/settings.d.ts +634 -0
  75. package/dist/config/settings.d.ts.map +1 -0
  76. package/dist/config/settings.js +459 -0
  77. package/dist/config/settings.js.map +1 -0
  78. package/dist/config/skills.d.ts +18 -0
  79. package/dist/config/skills.d.ts.map +1 -0
  80. package/dist/config/skills.js +174 -0
  81. package/dist/config/skills.js.map +1 -0
  82. package/dist/config/workspaces.d.ts +961 -0
  83. package/dist/config/workspaces.d.ts.map +1 -0
  84. package/dist/config/workspaces.js +482 -0
  85. package/dist/config/workspaces.js.map +1 -0
  86. package/dist/core/app-manager.d.ts +85 -0
  87. package/dist/core/app-manager.d.ts.map +1 -0
  88. package/dist/core/app-manager.js +447 -0
  89. package/dist/core/app-manager.js.map +1 -0
  90. package/dist/core/claude-invoker.d.ts +49 -0
  91. package/dist/core/claude-invoker.d.ts.map +1 -0
  92. package/dist/core/claude-invoker.js +583 -0
  93. package/dist/core/claude-invoker.js.map +1 -0
  94. package/dist/core/claude-session-reader.d.ts +25 -0
  95. package/dist/core/claude-session-reader.d.ts.map +1 -0
  96. package/dist/core/claude-session-reader.js +184 -0
  97. package/dist/core/claude-session-reader.js.map +1 -0
  98. package/dist/core/claude-usage-query.d.ts +78 -0
  99. package/dist/core/claude-usage-query.d.ts.map +1 -0
  100. package/dist/core/claude-usage-query.js +294 -0
  101. package/dist/core/claude-usage-query.js.map +1 -0
  102. package/dist/core/git-credential-helper.d.ts +57 -0
  103. package/dist/core/git-credential-helper.d.ts.map +1 -0
  104. package/dist/core/git-credential-helper.js +176 -0
  105. package/dist/core/git-credential-helper.js.map +1 -0
  106. package/dist/core/git-sandbox.d.ts +135 -0
  107. package/dist/core/git-sandbox.d.ts.map +1 -0
  108. package/dist/core/git-sandbox.js +907 -0
  109. package/dist/core/git-sandbox.js.map +1 -0
  110. package/dist/core/github-integration.d.ts +66 -0
  111. package/dist/core/github-integration.d.ts.map +1 -0
  112. package/dist/core/github-integration.js +350 -0
  113. package/dist/core/github-integration.js.map +1 -0
  114. package/dist/core/github-oauth.d.ts +88 -0
  115. package/dist/core/github-oauth.d.ts.map +1 -0
  116. package/dist/core/github-oauth.js +244 -0
  117. package/dist/core/github-oauth.js.map +1 -0
  118. package/dist/core/gitlab-integration.d.ts +66 -0
  119. package/dist/core/gitlab-integration.d.ts.map +1 -0
  120. package/dist/core/gitlab-integration.js +353 -0
  121. package/dist/core/gitlab-integration.js.map +1 -0
  122. package/dist/core/gitlab-oauth.d.ts +100 -0
  123. package/dist/core/gitlab-oauth.d.ts.map +1 -0
  124. package/dist/core/gitlab-oauth.js +366 -0
  125. package/dist/core/gitlab-oauth.js.map +1 -0
  126. package/dist/core/insights-extractor.d.ts +68 -0
  127. package/dist/core/insights-extractor.d.ts.map +1 -0
  128. package/dist/core/insights-extractor.js +402 -0
  129. package/dist/core/insights-extractor.js.map +1 -0
  130. package/dist/core/logger.d.ts +27 -0
  131. package/dist/core/logger.d.ts.map +1 -0
  132. package/dist/core/logger.js +70 -0
  133. package/dist/core/logger.js.map +1 -0
  134. package/dist/core/process-runner.d.ts +27 -0
  135. package/dist/core/process-runner.d.ts.map +1 -0
  136. package/dist/core/process-runner.js +147 -0
  137. package/dist/core/process-runner.js.map +1 -0
  138. package/dist/core/project-detector.d.ts +30 -0
  139. package/dist/core/project-detector.d.ts.map +1 -0
  140. package/dist/core/project-detector.js +482 -0
  141. package/dist/core/project-detector.js.map +1 -0
  142. package/dist/core/qr-generator.d.ts +18 -0
  143. package/dist/core/qr-generator.d.ts.map +1 -0
  144. package/dist/core/qr-generator.js +61 -0
  145. package/dist/core/qr-generator.js.map +1 -0
  146. package/dist/core/remote-tunnel-manager.d.ts +59 -0
  147. package/dist/core/remote-tunnel-manager.d.ts.map +1 -0
  148. package/dist/core/remote-tunnel-manager.js +235 -0
  149. package/dist/core/remote-tunnel-manager.js.map +1 -0
  150. package/dist/core/shared-docker-manager.d.ts +41 -0
  151. package/dist/core/shared-docker-manager.d.ts.map +1 -0
  152. package/dist/core/shared-docker-manager.js +409 -0
  153. package/dist/core/shared-docker-manager.js.map +1 -0
  154. package/dist/core/skill-executor.d.ts +25 -0
  155. package/dist/core/skill-executor.d.ts.map +1 -0
  156. package/dist/core/skill-executor.js +171 -0
  157. package/dist/core/skill-executor.js.map +1 -0
  158. package/dist/core/terminal-session.d.ts +149 -0
  159. package/dist/core/terminal-session.d.ts.map +1 -0
  160. package/dist/core/terminal-session.js +2340 -0
  161. package/dist/core/terminal-session.js.map +1 -0
  162. package/dist/core/tunnel-manager.d.ts +35 -0
  163. package/dist/core/tunnel-manager.d.ts.map +1 -0
  164. package/dist/core/tunnel-manager.js +137 -0
  165. package/dist/core/tunnel-manager.js.map +1 -0
  166. package/dist/core/usage-manager.d.ts +57 -0
  167. package/dist/core/usage-manager.d.ts.map +1 -0
  168. package/dist/core/usage-manager.js +363 -0
  169. package/dist/core/usage-manager.js.map +1 -0
  170. package/dist/core/ws-manager.d.ts +39 -0
  171. package/dist/core/ws-manager.d.ts.map +1 -0
  172. package/dist/core/ws-manager.js +190 -0
  173. package/dist/core/ws-manager.js.map +1 -0
  174. package/dist/index.d.ts +7 -0
  175. package/dist/index.d.ts.map +1 -0
  176. package/dist/index.js +229 -0
  177. package/dist/index.js.map +1 -0
  178. package/dist/types.d.ts +868 -0
  179. package/dist/types.d.ts.map +1 -0
  180. package/dist/types.js +119 -0
  181. package/dist/types.js.map +1 -0
  182. package/package.json +96 -0
@@ -0,0 +1,363 @@
1
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
2
+ import { join } from 'path';
3
+ const USAGE_DIR = join(process.cwd(), 'config', 'usage');
4
+ const GLOBAL_USAGE_FILE = join(USAGE_DIR, 'global-usage.json');
5
+ const WEEKLY_USAGE_FILE = join(USAGE_DIR, 'weekly-usage.json');
6
+ const SESSIONS_USAGE_DIR = join(USAGE_DIR, 'sessions');
7
+ // Model pricing per 1M tokens (input / output)
8
+ const MODEL_PRICING = {
9
+ 'claude-opus-4-5-20251101': { input: 15, output: 75 },
10
+ 'claude-sonnet-4-20250514': { input: 3, output: 15 },
11
+ 'claude-3-5-sonnet-20241022': { input: 3, output: 15 },
12
+ 'claude-3-5-haiku-20241022': { input: 1, output: 5 },
13
+ // Default pricing if model not found
14
+ 'default': { input: 3, output: 15 },
15
+ };
16
+ /**
17
+ * Get the start of the week (Sunday 00:00:00) for a given date
18
+ */
19
+ function getWeekStart(date) {
20
+ const d = new Date(date);
21
+ const day = d.getDay(); // 0 = Sunday
22
+ d.setDate(d.getDate() - day);
23
+ d.setHours(0, 0, 0, 0);
24
+ return d;
25
+ }
26
+ /**
27
+ * Get the end of the week (Saturday 23:59:59) for a given date
28
+ */
29
+ function getWeekEnd(date) {
30
+ const weekStart = getWeekStart(date);
31
+ const weekEnd = new Date(weekStart);
32
+ weekEnd.setDate(weekEnd.getDate() + 6);
33
+ weekEnd.setHours(23, 59, 59, 999);
34
+ return weekEnd;
35
+ }
36
+ class UsageManager {
37
+ constructor() {
38
+ this.ensureDirectories();
39
+ }
40
+ ensureDirectories() {
41
+ if (!existsSync(USAGE_DIR)) {
42
+ mkdirSync(USAGE_DIR, { recursive: true });
43
+ }
44
+ if (!existsSync(SESSIONS_USAGE_DIR)) {
45
+ mkdirSync(SESSIONS_USAGE_DIR, { recursive: true });
46
+ }
47
+ }
48
+ /**
49
+ * Calculate cost based on model and token usage
50
+ */
51
+ calculateCost(model, inputTokens, outputTokens) {
52
+ // Find pricing for the model
53
+ const pricing = MODEL_PRICING[model] || MODEL_PRICING['default'];
54
+ // Cost = (tokens / 1M) * price per 1M tokens
55
+ const inputCost = (inputTokens / 1_000_000) * pricing.input;
56
+ const outputCost = (outputTokens / 1_000_000) * pricing.output;
57
+ return inputCost + outputCost;
58
+ }
59
+ /**
60
+ * Get model short name for display
61
+ */
62
+ getModelShortName(model) {
63
+ if (model.includes('opus'))
64
+ return 'Opus';
65
+ if (model.includes('sonnet'))
66
+ return 'Sonnet';
67
+ if (model.includes('haiku'))
68
+ return 'Haiku';
69
+ return model.split('-').slice(0, 2).join(' ');
70
+ }
71
+ /**
72
+ * Record usage for a message in a session
73
+ */
74
+ recordMessageUsage(sessionId, data, toolUseCount = 0, filesChanged = 0) {
75
+ if (!data.usage)
76
+ return;
77
+ const model = data.model || 'unknown';
78
+ const cost = data.costUsd ?? this.calculateCost(model, data.usage.inputTokens, data.usage.outputTokens);
79
+ const messageUsage = {
80
+ messageId: data.messageId,
81
+ timestamp: new Date().toISOString(),
82
+ model,
83
+ usage: data.usage,
84
+ costUsd: cost,
85
+ durationMs: data.durationMs || 0,
86
+ };
87
+ // Update session usage
88
+ this.updateSessionUsage(sessionId, messageUsage, toolUseCount, filesChanged);
89
+ // Update global usage (daily)
90
+ this.updateGlobalUsage(messageUsage);
91
+ // Update weekly usage
92
+ this.updateWeeklyUsage(messageUsage);
93
+ }
94
+ /**
95
+ * Update session-specific usage data
96
+ */
97
+ updateSessionUsage(sessionId, messageUsage, toolUseCount, filesChanged) {
98
+ const sessionFile = join(SESSIONS_USAGE_DIR, `${sessionId}.json`);
99
+ let sessionData = {
100
+ sessionId,
101
+ messages: [],
102
+ toolUseCount: 0,
103
+ filesChanged: 0,
104
+ };
105
+ if (existsSync(sessionFile)) {
106
+ try {
107
+ sessionData = JSON.parse(readFileSync(sessionFile, 'utf-8'));
108
+ }
109
+ catch {
110
+ // Use default
111
+ }
112
+ }
113
+ sessionData.messages.push(messageUsage);
114
+ sessionData.toolUseCount += toolUseCount;
115
+ sessionData.filesChanged += filesChanged;
116
+ writeFileSync(sessionFile, JSON.stringify(sessionData, null, 2));
117
+ }
118
+ /**
119
+ * Update global usage data
120
+ */
121
+ updateGlobalUsage(messageUsage) {
122
+ const today = new Date().toISOString().split('T')[0];
123
+ let globalData = {
124
+ periodStart: today,
125
+ messages: [],
126
+ byModel: {},
127
+ };
128
+ if (existsSync(GLOBAL_USAGE_FILE)) {
129
+ try {
130
+ globalData = JSON.parse(readFileSync(GLOBAL_USAGE_FILE, 'utf-8'));
131
+ // Reset if it's a new day
132
+ if (globalData.periodStart !== today) {
133
+ globalData = {
134
+ periodStart: today,
135
+ messages: [],
136
+ byModel: {},
137
+ };
138
+ }
139
+ }
140
+ catch {
141
+ // Use default
142
+ }
143
+ }
144
+ globalData.messages.push(messageUsage);
145
+ // Update by-model stats
146
+ const model = messageUsage.model;
147
+ if (!globalData.byModel[model]) {
148
+ globalData.byModel[model] = { inputTokens: 0, outputTokens: 0, costUsd: 0 };
149
+ }
150
+ globalData.byModel[model].inputTokens += messageUsage.usage.inputTokens;
151
+ globalData.byModel[model].outputTokens += messageUsage.usage.outputTokens;
152
+ globalData.byModel[model].costUsd += messageUsage.costUsd;
153
+ writeFileSync(GLOBAL_USAGE_FILE, JSON.stringify(globalData, null, 2));
154
+ }
155
+ /**
156
+ * Update weekly usage data
157
+ */
158
+ updateWeeklyUsage(messageUsage) {
159
+ const now = new Date();
160
+ const weekStart = getWeekStart(now);
161
+ const weekEnd = getWeekEnd(now);
162
+ const weekStartStr = weekStart.toISOString();
163
+ const weekEndStr = weekEnd.toISOString();
164
+ const today = now.toISOString().split('T')[0];
165
+ let weeklyData = {
166
+ weekStart: weekStartStr,
167
+ weekEnd: weekEndStr,
168
+ messages: [],
169
+ byModel: {},
170
+ dailyBreakdown: {},
171
+ };
172
+ if (existsSync(WEEKLY_USAGE_FILE)) {
173
+ try {
174
+ weeklyData = JSON.parse(readFileSync(WEEKLY_USAGE_FILE, 'utf-8'));
175
+ // Reset if it's a new week
176
+ const storedWeekStart = new Date(weeklyData.weekStart);
177
+ if (storedWeekStart.getTime() !== weekStart.getTime()) {
178
+ weeklyData = {
179
+ weekStart: weekStartStr,
180
+ weekEnd: weekEndStr,
181
+ messages: [],
182
+ byModel: {},
183
+ dailyBreakdown: {},
184
+ };
185
+ }
186
+ }
187
+ catch {
188
+ // Use default
189
+ }
190
+ }
191
+ weeklyData.messages.push(messageUsage);
192
+ // Update by-model stats
193
+ const model = messageUsage.model;
194
+ if (!weeklyData.byModel[model]) {
195
+ weeklyData.byModel[model] = { inputTokens: 0, outputTokens: 0, costUsd: 0, apiCalls: 0 };
196
+ }
197
+ weeklyData.byModel[model].inputTokens += messageUsage.usage.inputTokens;
198
+ weeklyData.byModel[model].outputTokens += messageUsage.usage.outputTokens;
199
+ weeklyData.byModel[model].costUsd += messageUsage.costUsd;
200
+ weeklyData.byModel[model].apiCalls += 1;
201
+ // Update daily breakdown
202
+ if (!weeklyData.dailyBreakdown[today]) {
203
+ weeklyData.dailyBreakdown[today] = { inputTokens: 0, outputTokens: 0, costUsd: 0, apiCalls: 0 };
204
+ }
205
+ weeklyData.dailyBreakdown[today].inputTokens += messageUsage.usage.inputTokens;
206
+ weeklyData.dailyBreakdown[today].outputTokens += messageUsage.usage.outputTokens;
207
+ weeklyData.dailyBreakdown[today].costUsd += messageUsage.costUsd;
208
+ weeklyData.dailyBreakdown[today].apiCalls += 1;
209
+ writeFileSync(WEEKLY_USAGE_FILE, JSON.stringify(weeklyData, null, 2));
210
+ }
211
+ /**
212
+ * Get usage stats for a specific session
213
+ */
214
+ getSessionUsage(sessionId) {
215
+ const sessionFile = join(SESSIONS_USAGE_DIR, `${sessionId}.json`);
216
+ const defaultStats = {
217
+ totalInputTokens: 0,
218
+ totalOutputTokens: 0,
219
+ totalCostUsd: 0,
220
+ messageCount: 0,
221
+ toolUseCount: 0,
222
+ filesChanged: 0,
223
+ };
224
+ if (!existsSync(sessionFile)) {
225
+ return defaultStats;
226
+ }
227
+ try {
228
+ const sessionData = JSON.parse(readFileSync(sessionFile, 'utf-8'));
229
+ let totalInput = 0;
230
+ let totalOutput = 0;
231
+ let totalCost = 0;
232
+ let lastModel;
233
+ for (const msg of sessionData.messages) {
234
+ totalInput += msg.usage.inputTokens;
235
+ totalOutput += msg.usage.outputTokens;
236
+ totalCost += msg.costUsd;
237
+ lastModel = msg.model;
238
+ }
239
+ return {
240
+ totalInputTokens: totalInput,
241
+ totalOutputTokens: totalOutput,
242
+ totalCostUsd: totalCost,
243
+ messageCount: sessionData.messages.length,
244
+ toolUseCount: sessionData.toolUseCount,
245
+ filesChanged: sessionData.filesChanged,
246
+ model: lastModel,
247
+ };
248
+ }
249
+ catch {
250
+ return defaultStats;
251
+ }
252
+ }
253
+ /**
254
+ * Get global usage stats for today
255
+ */
256
+ getGlobalUsage() {
257
+ const today = new Date().toISOString().split('T')[0];
258
+ const defaultStats = {
259
+ periodStart: today,
260
+ totalInputTokens: 0,
261
+ totalOutputTokens: 0,
262
+ totalCostUsd: 0,
263
+ totalApiCalls: 0,
264
+ byModel: {},
265
+ };
266
+ if (!existsSync(GLOBAL_USAGE_FILE)) {
267
+ return defaultStats;
268
+ }
269
+ try {
270
+ const globalData = JSON.parse(readFileSync(GLOBAL_USAGE_FILE, 'utf-8'));
271
+ // Return default if data is from a different day
272
+ if (globalData.periodStart !== today) {
273
+ return defaultStats;
274
+ }
275
+ let totalInput = 0;
276
+ let totalOutput = 0;
277
+ let totalCost = 0;
278
+ for (const msg of globalData.messages) {
279
+ totalInput += msg.usage.inputTokens;
280
+ totalOutput += msg.usage.outputTokens;
281
+ totalCost += msg.costUsd;
282
+ }
283
+ return {
284
+ periodStart: globalData.periodStart,
285
+ totalInputTokens: totalInput,
286
+ totalOutputTokens: totalOutput,
287
+ totalCostUsd: totalCost,
288
+ totalApiCalls: globalData.messages.length,
289
+ byModel: globalData.byModel,
290
+ };
291
+ }
292
+ catch {
293
+ return defaultStats;
294
+ }
295
+ }
296
+ /**
297
+ * Get weekly usage stats (resets on Sunday)
298
+ */
299
+ getWeeklyUsage() {
300
+ const now = new Date();
301
+ const weekStart = getWeekStart(now);
302
+ const weekEnd = getWeekEnd(now);
303
+ const defaultStats = {
304
+ weekStart: weekStart.toISOString(),
305
+ weekEnd: weekEnd.toISOString(),
306
+ totalInputTokens: 0,
307
+ totalOutputTokens: 0,
308
+ totalCostUsd: 0,
309
+ totalApiCalls: 0,
310
+ byModel: {},
311
+ dailyBreakdown: {},
312
+ };
313
+ if (!existsSync(WEEKLY_USAGE_FILE)) {
314
+ return defaultStats;
315
+ }
316
+ try {
317
+ const weeklyData = JSON.parse(readFileSync(WEEKLY_USAGE_FILE, 'utf-8'));
318
+ // Return default if data is from a different week
319
+ const storedWeekStart = new Date(weeklyData.weekStart);
320
+ if (storedWeekStart.getTime() !== weekStart.getTime()) {
321
+ return defaultStats;
322
+ }
323
+ let totalInput = 0;
324
+ let totalOutput = 0;
325
+ let totalCost = 0;
326
+ for (const msg of weeklyData.messages) {
327
+ totalInput += msg.usage.inputTokens;
328
+ totalOutput += msg.usage.outputTokens;
329
+ totalCost += msg.costUsd;
330
+ }
331
+ return {
332
+ weekStart: weeklyData.weekStart,
333
+ weekEnd: weeklyData.weekEnd,
334
+ totalInputTokens: totalInput,
335
+ totalOutputTokens: totalOutput,
336
+ totalCostUsd: totalCost,
337
+ totalApiCalls: weeklyData.messages.length,
338
+ byModel: weeklyData.byModel,
339
+ dailyBreakdown: weeklyData.dailyBreakdown,
340
+ };
341
+ }
342
+ catch {
343
+ return defaultStats;
344
+ }
345
+ }
346
+ /**
347
+ * Delete session usage data when session is closed
348
+ */
349
+ deleteSessionUsage(sessionId) {
350
+ const sessionFile = join(SESSIONS_USAGE_DIR, `${sessionId}.json`);
351
+ if (existsSync(sessionFile)) {
352
+ try {
353
+ const fs = require('fs');
354
+ fs.unlinkSync(sessionFile);
355
+ }
356
+ catch {
357
+ // Ignore deletion errors
358
+ }
359
+ }
360
+ }
361
+ }
362
+ export const usageManager = new UsageManager();
363
+ //# sourceMappingURL=usage-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usage-manager.js","sourceRoot":"","sources":["../../src/core/usage-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ import { WebSocket } from 'ws';
2
+ import { Server } from 'http';
3
+ export interface WSMessage {
4
+ type: string;
5
+ sessionId?: string;
6
+ content?: string;
7
+ mode?: 'plan' | 'direct';
8
+ [key: string]: unknown;
9
+ }
10
+ export interface WSClient {
11
+ id: string;
12
+ ws: WebSocket;
13
+ token: string;
14
+ subscribedSessions: Set<string>;
15
+ isAlive: boolean;
16
+ }
17
+ type MessageHandler = (client: WSClient, message: WSMessage) => void | Promise<void>;
18
+ declare class WebSocketManager {
19
+ private wss;
20
+ private clients;
21
+ private handlers;
22
+ private heartbeatInterval;
23
+ initialize(server: Server, authToken: string): void;
24
+ private startHeartbeat;
25
+ private handleMessage;
26
+ on(type: string, handler: MessageHandler): void;
27
+ send(client: WSClient, message: WSMessage): void;
28
+ broadcastToSession(sessionId: string, message: WSMessage): void;
29
+ broadcastAll(message: WSMessage): void;
30
+ subscribeToSession(client: WSClient, sessionId: string): void;
31
+ unsubscribeFromSession(client: WSClient, sessionId: string): void;
32
+ getSessionSubscribers(sessionId: string): WSClient[];
33
+ getClientCount(): number;
34
+ shutdown(): void;
35
+ private generateId;
36
+ }
37
+ export declare const wsManager: WebSocketManager;
38
+ export {};
39
+ //# sourceMappingURL=ws-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ws-manager.d.ts","sourceRoot":"","sources":["../../src/core/ws-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,SAAS,EAAE,MAAM,IAAI,CAAC;AAChD,OAAO,EAAE,MAAM,EAAmB,MAAM,MAAM,CAAC;AAG/C,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;IACzB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,SAAS,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,kBAAkB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAChC,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,KAAK,cAAc,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAErF,cAAM,gBAAgB;IACpB,OAAO,CAAC,GAAG,CAAgC;IAC3C,OAAO,CAAC,OAAO,CAAoC;IACnD,OAAO,CAAC,QAAQ,CAA0C;IAC1D,OAAO,CAAC,iBAAiB,CAA+B;IAExD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAuGnD,OAAO,CAAC,cAAc;YAeR,aAAa;IAkB3B,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IAK/C,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAOhD,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI;IAS/D,YAAY,CAAC,OAAO,EAAE,SAAS,GAAG,IAAI;IAOtC,kBAAkB,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAM7D,sBAAsB,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAMjE,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,QAAQ,EAAE;IAOpD,cAAc,IAAI,MAAM;IAKxB,QAAQ,IAAI,IAAI;IAiBhB,OAAO,CAAC,UAAU;CAGnB;AAGD,eAAO,MAAM,SAAS,kBAAyB,CAAC"}
@@ -0,0 +1,190 @@
1
+ import { WebSocketServer, WebSocket } from 'ws';
2
+ import { parse as parseUrl } from 'url';
3
+ class WebSocketManager {
4
+ wss = null;
5
+ clients = new Map();
6
+ handlers = new Map();
7
+ heartbeatInterval = null;
8
+ initialize(server, authToken) {
9
+ this.wss = new WebSocketServer({ noServer: true });
10
+ // Handle HTTP upgrade requests
11
+ server.on('upgrade', (request, socket, head) => {
12
+ const { pathname, query } = parseUrl(request.url || '', true);
13
+ if (pathname === '/ws') {
14
+ // SEC-05: Prefer Sec-WebSocket-Protocol header over query string to avoid token in logs
15
+ // Protocol header format: "token, <actual-token>" - the first value identifies the protocol,
16
+ // the second is the actual authentication token
17
+ let token;
18
+ let useProtocolHeader = false;
19
+ const protocolHeader = request.headers['sec-websocket-protocol'];
20
+ if (protocolHeader) {
21
+ // Parse "token, <actual-token>" format
22
+ const protocols = typeof protocolHeader === 'string'
23
+ ? protocolHeader.split(',').map(p => p.trim())
24
+ : protocolHeader;
25
+ if (protocols.length >= 2 && protocols[0] === 'token') {
26
+ token = protocols[1];
27
+ useProtocolHeader = true;
28
+ }
29
+ }
30
+ // Fall back to query param for backward compatibility (deprecated)
31
+ if (!token) {
32
+ token = query.token;
33
+ }
34
+ if (token !== authToken) {
35
+ socket.write('HTTP/1.1 401 Unauthorized\r\n\r\n');
36
+ socket.destroy();
37
+ return;
38
+ }
39
+ this.wss.handleUpgrade(request, socket, head, (ws) => {
40
+ // If client used protocol header auth, echo back the protocol name
41
+ // This is required by WebSocket spec when using Sec-WebSocket-Protocol
42
+ if (useProtocolHeader) {
43
+ // Note: ws library handles this automatically if we pass protocol to handleUpgrade
44
+ // but we emit connection event manually, so client will receive the echo
45
+ }
46
+ this.wss.emit('connection', ws, request, token);
47
+ });
48
+ }
49
+ else {
50
+ socket.destroy();
51
+ }
52
+ });
53
+ // Handle new connections
54
+ this.wss.on('connection', (ws, _request, token) => {
55
+ const clientId = this.generateId();
56
+ const client = {
57
+ id: clientId,
58
+ ws,
59
+ token,
60
+ subscribedSessions: new Set(),
61
+ isAlive: true,
62
+ };
63
+ this.clients.set(clientId, client);
64
+ console.log(`[WS] Client connected: ${clientId}`);
65
+ // Send welcome message
66
+ this.send(client, { type: 'connected', clientId });
67
+ // Handle incoming messages
68
+ ws.on('message', async (data) => {
69
+ try {
70
+ const message = JSON.parse(data.toString());
71
+ await this.handleMessage(client, message);
72
+ }
73
+ catch (error) {
74
+ console.error('[WS] Failed to parse message:', error);
75
+ this.send(client, { type: 'error', error: 'Invalid message format' });
76
+ }
77
+ });
78
+ // Handle pong for heartbeat
79
+ ws.on('pong', () => {
80
+ client.isAlive = true;
81
+ });
82
+ // Handle close
83
+ ws.on('close', () => {
84
+ console.log(`[WS] Client disconnected: ${clientId}`);
85
+ this.clients.delete(clientId);
86
+ });
87
+ // Handle errors
88
+ ws.on('error', (error) => {
89
+ console.error(`[WS] Client error ${clientId}:`, error);
90
+ this.clients.delete(clientId);
91
+ });
92
+ });
93
+ // Start heartbeat to detect dead connections
94
+ this.startHeartbeat();
95
+ console.log('[WS] WebSocket server initialized');
96
+ }
97
+ startHeartbeat() {
98
+ this.heartbeatInterval = setInterval(() => {
99
+ this.clients.forEach((client, id) => {
100
+ if (!client.isAlive) {
101
+ console.log(`[WS] Terminating inactive client: ${id}`);
102
+ client.ws.terminate();
103
+ this.clients.delete(id);
104
+ return;
105
+ }
106
+ client.isAlive = false;
107
+ client.ws.ping();
108
+ });
109
+ }, 30000); // Check every 30 seconds
110
+ }
111
+ async handleMessage(client, message) {
112
+ const handler = this.handlers.get(message.type);
113
+ if (handler) {
114
+ try {
115
+ await handler(client, message);
116
+ }
117
+ catch (error) {
118
+ const errorMsg = error instanceof Error ? error.message : String(error);
119
+ console.error(`[WS] Handler error for ${message.type}:`, errorMsg);
120
+ this.send(client, { type: 'error', error: errorMsg });
121
+ }
122
+ }
123
+ else {
124
+ console.warn(`[WS] Unknown message type: ${message.type}`);
125
+ this.send(client, { type: 'error', error: `Unknown message type: ${message.type}` });
126
+ }
127
+ }
128
+ // Register a message handler
129
+ on(type, handler) {
130
+ this.handlers.set(type, handler);
131
+ }
132
+ // Send message to a specific client
133
+ send(client, message) {
134
+ if (client.ws.readyState === WebSocket.OPEN) {
135
+ client.ws.send(JSON.stringify(message));
136
+ }
137
+ }
138
+ // Broadcast to all clients subscribed to a session
139
+ broadcastToSession(sessionId, message) {
140
+ this.clients.forEach((client) => {
141
+ if (client.subscribedSessions.has(sessionId)) {
142
+ this.send(client, { ...message, sessionId });
143
+ }
144
+ });
145
+ }
146
+ // Broadcast to all connected clients
147
+ broadcastAll(message) {
148
+ this.clients.forEach((client) => {
149
+ this.send(client, message);
150
+ });
151
+ }
152
+ // Subscribe client to a session
153
+ subscribeToSession(client, sessionId) {
154
+ client.subscribedSessions.add(sessionId);
155
+ console.log(`[WS] Client ${client.id} subscribed to session ${sessionId}`);
156
+ }
157
+ // Unsubscribe client from a session
158
+ unsubscribeFromSession(client, sessionId) {
159
+ client.subscribedSessions.delete(sessionId);
160
+ console.log(`[WS] Client ${client.id} unsubscribed from session ${sessionId}`);
161
+ }
162
+ // Get all clients subscribed to a session
163
+ getSessionSubscribers(sessionId) {
164
+ return Array.from(this.clients.values()).filter((client) => client.subscribedSessions.has(sessionId));
165
+ }
166
+ // Get client count
167
+ getClientCount() {
168
+ return this.clients.size;
169
+ }
170
+ // Cleanup
171
+ shutdown() {
172
+ if (this.heartbeatInterval) {
173
+ clearInterval(this.heartbeatInterval);
174
+ }
175
+ this.clients.forEach((client) => {
176
+ client.ws.close();
177
+ });
178
+ this.clients.clear();
179
+ if (this.wss) {
180
+ this.wss.close();
181
+ }
182
+ console.log('[WS] WebSocket server shut down');
183
+ }
184
+ generateId() {
185
+ return Math.random().toString(36).substring(2, 15);
186
+ }
187
+ }
188
+ // Singleton instance
189
+ export const wsManager = new WebSocketManager();
190
+ //# sourceMappingURL=ws-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ws-manager.js","sourceRoot":"","sources":["../../src/core/ws-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export interface StartServerOptions {
2
+ port?: number;
3
+ host?: string;
4
+ skipWizard?: boolean;
5
+ }
6
+ export declare function startServer(options?: StartServerOptions): Promise<void>;
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,kBAAkB;IACjC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAeD,wBAAsB,WAAW,CAAC,OAAO,GAAE,kBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CA6MjF"}