@oflow-ai/oflow-cli 0.1.0 → 0.1.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 (3) hide show
  1. package/dist/cli.js +84 -24
  2. package/dist/index.js +42 -11
  3. package/package.json +1 -1
package/dist/cli.js CHANGED
@@ -44,7 +44,7 @@ const ora_1 = __importDefault(require("ora"));
44
44
  const core_1 = require("@oflow-ai/core");
45
45
  const commands_1 = require("./commands");
46
46
  let sandboxExecutor = null;
47
- let showThinking = false;
47
+ let currentShowThinking = false;
48
48
  async function startInteractiveMode(options) {
49
49
  const configManager = (0, core_1.getConfigManager)();
50
50
  const auth = configManager.getAuth();
@@ -54,26 +54,39 @@ async function startInteractiveMode(options) {
54
54
  }
55
55
  // 初始化沙箱执行器
56
56
  if (options.sandbox || configManager.get('sandbox')) {
57
- sandboxExecutor = await (0, core_1.createSandboxExecutor)();
58
- console.log(chalk_1.default.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));
57
+ try {
58
+ sandboxExecutor = await (0, core_1.createSandboxExecutor)();
59
+ console.log(chalk_1.default.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));
60
+ }
61
+ catch (error) {
62
+ console.log(chalk_1.default.yellow('Sandbox mode: unavailable'));
63
+ }
59
64
  }
60
65
  // 获取思考过程显示设置
61
- showThinking = options.showThinking ?? configManager.getShowThinking();
66
+ currentShowThinking = options.showThinking ?? configManager.getShowThinking();
62
67
  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
