claude-self-reflect 1.3.5 → 2.2.1

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 (60) hide show
  1. package/.claude/agents/README.md +138 -0
  2. package/.claude/agents/docker-orchestrator.md +264 -0
  3. package/.claude/agents/documentation-writer.md +262 -0
  4. package/.claude/agents/import-debugger.md +203 -0
  5. package/.claude/agents/mcp-integration.md +286 -0
  6. package/.claude/agents/open-source-maintainer.md +150 -0
  7. package/.claude/agents/performance-tuner.md +276 -0
  8. package/.claude/agents/qdrant-specialist.md +138 -0
  9. package/.claude/agents/reflection-specialist.md +361 -0
  10. package/.claude/agents/search-optimizer.md +307 -0
  11. package/LICENSE +21 -0
  12. package/README.md +128 -0
  13. package/installer/cli.js +122 -0
  14. package/installer/postinstall.js +13 -0
  15. package/installer/setup-wizard.js +204 -0
  16. package/mcp-server/pyproject.toml +27 -0
  17. package/mcp-server/run-mcp.sh +21 -0
  18. package/mcp-server/src/__init__.py +1 -0
  19. package/mcp-server/src/__main__.py +23 -0
  20. package/mcp-server/src/server.py +316 -0
  21. package/mcp-server/src/server_v2.py +240 -0
  22. package/package.json +12 -36
  23. package/scripts/import-conversations-isolated.py +311 -0
  24. package/scripts/import-conversations-voyage-streaming.py +377 -0
  25. package/scripts/import-conversations-voyage.py +428 -0
  26. package/scripts/import-conversations.py +240 -0
  27. package/scripts/import-current-conversation.py +38 -0
  28. package/scripts/import-live-conversation.py +152 -0
  29. package/scripts/import-openai-enhanced.py +867 -0
  30. package/scripts/import-recent-only.py +29 -0
  31. package/scripts/import-single-project.py +278 -0
  32. package/scripts/import-watcher.py +169 -0
  33. package/config/claude-desktop-config.json +0 -12
  34. package/dist/cli.d.ts +0 -3
  35. package/dist/cli.d.ts.map +0 -1
  36. package/dist/cli.js +0 -55
  37. package/dist/cli.js.map +0 -1
  38. package/dist/embeddings-gemini.d.ts +0 -76
  39. package/dist/embeddings-gemini.d.ts.map +0 -1
  40. package/dist/embeddings-gemini.js +0 -158
  41. package/dist/embeddings-gemini.js.map +0 -1
  42. package/dist/embeddings.d.ts +0 -67
  43. package/dist/embeddings.d.ts.map +0 -1
  44. package/dist/embeddings.js +0 -252
  45. package/dist/embeddings.js.map +0 -1
  46. package/dist/index.d.ts +0 -3
  47. package/dist/index.d.ts.map +0 -1
  48. package/dist/index.js +0 -439
  49. package/dist/index.js.map +0 -1
  50. package/dist/project-isolation.d.ts +0 -29
  51. package/dist/project-isolation.d.ts.map +0 -1
  52. package/dist/project-isolation.js +0 -78
  53. package/dist/project-isolation.js.map +0 -1
  54. package/scripts/install-agent.js +0 -70
  55. package/scripts/setup-wizard.js +0 -596
  56. package/src/cli.ts +0 -56
  57. package/src/embeddings-gemini.ts +0 -176
  58. package/src/embeddings.ts +0 -296
  59. package/src/index.ts +0 -513
  60. package/src/project-isolation.ts +0 -93
