@qnote/q-ai-note 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 (72) hide show
  1. package/README.md +50 -0
  2. package/dist/cli.d.ts +3 -0
  3. package/dist/cli.d.ts.map +1 -0
  4. package/dist/cli.js +55 -0
  5. package/dist/cli.js.map +1 -0
  6. package/dist/server/aiClient.d.ts +11 -0
  7. package/dist/server/aiClient.d.ts.map +1 -0
  8. package/dist/server/aiClient.js +83 -0
  9. package/dist/server/aiClient.js.map +1 -0
  10. package/dist/server/api/batchRecovery.d.ts +11 -0
  11. package/dist/server/api/batchRecovery.d.ts.map +1 -0
  12. package/dist/server/api/batchRecovery.js +68 -0
  13. package/dist/server/api/batchRecovery.js.map +1 -0
  14. package/dist/server/api/chat.d.ts +3 -0
  15. package/dist/server/api/chat.d.ts.map +1 -0
  16. package/dist/server/api/chat.js +485 -0
  17. package/dist/server/api/chat.js.map +1 -0
  18. package/dist/server/api/diary.d.ts +3 -0
  19. package/dist/server/api/diary.d.ts.map +1 -0
  20. package/dist/server/api/diary.js +102 -0
  21. package/dist/server/api/diary.js.map +1 -0
  22. package/dist/server/api/sandbox.d.ts +3 -0
  23. package/dist/server/api/sandbox.d.ts.map +1 -0
  24. package/dist/server/api/sandbox.js +87 -0
  25. package/dist/server/api/sandbox.js.map +1 -0
  26. package/dist/server/api/settings.d.ts +3 -0
  27. package/dist/server/api/settings.d.ts.map +1 -0
  28. package/dist/server/api/settings.js +45 -0
  29. package/dist/server/api/settings.js.map +1 -0
  30. package/dist/server/api/workItem.d.ts +3 -0
  31. package/dist/server/api/workItem.d.ts.map +1 -0
  32. package/dist/server/api/workItem.js +290 -0
  33. package/dist/server/api/workItem.js.map +1 -0
  34. package/dist/server/chatUtils.d.ts +15 -0
  35. package/dist/server/chatUtils.d.ts.map +1 -0
  36. package/dist/server/chatUtils.js +52 -0
  37. package/dist/server/chatUtils.js.map +1 -0
  38. package/dist/server/config.d.ts +14 -0
  39. package/dist/server/config.d.ts.map +1 -0
  40. package/dist/server/config.js +56 -0
  41. package/dist/server/config.js.map +1 -0
  42. package/dist/server/db.d.ts +6 -0
  43. package/dist/server/db.d.ts.map +1 -0
  44. package/dist/server/db.js +106 -0
  45. package/dist/server/db.js.map +1 -0
  46. package/dist/server/index.d.ts +5 -0
  47. package/dist/server/index.d.ts.map +1 -0
  48. package/dist/server/index.js +72 -0
  49. package/dist/server/index.js.map +1 -0
  50. package/dist/server/react/agent.d.ts +56 -0
  51. package/dist/server/react/agent.d.ts.map +1 -0
  52. package/dist/server/react/agent.js +219 -0
  53. package/dist/server/react/agent.js.map +1 -0
  54. package/dist/server/react/prompts.d.ts +13 -0
  55. package/dist/server/react/prompts.d.ts.map +1 -0
  56. package/dist/server/react/prompts.js +84 -0
  57. package/dist/server/react/prompts.js.map +1 -0
  58. package/dist/server/react/tools.d.ts +67 -0
  59. package/dist/server/react/tools.d.ts.map +1 -0
  60. package/dist/server/react/tools.js +208 -0
  61. package/dist/server/react/tools.js.map +1 -0
  62. package/dist/server/types.d.ts +59 -0
  63. package/dist/server/types.d.ts.map +1 -0
  64. package/dist/server/types.js +2 -0
  65. package/dist/server/types.js.map +1 -0
  66. package/dist/web/app.js +1081 -0
  67. package/dist/web/chatView.js +31 -0
  68. package/dist/web/index.html +218 -0
  69. package/dist/web/shared.js +49 -0
  70. package/dist/web/styles.css +1320 -0
  71. package/dist/web/vueRenderers.js +191 -0
  72. package/package.json +46 -0