63
- const provider = (0, core_1.createAIProvider)(auth, model);
64
- const agentFactory = new core_1.AgentFactory(provider, process.cwd());
68
+ let provider;
69
+ try {
70
+ provider = (0, core_1.createAIProvider)(auth, model);
71
+ }
72
+ catch (error) {
73
+ console.log(chalk_1.default.red('Failed to create AI provider:', error instanceof Error ? error.message : String(error)));
74
+ return;
75
+ }
65
76
  const conversation = new core_1.Conversation({
66
77
  provider,
67
78
  workingDirectory: process.cwd(),
68
79
  maxTokens: configManager.get('maxTokens'),
69
80
  temperature: configManager.get('temperature'),
70
- showThinking: showThinking,
81
+ showThinking: currentShowThinking,
71
82
  onContent: (content) => {
72
83
  process.stdout.write(chalk_1.default.white(content));
73
84
  },
74
85
  onThinking: (thinking) => {
75
86
  // 显示思考过程,使用不同的颜色
76
- process.stdout.write(chalk_1.default.magenta(thinking));
87
+ if (currentShowThinking) {
88
+ process.stdout.write(chalk_1.default.magenta(thinking));
89
+ }
77
90
  },
78
91
  onToolCall: (toolCall) => {
79
92
  console.log(chalk_1.default.cyan(`\n🔧 Using tool: ${toolCall.function.name}`));
@@ -88,12 +101,13 @@ async function startInteractiveMode(options) {
88
101
  console.log(chalk_1.default.bold.blue('║ Welcome to oflow CLI ║'));
89
102
  console.log(chalk_1.default.bold.blue('╚═══════════════════════════════════════╝'));
90
103
  console.log('');
104
+ console.log(chalk_1.default.gray(`Provider: ${auth.provider}`));
91
105
  console.log(chalk_1.default.gray(`Model: ${model}`));
92
106
  console.log(chalk_1.default.gray(`Working directory: ${process.cwd()}`));
93
107
  if (sandboxExecutor) {
94
108
  console.log(chalk_1.default.gray(`Sandbox: enabled`));
95
109
  }
96
- console.log(chalk_1.default.gray(`Thinking: ${showThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));
110
+ console.log(chalk_1.default.gray(`Thinking: ${currentShowThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));
97
111
  console.log('');
98
112
  console.log(chalk_1.default.gray('Type your message and press Enter to chat.'));
99
113
  console.log(chalk_1.default.gray('Type /help for available commands.'));
@@ -114,6 +128,16 @@ async function startInteractiveMode(options) {
114
128
  }
115
129
  // Check for slash commands
116
130
  if ((0, commands_1.isSlashCommand)(input)) {
131
+ // 特殊处理 /thinking 命令
132
+ if (input.toLowerCase() === '/thinking') {
133
+ currentShowThinking = !currentShowThinking;
134
+ configManager.setShowThinking(currentShowThinking);
135
+ console.log('');
136
+ console.log(chalk_1.default.green(`✓ Thinking process display: ${currentShowThinking ? chalk_1.default.cyan('ON') : chalk_1.default.gray('OFF')}`));
137
+ console.log('');
138
+ rl.prompt();
139
+ return;
140
+ }
117
141
  const shouldContinue = await (0, commands_1.executeSlashCommand)(input, {
118
142
  conversation,
119
143
  rl,
@@ -128,7 +152,7 @@ async function startInteractiveMode(options) {
128
152
  }
129
153
  // Check for agent calls (starting with $)
130
154
  if (input.startsWith('$')) {
131
- await handleAgentCall(input, agentFactory, options);
155
+ await handleAgentCall(input, provider, options);
132
156
  rl.prompt();
133
157
  return;
134
158
  }
@@ -150,7 +174,21 @@ async function startInteractiveMode(options) {
150
174
  }
151
175
  catch (error) {
152
176
  spinner.fail('Error');
153
- console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
177
+ const errorMessage = error instanceof Error ? error.message : String(error);
178
+ console.log(chalk_1.default.red(errorMessage));
179
+ // 提供更详细的错误信息
180
+ if (errorMessage.includes('400')) {
181
+ console.log(chalk_1.default.yellow('\n可能的解决方案:'));
182
+ console.log(chalk_1.default.gray(' 1. 检查API Key是否正确'));
183
+ console.log(chalk_1.default.gray(' 2. 检查模型名称是否正确'));
184
+ console.log(chalk_1.default.gray(' 3. 运行 "oflow auth" 重新配置'));
185
+ }
186
+ else if (errorMessage.includes('401') || errorMessage.includes('Unauthorized')) {
187
+ console.log(chalk_1.default.yellow('\n认证失败,请运行 "oflow auth" 重新配置'));
188
+ }
189
+ else if (errorMessage.includes('429')) {
190
+ console.log(chalk_1.default.yellow('\n请求过于频繁,请稍后再试'));
191
+ }
154
192
  rl.prompt();
155
193
  }
156
194
  });
@@ -164,7 +202,7 @@ async function startInteractiveMode(options) {
164
202
  process.exit(0);
165
203
  });
166
204
  }
167
- async function handleAgentCall(input, agentFactory, options) {
205
+ async function handleAgentCall(input, provider, options) {
168
206
  // Parse agent call: $agent-type "task description"
169
207
  const match = input.match(/^\$(\w+(?:-\w+)*)\s*(.*)$/);
170
208
  if (!match) {
@@ -179,6 +217,7 @@ async function handleAgentCall(input, agentFactory, options) {
179
217
  return;
180
218
  }
181
219
  try {
220
+ const agentFactory = new core_1.AgentFactory(provider, process.cwd());
182
221
  const agent = agentFactory.createAgent(agentType);
183
222
  console.log(chalk_1.default.cyan(`\n🤖 Starting ${agentType} agent...`));
184
223
  console.log(chalk_1.default.gray(`Task: ${task}\n`));
@@ -218,7 +257,12 @@ async function runSingleCommand(prompt, options) {
218
257
  }
219
258
  // 初始化沙箱执行器
220
259
  if (options.sandbox || configManager.get('sandbox')) {
221
- sandboxExecutor = await (0, core_1.createSandboxExecutor)();
260
+ try {
261
+ sandboxExecutor = await (0, core_1.createSandboxExecutor)();
262
+ }
263
+ catch {
264
+ // Ignore sandbox errors for single command
265
+ }
222
266
  }
223
267
  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
224
268
  const provider = (0, core_1.createAIProvider)(auth, model);
@@ -245,17 +289,22 @@ async function runSingleCommand(prompt, options) {
245
289
  }
246
290
  }
247
291
  async function executeShellCommand(command, sandbox) {
248
- const { spawn } = require('child_modules');
292
+ const { spawn } = require('child_process');
249
293
  if (sandbox && sandbox['config']?.backend !== 'none') {
250
- // Use sandbox execution
251
- const result = await sandbox.execute(command, process.cwd());
252
- if (result.stdout)
253
- console.log(result.stdout);
254
- if (result.stderr)
255
- console.error(result.stderr);
256
- if (result.timedOut)
257
- console.log(chalk_1.default.yellow('Command timed out'));
258
- return;
294
+ try {
295
+ const result = await sandbox.execute(command, process.cwd());
296
+ if (result.stdout)
297
+ console.log(result.stdout);
298
+ if (result.stderr)
299
+ console.error(result.stderr);
300
+ if (result.timedOut)
301
+ console.log(chalk_1.default.yellow('Command timed out'));
302
+ return;
303
+ }
304
+ catch (error) {
305
+ console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
306
+ return;
307
+ }
259
308
  }
260
309
  return new Promise((resolve) => {
261
310
  const isWindows = process.platform === 'win32';
@@ -268,6 +317,10 @@ async function executeShellCommand(command, sandbox) {
268
317
  proc.on('close', () => {
269
318
  resolve();
270
319
  });
320
+ proc.on('error', (err) => {
321
+ console.log(chalk_1.default.red(`Failed to execute command: ${err.message}`));
322
+ resolve();
323
+ });
271
324
  });
272
325
  }
273
326
  async function processFileReferences(input) {
@@ -284,6 +337,7 @@ async function processFileReferences(input) {
284
337
  }
285
338
  catch {
286
339
  // File not found, keep original reference
340
+ console.log(chalk_1.default.yellow(`Warning: Could not read file ${filePath}`));
287
341
  }
288
342
  }
289
343
  return result;
@@ -333,7 +387,13 @@ Your primary goal is to help users safely and efficiently complete programming t
333
387
  6. Verify changes after making them
334
388
  7. Provide actionable suggestions
335
389
 
390
+ # Important Rules
391
+ - When you need to use tools, first explain what you're going to do
392
+ - After using tools, summarize the results
393
+ - If a tool call fails, explain what went wrong and suggest alternatives
394
+ - Always provide clear, actionable responses
395
+
336
396
  Current working directory: ${process.cwd()}
337
397
  `;
338
398
  }
339
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import * as readline from 'readline';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n  getConfigManager,\n  createAIProvider,\n  Conversation,\n  Message,\n  AgentFactory,\n  Agent,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\nimport { renderMarkdown } from './utils/markdown';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet showThinking = false;\n\nexport async function startInteractiveMode(options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    sandboxExecutor = await createSandboxExecutor();\n    console.log(chalk.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));\n  }\n\n  // 获取思考过程显示设置\n  showThinking = options.showThinking ?? configManager.getShowThinking();\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const agentFactory = new AgentFactory(provider, process.cwd());\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: showThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      // 显示思考过程，使用不同的颜色\n      process.stdout.write(chalk.magenta(thinking));\n    },\n    onToolCall: (toolCall) => {\n      console.log(chalk.cyan(`\\n🔧 Using tool: ${toolCall.function.name}`));\n    },\n    onToolResult: (result) => {\n      // Tool result is handled silently\n    }\n  });\n\n  // Set system prompt\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  console.log(chalk.bold.blue('\\n╔═══════════════════════════════════════╗'));\n  console.log(chalk.bold.blue('║         Welcome to oflow CLI          ║'));\n  console.log(chalk.bold.blue('╚═══════════════════════════════════════╝'));\n  console.log('');\n  console.log(chalk.gray(`Model: ${model}`));\n  console.log(chalk.gray(`Working directory: ${process.cwd()}`));\n  if (sandboxExecutor) {\n    console.log(chalk.gray(`Sandbox: enabled`));\n  }\n  console.log(chalk.gray(`Thinking: ${showThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));\n  console.log('');\n  console.log(chalk.gray('Type your message and press Enter to chat.'));\n  console.log(chalk.gray('Type /help for available commands.'));\n  console.log(chalk.gray('Type $agent-name to call a sub-agent.'));\n  console.log(chalk.gray('Type /exit or press Ctrl+C to exit.'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n    prompt: chalk.green('> ')\n  });\n\n  rl.prompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      rl.prompt();\n      return;\n    }\n\n    // Check for slash commands\n    if (isSlashCommand(input)) {\n      const shouldContinue = await executeSlashCommand(input, {\n        conversation,\n        rl,\n        configManager\n      });\n      \n      if (!shouldContinue) {\n        rl.close();\n        return;\n      }\n      \n      rl.prompt();\n      return;\n    }\n\n    // Check for agent calls (starting with $)\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, agentFactory, options);\n      rl.prompt();\n      return;\n    }\n\n    // Check for shell commands (starting with !)\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      rl.prompt();\n      return;\n    }\n\n    // Check for file reference (starting with @)\n    const processedInput = await processFileReferences(input);\n\n    // Send to AI\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      \n      console.log(''); // New line after response\n      rl.prompt();\n    } catch (error) {\n      spinner.fail('Error');\n      console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n      rl.prompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n\n  // Handle Ctrl+C\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(\n  input: string, \n  agentFactory: AgentFactory,\n  options: CLIOptions\n): Promise<void> {\n  // Parse agent call: $agent-type \"task description\"\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid agent call format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('Available agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));\n    return;\n  }\n\n  const agentType = match[1] as AgentType;\n  const task = match[2].replace(/^[\"']|[\"']$/g, '');\n\n  if (!task) {\n    console.log(chalk.yellow('Please provide a task for the agent.'));\n    return;\n  }\n\n  try {\n    const agent = agentFactory.createAgent(agentType);\n    console.log(chalk.cyan(`\\n🤖 Starting ${agentType} agent...`));\n    console.log(chalk.gray(`Task: ${task}\\n`));\n\n    const spinner = ora('Agent working...').start();\n    \n    const result = await agent.execute(task, (update) => {\n      spinner.stop();\n      process.stdout.write(update);\n      spinner.start();\n    });\n\n    spinner.stop();\n    \n    if (result.success) {\n      console.log(chalk.green('\\n\\n✓ Agent completed successfully'));\n      if (result.filesModified && result.filesModified.length > 0) {\n        console.log(chalk.gray('Files modified:'));\n        result.filesModified.forEach(f => console.log(chalk.gray(`  - ${f}`)));\n      }\n    } else {\n      console.log(chalk.red('\\n\\n✗ Agent encountered errors:'));\n      result.errors?.forEach(e => console.log(chalk.red(`  - ${e}`)));\n    }\n\n    if (result.output) {\n      console.log(chalk.gray('\\nOutput:'));\n      console.log(result.output);\n    }\n\n  } catch (error) {\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nexport async function runSingleCommand(prompt: string, options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    sandboxExecutor = await createSandboxExecutor();\n  }\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const processedInput = await processFileReferences(prompt);\n  const spinner = ora('Processing...').start();\n\n  try {\n    await conversation.sendMessage(processedInput);\n    spinner.stop();\n    console.log('');\n  } catch (error) {\n    spinner.fail('Error');\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nasync function executeShellCommand(command: string, sandbox?: SandboxExecutor | null): Promise<void> {\n  const { spawn } = require('child_modules');\n  \n  if (sandbox && sandbox['config']?.backend !== 'none') {\n    // Use sandbox execution\n    const result = await sandbox.execute(command, process.cwd());\n    if (result.stdout) console.log(result.stdout);\n    if (result.stderr) console.error(result.stderr);\n    if (result.timedOut) console.log(chalk.yellow('Command timed out'));\n    return;\n  }\n  \n  return new Promise((resolve) => {\n    const isWindows = process.platform === 'win32';\n    const shell = isWindows ? 'powershell.exe' : '/bin/bash';\n    const args = isWindows ? ['-NoProfile', '-Command', command] : ['-c', command];\n\n    const proc = spawn(shell, args, {\n      stdio: 'inherit',\n      cwd: process.cwd()\n    });\n\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n\nasync function processFileReferences(input: string): Promise<string> {\n  const fileRefRegex = /@([^\\s]+)/g;\n  const matches = input.matchAll(fileRefRegex);\n  \n  let result = input;\n  const fs = require('fs');\n  const path = require('path');\n\n  for (const match of matches) {\n    const filePath = match[1];\n    try {\n      const content = fs.readFileSync(filePath, 'utf-8');\n      result = result.replace(match[0], `\\n[File: ${filePath}]\\n${content}\\n[End of file]\\n`);\n    } catch {\n      // File not found, keep original reference\n    }\n  }\n\n  return result;\n}\n\nfunction getSystemPrompt(): string {\n  return `You are oflow CLI, an interactive CLI agent specializing in software engineering tasks.\n\nYour primary goal is to help users safely and efficiently complete programming tasks.\n\n# Core Capabilities\n- Read, write, and edit files\n- Execute shell commands\n- Search and analyze code\n- Web search and fetch content\n- Manage project structure\n- Launch specialized sub-agents\n\n# Tools Available\n- read_file: Read file contents\n- write_file: Write to files\n- list_directory: List directory contents\n- glob: Find files by pattern\n- search_file_content: Search within files\n- run_shell_command: Execute shell commands\n- web_search: Search the web\n- web_fetch: Fetch web content\n- replace: Replace text in files\n- image_read: Analyze images\n- pdf_extract: Extract content from PDFs\n- ask_user_question: Ask user for input\n- task: Launch sub-agents\n- save_memory: Save information for future sessions\n\n# Sub-Agents (use $agent-name to call)\n- general-purpose: Complex multi-step tasks\n- plan-agent: Planning and analysis\n- explore-agent: Codebase exploration\n- code-reviewer: Code review\n- frontend-tester: UI testing\n\n# Guidelines\n1. Be concise and helpful\n2. Always explain what you're doing before using tools\n3. Ask for clarification when needed\n4. Prefer editing existing files over creating new ones\n5. Use appropriate tools for each task\n6. Verify changes after making them\n7. Provide actionable suggestions\n\nCurrent working directory: ${process.cwd()}\n`;\n}"]}
399
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,oDAiLC;AA6DD,4CA2CC;AAnTD,mDAAqC;AACrC,kDAA0B;AAC1B,8CAAsB;AACtB,yCAUwB;AACxB,yCAAiE;AASjE,IAAI,eAAe,GAA2B,IAAI,CAAC;AACnD,IAAI,mBAAmB,GAAG,KAAK,CAAC;AAEzB,KAAK,UAAU,oBAAoB,CAAC,OAAmB;IAC5D,MAAM,aAAa,GAAG,IAAA,uBAAgB,GAAE,CAAC;IACzC,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,EAAE,CAAC;IAErC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC,CAAC;QACrE,OAAO;IACT,CAAC;IAED,WAAW;IACX,IAAI,OAAO,CAAC,OAAO,IAAI,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;QACpD,IAAI,CAAC;YACH,eAAe,GAAG,MAAM,IAAA,4BAAqB,GAAE,CAAC;YAChD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QAC1F,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED,aAAa;IACb,mBAAmB,GAAG,OAAO,CAAC,YAAY,IAAI,aAAa,CAAC,eAAe,EAAE,CAAC;IAE9E,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,aAAa,CAAC,eAAe,EAAE,IAAI,QAAQ,CAAC;IAE3E,IAAI,QAAQ,CAAC;IACb,IAAI,CAAC;QACH,QAAQ,GAAG,IAAA,uBAAgB,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,+BAA+B,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAChH,OAAO;IACT,CAAC;IAED,MAAM,YAAY,GAAG,IAAI,mBAAY,CAAC;QACpC,QAAQ;QACR,gBAAgB,EAAE,OAAO,CAAC,GAAG,EAAE;QAC/B,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,WAAW,CAAC;QACzC,WAAW,EAAE,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC;QAC7C,YAAY,EAAE,mBAAmB;QACjC,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;YACrB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QAC7C,CAAC;QACD,UAAU,EAAE,CAAC,QAAQ,EAAE,EAAE;YACvB,iBAAiB;YACjB,IAAI,mBAAmB,EAAE,CAAC;gBACxB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;QACD,UAAU,EAAE,CAAC,QAAQ,EAAE,EAAE;YACvB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,oBAAoB,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QACxE,CAAC;QACD,YAAY,EAAE,CAAC,MAAM,EAAE,EAAE;YACvB,kCAAkC;QACpC,CAAC;KACF,CAAC,CAAC;IAEH,oBAAoB;IACpB,YAAY,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC,CAAC;IAEhD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC,CAAC;IAC5E,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC,CAAC;IAC1E,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC,CAAC;IAC1E,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IACtD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,UAAU,KAAK,EAAE,CAAC,CAAC,CAAC;IAC3C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,sBAAsB,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;IAC/D,IAAI,eAAe,EAAE,CAAC;QACpB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAC9C,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,aAAa,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,4BAA4B,CAAC,CAAC,CAAC;IACrG,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC,CAAC;IACtE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC,CAAC;IAC9D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC,CAAC;IACjE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC,CAAC;IAC/D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC;QAClC,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,MAAM,EAAE,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC;KAC1B,CAAC,CAAC;IAEH,EAAE,CAAC,MAAM,EAAE,CAAC;IAEZ,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QAE1B,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,2BAA2B;QAC3B,IAAI,IAAA,yBAAc,EAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,oBAAoB;YACpB,IAAI,KAAK,CAAC,WAAW,EAAE,KAAK,WAAW,EAAE,CAAC;gBACxC,mBAAmB,GAAG,CAAC,mBAAmB,CAAC;gBAC3C,aAAa,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;gBACnD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,+BAA+B,mBAAmB,CAAC,CAAC,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,eAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBACtH,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChB,EAAE,CAAC,MAAM,EAAE,CAAC;gBACZ,OAAO;YACT,CAAC;YAED,MAAM,cAAc,GAAG,MAAM,IAAA,8BAAmB,EAAC,KAAK,EAAE;gBACtD,YAAY;gBACZ,EAAE;gBACF,aAAa;aACd,CAAC,CAAC;YAEH,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,EAAE,CAAC,KAAK,EAAE,CAAC;gBACX,OAAO;YACT,CAAC;YAED,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,0CAA0C;QAC1C,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,eAAe,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;YAChD,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,6CAA6C;QAC7C,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;YAC3D,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,6CAA6C;QAC7C,MAAM,cAAc,GAAG,MAAM,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAE1D,aAAa;QACb,MAAM,OAAO,GAAG,IAAA,aAAG,EAAC,aAAa,CAAC,CAAC,KAAK,EAAE,CAAC;QAE3C,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YAChE,OAAO,CAAC,IAAI,EAAE,CAAC;YAEf,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,0BAA0B;YAC3C,EAAE,CAAC,MAAM,EAAE,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACtB,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC5E,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC;YAErC,aAAa;YACb,IAAI,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;gBACjC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;gBACxC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;gBAC9C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACvD,CAAC;iBAAM,IAAI,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;gBACjF,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,8BAA8B,CAAC,CAAC,CAAC;YAC5D,CAAC;iBAAM,IAAI,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;YAC9C,CAAC;YAED,EAAE,CAAC,MAAM,EAAE,CAAC;QACd,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;QAClB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,gBAAgB;IAChB,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,KAAK,UAAU,eAAe,CAC5B,KAAa,EACb,QAAa,EACb,OAAmB;IAEnB,mDAAmD;IACnD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAEvD,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,oDAAoD,CAAC,CAAC,CAAC;QAChF,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,8FAA8F,CAAC,CAAC,CAAC;QACxH,OAAO;IACT,CAAC;IAED,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAc,CAAC;IACxC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;IAElD,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,sCAAsC,CAAC,CAAC,CAAC;QAClE,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,IAAI,mBAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;QAC/D,MAAM,KAAK,GAAG,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,SAAS,WAAW,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC,CAAC;QAE3C,MAAM,OAAO,GAAG,IAAA,aAAG,EAAC,kBAAkB,CAAC,CAAC,KAAK,EAAE,CAAC;QAEhD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE,EAAE;YAClD,OAAO,CAAC,IAAI,EAAE,CAAC;YACf,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC7B,OAAO,CAAC,KAAK,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,IAAI,EAAE,CAAC;QAEf,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC,CAAC;YAC/D,IAAI,MAAM,CAAC,aAAa,IAAI,MAAM,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBAC3C,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACzE,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC,CAAC;YAC1D,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC;QAED,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YACrC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC7B,CAAC;IAEH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACjF,CAAC;AACH,CAAC;AAEM,KAAK,UAAU,gBAAgB,CAAC,MAAc,EAAE,OAAmB;IACxE,MAAM,aAAa,GAAG,IAAA,uBAAgB,GAAE,CAAC;IACzC,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,EAAE,CAAC;IAErC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC,CAAC;QACrE,OAAO;IACT,CAAC;IAED,WAAW;IACX,IAAI,OAAO,CAAC,OAAO,IAAI,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;QACpD,IAAI,CAAC;YACH,eAAe,GAAG,MAAM,IAAA,4BAAqB,GAAE,CAAC;QAClD,CAAC;QAAC,MAAM,CAAC;YACP,2CAA2C;QAC7C,CAAC;IACH,CAAC;IAED,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,aAAa,CAAC,eAAe,EAAE,IAAI,QAAQ,CAAC;IAC3E,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC/C,MAAM,YAAY,GAAG,IAAI,mBAAY,CAAC;QACpC,QAAQ;QACR,gBAAgB,EAAE,OAAO,CAAC,GAAG,EAAE;QAC/B,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,WAAW,CAAC;QACzC,WAAW,EAAE,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC;QAC7C,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;YACrB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QAC7C,CAAC;KACF,CAAC,CAAC;IAEH,YAAY,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC,CAAC;IAEhD,MAAM,cAAc,GAAG,MAAM,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAC3D,MAAM,OAAO,GAAG,IAAA,aAAG,EAAC,eAAe,CAAC,CAAC,KAAK,EAAE,CAAC;IAE7C,IAAI,CAAC;QACH,MAAM,YAAY,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QAC/C,OAAO,CAAC,IAAI,EAAE,CAAC;QACf,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACjF,CAAC;AACH,CAAC;AAED,KAAK,UAAU,mBAAmB,CAAC,OAAe,EAAE,OAAgC;IAClF,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAE3C,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE,OAAO,KAAK,MAAM,EAAE,CAAC;QACrD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;YAC7D,IAAI,MAAM,CAAC,MAAM;gBAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC9C,IAAI,MAAM,CAAC,MAAM;gBAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAChD,IAAI,MAAM,CAAC,QAAQ;gBAAE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC;YACpE,OAAO;QACT,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC/E,OAAO;QACT,CAAC;IACH,CAAC;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC;QAC/C,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,WAAW,CAAC;QACzD,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAE/E,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE;YAC9B,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE;SACnB,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;YACpB,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAU,EAAE,EAAE;YAC9B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,GAAG,CAAC,8BAA8B,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YACpE,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,KAAK,UAAU,qBAAqB,CAAC,KAAa;IAChD,MAAM,YAAY,GAAG,YAAY,CAAC;IAClC,MAAM,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;IAE7C,IAAI,MAAM,GAAG,KAAK,CAAC;IACnB,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAE7B,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACnD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,QAAQ,MAAM,OAAO,mBAAmB,CAAC,CAAC;QAC1F,CAAC;QAAC,MAAM,CAAC;YACP,0CAA0C;YAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,gCAAgC,QAAQ,EAAE,CAAC,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,eAAe;IACtB,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAkDoB,OAAO,CAAC,GAAG,EAAE;CACzC,CAAC;AACF,CAAC","sourcesContent":["import * as readline from 'readline';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n  getConfigManager,\n  createAIProvider,\n  Conversation,\n  Message,\n  AgentFactory,\n  Agent,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet currentShowThinking = false;\n\nexport async function startInteractiveMode(options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n      console.log(chalk.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));\n    } catch (error) {\n      console.log(chalk.yellow('Sandbox mode: unavailable'));\n    }\n  }\n\n  // 获取思考过程显示设置\n  currentShowThinking = options.showThinking ?? configManager.getShowThinking();\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  \n  let provider;\n  try {\n    provider = createAIProvider(auth, model);\n  } catch (error) {\n    console.log(chalk.red('Failed to create AI provider:', error instanceof Error ? error.message : String(error)));\n    return;\n  }\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: currentShowThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      // 显示思考过程，使用不同的颜色\n      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      console.log(chalk.cyan(`\\n🔧 Using tool: ${toolCall.function.name}`));\n    },\n    onToolResult: (result) => {\n      // Tool result is handled silently\n    }\n  });\n\n  // Set system prompt\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  console.log(chalk.bold.blue('\\n╔═══════════════════════════════════════╗'));\n  console.log(chalk.bold.blue('║         Welcome to oflow CLI          ║'));\n  console.log(chalk.bold.blue('╚═══════════════════════════════════════╝'));\n  console.log('');\n  console.log(chalk.gray(`Provider: ${auth.provider}`));\n  console.log(chalk.gray(`Model: ${model}`));\n  console.log(chalk.gray(`Working directory: ${process.cwd()}`));\n  if (sandboxExecutor) {\n    console.log(chalk.gray(`Sandbox: enabled`));\n  }\n  console.log(chalk.gray(`Thinking: ${currentShowThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));\n  console.log('');\n  console.log(chalk.gray('Type your message and press Enter to chat.'));\n  console.log(chalk.gray('Type /help for available commands.'));\n  console.log(chalk.gray('Type $agent-name to call a sub-agent.'));\n  console.log(chalk.gray('Type /exit or press Ctrl+C to exit.'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n    prompt: chalk.green('> ')\n  });\n\n  rl.prompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      rl.prompt();\n      return;\n    }\n\n    // Check for slash commands\n    if (isSlashCommand(input)) {\n      // 特殊处理 /thinking 命令\n      if (input.toLowerCase() === '/thinking') {\n        currentShowThinking = !currentShowThinking;\n        configManager.setShowThinking(currentShowThinking);\n        console.log('');\n        console.log(chalk.green(`✓ Thinking process display: ${currentShowThinking ? chalk.cyan('ON') : chalk.gray('OFF')}`));\n        console.log('');\n        rl.prompt();\n        return;\n      }\n\n      const shouldContinue = await executeSlashCommand(input, {\n        conversation,\n        rl,\n        configManager\n      });\n      \n      if (!shouldContinue) {\n        rl.close();\n        return;\n      }\n      \n      rl.prompt();\n      return;\n    }\n\n    // Check for agent calls (starting with $)\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider, options);\n      rl.prompt();\n      return;\n    }\n\n    // Check for shell commands (starting with !)\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      rl.prompt();\n      return;\n    }\n\n    // Check for file reference (starting with @)\n    const processedInput = await processFileReferences(input);\n\n    // Send to AI\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      \n      console.log(''); // New line after response\n      rl.prompt();\n    } catch (error) {\n      spinner.fail('Error');\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      console.log(chalk.red(errorMessage));\n      \n      // 提供更详细的错误信息\n      if (errorMessage.includes('400')) {\n        console.log(chalk.yellow('\\n可能的解决方案:'));\n        console.log(chalk.gray('  1. 检查API Key是否正确'));\n        console.log(chalk.gray('  2. 检查模型名称是否正确'));\n        console.log(chalk.gray('  3. 运行 \"oflow auth\" 重新配置'));\n      } else if (errorMessage.includes('401') || errorMessage.includes('Unauthorized')) {\n        console.log(chalk.yellow('\\n认证失败，请运行 \"oflow auth\" 重新配置'));\n      } else if (errorMessage.includes('429')) {\n        console.log(chalk.yellow('\\n请求过于频繁，请稍后再试'));\n      }\n      \n      rl.prompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n\n  // Handle Ctrl+C\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(\n  input: string, \n  provider: any,\n  options: CLIOptions\n): Promise<void> {\n  // Parse agent call: $agent-type \"task description\"\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid agent call format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('Available agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));\n    return;\n  }\n\n  const agentType = match[1] as AgentType;\n  const task = match[2].replace(/^[\"']|[\"']$/g, '');\n\n  if (!task) {\n    console.log(chalk.yellow('Please provide a task for the agent.'));\n    return;\n  }\n\n  try {\n    const agentFactory = new AgentFactory(provider, process.cwd());\n    const agent = agentFactory.createAgent(agentType);\n    console.log(chalk.cyan(`\\n🤖 Starting ${agentType} agent...`));\n    console.log(chalk.gray(`Task: ${task}\\n`));\n\n    const spinner = ora('Agent working...').start();\n    \n    const result = await agent.execute(task, (update) => {\n      spinner.stop();\n      process.stdout.write(update);\n      spinner.start();\n    });\n\n    spinner.stop();\n    \n    if (result.success) {\n      console.log(chalk.green('\\n\\n✓ Agent completed successfully'));\n      if (result.filesModified && result.filesModified.length > 0) {\n        console.log(chalk.gray('Files modified:'));\n        result.filesModified.forEach(f => console.log(chalk.gray(`  - ${f}`)));\n      }\n    } else {\n      console.log(chalk.red('\\n\\n✗ Agent encountered errors:'));\n      result.errors?.forEach(e => console.log(chalk.red(`  - ${e}`)));\n    }\n\n    if (result.output) {\n      console.log(chalk.gray('\\nOutput:'));\n      console.log(result.output);\n    }\n\n  } catch (error) {\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nexport async function runSingleCommand(prompt: string, options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {\n      // Ignore sandbox errors for single command\n    }\n  }\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const processedInput = await processFileReferences(prompt);\n  const spinner = ora('Processing...').start();\n\n  try {\n    await conversation.sendMessage(processedInput);\n    spinner.stop();\n    console.log('');\n  } catch (error) {\n    spinner.fail('Error');\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nasync function executeShellCommand(command: string, sandbox?: SandboxExecutor | null): Promise<void> {\n  const { spawn } = require('child_process');\n  \n  if (sandbox && sandbox['config']?.backend !== 'none') {\n    try {\n      const result = await sandbox.execute(command, process.cwd());\n      if (result.stdout) console.log(result.stdout);\n      if (result.stderr) console.error(result.stderr);\n      if (result.timedOut) console.log(chalk.yellow('Command timed out'));\n      return;\n    } catch (error) {\n      console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n      return;\n    }\n  }\n  \n  return new Promise((resolve) => {\n    const isWindows = process.platform === 'win32';\n    const shell = isWindows ? 'powershell.exe' : '/bin/bash';\n    const args = isWindows ? ['-NoProfile', '-Command', command] : ['-c', command];\n\n    const proc = spawn(shell, args, {\n      stdio: 'inherit',\n      cwd: process.cwd()\n    });\n\n    proc.on('close', () => {\n      resolve();\n    });\n\n    proc.on('error', (err: Error) => {\n      console.log(chalk.red(`Failed to execute command: ${err.message}`));\n      resolve();\n    });\n  });\n}\n\nasync function processFileReferences(input: string): Promise<string> {\n  const fileRefRegex = /@([^\\s]+)/g;\n  const matches = input.matchAll(fileRefRegex);\n  \n  let result = input;\n  const fs = require('fs');\n  const path = require('path');\n\n  for (const match of matches) {\n    const filePath = match[1];\n    try {\n      const content = fs.readFileSync(filePath, 'utf-8');\n      result = result.replace(match[0], `\\n[File: ${filePath}]\\n${content}\\n[End of file]\\n`);\n    } catch {\n      // File not found, keep original reference\n      console.log(chalk.yellow(`Warning: Could not read file ${filePath}`));\n    }\n  }\n\n  return result;\n}\n\nfunction getSystemPrompt(): string {\n  return `You are oflow CLI, an interactive CLI agent specializing in software engineering tasks.\n\nYour primary goal is to help users safely and efficiently complete programming tasks.\n\n# Core Capabilities\n- Read, write, and edit files\n- Execute shell commands\n- Search and analyze code\n- Web search and fetch content\n- Manage project structure\n- Launch specialized sub-agents\n\n# Tools Available\n- read_file: Read file contents\n- write_file: Write to files\n- list_directory: List directory contents\n- glob: Find files by pattern\n- search_file_content: Search within files\n- run_shell_command: Execute shell commands\n- web_search: Search the web\n- web_fetch: Fetch web content\n- replace: Replace text in files\n- image_read: Analyze images\n- pdf_extract: Extract content from PDFs\n- ask_user_question: Ask user for input\n- task: Launch sub-agents\n- save_memory: Save information for future sessions\n\n# Sub-Agents (use $agent-name to call)\n- general-purpose: Complex multi-step tasks\n- plan-agent: Planning and analysis\n- explore-agent: Codebase exploration\n- code-reviewer: Code review\n- frontend-tester: UI testing\n\n# Guidelines\n1. Be concise and helpful\n2. Always explain what you're doing before using tools\n3. Ask for clarification when needed\n4. Prefer editing existing files over creating new ones\n5. Use appropriate tools for each task\n6. Verify changes after making them\n7. Provide actionable suggestions\n\n# Important Rules\n- When you need to use tools, first explain what you're going to do\n- After using tools, summarize the results\n- If a tool call fails, explain what went wrong and suggest alternatives\n- Always provide clear, actionable responses\n\nCurrent working directory: ${process.cwd()}\n`;\n}\n"]}
package/dist/index.js CHANGED
@@ -74,7 +74,15 @@ program
74
74
  if (!configManager.isAuthenticated()) {
75
75
  console.log(chalk_1.default.yellow('Welcome to oflow! Let\'s get you set up.'));
76
76
  console.log('');
77
- await runAuthFlow();
77
+ const authSuccess = await runAuthFlow();
78
+ // 【修复】认证成功后启动交互模式
79
+ if (authSuccess) {
80
+ console.log(chalk_1.default.cyan('\nStarting oflow CLI...\n'));
81
+ await (0, cli_1.startInteractiveMode)({
82
+ model: options.model,
83
+ yolo: options.yolo
84
+ });
85
+ }
78
86
  return;
79
87
  }
80
88
  // Set model if specified
@@ -112,7 +120,10 @@ program
112
120
  .description('Configure authentication')
113
121
  .option('--provider <provider>', 'Provider (openai, deepseek, qwen, etc.)')
114
122
  .action(async (options) => {
115
- await runAuthFlow(options.provider);
123
+ const success = await runAuthFlow(options.provider);
124
+ if (success) {
125
+ console.log(chalk_1.default.cyan('\nYou can now run "oflow" to start the CLI.'));
126
+ }
116
127
  });
117
128
  // Config command
118
129
  program
@@ -125,7 +136,13 @@ program
125
136
  const configManager = (0, core_1.getConfigManager)();
126
137
  if (options.list) {
127
138
  console.log(chalk_1.default.bold('Current Configuration:'));
128
- console.log(JSON.stringify(configManager.getAll(), null, 2));
139
+ const config = configManager.getAll();
140
+ // 隐藏敏感信息
141
+ const safeConfig = { ...config };
142
+ if (safeConfig.auth?.apiKey) {
143
+ safeConfig.auth = { ...safeConfig.auth, apiKey: '****' + safeConfig.auth.apiKey.slice(-4) };
144
+ }
145
+ console.log(JSON.stringify(safeConfig, null, 2));
129
146
  console.log('');
130
147
  console.log(chalk_1.default.gray(`Config file: ${configManager.getConfigPath()}`));
131
148
  }
@@ -141,6 +158,7 @@ program
141
158
  else {
142
159
  console.log(`Config file: ${configManager.getConfigPath()}`);
143
160
  console.log(`Thinking display: ${configManager.getShowThinking() ? 'ON' : 'OFF'}`);
161
+ console.log(`Current model: ${configManager.getDefaultModel()}`);
144
162
  }
145
163
  });
146
164
  // Models command
@@ -206,6 +224,7 @@ async function runAuthFlow(provider) {
206
224
  });
207
225
  configManager.setDefaultModel(answers.model);
208
226
  console.log(chalk_1.default.green('\n✓ Authentication configured successfully!'));
227
+ return true;
209
228
  }