@@ -1,596 +0,0 @@
1
- #!/usr/bin/env node
2
- import readline from 'readline';
3
- import { execSync, spawn } from 'child_process';
4
- import { existsSync, mkdirSync, writeFileSync, readFileSync } from 'fs';
5
- import { join, dirname } from 'path';
6
- import { fileURLToPath } from 'url';
7
- import { homedir } from 'os';
8
- import https from 'https';
9
-
10
- const __filename = fileURLToPath(import.meta.url);
11
- const __dirname = dirname(__filename);
12
-
13
- const rl = readline.createInterface({
14
- input: process.stdin,
15
- output: process.stdout
16
- });
17
-
18
- // ANSI color codes
19
- const colors = {
20
- reset: '\x1b[0m',
21
- green: '\x1b[32m',
22
- yellow: '\x1b[33m',
23
- blue: '\x1b[34m',
24
- red: '\x1b[31m',
25
- cyan: '\x1b[36m'
26
- };
27
-
28
- function question(prompt) {
29
- return new Promise((resolve) => {
30
- rl.question(prompt, resolve);
31
- });
32
- }
33
-
34
- function success(message) {
35
- console.log(`${colors.green}✅ ${message}${colors.reset}`);
36
- }
37
-
38
- function info(message) {
39
- console.log(`${colors.blue}ℹ️ ${message}${colors.reset}`);
40
- }
41
-
42
- function warning(message) {
43
- console.log(`${colors.yellow}⚠️ ${message}${colors.reset}`);
44
- }
45
-
46
- function error(message) {
47
- console.log(`${colors.red}❌ ${message}${colors.reset}`);
48
- }
49
-
50
- function header(message) {
51
- console.log(`\n${colors.cyan}${'='.repeat(60)}${colors.reset}`);
52
- console.log(`${colors.cyan}${message}${colors.reset}`);
53
- console.log(`${colors.cyan}${'='.repeat(60)}${colors.reset}\n`);
54
- }
55
-
56
- async function checkCommand(command) {
57
- try {
58
- execSync(`which ${command}`, { stdio: 'ignore' });
59
- return true;
60
- } catch {
61
- return false;
62
- }
63
- }
64
-
65
- async function checkDocker() {
66
- if (!await checkCommand('docker')) {
67
- return { installed: false };
68
- }
69
-
70
- try {
71
- execSync('docker info', { stdio: 'ignore' });
72
- return { installed: true, running: true };
73
- } catch {
74
- return { installed: true, running: false };
75
- }
76
- }
77
-
78
- async function checkPython() {
79
- const commands = ['python3', 'python'];
80
- for (const cmd of commands) {
81
- if (await checkCommand(cmd)) {
82
- try {
83
- const version = execSync(`${cmd} --version`, { encoding: 'utf8' }).trim();
84
- return { installed: true, command: cmd, version };
85
- } catch {}
86
- }
87
- }
88
- return { installed: false };
89
- }
90
-
91
- async function validateApiKey(provider, apiKey) {
92
- return new Promise((resolve) => {
93
- if (!apiKey || apiKey.length < 10) {
94
- resolve(false);
95
- return;
96
- }
97
-
98
- let options;
99
- switch (provider) {
100
- case 'voyage':
101
- options = {
102
- hostname: 'api.voyageai.com',
103
- path: '/v1/models',
104
- method: 'GET',
105
- headers: {
106
- 'Authorization': `Bearer ${apiKey}`
107
- }
108
- };
109
- break;
110
- case 'openai':
111
- options = {
112
- hostname: 'api.openai.com',
113
- path: '/v1/models',
114
- method: 'GET',
115
- headers: {
116
- 'Authorization': `Bearer ${apiKey}`
117
- }
118
- };
119
- break;
120
- case 'gemini':
121
- // Gemini uses a different validation approach
122
- resolve(apiKey.startsWith('AI') && apiKey.length > 20);
123
- return;
124
- default:
125
- resolve(true);
126
- return;
127
- }
128
-
129
- const req = https.request(options, (res) => {
130
- resolve(res.statusCode === 200);
131
- });
132
-
133
- req.on('error', () => resolve(false));
134
- req.setTimeout(5000, () => {
135
- req.destroy();
136
- resolve(false);
137
- });
138
- req.end();
139
- });
140
- }
141
-
142
- async function setupQdrant() {
143
- header('Setting up Qdrant Vector Database');
144
-
145
- const docker = await checkDocker();
146
-
147
- if (!docker.installed) {
148
- error('Docker is not installed');
149
- console.log('\nTo install Docker:');
150
- console.log('1. Visit https://docs.docker.com/get-docker/');
151
- console.log('2. Download Docker Desktop for your platform');
152
- console.log('3. Run the installer and start Docker');
153
- console.log('4. Run this setup again\n');
154
-
155
- const proceed = await question('Would you like to continue without Docker? (y/n): ');
156
- if (proceed.toLowerCase() !== 'y') {
157
- return false;
158
- }
159
-
160
- warning('Continuing without vector database - search functionality will be limited');
161
- return true;
162
- }
163
-
164
- if (!docker.running) {
165
- error('Docker is installed but not running');
166
- console.log('Please start Docker Desktop and run this setup again\n');
167
- return false;
168
- }
169
-
170
- // Check if Qdrant is already running
171
- try {
172
- execSync('docker ps | grep qdrant', { stdio: 'ignore' });
173
- success('Qdrant is already running');
174
- return true;
175
- } catch {
176
- // Not running, let's start it
177
- }
178
-
179
- info('Starting Qdrant container...');
180
- try {
181
- execSync('docker run -d --name qdrant -p 6333:6333 --restart always qdrant/qdrant:latest', {
182
- stdio: 'inherit'
183
- });
184
- success('Qdrant started successfully');
185
- return true;
186
- } catch (err) {
187
- // Container might already exist but be stopped
188
- try {
189
- execSync('docker start qdrant', { stdio: 'inherit' });
190
- success('Qdrant restarted successfully');
191
- return true;
192
- } catch {
193
- error('Failed to start Qdrant');
194
- return false;
195
- }
196
- }
197
- }
198
-
199
- async function selectEmbeddingProvider() {
200
- header('Choose Your Embedding Provider');
201
-
202
- console.log('Embedding models convert your conversations into searchable vectors.\n');
203
-
204
- console.log(`${colors.green}1. Voyage AI (Recommended)${colors.reset}`);
205
- console.log(' ✅ 200M tokens FREE - covers most users completely');
206
- console.log(' ✅ Best quality for conversation search');
207
- console.log(' ✅ Only $0.02/1M tokens after free tier\n');
208
-
209
- console.log(`${colors.blue}2. Google Gemini${colors.reset}`);
210
- console.log(' ✅ Completely FREE (unlimited usage)');
211
- console.log(' ⚠️ Your data used to improve Google products');
212
- console.log(' ✅ Good multilingual support\n');
213
-
214
- console.log(`${colors.yellow}3. Local Processing${colors.reset}`);
215
- console.log(' ✅ Completely FREE, works offline');
216
- console.log(' ✅ No API keys, no data sharing');
217
- console.log(' ⚠️ Lower quality results, slower processing\n');
218
-
219
- console.log(`${colors.cyan}4. OpenAI${colors.reset}`);
220
- console.log(' ❌ No free tier');
221
- console.log(' ✅ $0.02/1M tokens (same as Voyage paid)');
222
- console.log(' ✅ Good quality, established ecosystem\n');
223
-
224
- const choice = await question('Enter your choice (1-4): ');
225
-
226
- switch (choice) {
227
- case '1': return 'voyage';
228
- case '2': return 'gemini';
229
- case '3': return 'local';
230
- case '4': return 'openai';
231
- default:
232
- warning('Invalid choice, defaulting to Voyage AI');
233
- return 'voyage';
234
- }
235
- }
236
-
237
- async function getApiKey(provider) {
238
- if (provider === 'local') return null;
239
-
240
- const urls = {
241
- voyage: 'https://dash.voyageai.com/',
242
- gemini: 'https://ai.google.dev/gemini-api/docs',
243
- openai: 'https://platform.openai.com/api-keys'
244
- };
245
-
246
- console.log(`\nTo get your API key, visit: ${colors.blue}${urls[provider]}${colors.reset}`);
247
-
248
- let apiKey;
249
- let valid = false;
250
-
251
- while (!valid) {
252
- apiKey = await question(`Enter your ${provider.toUpperCase()} API key: `);
253
-
254
- if (!apiKey) {
255
- const skip = await question('Skip API key for now? (y/n): ');
256
- if (skip.toLowerCase() === 'y') {
257
- return null;
258
- }
259
- continue;
260
- }
261
-
262
- info('Validating API key...');
263
- valid = await validateApiKey(provider, apiKey);
264
-
265
- if (valid) {
266
- success('API key validated successfully');
267
- } else {
268
- error('Invalid API key. Please check and try again.');
269
- }
270
- }
271
-
272
- return apiKey;
273
- }
274
-
275
- async function setupPython() {
276
- header('Setting up Python Dependencies');
277
-
278
- const python = await checkPython();
279
-
280
- if (!python.installed) {
281
- error('Python is not installed');
282
- console.log('\nTo install Python:');
283
- console.log('1. Visit https://www.python.org/downloads/');
284
- console.log('2. Download Python 3.8 or later');
285
- console.log('3. Run the installer\n');
286
- return false;
287
- }
288
-
289
- success(`Found ${python.version}`);
290
-
291
- // Clone the repository if needed
292
- const repoPath = join(homedir(), '.claude-self-reflect');
293
-
294
- if (!existsSync(repoPath)) {
295
- info('Downloading import scripts...');
296
- try {
297
- execSync(`git clone https://github.com/ramakay/claude-self-reflect.git "${repoPath}"`, {
298
- stdio: 'inherit'
299
- });
300
- success('Downloaded import scripts');
301
- } catch {
302
- error('Failed to download import scripts');
303
- return false;
304
- }
305
- }
306
-
307
- // Install Python dependencies
308
- info('Installing Python dependencies...');
309
- const requirementsPath = join(repoPath, 'scripts', 'requirements.txt');
310
-
311
- try {
312
- execSync(`${python.command} -m pip install -r "${requirementsPath}"`, {
313
- stdio: 'inherit',
314
- cwd: repoPath
315
- });
316
- success('Python dependencies installed');
317
- return { command: python.command, repoPath };
318
- } catch {
319
- error('Failed to install Python dependencies');
320
- warning('You may need to install pip or run with administrator privileges');
321
- return false;
322
- }
323
- }
324
-
325
- async function configureMemoryDecay() {
326
- header('Configure Memory Decay (Optional)');
327
-
328
- console.log('Memory Decay helps prioritize recent conversations over older ones.\n');
329
- console.log('When enabled, search results will favor more recent memories while');
330
- console.log('still including relevant older content.\n');
331
-
332
- const enable = await question('Enable memory decay? (y/n) [default: n]: ');
333
-
334
- if (enable.toLowerCase() === 'y') {
335
- console.log('\nDecay Configuration:');
336
- console.log('1. Light decay (30 days) - Minimal recency bias');
337
- console.log('2. Medium decay (90 days) - Balanced approach (Recommended)');
338
- console.log('3. Strong decay (180 days) - Strong recency preference');
339
- console.log('4. Custom configuration\n');
340
-
341
- const choice = await question('Choose decay configuration (1-4) [default: 2]: ') || '2';
342
-
343
- let weight = 0.3;
344
- let scaleDays = 90;
345
-
346
- switch (choice) {
347
- case '1':
348
- weight = 0.1;
349
- scaleDays = 30;
350
- break;
351
- case '2':
352
- weight = 0.3;
353
- scaleDays = 90;
354
- break;
355
- case '3':
356
- weight = 0.5;
357
- scaleDays = 180;
358
- break;
359
- case '4':
360
- const customWeight = await question('Decay weight (0.1-1.0) [default: 0.3]: ');
361
- const customScale = await question('Decay scale in days [default: 90]: ');
362
- weight = parseFloat(customWeight) || 0.3;
363
- scaleDays = parseInt(customScale) || 90;
364
- break;
365
- }
366
-
367
- success(`Memory decay configured: weight=${weight}, scale=${scaleDays} days`);
368
- return { enabled: true, weight, scaleDays };
369
- }
370
-
371
- return { enabled: false };
372
- }
373
-
374
- async function saveConfiguration(config) {
375
- const envPath = join(homedir(), '.claude-self-reflect', '.env');
376
- const envDir = dirname(envPath);
377
-
378
- if (!existsSync(envDir)) {
379
- mkdirSync(envDir, { recursive: true });
380
- }
381
-
382
- let envContent = '# Claude Self-Reflect Configuration\n';
383
- envContent += '# Generated by setup wizard\n\n';
384
-
385
- if (config.provider === 'voyage' && config.apiKey) {
386
- envContent += `VOYAGE_API_KEY="${config.apiKey}"\n`;
387
- } else if (config.provider === 'gemini' && config.apiKey) {
388
- envContent += `GEMINI_API_KEY="${config.apiKey}"\n`;
389
- } else if (config.provider === 'openai' && config.apiKey) {
390
- envContent += `OPENAI_API_KEY="${config.apiKey}"\n`;
391
- } else if (config.provider === 'local') {
392
- envContent += 'USE_LOCAL_EMBEDDINGS=true\n';
393
- }
394
-
395
- envContent += 'QDRANT_URL=http://localhost:6333\n';
396
-
397
- // Memory decay configuration
398
- envContent += '\n# Memory Decay Configuration\n';
399
- envContent += `ENABLE_MEMORY_DECAY=${config.memoryDecay?.enabled ? 'true' : 'false'}\n`;
400
- if (config.memoryDecay?.enabled) {
401
- envContent += `DECAY_WEIGHT=${config.memoryDecay.weight}\n`;
402
- envContent += `DECAY_SCALE_DAYS=${config.memoryDecay.scaleDays}\n`;
403
- }
404
-
405
- writeFileSync(envPath, envContent);
406
- success(`Configuration saved to ${envPath}`);
407
- }
408
-
409
- async function runImport(pythonConfig, provider, apiKey) {
410
- header('Importing Conversation History');
411
-
412
- const claudeLogsPath = join(homedir(), '.claude', 'projects');
413
-
414
- if (!existsSync(claudeLogsPath)) {
415
- warning('No Claude conversation logs found at ~/.claude/projects');
416
- console.log('Make sure you have used Claude Desktop and have some conversations');
417
- return;
418
- }
419
-
420
- info('Scanning for conversation files...');
421
- const scriptPath = join(pythonConfig.repoPath, 'scripts', 'import-openai-enhanced.py');
422
-
423
- // Set environment variables for the import
424
- const env = { ...process.env };
425
- if (provider === 'voyage' && apiKey) {
426
- env.VOYAGE_API_KEY = apiKey;
427
- } else if (provider === 'gemini' && apiKey) {
428
- env.GEMINI_API_KEY = apiKey;
429
- } else if (provider === 'openai' && apiKey) {
430
- env.OPENAI_API_KEY = apiKey;
431
- } else if (provider === 'local') {
432
- env.USE_LOCAL_EMBEDDINGS = 'true';
433
- }
434
-
435
- const importProcess = spawn(pythonConfig.command, [scriptPath], {
436
- cwd: pythonConfig.repoPath,
437
- env,
438
- stdio: 'inherit'
439
- });
440
-
441
- return new Promise((resolve) => {
442
- importProcess.on('close', (code) => {
443
- if (code === 0) {
444
- success('Import completed successfully');
445
- resolve(true);
446
- } else {
447
- error('Import failed');
448
- resolve(false);
449
- }
450
- });
451
- });
452
- }
453
-
454
- async function setupClaudeDesktop(memoryDecayConfig) {
455
- header('Configure Claude Desktop (Optional)');
456
-
457
- console.log('To use this with Claude Desktop, add the following to your config:\n');
458
-
459
- const env = {
460
- QDRANT_URL: 'http://localhost:6333'
461
- };
462
-
463
- // Add memory decay configuration if enabled
464
- if (memoryDecayConfig?.enabled) {
465
- env.ENABLE_MEMORY_DECAY = 'true';
466
- env.DECAY_WEIGHT = memoryDecayConfig.weight.toString();
467
- env.DECAY_SCALE_DAYS = memoryDecayConfig.scaleDays.toString();
468
- }
469
-
470
- const config = {
471
- mcpServers: {
472
- 'claude-self-reflect': {
473
- command: 'npx',
474
- args: ['claude-self-reflect'],
475
- env
476
- }
477
- }
478
- };
479
-
480
- console.log(JSON.stringify(config, null, 2));
481
-
482
- console.log('\nConfig file location:');
483
- console.log('- macOS: ~/Library/Application Support/Claude/claude_desktop_config.json');
484
- console.log('- Windows: %APPDATA%\\Claude\\claude_desktop_config.json');
485
- console.log('- Linux: ~/.config/Claude/claude_desktop_config.json\n');
486
-
487
- const configure = await question('Would you like to automatically configure Claude Desktop? (y/n): ');
488
-
489
- if (configure.toLowerCase() === 'y') {
490
- // Detect platform and find config file
491
- const platform = process.platform;
492
- let configPath;
493
-
494
- if (platform === 'darwin') {
495
- configPath = join(homedir(), 'Library', 'Application Support', 'Claude', 'claude_desktop_config.json');
496
- } else if (platform === 'win32') {
497
- configPath = join(process.env.APPDATA, 'Claude', 'claude_desktop_config.json');
498
- } else {
499
- configPath = join(homedir(), '.config', 'Claude', 'claude_desktop_config.json');
500
- }
501
-
502
- try {
503
- let existingConfig = {};
504
- if (existsSync(configPath)) {
505
- existingConfig = JSON.parse(readFileSync(configPath, 'utf8'));
506
- }
507
-
508
- // Merge configurations
509
- existingConfig.mcpServers = existingConfig.mcpServers || {};
510
- existingConfig.mcpServers['claude-self-reflect'] = config.mcpServers['claude-self-reflect'];
511
-
512
- // Ensure directory exists
513
- mkdirSync(dirname(configPath), { recursive: true });
514
-
515
- // Write config
516
- writeFileSync(configPath, JSON.stringify(existingConfig, null, 2));
517
- success('Claude Desktop configured successfully');
518
- info('Restart Claude Desktop to use the new configuration');
519
- } catch (err) {
520
- error('Failed to configure Claude Desktop automatically');
521
- console.log('Please add the configuration manually');
522
- }
523
- }
524
- }
525
-
526
- async function main() {
527
- console.clear();
528
- header('🚀 Claude Self-Reflect Setup Wizard');
529
-
530
- console.log('This wizard will help you set up Claude Self-Reflect in just a few minutes.\n');
531
-
532
- // Step 1: Check and setup Qdrant
533
- const qdrantOk = await setupQdrant();
534
- if (!qdrantOk) {
535
- error('Setup incomplete. Please fix the issues and try again.');
536
- rl.close();
537
- process.exit(1);
538
- }
539
-
540
- // Step 2: Select embedding provider
541
- const provider = await selectEmbeddingProvider();
542
-
543
- // Step 3: Get API key
544
- const apiKey = await getApiKey(provider);
545
-
546
- // Step 4: Setup Python
547
- const pythonConfig = await setupPython();
548
- if (!pythonConfig) {
549
- error('Setup incomplete. Please fix the issues and try again.');
550
- rl.close();
551
- process.exit(1);
552
- }
553
-
554
- // Step 5: Configure memory decay
555
- const memoryDecay = await configureMemoryDecay();
556
-
557
- // Step 6: Save configuration
558
- await saveConfiguration({ provider, apiKey, memoryDecay });
559
-
560
- // Step 7: Run import
561
- if (apiKey || provider === 'local') {
562
- const runImportNow = await question('\nWould you like to import your conversation history now? (y/n): ');
563
- if (runImportNow.toLowerCase() === 'y') {
564
- await runImport(pythonConfig, provider, apiKey);
565
- }
566
- }
567
-
568
- // Step 8: Configure Claude Desktop
569
- await setupClaudeDesktop(memoryDecay);
570
-
571
- // Done!
572
- header('✨ Setup Complete!');
573
-
574
- console.log('Next steps:');
575
- console.log('1. If using Claude Code, the reflection agent is already available');
576
- console.log('2. Try asking: "Find our previous discussions about [topic]"');
577
- console.log('3. To re-run import later: python scripts/import-openai-enhanced.py\n');
578
-
579
- success('Happy reflecting! 🎉');
580
-
581
- rl.close();
582
- }
583
-
584
- // Handle errors gracefully
585
- process.on('unhandledRejection', (error) => {
586
- console.error('\nSetup failed with error:', error);
587
- rl.close();
588
- process.exit(1);
589
- });
590
-
591
- // Run the wizard
592
- main().catch((error) => {
593
- console.error('\nSetup failed:', error);
594
- rl.close();
595
- process.exit(1);
596
- });
package/src/cli.ts DELETED
@@ -1,56 +0,0 @@
1
- #!/usr/bin/env node
2
- import { spawn } from 'child_process';
3
- import { fileURLToPath } from 'url';
4
- import { dirname, join } from 'path';
5
- import { readFileSync } from 'fs';
6
-
7
- const __filename = fileURLToPath(import.meta.url);
8
- const __dirname = dirname(__filename);
9
-
10
- // Handle command line arguments
11
- const args = process.argv.slice(2);
12
- const command = args[0];
13
-
14
- if (command === 'setup') {
15
- // Run the setup wizard
16
- const setupPath = join(__dirname, '..', 'scripts', 'setup-wizard.js');
17
- const child = spawn('node', [setupPath], {
18
- stdio: 'inherit'
19
- });
20
-
21
- child.on('error', (error) => {
22
- console.error('Failed to start setup wizard:', error);
23
- process.exit(1);
24
- });
25
-
26
- child.on('exit', (code) => {
27
- process.exit(code || 0);
28
- });
29
- } else if (command === '--version' || command === '-v') {
30
- // Read package.json to get version
31
- const packagePath = join(__dirname, '..', 'package.json');
32
- const pkg = JSON.parse(readFileSync(packagePath, 'utf8'));
33
- console.log(pkg.version);
34
- } else if (command === '--help' || command === '-h' || !command) {
35
- console.log(`
36
- Claude Self-Reflect - Give Claude perfect memory of all your conversations
37
-
38
- Usage:
39
- claude-self-reflect <command>
40
-
41
- Commands:
42
- setup Run the interactive setup wizard
43
-
44
- Options:
45
- --version Show version number
46
- --help Show this help message
47
-
48
- Examples:
49
- claude-self-reflect setup # Run interactive setup
50
- npx claude-self-reflect setup # Run without installing globally
51
- `);
52
- } else {
53
- console.error(`Unknown command: ${command}`);
54
- console.error('Run "claude-self-reflect --help" for usage information');
55
- process.exit(1);
56
- }