@@ -0,0 +1,485 @@
1
+ import { Router } from 'express';
2
+ import { v4 as uuidv4 } from 'uuid';
3
+ import { db } from '../db.js';
4
+ import { processMessage } from '../react/agent.js';
5
+ import { callAiText } from '../aiClient.js';
6
+ import { parseOperationResult, parseRelationIds, buildOperationsPrompt } from '../chatUtils.js';
7
+ import { supplementBatchCreateActionsByContent } from './batchRecovery.js';
8
+ const router = Router();
9
+ function isExecuteIntent(text) {
10
+ const normalized = text.trim().toLowerCase();
11
+ return /^(执行|确认执行|确认|继续|好的执行|好,执行|ok|yes|go)$/i.test(normalized);
12
+ }
13
+ function isCancelIntent(text) {
14
+ const normalized = text.trim().toLowerCase();
15
+ return /^(取消|算了|停止|不要了|不用了|stop|cancel)$/i.test(normalized);
16
+ }
17
+ function now() {
18
+ return new Date().toISOString();
19
+ }
20
+ function toSuggestionItems(operations) {
21
+ return operations.map((op) => ({
22
+ name: op.name || op.task_id || '',
23
+ action: op.action,
24
+ task_id: op.task_id,
25
+ description: op.description,
26
+ }));
27
+ }
28
+ function createResponseAction(responseText) {
29
+ return {
30
+ thought: '普通对话回复',
31
+ action: 'response',
32
+ response: responseText,
33
+ };
34
+ }
35
+ router.get('/', (_req, res) => {
36
+ try {
37
+ const chats = db.prepare(`
38
+ SELECT c.*
39
+ FROM chats c
40
+ LEFT JOIN chat_sandbox_relations r ON r.chat_id = c.id
41
+ WHERE r.chat_id IS NULL
42
+ ORDER BY c.created_at DESC
43
+ LIMIT 20
44
+ `).all();
45
+ const result = chats.map(row => ({
46
+ id: row.id,
47
+ role: row.role,
48
+ content: row.content,
49
+ created_at: row.created_at,
50
+ }));
51
+ const response = { success: true, data: result.reverse() };
52
+ res.json(response);
53
+ }
54
+ catch (error) {
55
+ const response = { success: false, error: String(error) };
56
+ res.status(500).json(response);
57
+ }
58
+ });
59
+ router.post('/', async (req, res) => {
60
+ try {
61
+ const { content, sandbox_id } = req.body;
62
+ if (!content) {
63
+ const response = { success: false, error: 'Content is required' };
64
+ return res.status(400).json(response);
65
+ }
66
+ const timestamp = now();
67
+ const chatId = uuidv4();
68
+ db.prepare('INSERT INTO chats (id, role, content, created_at) VALUES (?, ?, ?, ?)').run(chatId, 'user', content, timestamp);
69
+ let chatResponse;
70
+ let suggestions = [];
71
+ let relations = [];
72
+ if (sandbox_id) {
73
+ relations = [sandbox_id];
74
+ db.prepare('INSERT OR IGNORE INTO chat_sandbox_relations (chat_id, sandbox_id) VALUES (?, ?)').run(chatId, sandbox_id);
75
+ const aiResponse = await callAiText(buildOperationsPrompt(content, sandbox_id));
76
+ const parsed = parseOperationResult(aiResponse);
77
+ chatResponse = parsed?.reply || aiResponse;
78
+ if (parsed && parsed.operations.length > 0) {
79
+ suggestions.push({
80
+ sandbox_id,
81
+ items: toSuggestionItems(parsed.operations),
82
+ });
83
+ }
84
+ }
85
+ else {
86
+ chatResponse = await callAiText(content);
87
+ const sandboxes = db.prepare('SELECT id, name FROM sandboxes').all();
88
+ const sandboxList = sandboxes.map(s => `- ${s.name} (${s.id})`).join('\n');
89
+ const relationPrompt = `Given the following message: "${content}"
90
+
91
+ Available sandboxes:
92
+ ${sandboxList || 'No sandboxes exist'}
93
+
94
+ Identify which sandbox(es) this message relates to. Return the sandbox IDs separated by commas, or "none" if no relation. Just return the IDs or "none".`;
95
+ const relationResponse = await callAiText(relationPrompt);
96
+ const ids = parseRelationIds(relationResponse);
97
+ for (const id of ids) {
98
+ const sandbox = sandboxes.find(s => s.id === id);
99
+ if (!sandbox) {
100
+ continue;
101
+ }
102
+ relations.push(id);
103
+ const itemsResponse = await callAiText(buildOperationsPrompt(content, sandbox.name));
104
+ const parsed = parseOperationResult(itemsResponse);
105
+ if (parsed && parsed.operations.length > 0) {
106
+ suggestions.push({
107
+ sandbox_id: id,
108
+ items: toSuggestionItems(parsed.operations),
109
+ });
110
+ }
111
+ }
112
+ }
113
+ const assistantId = uuidv4();
114
+ db.prepare('INSERT INTO chats (id, role, content, created_at) VALUES (?, ?, ?, ?)').run(assistantId, 'assistant', chatResponse, now());
115
+ if (sandbox_id) {
116
+ db.prepare('INSERT OR IGNORE INTO chat_sandbox_relations (chat_id, sandbox_id) VALUES (?, ?)').run(assistantId, sandbox_id);
117
+ }
118
+ const userChat = { id: chatId, role: 'user', content, created_at: timestamp };
119
+ const assistantChat = { id: assistantId, role: 'assistant', content: chatResponse, created_at: now() };
120
+ const response = {
121
+ success: true,
122
+ data: {
123
+ user: userChat,
124
+ assistant: assistantChat,
125
+ action: createResponseAction(chatResponse),
126
+ related_sandboxes: relations,
127
+ ...(suggestions.length > 0 ? { suggestions } : {})
128
+ },
129
+ };
130
+ res.json(response);
131
+ }
132
+ catch (error) {
133
+ const response = { success: false, error: String(error) };
134
+ res.status(500).json(response);
135
+ }
136
+ });
137
+ router.post('/react', async (req, res) => {
138
+ try {
139
+ const { content, sandbox_id, history, pending_action } = req.body;
140
+ if (!content) {
141
+ const response = { success: false, error: 'Content is required' };
142
+ return res.status(400).json(response);
143
+ }
144
+ const timestamp = now();
145
+ const chatId = uuidv4();
146
+ db.prepare('INSERT INTO chats (id, role, content, created_at) VALUES (?, ?, ?, ?)').run(chatId, 'user', content, timestamp);
147
+ if (sandbox_id) {
148
+ db.prepare('INSERT OR IGNORE INTO chat_sandbox_relations (chat_id, sandbox_id) VALUES (?, ?)').run(chatId, sandbox_id);
149
+ }
150
+ const sandbox = sandbox_id ? db.prepare('SELECT * FROM sandboxes WHERE id = ?').get(sandbox_id) : undefined;
151
+ const context = {
152
+ sandboxId: sandbox_id,
153
+ sandboxName: sandbox?.name,
154
+ history: (history || []).map((h) => ({ role: h.role, content: h.content })),
155
+ pendingAction: pending_action || null
156
+ };
157
+ const action = pending_action && isExecuteIntent(content)
158
+ ? {
159
+ thought: '用户确认执行待处理操作',
160
+ action: 'done',
161
+ action_type: pending_action.action_type,
162
+ action_input: pending_action.action_input,
163
+ batch_actions: pending_action.batch_actions,
164
+ }
165
+ : pending_action && isCancelIntent(content)
166
+ ? {
167
+ thought: '用户取消待处理操作',
168
+ action: 'stop',
169
+ observation: '已取消操作',
170
+ }
171
+ : await processMessage(content, context);
172
+ let operationId = null;
173
+ let actionToExecute = action;
174
+ const shouldExecute = action.action === 'done' || action.action === 'confirm';
175
+ if (shouldExecute) {
176
+ if (action.action_type && action.action_input) {
177
+ actionToExecute = action;
178
+ }
179
+ else if (Array.isArray(pending_action?.batch_actions) && pending_action.batch_actions.length > 0) {
180
+ actionToExecute = { ...action, batch_actions: pending_action.batch_actions };
181
+ }
182
+ else if (pending_action && pending_action.action_type && pending_action.action_input) {
183
+ actionToExecute = { ...action, action_type: pending_action.action_type, action_input: pending_action.action_input };
184
+ }
185
+ }
186
+ let batchActions = Array.isArray(actionToExecute.batch_actions)
187
+ ? actionToExecute.batch_actions
188
+ : [];
189
+ let supplementedNames = [];
190
+ if (actionToExecute.action === 'done' && batchActions.length > 0) {
191
+ const supplemented = supplementBatchCreateActionsByContent(batchActions, content);
192
+ batchActions = supplemented.batch_actions;
193
+ supplementedNames = supplemented.supplemented_names;
194
+ if (supplementedNames.length > 0) {
195
+ actionToExecute = { ...actionToExecute, batch_actions: batchActions };
196
+ action.batch_actions = batchActions;
197
+ }
198
+ }
199
+ const shouldExecuteBatch = actionToExecute.action === 'done' && batchActions.length > 0;
200
+ const shouldExecuteSingle = actionToExecute.action === 'done' && Boolean(actionToExecute.action_type && actionToExecute.action_input);
201
+ if (shouldExecuteBatch) {
202
+ try {
203
+ const { executeTool } = await import('../react/tools.js');
204
+ const results = [];
205
+ for (const batchAction of batchActions) {
206
+ const toolResult = executeTool(batchAction.action_type, batchAction.action_input);
207
+ results.push({ ...toolResult, action_type: batchAction.action_type });
208
+ }
209
+ const successCount = results.filter((result) => result.success).length;
210
+ const failed = results.filter((result) => !result.success);
211
+ const briefFailed = failed.slice(0, 3).map((result) => `${result.action_type}: ${result.observation}`).join(';');
212
+ const status = failed.length === 0
213
+ ? 'success'
214
+ : successCount === 0
215
+ ? 'failed'
216
+ : 'partial';
217
+ action.execution_result = {
218
+ status,
219
+ total: results.length,
220
+ success_count: successCount,
221
+ failure_count: failed.length,
222
+ failures: failed.map((result) => `${result.action_type}: ${result.observation}`),
223
+ };
224
+ action.observation = failed.length > 0
225
+ ? `批量执行完成:成功 ${successCount}/${results.length}。失败:${briefFailed}`
226
+ : `批量执行完成:成功 ${successCount}/${results.length}。`;
227
+ if (supplementedNames.length > 0) {
228
+ action.observation += `(已自动补全:${supplementedNames.join('、')})`;
229
+ }
230
+ const recentOp = db.prepare('SELECT id FROM operations WHERE sandbox_id = ? ORDER BY created_at DESC LIMIT 1').get(sandbox_id);
231
+ if (recentOp) {
232
+ operationId = recentOp.id;
233
+ }
234
+ }
235
+ catch (error) {
236
+ action.action = 'response';
237
+ action.observation = '';
238
+ action.response = `批量执行出错: ${error}`;
239
+ }
240
+ }
241
+ else if (shouldExecuteSingle) {
242
+ try {
243
+ const { executeTool } = await import('../react/tools.js');
244
+ const toolResult = executeTool(actionToExecute.action_type, actionToExecute.action_input);
245
+ if (toolResult.success) {
246
+ action.execution_result = {
247
+ status: 'success',
248
+ total: 1,
249
+ success_count: 1,
250
+ failure_count: 0,
251
+ failures: [],
252
+ };
253
+ action.observation = toolResult.observation;
254
+ const recentOp = db.prepare('SELECT id FROM operations WHERE sandbox_id = ? ORDER BY created_at DESC LIMIT 1').get(sandbox_id);
255
+ if (recentOp) {
256
+ operationId = recentOp.id;
257
+ }
258
+ }
259
+ else {
260
+ action.execution_result = {
261
+ status: 'failed',
262
+ total: 1,
263
+ success_count: 0,
264
+ failure_count: 1,
265
+ failures: [toolResult.observation],
266
+ };
267
+ action.action = 'response';
268
+ action.observation = '';
269
+ action.response = `执行失败: ${toolResult.observation}`;
270
+ }
271
+ }
272
+ catch (error) {
273
+ action.action = 'response';
274
+ action.observation = '';
275
+ action.response = `执行出错: ${error}`;
276
+ }
277
+ }
278
+ const assistantId = uuidv4();
279
+ const actionWithOp = { ...action, operationId };
280
+ db.prepare('INSERT INTO chats (id, role, content, created_at) VALUES (?, ?, ?, ?)').run(assistantId, 'assistant', JSON.stringify(actionWithOp), now());
281
+ if (sandbox_id) {
282
+ db.prepare('INSERT OR IGNORE INTO chat_sandbox_relations (chat_id, sandbox_id) VALUES (?, ?)').run(assistantId, sandbox_id);
283
+ }
284
+ const assistantChat = {
285
+ id: assistantId,
286
+ role: 'assistant',
287
+ content: JSON.stringify(actionWithOp),
288
+ created_at: now()
289
+ };
290
+ const response = {
291
+ success: true,
292
+ data: {
293
+ user: { id: chatId, role: 'user', content, created_at: timestamp },
294
+ assistant: assistantChat,
295
+ action,
296
+ related_sandboxes: sandbox_id ? [sandbox_id] : []
297
+ }
298
+ };
299
+ res.json(response);
300
+ }
301
+ catch (error) {
302
+ const response = { success: false, error: String(error) };
303
+ res.status(500).json(response);
304
+ }
305
+ });
306
+ router.post('/confirm', async (req, res) => {
307
+ try {
308
+ const { sandbox_id, confirm_items } = req.body;
309
+ if (!sandbox_id || !confirm_items || !Array.isArray(confirm_items)) {
310
+ const response = { success: false, error: 'Invalid parameters' };
311
+ return res.status(400).json(response);
312
+ }
313
+ const { executeTool } = await import('../react/tools.js');
314
+ const results = [];
315
+ for (const item of confirm_items) {
316
+ let actionType = '';
317
+ let actionInput = { sandbox_id };
318
+ if (item.type === '创建任务' || item.type === 'create_work_item') {
319
+ actionType = 'create_work_item';
320
+ actionInput.name = item.name;
321
+ if (item.description)
322
+ actionInput.description = item.description;
323
+ if (item.params?.parent_id)
324
+ actionInput.parent_id = item.params.parent_id;
325
+ }
326
+ else if (item.type === '更新任务' || item.type === 'update_work_item') {
327
+ actionType = 'update_work_item';
328
+ actionInput.task_id = item.task_id || item.params?.task_id;
329
+ if (item.name)
330
+ actionInput.name = item.name;
331
+ }
332
+ else if (item.type === '删除任务' || item.type === 'delete_work_item') {
333
+ actionType = 'delete_work_item';
334
+ actionInput.task_id = item.task_id || item.params?.task_id;
335
+ }
336
+ else if (item.type === '移动任务' || item.type === 'move_work_item') {
337
+ actionType = 'move_work_item';
338
+ actionInput.task_id = item.task_id || item.params?.task_id;
339
+ actionInput.new_parent_id = item.params?.new_parent_id;
340
+ }
341
+ if (actionType) {
342
+ const result = executeTool(actionType, actionInput);
343
+ results.push({
344
+ type: item.type,
345
+ name: item.name,
346
+ success: result.success,
347
+ message: result.observation
348
+ });
349
+ }
350
+ }
351
+ const response = {
352
+ success: true,
353
+ data: { results }
354
+ };
355
+ res.json(response);
356
+ }
357
+ catch (error) {
358
+ const response = { success: false, error: String(error) };
359
+ res.status(500).json(response);
360
+ }
361
+ });
362
+ router.post('/execute', async (req, res) => {
363
+ try {
364
+ const { sandbox_id, operations } = req.body;
365
+ if (!sandbox_id || !operations || !Array.isArray(operations)) {
366
+ const response = { success: false, error: 'Invalid parameters' };
367
+ return res.status(400).json(response);
368
+ }
369
+ const timestamp = now();
370
+ const results = [];
371
+ for (const op of operations) {
372
+ try {
373
+ if (op.action === 'create') {
374
+ const itemId = uuidv4();
375
+ db.prepare(`
376
+ INSERT INTO work_items (id, sandbox_id, parent_id, name, description, assignee, status, priority, tags, extra_data, created_at, updated_at)
377
+ VALUES (?, ?, NULL, ?, ?, '', 'pending', 'medium', '[]', '{}', ?, ?)
378
+ `).run(itemId, sandbox_id, op.name, op.description || '', timestamp, timestamp);
379
+ results.push({ action: 'create', name: op.name, success: true });
380
+ }
381
+ else if (op.action === 'update' && op.task_id) {
382
+ db.prepare(`
383
+ UPDATE work_items SET name = COALESCE(?, name), description = COALESCE(?, description), updated_at = ?
384
+ WHERE id = ?
385
+ `).run(op.name || null, op.description || null, timestamp, op.task_id);
386
+ results.push({ action: 'update', name: op.task_id, success: true });
387
+ }
388
+ else if (op.action === 'delete' && op.task_id) {
389
+ db.prepare('DELETE FROM work_items WHERE id = ?').run(op.task_id);
390
+ results.push({ action: 'delete', name: op.task_id, success: true });
391
+ }
392
+ }
393
+ catch (err) {
394
+ results.push({ action: op.action, name: op.name || op.task_id, success: false, error: String(err) });
395
+ }
396
+ }
397
+ db.prepare('UPDATE sandboxes SET updated_at = ? WHERE id = ?').run(timestamp, sandbox_id);
398
+ const response = {
399
+ success: true,
400
+ data: { results },
401
+ };
402
+ res.json(response);
403
+ }
404
+ catch (error) {
405
+ const response = { success: false, error: String(error) };
406
+ res.status(500).json(response);
407
+ }
408
+ });
409
+ router.get('/sandbox/:sandboxId/insight', async (req, res) => {
410
+ try {
411
+ const { sandboxId } = req.params;
412
+ const sandbox = db.prepare('SELECT id, name FROM sandboxes WHERE id = ?').get(sandboxId);
413
+ if (!sandbox) {
414
+ const response = { success: false, error: 'Sandbox not found' };
415
+ return res.status(404).json(response);
416
+ }
417
+ const items = db.prepare('SELECT name, status, priority, assignee FROM work_items WHERE sandbox_id = ? ORDER BY created_at DESC LIMIT 80').all(sandboxId);
418
+ const diaries = db.prepare('SELECT content, created_at FROM diaries WHERE sandbox_id = ? ORDER BY created_at DESC LIMIT 20').all(sandboxId);
419
+ const fallback = [
420
+ `沙盘:${sandbox.name}`,
421
+ `任务总数 ${items.length},完成 ${items.filter((i) => i.status === 'done').length},进行中 ${items.filter((i) => i.status === 'in_progress').length},待处理 ${items.filter((i) => i.status === 'pending').length}`,
422
+ `高优先级任务 ${items.filter((i) => i.priority === 'high').length} 项`,
423
+ diaries.length ? `最近日记:${diaries[0].content}` : '最近没有关联日记',
424
+ '建议:优先收敛高优先级且未完成任务,并将进行中任务拆分为可交付子结果。',
425
+ ].join('\n');
426
+ const prompt = `你是项目管理助手。请基于以下信息给出简洁、理性的中文总结,输出3段:
427
+ 1) 当前整体状态
428
+ 2) 关键变化与风险
429
+ 3) 下一步建议(3条)
430
+
431
+ 沙盘:${sandbox.name}
432
+ 任务:${JSON.stringify(items)}
433
+ 日记:${JSON.stringify(diaries)}
434
+ `;
435
+ const ai = await callAiText(prompt);
436
+ const insight = ai
437
+ && !ai.startsWith('AI configuration not found')
438
+ && !ai.startsWith('AI request')
439
+ && !ai.startsWith('AI error')
440
+ && !ai.startsWith('Network error')
441
+ ? ai
442
+ : fallback;
443
+ const response = { success: true, data: { insight } };
444
+ res.json(response);
445
+ }
446
+ catch (error) {
447
+ const response = { success: false, error: String(error) };
448
+ res.status(500).json(response);
449
+ }
450
+ });
451
+ router.get('/sandbox/:sandboxId', (req, res) => {
452
+ try {
453
+ const { sandboxId } = req.params;
454
+ const relations = db.prepare('SELECT chat_id FROM chat_sandbox_relations WHERE sandbox_id = ?').all(sandboxId);
455
+ const chatIds = relations.map(r => r.chat_id);
456
+ if (chatIds.length === 0) {
457
+ const response = { success: true, data: [] };
458
+ return res.json(response);
459
+ }
460
+ const placeholders = chatIds.map(() => '?').join(',');
461
+ const chats = db.prepare(`SELECT * FROM chats WHERE id IN (${placeholders}) ORDER BY created_at ASC`).all(...chatIds);
462
+ const diaries = db.prepare('SELECT * FROM diaries WHERE sandbox_id = ? ORDER BY created_at DESC LIMIT 50').all(sandboxId);
463
+ const merged = [
464
+ ...chats.map(row => ({
465
+ id: row.id,
466
+ role: row.role,
467
+ content: row.content,
468
+ created_at: row.created_at,
469
+ })),
470
+ ...diaries.map(row => ({
471
+ type: 'diary',
472
+ content: row.content,
473
+ created_at: row.created_at,
474
+ })),
475
+ ].sort((a, b) => new Date(a.created_at).getTime() - new Date(b.created_at).getTime());
476
+ const response = { success: true, data: merged };
477
+ res.json(response);
478
+ }
479
+ catch (error) {
480
+ const response = { success: false, error: String(error) };
481
+ res.status(500).json(response);
482
+ }
483
+ });
484
+ export default router;
485
+ //# sourceMappingURL=chat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat.js","sourceRoot":"","sources":["../../../src/server/api/chat.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ declare const router: import("express-serve-static-core").Router;
2
+ export default router;
3
+ //# sourceMappingURL=diary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diary.d.ts","sourceRoot":"","sources":["../../../src/server/api/diary.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,MAAM,4CAAW,CAAC;AAwGxB,eAAe,MAAM,CAAC"}
@@ -0,0 +1,102 @@
1
+ import { Router } from 'express';
2
+ import { v4 as uuidv4 } from 'uuid';
3
+ import { db } from '../db.js';
4
+ const router = Router();
5
+ function now() {
6
+ return new Date().toISOString();
7
+ }
8
+ router.get('/', (req, res) => {
9
+ try {
10
+ const { sandbox_id, processed } = req.query;
11
+ let sql = 'SELECT * FROM diaries WHERE 1=1';
12
+ const params = [];
13
+ if (sandbox_id) {
14
+ sql += ' AND sandbox_id = ?';
15
+ params.push(sandbox_id);
16
+ }
17
+ if (processed !== undefined) {
18
+ sql += ' AND processed = ?';
19
+ params.push(processed === 'true' ? 1 : 0);
20
+ }
21
+ sql += ' ORDER BY created_at DESC';
22
+ const diaries = db.prepare(sql).all(...params);
23
+ const result = diaries.map(row => ({
24
+ id: row.id,
25
+ sandbox_id: row.sandbox_id,
26
+ work_item_id: row.work_item_id,
27
+ content: row.content,
28
+ processed: Boolean(row.processed),
29
+ created_at: row.created_at,
30
+ }));
31
+ const response = { success: true, data: result };
32
+ res.json(response);
33
+ }
34
+ catch (error) {
35
+ const response = { success: false, error: String(error) };
36
+ res.status(500).json(response);
37
+ }
38
+ });
39
+ router.get('/:id', (req, res) => {
40
+ try {
41
+ const diary = db.prepare('SELECT * FROM diaries WHERE id = ?').get(req.params.id);
42
+ if (!diary) {
43
+ const response = { success: false, error: 'Diary not found' };
44
+ return res.status(404).json(response);
45
+ }
46
+ const result = {
47
+ id: diary.id,
48
+ sandbox_id: diary.sandbox_id,
49
+ work_item_id: diary.work_item_id,
50
+ content: diary.content,
51
+ processed: Boolean(diary.processed),
52
+ created_at: diary.created_at,
53
+ };
54
+ const response = { success: true, data: result };
55
+ res.json(response);
56
+ }
57
+ catch (error) {
58
+ const response = { success: false, error: String(error) };
59
+ res.status(500).json(response);
60
+ }
61
+ });
62
+ router.post('/', (req, res) => {
63
+ try {
64
+ const { sandbox_id = null, work_item_id = null, content } = req.body;
65
+ if (!content) {
66
+ const response = { success: false, error: 'Content is required' };
67
+ return res.status(400).json(response);
68
+ }
69
+ const id = uuidv4();
70
+ const timestamp = now();
71
+ db.prepare('INSERT INTO diaries (id, sandbox_id, work_item_id, content, processed, created_at) VALUES (?, ?, ?, ?, 0, ?)').run(id, sandbox_id, work_item_id, content, timestamp);
72
+ const diary = { id, sandbox_id, work_item_id, content, processed: false, created_at: timestamp };
73
+ const response = { success: true, data: diary };
74
+ res.status(201).json(response);
75
+ }
76
+ catch (error) {
77
+ const response = { success: false, error: String(error) };
78
+ res.status(500).json(response);
79
+ }
80
+ });
81
+ router.put('/:id/process', (req, res) => {
82
+ try {
83
+ const { action } = req.body;
84
+ if (action !== 'confirm' && action !== 'ignore') {
85
+ const response = { success: false, error: 'Invalid action' };
86
+ return res.status(400).json(response);
87
+ }
88
+ const result = db.prepare('UPDATE diaries SET processed = 1 WHERE id = ?').run(req.params.id);
89
+ if (result.changes === 0) {
90
+ const response = { success: false, error: 'Diary not found' };
91
+ return res.status(404).json(response);
92
+ }
93
+ const response = { success: true, data: { action } };
94
+ res.json(response);
95
+ }
96
+ catch (error) {
97
+ const response = { success: false, error: String(error) };
98
+ res.status(500).json(response);
99
+ }
100
+ });
101
+ export default router;
102
+ //# sourceMappingURL=diary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diary.js","sourceRoot":"","sources":["../../../src/server/api/diary.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ declare const router: import("express-serve-static-core").Router;
2
+ export default router;
3
+ //# sourceMappingURL=sandbox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sandbox.d.ts","sourceRoot":"","sources":["../../../src/server/api/sandbox.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,MAAM,4CAAW,CAAC;AAoFxB,eAAe,MAAM,CAAC"}