210
229
  // Custom
211
230
  else if (provider === 'custom') {
@@ -214,7 +233,14 @@ async function runAuthFlow(provider) {
214
233
  type: 'input',
215
234
  name: 'baseUrl',
216
235
  message: 'Enter API base URL:',
217
- default: 'https://api.openai.com/v1'
236
+ default: 'https://api.openai.com/v1',
237
+ validate: (input) => {
238
+ if (!input)
239
+ return 'Base URL is required';
240
+ if (!input.startsWith('http'))
241
+ return 'URL must start with http:// or https://';
242
+ return true;
243
+ }
218
244
  },
219
245
  {
220
246
  type: 'password',
@@ -237,6 +263,7 @@ async function runAuthFlow(provider) {
237
263
  });
238
264
  configManager.setDefaultModel(answers.model);
239
265
  console.log(chalk_1.default.green('\n✓ Authentication configured successfully!'));
266
+ return true;
240
267
  }
241
268
  // 国内模型
242
269
  else if (core_1.CHINESE_MODELS[provider]) {
@@ -253,8 +280,11 @@ async function runAuthFlow(provider) {
253
280
  type: 'list',
254
281
  name: 'model',
255
282
  message: 'Select default model:',
256
- choices: modelConfig.models,
257
- default: modelConfig.models[0]
283
+ choices: modelConfig.models.map((m) => ({
284
+ name: `${m.id} - ${m.name}`,
285
+ value: m.id
286
+ })),
287
+ default: modelConfig.models[0].id
258
288
  }
259
289
  ]);
