@oflow-ai/oflow-cli 0.1.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.
@@ -0,0 +1,467 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.isSlashCommand = isSlashCommand;
40
+ exports.executeSlashCommand = executeSlashCommand;
41
+ const chalk_1 = __importDefault(require("chalk"));
42
+ const core_1 = require("@oflow-ai/core");
43
+ const fs = __importStar(require("fs"));
44
+ const path = __importStar(require("path"));
45
+ function isSlashCommand(input) {
46
+ return input.startsWith('/');
47
+ }
48
+ async function executeSlashCommand(input, context) {
49
+ const [command, ...args] = input.split(' ');
50
+ const argString = args.join(' ');
51
+ switch (command.toLowerCase()) {
52
+ case '/help':
53
+ return showHelp();
54
+ case '/exit':
55
+ case '/quit':
56
+ case '/q':
57
+ return false;
58
+ case '/clear':
59
+ return clearConversation(context);
60
+ case '/init':
61
+ return initProject(context);
62
+ case '/model':
63
+ return showOrSetModel(argString, context);
64
+ case '/config':
65
+ return showConfig(context);
66
+ case '/reset':
67
+ return resetConfig(context);
68
+ case '/history':
69
+ return showHistory(context);
70
+ case '/tools':
71
+ return showTools();
72
+ case '/version':
73
+ return showVersion();
74
+ case '/agents':
75
+ return showAgents();
76
+ case '/sandbox':
77
+ return showSandboxInfo();
78
+ case '/skills':
79
+ return showSkills(argString);
80
+ case '/mcp':
81
+ return showMCPInfo();
82
+ case '/memory':
83
+ return showMemory();
84
+ case '/commit':
85
+ return generateCommit(context);
86
+ case '/review':
87
+ return reviewCode(context);
88
+ case '/thinking':
89
+ return toggleThinking(context);
90
+ default:
91
+ console.log(chalk_1.default.yellow(`Unknown command: ${command}`));
92
+ console.log(chalk_1.default.gray('Type /help for available commands.'));
93
+ return true;
94
+ }
95
+ }
96
+ function showHelp() {
97
+ console.log('');
98
+ console.log(chalk_1.default.bold('Available Commands:'));
99
+ console.log('');
100
+ const commands = [
101
+ { cmd: '/help', desc: 'Show this help message' },
102
+ { cmd: '/exit, /quit, /q', desc: 'Exit oflow CLI' },
103
+ { cmd: '/clear', desc: 'Clear conversation history' },
104
+ { cmd: '/init', desc: 'Analyze and initialize current project' },
105
+ { cmd: '/model [name]', desc: 'Show or set the current model' },
106
+ { cmd: '/thinking', desc: 'Toggle thinking process display (ON/OFF)' },
107
+ { cmd: '/config', desc: 'Show current configuration' },
108
+ { cmd: '/reset', desc: 'Reset configuration to defaults' },
109
+ { cmd: '/history', desc: 'Show conversation history' },
110
+ { cmd: '/tools', desc: 'List available tools' },
111
+ { cmd: '/agents', desc: 'List available sub-agents' },
112
+ { cmd: '/sandbox', desc: 'Show sandbox status' },
113
+ { cmd: '/skills [list|refresh]', desc: 'Manage skills' },
114
+ { cmd: '/mcp', desc: 'Show MCP server status' },
115
+ { cmd: '/memory', desc: 'Show saved memories' },
116
+ { cmd: '/commit', desc: 'Generate commit message' },
117
+ { cmd: '/review', desc: 'Review recent code changes' },
118
+ { cmd: '/version', desc: 'Show version information' }
119
+ ];
120
+ commands.forEach(({ cmd, desc }) => {
121
+ console.log(` ${chalk_1.default.cyan(cmd.padEnd(20))} ${chalk_1.default.gray(desc)}`);
122
+ });
123
+ console.log('');
124
+ console.log(chalk_1.default.bold('Special Syntax:'));
125
+ console.log(` ${chalk_1.default.cyan('!command')} ${chalk_1.default.gray('Execute a shell command')}`);
126
+ console.log(` ${chalk_1.default.cyan('@filepath')} ${chalk_1.default.gray('Reference a file in your message')}`);
127
+ console.log(` ${chalk_1.default.cyan('$agent')} ${chalk_1.default.gray('Call a sub-agent (e.g., $explore-agent "task")')}`);
128
+ console.log('');
129
+ return true;
130
+ }
131
+ function clearConversation(context) {
132
+ context.conversation.clear();
133
+ console.log(chalk_1.default.green('✓ Conversation history cleared.'));
134
+ return true;
135
+ }
136
+ async function initProject(context) {
137
+ const workingDir = process.cwd();
138
+ const projectName = path.basename(workingDir);
139
+ console.log(chalk_1.default.cyan(`\nAnalyzing project: ${projectName}\n`));
140
+ // Check for common project files
141
+ const checks = [
142
+ { file: 'package.json', type: 'Node.js' },
143
+ { file: 'tsconfig.json', type: 'TypeScript' },
144
+ { file: 'pyproject.toml', type: 'Python (modern)' },
145
+ { file: 'requirements.txt', type: 'Python' },
146
+ { file: 'Cargo.toml', type: 'Rust' },
147
+ { file: 'go.mod', type: 'Go' },
148
+ { file: 'pom.xml', type: 'Java (Maven)' },
149
+ { file: 'build.gradle', type: 'Java (Gradle)' },
150
+ { file: '.git', type: 'Git repository' }
151
+ ];
152
+ const detected = [];
153
+ for (const check of checks) {
154
+ const filePath = path.join(workingDir, check.file);
155
+ if (fs.existsSync(filePath)) {
156
+ detected.push(check.type);
157
+ }
158
+ }
159
+ if (detected.length > 0) {
160
+ console.log(chalk_1.default.bold('Detected project types:'));
161
+ detected.forEach(t => console.log(` • ${t}`));
162
+ }
163
+ else {
164
+ console.log(chalk_1.default.yellow('No recognized project type detected.'));
165
+ }
166
+ // List top-level files and directories
167
+ console.log(chalk_1.default.bold('\nProject structure:'));
168
+ const entries = fs.readdirSync(workingDir, { withFileTypes: true });
169
+ entries.slice(0, 20).forEach(entry => {
170
+ const prefix = entry.isDirectory() ? '📁 ' : '📄 ';
171
+ console.log(` ${prefix}${entry.name}`);
172
+ });
173
+ if (entries.length > 20) {
174
+ console.log(chalk_1.default.gray(` ... and ${entries.length - 20} more items`));
175
+ }
176
+ console.log('');
177
+ // Add init context to conversation
178
+ const initMessage = `Please analyze the current project structure and provide:
179
+ 1. A brief overview of the project type and purpose
180
+ 2. Key files and their roles
181
+ 3. Suggestions for improvements or best practices
182
+
183
+ Working directory: ${workingDir}
184
+ Detected types: ${detected.join(', ')}`;
185
+ try {
186
+ await context.conversation.sendMessage(initMessage);
187
+ }
188
+ catch (error) {
189
+ console.log(chalk_1.default.red('Error during analysis.'));
190
+ }
191
+ return true;
192
+ }
193
+ function showOrSetModel(modelName, context) {
194
+ if (modelName) {
195
+ context.configManager.setDefaultModel(modelName);
196
+ console.log(chalk_1.default.green(`✓ Model set to: ${modelName}`));
197
+ }
198
+ else {
199
+ const currentModel = context.configManager.getDefaultModel();
200
+ console.log(chalk_1.default.cyan(`Current model: ${currentModel}`));
201
+ console.log('');
202
+ console.log('Available models:');
203
+ const models = ['gpt-4o', 'gpt-4o-mini', 'gpt-4-turbo', 'gpt-3.5-turbo', 'o1-preview', 'o1-mini'];
204
+ models.forEach(m => {
205
+ if (m === currentModel) {
206
+ console.log(chalk_1.default.green(` * ${m} (current)`));
207
+ }
208
+ else {
209
+ console.log(` ${m}`);
210
+ }
211
+ });
212
+ }
213
+ return true;
214
+ }
215
+ function showConfig(context) {
216
+ const config = context.configManager.getAll();
217
+ console.log(chalk_1.default.bold('\nCurrent Configuration:'));
218
+ console.log(JSON.stringify(config, null, 2));
219
+ console.log('');
220
+ console.log(chalk_1.default.gray(`Config file: ${context.configManager.getConfigPath()}`));
221
+ return true;
222
+ }
223
+ function resetConfig(context) {
224
+ context.configManager.clear();
225
+ console.log(chalk_1.default.green('✓ Configuration reset to defaults.'));
226
+ console.log(chalk_1.default.yellow('You will need to run `oflow auth` to reconfigure authentication.'));
227
+ return false; // Exit to force re-auth
228
+ }
229
+ function showHistory(context) {
230
+ const messages = context.conversation.getMessages();
231
+ if (messages.length === 0) {
232
+ console.log(chalk_1.default.gray('No conversation history.'));
233
+ return true;
234
+ }
235
+ console.log(chalk_1.default.bold('\nConversation History:'));
236
+ console.log('');
237
+ messages.forEach((msg, index) => {
238
+ if (msg.role === 'system')
239
+ return;
240
+ const roleColors = {
241
+ user: chalk_1.default.green,
242
+ assistant: chalk_1.default.blue,
243
+ tool: chalk_1.default.gray
244
+ };
245
+ const color = roleColors[msg.role] || chalk_1.default.white;
246
+ const preview = typeof msg.content === 'string'
247
+ ? msg.content.substring(0, 100) + (msg.content.length > 100 ? '...' : '')
248
+ : '[complex content]';
249
+ console.log(`${index}. ${color(msg.role)}: ${preview}`);
250
+ });
251
+ console.log('');
252
+ return true;
253
+ }
254
+ function showTools() {
255
+ console.log(chalk_1.default.bold('\nAvailable Tools:'));
256
+ console.log('');
257
+ const tools = [
258
+ { name: 'read_file', desc: 'Read file contents' },
259
+ { name: 'write_file', desc: 'Write to files' },
260
+ { name: 'list_directory', desc: 'List directory contents' },
261
+ { name: 'glob', desc: 'Find files by pattern' },
262
+ { name: 'search_file_content', desc: 'Search within files' },
263
+ { name: 'run_shell_command', desc: 'Execute shell commands' },
264
+ { name: 'web_search', desc: 'Search the web' },
265
+ { name: 'web_fetch', desc: 'Fetch web content' },
266
+ { name: 'replace', desc: 'Replace text in files' },
267
+ { name: 'image_read', desc: 'Analyze images with VL models' },
268
+ { name: 'pdf_extract', desc: 'Extract content from PDFs' },
269
+ { name: 'ask_user_question', desc: 'Ask user for input' },
270
+ { name: 'task', desc: 'Launch sub-agents' },
271
+ { name: 'save_memory', desc: 'Save information for future' }
272
+ ];
273
+ tools.forEach(({ name, desc }) => {
274
+ console.log(` ${chalk_1.default.cyan(name.padEnd(20))} ${chalk_1.default.gray(desc)}`);
275
+ });
276
+ console.log('');
277
+ return true;
278
+ }
279
+ function showVersion() {
280
+ const packageJsonPath = path.join(__dirname, '..', '..', 'package.json');
281
+ try {
282
+ const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
283
+ console.log(chalk_1.default.cyan(`oflow CLI v${packageJson.version}`));
284
+ }
285
+ catch {
286
+ console.log(chalk_1.default.cyan('oflow CLI (version unknown)'));
287
+ }
288
+ return true;
289
+ }
290
+ function showAgents() {
291
+ console.log(chalk_1.default.bold('\nAvailable Sub-Agents:'));
292
+ console.log('');
293
+ const agents = Object.values(core_1.AGENT_DEFINITIONS);
294
+ agents.forEach(agent => {
295
+ console.log(` ${chalk_1.default.cyan(`$${agent.type}`)}`);
296
+ console.log(` ${chalk_1.default.gray(agent.description)}`);
297
+ console.log(` Tools: ${agent.allowedTools === '*' ? 'all' : agent.allowedTools.join(', ')}`);
298
+ console.log('');
299
+ });
300
+ console.log(chalk_1.default.gray('Usage: $agent-type "your task here"'));
301
+ console.log('');
302
+ return true;
303
+ }
304
+ async function showSandboxInfo() {
305
+ console.log(chalk_1.default.bold('\nSandbox Status:'));
306
+ console.log('');
307
+ try {
308
+ const backend = await (0, core_1.createSandboxExecutor)();
309
+ console.log(` Backend: ${chalk_1.default.cyan(backend ? 'available' : 'unavailable')}`);
310
+ console.log(` Mode: ${chalk_1.default.cyan(backend ? backend['config']?.backend || 'none' : 'none')}`);
311
+ }
312
+ catch {
313
+ console.log(' Backend: ' + chalk_1.default.yellow('not available'));
314
+ }
315
+ console.log('');
316
+ console.log(chalk_1.default.gray('Enable with: oflow --sandbox'));
317
+ console.log('');
318
+ return true;
319
+ }
320
+ function showSkills(subCommand) {
321
+ console.log(chalk_1.default.bold('\nSkills System:'));
322
+ console.log('');
323
+ if (subCommand === 'list' || !subCommand) {
324
+ console.log('Skills allow extending oflow with specialized capabilities.');
325
+ console.log('');
326
+ console.log(chalk_1.default.bold('Available Skill Categories:'));
327
+ console.log(' • Document Processing (pdf, docx, pptx)');
328
+ console.log(' • Creative Tools (algorithmic-art, canvas-design)');
329
+ console.log(' • Development Tools (mcp-builder, skill-creator)');
330
+ console.log('');
331
+ console.log(chalk_1.default.gray('Skills are stored in:'));
332
+ console.log(chalk_1.default.gray(' Global: ~/.oflow/skills/'));
333
+ console.log(chalk_1.default.gray(' Project: ./.oflow/skills/'));
334
+ }
335
+ else if (subCommand === 'refresh') {
336
+ console.log(chalk_1.default.green('✓ Skills registry refreshed.'));
337
+ }
338
+ else {
339
+ console.log(chalk_1.default.yellow(`Unknown subcommand: ${subCommand}`));
340
+ console.log(chalk_1.default.gray('Usage: /skills [list|refresh]'));
341
+ }
342
+ console.log('');
343
+ return true;
344
+ }
345
+ function showMCPInfo() {
346
+ console.log(chalk_1.default.bold('\nMCP (Model Context Protocol) Status:'));
347
+ console.log('');
348
+ console.log('MCP allows extending oflow with external tool servers.');
349
+ console.log('');
350
+ console.log(chalk_1.default.bold('Configuration:'));
351
+ console.log(chalk_1.default.gray('Add servers to ~/.oflow/settings.json:'));
352
+ console.log('');
353
+ console.log(chalk_1.default.cyan(`{
354
+ "mcpServers": {
355
+ "my_server": {
356
+ "command": "npx",
357
+ "args": ["-y", "my-mcp-server"]
358
+ }
359
+ }
360
+ }`));
361
+ console.log('');
362
+ return true;
363
+ }
364
+ function showMemory() {
365
+ console.log(chalk_1.default.bold('\nSaved Memories:'));
366
+ console.log('');
367
+ const homeDir = process.env.HOME || process.env.USERPROFILE || '';
368
+ const memoryFile = path.join(homeDir, '.oflow', 'memory.json');
369
+ try {
370
+ if (fs.existsSync(memoryFile)) {
371
+ const content = fs.readFileSync(memoryFile, 'utf-8');
372
+ const memories = JSON.parse(content);
373
+ if (memories.length === 0) {
374
+ console.log(chalk_1.default.gray('No memories saved.'));
375
+ }
376
+ else {
377
+ memories.forEach((m, i) => {
378
+ console.log(`${i + 1}. ${chalk_1.default.white(m.fact)}`);
379
+ console.log(` ${chalk_1.default.gray(new Date(m.createdAt).toLocaleString())}`);
380
+ console.log('');
381
+ });
382
+ }
383
+ }
384
+ else {
385
+ console.log(chalk_1.default.gray('No memories saved.'));
386
+ }
387
+ }
388
+ catch {
389
+ console.log(chalk_1.default.yellow('Could not read memory file.'));
390
+ }
391
+ console.log('');
392
+ return true;
393
+ }
394
+ async function generateCommit(context) {
395
+ console.log(chalk_1.default.cyan('\nGenerating commit message...'));
396
+ console.log('');
397
+ // 检查是否是git仓库
398
+ const gitDir = path.join(process.cwd(), '.git');
399
+ if (!fs.existsSync(gitDir)) {
400
+ console.log(chalk_1.default.yellow('Not a git repository.'));
401
+ return true;
402
+ }
403
+ const commitPrompt = `Please analyze the current git repository state and generate an appropriate commit message.
404
+
405
+ Working directory: ${process.cwd()}
406
+
407
+ Steps:
408
+ 1. Run 'git status' to see changed files
409
+ 2. Run 'git diff --staged' to see staged changes (if any)
410
+ 3. Run 'git diff' to see unstaged changes
411
+ 4. Generate a clear, concise commit message following conventional commit format
412
+
413
+ Provide the commit message as your response.`;
414
+ try {
415
+ await context.conversation.sendMessage(commitPrompt);
416
+ }
417
+ catch (error) {
418
+ console.log(chalk_1.default.red('Error generating commit message.'));
419
+ }
420
+ return true;
421
+ }
422
+ async function reviewCode(context) {
423
+ console.log(chalk_1.default.cyan('\nReviewing recent changes...'));
424
+ console.log('');
425
+ // 检查是否是git仓库
426
+ const gitDir = path.join(process.cwd(), '.git');
427
+ if (!fs.existsSync(gitDir)) {
428
+ console.log(chalk_1.default.yellow('Not a git repository.'));
429
+ return true;
430
+ }
431
+ const reviewPrompt = `Please review the recent code changes in this repository.
432
+
433
+ Working directory: ${process.cwd()}
434
+
435
+ Steps:
436
+ 1. Run 'git log -5 --oneline' to see recent commits
437
+ 2. Run 'git diff HEAD~1 HEAD' to see the latest changes
438
+ 3. Review the code for:
439
+ - Potential bugs
440
+ - Security vulnerabilities
441
+ - Code style issues
442
+ - Performance concerns
443
+ - Best practice violations
444
+
445
+ Provide a structured review with specific findings and suggestions.`;
446
+ try {
447
+ await context.conversation.sendMessage(reviewPrompt);
448
+ }
449
+ catch (error) {
450
+ console.log(chalk_1.default.red('Error during code review.'));
451
+ }
452
+ return true;
453
+ }
454
+ function toggleThinking(context) {
455
+ const newValue = context.configManager.toggleShowThinking();
456
+ console.log('');
457
+ console.log(chalk_1.default.green(`✓ Thinking process display: ${newValue ? chalk_1.default.cyan('ON') : chalk_1.default.gray('OFF')}`));
458
+ console.log('');
459
+ if (newValue) {
460
+ console.log(chalk_1.default.gray('The AI will now show its thinking/reasoning process (for supported models like DeepSeek Reasoner).'));
461
+ }
462
+ else {
463
+ console.log(chalk_1.default.gray('The AI thinking process is now hidden.'));
464
+ }
465
+ return true;
466
+ }
467
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { Conversation, ConfigManager, AgentFactory, AGENT_DEFINITIONS, createSandboxExecutor } from '@oflow-ai/core';\nimport * as readline from 'readline';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nexport interface CommandContext {\n  conversation: Conversation;\n  rl: readline.Interface;\n  configManager: ConfigManager;\n}\n\nexport function isSlashCommand(input: string): boolean {\n  return input.startsWith('/');\n}\n\nexport async function executeSlashCommand(\n  input: string,\n  context: CommandContext\n): Promise<boolean> {\n  const [command, ...args] = input.split(' ');\n  const argString = args.join(' ');\n\n  switch (command.toLowerCase()) {\n    case '/help':\n      return showHelp();\n    \n    case '/exit':\n    case '/quit':\n    case '/q':\n      return false;\n    \n    case '/clear':\n      return clearConversation(context);\n    \n    case '/init':\n      return initProject(context);\n    \n    case '/model':\n      return showOrSetModel(argString, context);\n    \n    case '/config':\n      return showConfig(context);\n    \n    case '/reset':\n      return resetConfig(context);\n    \n    case '/history':\n      return showHistory(context);\n    \n    case '/tools':\n      return showTools();\n    \n    case '/version':\n      return showVersion();\n    \n    case '/agents':\n      return showAgents();\n    \n    case '/sandbox':\n      return showSandboxInfo();\n    \n    case '/skills':\n      return showSkills(argString);\n    \n    case '/mcp':\n      return showMCPInfo();\n    \n    case '/memory':\n      return showMemory();\n    \n    case '/commit':\n      return generateCommit(context);\n    \n    case '/review':\n      return reviewCode(context);\n    \n    case '/thinking':\n      return toggleThinking(context);\n    \n    default:\n      console.log(chalk.yellow(`Unknown command: ${command}`));\n      console.log(chalk.gray('Type /help for available commands.'));\n      return true;\n  }\n}\n\nfunction showHelp(): boolean {\n  console.log('');\n  console.log(chalk.bold('Available Commands:'));\n  console.log('');\n  \n  const commands = [\n    { cmd: '/help', desc: 'Show this help message' },\n    { cmd: '/exit, /quit, /q', desc: 'Exit oflow CLI' },\n    { cmd: '/clear', desc: 'Clear conversation history' },\n    { cmd: '/init', desc: 'Analyze and initialize current project' },\n    { cmd: '/model [name]', desc: 'Show or set the current model' },\n    { cmd: '/thinking', desc: 'Toggle thinking process display (ON/OFF)' },\n    { cmd: '/config', desc: 'Show current configuration' },\n    { cmd: '/reset', desc: 'Reset configuration to defaults' },\n    { cmd: '/history', desc: 'Show conversation history' },\n    { cmd: '/tools', desc: 'List available tools' },\n    { cmd: '/agents', desc: 'List available sub-agents' },\n    { cmd: '/sandbox', desc: 'Show sandbox status' },\n    { cmd: '/skills [list|refresh]', desc: 'Manage skills' },\n    { cmd: '/mcp', desc: 'Show MCP server status' },\n    { cmd: '/memory', desc: 'Show saved memories' },\n    { cmd: '/commit', desc: 'Generate commit message' },\n    { cmd: '/review', desc: 'Review recent code changes' },\n    { cmd: '/version', desc: 'Show version information' }\n  ];\n\n  commands.forEach(({ cmd, desc }) => {\n    console.log(`  ${chalk.cyan(cmd.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  console.log(chalk.bold('Special Syntax:'));\n  console.log(`  ${chalk.cyan('!command')}    ${chalk.gray('Execute a shell command')}`);\n  console.log(`  ${chalk.cyan('@filepath')}   ${chalk.gray('Reference a file in your message')}`);\n  console.log(`  ${chalk.cyan('$agent')}      ${chalk.gray('Call a sub-agent (e.g., $explore-agent \"task\")')}`);\n  console.log('');\n  \n  return true;\n}\n\nfunction clearConversation(context: CommandContext): boolean {\n  context.conversation.clear();\n  console.log(chalk.green('✓ Conversation history cleared.'));\n  return true;\n}\n\nasync function initProject(context: CommandContext): Promise<boolean> {\n  const workingDir = process.cwd();\n  const projectName = path.basename(workingDir);\n  \n  console.log(chalk.cyan(`\\nAnalyzing project: ${projectName}\\n`));\n  \n  // Check for common project files\n  const checks = [\n    { file: 'package.json', type: 'Node.js' },\n    { file: 'tsconfig.json', type: 'TypeScript' },\n    { file: 'pyproject.toml', type: 'Python (modern)' },\n    { file: 'requirements.txt', type: 'Python' },\n    { file: 'Cargo.toml', type: 'Rust' },\n    { file: 'go.mod', type: 'Go' },\n    { file: 'pom.xml', type: 'Java (Maven)' },\n    { file: 'build.gradle', type: 'Java (Gradle)' },\n    { file: '.git', type: 'Git repository' }\n  ];\n\n  const detected: string[] = [];\n  \n  for (const check of checks) {\n    const filePath = path.join(workingDir, check.file);\n    if (fs.existsSync(filePath)) {\n      detected.push(check.type);\n    }\n  }\n\n  if (detected.length > 0) {\n    console.log(chalk.bold('Detected project types:'));\n    detected.forEach(t => console.log(`  • ${t}`));\n  } else {\n    console.log(chalk.yellow('No recognized project type detected.'));\n  }\n\n  // List top-level files and directories\n  console.log(chalk.bold('\\nProject structure:'));\n  const entries = fs.readdirSync(workingDir, { withFileTypes: true });\n  entries.slice(0, 20).forEach(entry => {\n    const prefix = entry.isDirectory() ? '📁 ' : '📄 ';\n    console.log(`  ${prefix}${entry.name}`);\n  });\n\n  if (entries.length > 20) {\n    console.log(chalk.gray(`  ... and ${entries.length - 20} more items`));\n  }\n\n  console.log('');\n\n  // Add init context to conversation\n  const initMessage = `Please analyze the current project structure and provide:\n1. A brief overview of the project type and purpose\n2. Key files and their roles\n3. Suggestions for improvements or best practices\n\nWorking directory: ${workingDir}\nDetected types: ${detected.join(', ')}`;\n\n  try {\n    await context.conversation.sendMessage(initMessage);\n  } catch (error) {\n    console.log(chalk.red('Error during analysis.'));\n  }\n\n  return true;\n}\n\nfunction showOrSetModel(modelName: string, context: CommandContext): boolean {\n  if (modelName) {\n    context.configManager.setDefaultModel(modelName);\n    console.log(chalk.green(`✓ Model set to: ${modelName}`));\n  } else {\n    const currentModel = context.configManager.getDefaultModel();\n    console.log(chalk.cyan(`Current model: ${currentModel}`));\n    console.log('');\n    console.log('Available models:');\n    const models = ['gpt-4o', 'gpt-4o-mini', 'gpt-4-turbo', 'gpt-3.5-turbo', 'o1-preview', 'o1-mini'];\n    models.forEach(m => {\n      if (m === currentModel) {\n        console.log(chalk.green(`  * ${m} (current)`));\n      } else {\n        console.log(`    ${m}`);\n      }\n    });\n  }\n  return true;\n}\n\nfunction showConfig(context: CommandContext): boolean {\n  const config = context.configManager.getAll();\n  console.log(chalk.bold('\\nCurrent Configuration:'));\n  console.log(JSON.stringify(config, null, 2));\n  console.log('');\n  console.log(chalk.gray(`Config file: ${context.configManager.getConfigPath()}`));\n  return true;\n}\n\nfunction resetConfig(context: CommandContext): boolean {\n  context.configManager.clear();\n  console.log(chalk.green('✓ Configuration reset to defaults.'));\n  console.log(chalk.yellow('You will need to run `oflow auth` to reconfigure authentication.'));\n  return false; // Exit to force re-auth\n}\n\nfunction showHistory(context: CommandContext): boolean {\n  const messages = context.conversation.getMessages();\n  \n  if (messages.length === 0) {\n    console.log(chalk.gray('No conversation history.'));\n    return true;\n  }\n\n  console.log(chalk.bold('\\nConversation History:'));\n  console.log('');\n  \n  messages.forEach((msg, index) => {\n    if (msg.role === 'system') return;\n    \n    const roleColors: Record<string, chalk.Chalk> = {\n      user: chalk.green,\n      assistant: chalk.blue,\n      tool: chalk.gray\n    };\n    \n    const color = roleColors[msg.role] || chalk.white;\n    const preview = typeof msg.content === 'string' \n      ? msg.content.substring(0, 100) + (msg.content.length > 100 ? '...' : '')\n      : '[complex content]';\n    \n    console.log(`${index}. ${color(msg.role)}: ${preview}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showTools(): boolean {\n  console.log(chalk.bold('\\nAvailable Tools:'));\n  console.log('');\n  \n  const tools = [\n    { name: 'read_file', desc: 'Read file contents' },\n    { name: 'write_file', desc: 'Write to files' },\n    { name: 'list_directory', desc: 'List directory contents' },\n    { name: 'glob', desc: 'Find files by pattern' },\n    { name: 'search_file_content', desc: 'Search within files' },\n    { name: 'run_shell_command', desc: 'Execute shell commands' },\n    { name: 'web_search', desc: 'Search the web' },\n    { name: 'web_fetch', desc: 'Fetch web content' },\n    { name: 'replace', desc: 'Replace text in files' },\n    { name: 'image_read', desc: 'Analyze images with VL models' },\n    { name: 'pdf_extract', desc: 'Extract content from PDFs' },\n    { name: 'ask_user_question', desc: 'Ask user for input' },\n    { name: 'task', desc: 'Launch sub-agents' },\n    { name: 'save_memory', desc: 'Save information for future' }\n  ];\n\n  tools.forEach(({ name, desc }) => {\n    console.log(`  ${chalk.cyan(name.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showVersion(): boolean {\n  const packageJsonPath = path.join(__dirname, '..', '..', 'package.json');\n  try {\n    const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n    console.log(chalk.cyan(`oflow CLI v${packageJson.version}`));\n  } catch {\n    console.log(chalk.cyan('oflow CLI (version unknown)'));\n  }\n  return true;\n}\n\nfunction showAgents(): boolean {\n  console.log(chalk.bold('\\nAvailable Sub-Agents:'));\n  console.log('');\n  \n  const agents = Object.values(AGENT_DEFINITIONS);\n  agents.forEach(agent => {\n    console.log(`  ${chalk.cyan(`$${agent.type}`)}`);\n    console.log(`    ${chalk.gray(agent.description)}`);\n    console.log(`    Tools: ${agent.allowedTools === '*' ? 'all' : agent.allowedTools.join(', ')}`);\n    console.log('');\n  });\n\n  console.log(chalk.gray('Usage: $agent-type \"your task here\"'));\n  console.log('');\n  return true;\n}\n\nasync function showSandboxInfo(): Promise<boolean> {\n  console.log(chalk.bold('\\nSandbox Status:'));\n  console.log('');\n  \n  try {\n    const backend = await createSandboxExecutor();\n    console.log(`  Backend: ${chalk.cyan(backend ? 'available' : 'unavailable')}`);\n    console.log(`  Mode: ${chalk.cyan(backend ? backend['config']?.backend || 'none' : 'none')}`);\n  } catch {\n    console.log('  Backend: ' + chalk.yellow('not available'));\n  }\n\n  console.log('');\n  console.log(chalk.gray('Enable with: oflow --sandbox'));\n  console.log('');\n  return true;\n}\n\nfunction showSkills(subCommand: string): boolean {\n  console.log(chalk.bold('\\nSkills System:'));\n  console.log('');\n  \n  if (subCommand === 'list' || !subCommand) {\n    console.log('Skills allow extending oflow with specialized capabilities.');\n    console.log('');\n    console.log(chalk.bold('Available Skill Categories:'));\n    console.log('  • Document Processing (pdf, docx, pptx)');\n    console.log('  • Creative Tools (algorithmic-art, canvas-design)');\n    console.log('  • Development Tools (mcp-builder, skill-creator)');\n    console.log('');\n    console.log(chalk.gray('Skills are stored in:'));\n    console.log(chalk.gray('  Global: ~/.oflow/skills/'));\n    console.log(chalk.gray('  Project: ./.oflow/skills/'));\n  } else if (subCommand === 'refresh') {\n    console.log(chalk.green('✓ Skills registry refreshed.'));\n  } else {\n    console.log(chalk.yellow(`Unknown subcommand: ${subCommand}`));\n    console.log(chalk.gray('Usage: /skills [list|refresh]'));\n  }\n\n  console.log('');\n  return true;\n}\n\nfunction showMCPInfo(): boolean {\n  console.log(chalk.bold('\\nMCP (Model Context Protocol) Status:'));\n  console.log('');\n  \n  console.log('MCP allows extending oflow with external tool servers.');\n  console.log('');\n  console.log(chalk.bold('Configuration:'));\n  console.log(chalk.gray('Add servers to ~/.oflow/settings.json:'));\n  console.log('');\n  console.log(chalk.cyan(`{\n  \"mcpServers\": {\n    \"my_server\": {\n      \"command\": \"npx\",\n      \"args\": [\"-y\", \"my-mcp-server\"]\n    }\n  }\n}`));\n  console.log('');\n  return true;\n}\n\nfunction showMemory(): boolean {\n  console.log(chalk.bold('\\nSaved Memories:'));\n  console.log('');\n  \n  const homeDir = process.env.HOME || process.env.USERPROFILE || '';\n  const memoryFile = path.join(homeDir, '.oflow', 'memory.json');\n  \n  try {\n    if (fs.existsSync(memoryFile)) {\n      const content = fs.readFileSync(memoryFile, 'utf-8');\n      const memories = JSON.parse(content);\n      \n      if (memories.length === 0) {\n        console.log(chalk.gray('No memories saved.'));\n      } else {\n        memories.forEach((m: { fact: string; createdAt: string }, i: number) => {\n          console.log(`${i + 1}. ${chalk.white(m.fact)}`);\n          console.log(`   ${chalk.gray(new Date(m.createdAt).toLocaleString())}`);\n          console.log('');\n        });\n      }\n    } else {\n      console.log(chalk.gray('No memories saved.'));\n    }\n  } catch {\n    console.log(chalk.yellow('Could not read memory file.'));\n  }\n\n  console.log('');\n  return true;\n}\n\nasync function generateCommit(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nGenerating commit message...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const commitPrompt = `Please analyze the current git repository state and generate an appropriate commit message.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git status' to see changed files\n2. Run 'git diff --staged' to see staged changes (if any)\n3. Run 'git diff' to see unstaged changes\n4. Generate a clear, concise commit message following conventional commit format\n\nProvide the commit message as your response.`;\n\n  try {\n    await context.conversation.sendMessage(commitPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error generating commit message.'));\n  }\n\n  return true;\n}\n\nasync function reviewCode(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nReviewing recent changes...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const reviewPrompt = `Please review the recent code changes in this repository.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git log -5 --oneline' to see recent commits\n2. Run 'git diff HEAD~1 HEAD' to see the latest changes\n3. Review the code for:\n   - Potential bugs\n   - Security vulnerabilities\n   - Code style issues\n   - Performance concerns\n   - Best practice violations\n\nProvide a structured review with specific findings and suggestions.`;\n\n  try {\n    await context.conversation.sendMessage(reviewPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error during code review.'));\n  }\n\n  return true;\n}\n\nfunction toggleThinking(context: CommandContext): boolean {\n  const newValue = context.configManager.toggleShowThinking();\n  console.log('');\n  console.log(chalk.green(`✓ Thinking process display: ${newValue ? chalk.cyan('ON') : chalk.gray('OFF')}`));\n  console.log('');\n  \n  if (newValue) {\n    console.log(chalk.gray('The AI will now show its thinking/reasoning process (for supported models like DeepSeek Reasoner).'));\n  } else {\n    console.log(chalk.gray('The AI thinking process is now hidden.'));\n  }\n  \n  return true;\n}\n"]}
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ export {};