260
290
  configManager.setAuth({
@@ -269,15 +299,13 @@ async function runAuthFlow(provider) {
269
299
  if (provider === 'deepseek' && answers.model === 'deepseek-reasoner') {
270
300
  console.log(chalk_1.default.yellow('💡 提示: deepseek-reasoner 支持显示思考过程,使用 --thinking 开启'));
271
301
  }
302
+ return true;
272
303
  }
304
+ return false;
273
305
  }
274
306
  async function listModels() {
275
307
  const configManager = (0, core_1.getConfigManager)();
276
308
  const auth = configManager.getAuth();
277
- if (!auth) {
278
- console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
279
- return;
280
- }
281
309
  console.log(chalk_1.default.bold('\n═══════════════════════════════════════════════════════════'));
282
310
  console.log(chalk_1.default.bold(' Available Models '));
283
311
  console.log(chalk_1.default.bold('═══════════════════════════════════════════════════════════\n'));
@@ -312,9 +340,12 @@ async function listModels() {
312
340
  }
313
341
  // 显示当前配置
314
342
  console.log(chalk_1.default.bold('───────────────────────────────────────────────────────────'));
343
+ if (auth) {
344
+ console.log(`Current provider: ${chalk_1.default.green(auth.provider)}`);
345
+ }
315
346
  console.log(`Current model: ${chalk_1.default.green(configManager.getDefaultModel())}`);
316
347
  console.log(`Thinking display: ${configManager.getShowThinking() ? chalk_1.default.green('ON') : chalk_1.default.gray('OFF')}`);
317
348
  console.log('');
318
349
  }
319
350
  program.parse();
320
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport { startInteractiveMode, runSingleCommand } from './cli';\nimport { getConfigManager, CHINESE_MODELS } from '@oflow-ai/core';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\n// Read package.json for version\nconst packageJsonPath = path.join(__dirname, '..', 'package.json');\nconst packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n\n// Simple update check (without update-notifier due to type issues)\ntry {\n  const updateNotifier = require('update-notifier');\n  const notifier = updateNotifier({ pkg: packageJson });\n  if (notifier.notify) {\n    notifier.notify();\n  }\n} catch {\n  // Ignore update check errors\n}\n\nconst program = new Command();\n\nprogram\n  .name('oflow')\n  .description('AI-powered CLI assistant for terminal')\n  .version(packageJson.version)\n  .option('-m, --model <model>', 'Specify the AI model to use')\n  .option('-d, --directory <dir>', 'Working directory')\n  .option('--yolo', 'Run in yolo mode (auto-approve all operations)')\n  .option('--thinking', 'Show AI thinking/reasoning process')\n  .option('--no-thinking', 'Hide AI thinking/reasoning process')\n  .argument('[prompt]', 'Prompt to send to AI (starts interactive mode if not provided)')\n  .action(async (prompt, options) => {\n    const configManager = getConfigManager();\n    \n    // Check authentication\n    if (!configManager.isAuthenticated()) {\n      console.log(chalk.yellow('Welcome to oflow! Let\\'s get you set up.'));\n      console.log('');\n      await runAuthFlow();\n      return;\n    }\n\n    // Set model if specified\n    if (options.model) {\n      configManager.setDefaultModel(options.model);\n    }\n\n    // Set thinking mode if specified\n    if (options.thinking === true) {\n      configManager.setShowThinking(true);\n    } else if (options.thinking === false) {\n      configManager.setShowThinking(false);\n    }\n\n    // Set working directory\n    const workingDir = options.directory || process.cwd();\n    process.chdir(workingDir);\n\n    if (prompt) {\n      // Single command mode\n      await runSingleCommand(prompt, {\n        model: options.model,\n        yolo: options.yolo\n      });\n    } else {\n      // Interactive mode\n      await startInteractiveMode({\n        model: options.model,\n        yolo: options.yolo\n      });\n    }\n  });\n\n// Auth command\nprogram\n  .command('auth')\n  .description('Configure authentication')\n  .option('--provider <provider>', 'Provider (openai, deepseek, qwen, etc.)')\n  .action(async (options) => {\n    await runAuthFlow(options.provider);\n  });\n\n// Config command\nprogram\n  .command('config')\n  .description('View or edit configuration')\n  .option('--list', 'List current configuration')\n  .option('--set <key=value>', 'Set a configuration value')\n  .option('--thinking', 'Toggle thinking process display')\n  .action(async (options) => {\n    const configManager = getConfigManager();\n    \n    if (options.list) {\n      console.log(chalk.bold('Current Configuration:'));\n      console.log(JSON.stringify(configManager.getAll(), null, 2));\n      console.log('');\n      console.log(chalk.gray(`Config file: ${configManager.getConfigPath()}`));\n    } else if (options.thinking) {\n      const newValue = configManager.toggleShowThinking();\n      console.log(chalk.green(`✓ Thinking process display: ${newValue ? 'ON' : 'OFF'}`));\n    } else if (options.set) {\n      const [key, value] = options.set.split('=');\n      configManager.set(key as any, value);\n      console.log(chalk.green(`Set ${key} = ${value}`));\n    } else {\n      console.log(`Config file: ${configManager.getConfigPath()}`);\n      console.log(`Thinking display: ${configManager.getShowThinking() ? 'ON' : 'OFF'}`);\n    }\n  });\n\n// Models command\nprogram\n  .command('models')\n  .description('List available AI models')\n  .action(async () => {\n    await listModels();\n  });\n\nasync function runAuthFlow(provider?: string): Promise<void> {\n  const inquirer = require('inquirer');\n  const configManager = getConfigManager();\n\n  if (!provider) {\n    const answers = await inquirer.prompt([\n      {\n        type: 'list',\n        name: 'provider',\n        message: 'Select AI provider:',\n        choices: [\n          { name: '🌐 OpenAI (Official API)', value: 'openai' },\n          { name: '🔧 Custom (OpenAI-compatible)', value: 'custom' },\n          { name: '────────── 国内模型 ──────────', value: 'separator', disabled: true },\n          { name: '🇨🇳 DeepSeek (深度求索) - 推荐推理模型', value: 'deepseek' },\n          { name: '🇨🇳 Qwen (通义千问)', value: 'qwen' },\n          { name: '🇨🇳 GLM (智谱)', value: 'zhipu' },\n          { name: '🇨🇳 Baichuan (百川)', value: 'baichuan' },\n          { name: '🇨🇳 Yi (零一万物)', value: 'yi' },\n          { name: '🇨🇳 Moonshot (月之暗面/Kimi)', value: 'moonshot' },\n          { name: '🇨🇳 SiliconFlow (硅基流动)', value: 'siliconflow' }\n        ]\n      }\n    ]);\n    provider = answers.provider;\n  }\n\n  // OpenAI\n  if (provider === 'openai') {\n    const answers = await inquirer.prompt([\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: 'Enter your OpenAI API key:',\n        mask: '*'\n      },\n      {\n        type: 'list',\n        name: 'model',\n        message: 'Select default model:',\n        choices: [\n          'gpt-4o',\n          'gpt-4o-mini',\n          'gpt-4-turbo',\n          'gpt-3.5-turbo',\n          'o1-preview',\n          'o1-mini'\n        ],\n        default: 'gpt-4o'\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: 'openai',\n      apiKey: answers.apiKey,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green('\\n✓ Authentication configured successfully!'));\n  } \n  // Custom\n  else if (provider === 'custom') {\n    const answers = await inquirer.prompt([\n      {\n        type: 'input',\n        name: 'baseUrl',\n        message: 'Enter API base URL:',\n        default: 'https://api.openai.com/v1'\n      },\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: 'Enter your API key:',\n        mask: '*'\n      },\n      {\n        type: 'input',\n        name: 'model',\n        message: 'Enter default model name:',\n        default: 'gpt-4o'\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: 'custom',\n      apiKey: answers.apiKey,\n      baseUrl: answers.baseUrl,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green('\\n✓ Authentication configured successfully!'));\n  }\n  // 国内模型\n  else if (CHINESE_MODELS[provider as keyof typeof CHINESE_MODELS]) {\n    const modelConfig = CHINESE_MODELS[provider as keyof typeof CHINESE_MODELS];\n    \n    console.log(chalk.cyan(`\\n配置 ${modelConfig.name}`));\n    \n    const answers = await inquirer.prompt([\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: `Enter your ${modelConfig.name} API key:`,\n        mask: '*'\n      },\n      {\n        type: 'list',\n        name: 'model',\n        message: 'Select default model:',\n        choices: modelConfig.models,\n        default: modelConfig.models[0]\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: provider as any,\n      apiKey: answers.apiKey,\n      baseUrl: modelConfig.baseUrl,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green(`\\n✓ ${modelConfig.name} 配置成功!`));\n    \n    // DeepSeek特殊提示\n    if (provider === 'deepseek' && answers.model === 'deepseek-reasoner') {\n      console.log(chalk.yellow('💡 提示: deepseek-reasoner 支持显示思考过程，使用 --thinking 开启'));\n    }\n  }\n}\n\nasync function listModels(): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  console.log(chalk.bold('\\n═══════════════════════════════════════════════════════════'));\n  console.log(chalk.bold('                    Available Models                        '));\n  console.log(chalk.bold('═══════════════════════════════════════════════════════════\\n'));\n\n  // OpenAI Models\n  console.log(chalk.cyan('🌐 OpenAI Models:'));\n  const openaiModels = [\n    { id: 'gpt-4o', desc: 'Most capable GPT-4 model' },\n    { id: 'gpt-4o-mini', desc: 'Fast and affordable' },\n    { id: 'gpt-4-turbo', desc: 'Previous GPT-4 version' },\n    { id: 'gpt-3.5-turbo', desc: 'Fast and cheap' },\n    { id: 'o1-preview', desc: 'Advanced reasoning' },\n    { id: 'o1-mini', desc: 'Efficient reasoning' }\n  ];\n  openaiModels.forEach(m => {\n    const current = m.id === configManager.getDefaultModel() ? chalk.green('* ') : '  ';\n    console.log(`${current}${m.id} - ${chalk.gray(m.desc)}`);\n  });\n\n  // 国内模型\n  console.log('');\n  console.log(chalk.cyan('🇨🇳 国内开源模型:\\n'));\n\n  for (const [key, config] of Object.entries(CHINESE_MODELS)) {\n    console.log(chalk.bold(`  ${config.name}`));\n    console.log(chalk.gray(`    API: ${config.baseUrl}`));\n    for (const m of config.models) {\n      const modelId = typeof m === 'string' ? m : m.id;\n      const modelName = typeof m === 'string' ? m : m.name;\n      const modelDesc = typeof m === 'string' ? '' : (m as any).desc;\n      const current = modelId === configManager.getDefaultModel() ? chalk.green('* ') : '    ';\n      console.log(`${current}${modelId} - ${chalk.gray(modelName)}${modelDesc ? chalk.gray(` (${modelDesc})`) : ''}`);\n    }\n    console.log('');\n  }\n\n  // 显示当前配置\n  console.log(chalk.bold('───────────────────────────────────────────────────────────'));\n  console.log(`Current model: ${chalk.green(configManager.getDefaultModel())}`);\n  console.log(`Thinking display: ${configManager.getShowThinking() ? chalk.green('ON') : chalk.gray('OFF')}`);\n  console.log('');\n}\n\nprogram.parse();"]}
351
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport { startInteractiveMode, runSingleCommand } from './cli';\nimport { getConfigManager, CHINESE_MODELS } from '@oflow-ai/core';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\n// Read package.json for version\nconst packageJsonPath = path.join(__dirname, '..', 'package.json');\nconst packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n\n// Simple update check (without update-notifier due to type issues)\ntry {\n  const updateNotifier = require('update-notifier');\n  const notifier = updateNotifier({ pkg: packageJson });\n  if (notifier.notify) {\n    notifier.notify();\n  }\n} catch {\n  // Ignore update check errors\n}\n\nconst program = new Command();\n\nprogram\n  .name('oflow')\n  .description('AI-powered CLI assistant for terminal')\n  .version(packageJson.version)\n  .option('-m, --model <model>', 'Specify the AI model to use')\n  .option('-d, --directory <dir>', 'Working directory')\n  .option('--yolo', 'Run in yolo mode (auto-approve all operations)')\n  .option('--thinking', 'Show AI thinking/reasoning process')\n  .option('--no-thinking', 'Hide AI thinking/reasoning process')\n  .argument('[prompt]', 'Prompt to send to AI (starts interactive mode if not provided)')\n  .action(async (prompt, options) => {\n    const configManager = getConfigManager();\n    \n    // Check authentication\n    if (!configManager.isAuthenticated()) {\n      console.log(chalk.yellow('Welcome to oflow! Let\\'s get you set up.'));\n      console.log('');\n      const authSuccess = await runAuthFlow();\n      \n      // 【修复】认证成功后启动交互模式\n      if (authSuccess) {\n        console.log(chalk.cyan('\\nStarting oflow CLI...\\n'));\n        await startInteractiveMode({\n          model: options.model,\n          yolo: options.yolo\n        });\n      }\n      return;\n    }\n\n    // Set model if specified\n    if (options.model) {\n      configManager.setDefaultModel(options.model);\n    }\n\n    // Set thinking mode if specified\n    if (options.thinking === true) {\n      configManager.setShowThinking(true);\n    } else if (options.thinking === false) {\n      configManager.setShowThinking(false);\n    }\n\n    // Set working directory\n    const workingDir = options.directory || process.cwd();\n    process.chdir(workingDir);\n\n    if (prompt) {\n      // Single command mode\n      await runSingleCommand(prompt, {\n        model: options.model,\n        yolo: options.yolo\n      });\n    } else {\n      // Interactive mode\n      await startInteractiveMode({\n        model: options.model,\n        yolo: options.yolo\n      });\n    }\n  });\n\n// Auth command\nprogram\n  .command('auth')\n  .description('Configure authentication')\n  .option('--provider <provider>', 'Provider (openai, deepseek, qwen, etc.)')\n  .action(async (options) => {\n    const success = await runAuthFlow(options.provider);\n    if (success) {\n      console.log(chalk.cyan('\\nYou can now run \"oflow\" to start the CLI.'));\n    }\n  });\n\n// Config command\nprogram\n  .command('config')\n  .description('View or edit configuration')\n  .option('--list', 'List current configuration')\n  .option('--set <key=value>', 'Set a configuration value')\n  .option('--thinking', 'Toggle thinking process display')\n  .action(async (options) => {\n    const configManager = getConfigManager();\n    \n    if (options.list) {\n      console.log(chalk.bold('Current Configuration:'));\n      const config = configManager.getAll();\n      // 隐藏敏感信息\n      const safeConfig = { ...config };\n      if (safeConfig.auth?.apiKey) {\n        safeConfig.auth = { ...safeConfig.auth, apiKey: '****' + safeConfig.auth.apiKey.slice(-4) };\n      }\n      console.log(JSON.stringify(safeConfig, null, 2));\n      console.log('');\n      console.log(chalk.gray(`Config file: ${configManager.getConfigPath()}`));\n    } else if (options.thinking) {\n      const newValue = configManager.toggleShowThinking();\n      console.log(chalk.green(`✓ Thinking process display: ${newValue ? 'ON' : 'OFF'}`));\n    } else if (options.set) {\n      const [key, value] = options.set.split('=');\n      configManager.set(key as any, value);\n      console.log(chalk.green(`Set ${key} = ${value}`));\n    } else {\n      console.log(`Config file: ${configManager.getConfigPath()}`);\n      console.log(`Thinking display: ${configManager.getShowThinking() ? 'ON' : 'OFF'}`);\n      console.log(`Current model: ${configManager.getDefaultModel()}`);\n    }\n  });\n\n// Models command\nprogram\n  .command('models')\n  .description('List available AI models')\n  .action(async () => {\n    await listModels();\n  });\n\nasync function runAuthFlow(provider?: string): Promise<boolean> {\n  const inquirer = require('inquirer');\n  const configManager = getConfigManager();\n\n  if (!provider) {\n    const answers = await inquirer.prompt([\n      {\n        type: 'list',\n        name: 'provider',\n        message: 'Select AI provider:',\n        choices: [\n          { name: '🌐 OpenAI (Official API)', value: 'openai' },\n          { name: '🔧 Custom (OpenAI-compatible)', value: 'custom' },\n          { name: '────────── 国内模型 ──────────', value: 'separator', disabled: true },\n          { name: '🇨🇳 DeepSeek (深度求索) - 推荐推理模型', value: 'deepseek' },\n          { name: '🇨🇳 Qwen (通义千问)', value: 'qwen' },\n          { name: '🇨🇳 GLM (智谱)', value: 'zhipu' },\n          { name: '🇨🇳 Baichuan (百川)', value: 'baichuan' },\n          { name: '🇨🇳 Yi (零一万物)', value: 'yi' },\n          { name: '🇨🇳 Moonshot (月之暗面/Kimi)', value: 'moonshot' },\n          { name: '🇨🇳 SiliconFlow (硅基流动)', value: 'siliconflow' }\n        ]\n      }\n    ]);\n    provider = answers.provider;\n  }\n\n  // OpenAI\n  if (provider === 'openai') {\n    const answers = await inquirer.prompt([\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: 'Enter your OpenAI API key:',\n        mask: '*'\n      },\n      {\n        type: 'list',\n        name: 'model',\n        message: 'Select default model:',\n        choices: [\n          'gpt-4o',\n          'gpt-4o-mini',\n          'gpt-4-turbo',\n          'gpt-3.5-turbo',\n          'o1-preview',\n          'o1-mini'\n        ],\n        default: 'gpt-4o'\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: 'openai',\n      apiKey: answers.apiKey,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green('\\n✓ Authentication configured successfully!'));\n    return true;\n  } \n  // Custom\n  else if (provider === 'custom') {\n    const answers = await inquirer.prompt([\n      {\n        type: 'input',\n        name: 'baseUrl',\n        message: 'Enter API base URL:',\n        default: 'https://api.openai.com/v1',\n        validate: (input: string) => {\n          if (!input) return 'Base URL is required';\n          if (!input.startsWith('http')) return 'URL must start with http:// or https://';\n          return true;\n        }\n      },\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: 'Enter your API key:',\n        mask: '*'\n      },\n      {\n        type: 'input',\n        name: 'model',\n        message: 'Enter default model name:',\n        default: 'gpt-4o'\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: 'custom',\n      apiKey: answers.apiKey,\n      baseUrl: answers.baseUrl,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green('\\n✓ Authentication configured successfully!'));\n    return true;\n  }\n  // 国内模型\n  else if (CHINESE_MODELS[provider as keyof typeof CHINESE_MODELS]) {\n    const modelConfig = CHINESE_MODELS[provider as keyof typeof CHINESE_MODELS];\n    \n    console.log(chalk.cyan(`\\n配置 ${modelConfig.name}`));\n    \n    const answers = await inquirer.prompt([\n      {\n        type: 'password',\n        name: 'apiKey',\n        message: `Enter your ${modelConfig.name} API key:`,\n        mask: '*'\n      },\n      {\n        type: 'list',\n        name: 'model',\n        message: 'Select default model:',\n        choices: modelConfig.models.map((m: any) => ({\n          name: `${m.id} - ${m.name}`,\n          value: m.id\n        })),\n        default: modelConfig.models[0].id\n      }\n    ]);\n\n    configManager.setAuth({\n      provider: provider as any,\n      apiKey: answers.apiKey,\n      baseUrl: modelConfig.baseUrl,\n      model: answers.model\n    });\n    configManager.setDefaultModel(answers.model);\n\n    console.log(chalk.green(`\\n✓ ${modelConfig.name} 配置成功!`));\n    \n    // DeepSeek特殊提示\n    if (provider === 'deepseek' && answers.model === 'deepseek-reasoner') {\n      console.log(chalk.yellow('💡 提示: deepseek-reasoner 支持显示思考过程，使用 --thinking 开启'));\n    }\n    return true;\n  }\n  \n  return false;\n}\n\nasync function listModels(): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  console.log(chalk.bold('\\n═══════════════════════════════════════════════════════════'));\n  console.log(chalk.bold('                    Available Models                        '));\n  console.log(chalk.bold('═══════════════════════════════════════════════════════════\\n'));\n\n  // OpenAI Models\n  console.log(chalk.cyan('🌐 OpenAI Models:'));\n  const openaiModels = [\n    { id: 'gpt-4o', desc: 'Most capable GPT-4 model' },\n    { id: 'gpt-4o-mini', desc: 'Fast and affordable' },\n    { id: 'gpt-4-turbo', desc: 'Previous GPT-4 version' },\n    { id: 'gpt-3.5-turbo', desc: 'Fast and cheap' },\n    { id: 'o1-preview', desc: 'Advanced reasoning' },\n    { id: 'o1-mini', desc: 'Efficient reasoning' }\n  ];\n  openaiModels.forEach(m => {\n    const current = m.id === configManager.getDefaultModel() ? chalk.green('* ') : '  ';\n    console.log(`${current}${m.id} - ${chalk.gray(m.desc)}`);\n  });\n\n  // 国内模型\n  console.log('');\n  console.log(chalk.cyan('🇨🇳 国内开源模型:\\n'));\n\n  for (const [key, config] of Object.entries(CHINESE_MODELS)) {\n    console.log(chalk.bold(`  ${config.name}`));\n    console.log(chalk.gray(`    API: ${config.baseUrl}`));\n    for (const m of config.models) {\n      const modelId = typeof m === 'string' ? m : m.id;\n      const modelName = typeof m === 'string' ? m : m.name;\n      const modelDesc = typeof m === 'string' ? '' : (m as any).desc;\n      const current = modelId === configManager.getDefaultModel() ? chalk.green('* ') : '    ';\n      console.log(`${current}${modelId} - ${chalk.gray(modelName)}${modelDesc ? chalk.gray(` (${modelDesc})`) : ''}`);\n    }\n    console.log('');\n  }\n\n  // 显示当前配置\n  console.log(chalk.bold('───────────────────────────────────────────────────────────'));\n  if (auth) {\n    console.log(`Current provider: ${chalk.green(auth.provider)}`);\n  }\n  console.log(`Current model: ${chalk.green(configManager.getDefaultModel())}`);\n  console.log(`Thinking display: ${configManager.getShowThinking() ? chalk.green('ON') : chalk.gray('OFF')}`);\n  console.log('');\n}\n\nprogram.parse();\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@oflow-ai/oflow-cli",
3
- "version": "0.1.0",
3
+ "version": "0.1.1",
4
4
  "description": "oFlow CLI - AI-powered terminal assistant for developers",
5
5
  "keywords": [
6
6
  "ai",