@oflow-ai/oflow-cli 0.1.5 → 0.1.6
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.
- package/dist/cli.js +14 -14
- package/dist/updater.d.ts +6 -7
- package/dist/updater.js +30 -123
- package/package.json +1 -1
package/dist/cli.js
CHANGED
|
@@ -137,19 +137,19 @@ async function startInteractiveMode(options) {
|
|
|
137
137
|
console.log(chalk_1.default.bold.blue(' oflow CLI ' + chalk_1.default.white(versionDisplay)));
|
|
138
138
|
console.log(chalk_1.default.gray(' Type /help for commands, /exit to quit'));
|
|
139
139
|
console.log('');
|
|
140
|
-
//
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
}
|
|
140
|
+
// 检测更新
|
|
141
|
+
let updateInfo = null;
|
|
142
|
+
try {
|
|
143
|
+
updateInfo = await (0, updater_1.checkForUpdates)();
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
// 忽略检测错误
|
|
147
|
+
}
|
|
148
|
+
if (updateInfo && updateInfo.hasUpdate) {
|
|
149
|
+
console.log(chalk_1.default.yellow(' New version available: ' + updateInfo.latestVersion));
|
|
150
|
+
console.log(chalk_1.default.gray(' Run /update to install the latest version'));
|
|
151
|
+
console.log('');
|
|
152
|
+
}
|
|
153
153
|
if (options.sandbox || configManager.get('sandbox')) {
|
|
154
154
|
try {
|
|
155
155
|
sandboxExecutor = await (0, core_1.createSandboxExecutor)();
|
|
@@ -496,4 +496,4 @@ Your primary goal is to help users safely and efficiently complete programming t
|
|
|
496
496
|
Current working directory: ${process.cwd()}
|
|
497
497
|
`;
|
|
498
498
|
}
|
|
499
|
-
//# 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  AgentFactory,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\nimport { checkForUpdates, performUpdate, getCurrentVersion, performBackgroundUpdate } from './updater';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\ninterface SessionStats {\n  toolCallsCount: number;\n  filesRead: string[];\n  filesWritten: string[];\n  commandsRun: string[];\n  startTime: Date;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet currentShowThinking = false;\nlet sessionStats: SessionStats = {\n  toolCallsCount: 0,\n  filesRead: [],\n  filesWritten: [],\n  commandsRun: [],\n  startTime: new Date()\n};\nlet contextTokens = 0;\nlet maxContextTokens = 128000;\nlet currentModel = 'gpt-4o';\n\n/**\n * 显示状态栏（固定在输入框上方）\n */\nfunction showStatusBar(): void {\n  const terminalWidth = process.stdout.columns || 80;\n  const contextPercent = Math.min(100, Math.round((contextTokens / maxContextTokens) * 100));\n  const contextColor = contextPercent > 80 ? chalk.red : contextPercent > 50 ? chalk.yellow : chalk.green;\n  const thinkingStatus = currentShowThinking ? chalk.cyan('ON') : chalk.gray('OFF');\n  \n  // 状态栏第一行\n  const statusParts = [\n    `${chalk.blue('Model:')} ${chalk.white(currentModel)}`,\n    `${chalk.blue('Context:')} ${contextColor(contextPercent + '%')}`,\n    `${chalk.blue('Thinking:')} ${thinkingStatus}`\n  ];\n  const statusLine1 = statusParts.join('  |  ');\n  \n  // 状态栏第二行 - 当前目录\n  const currentDir = process.cwd();\n  const maxDirLen = terminalWidth - 8;\n  const dirDisplay = currentDir.length > maxDirLen \n    ? '...' + currentDir.slice(-(maxDirLen - 3))\n    : currentDir;\n  const statusLine2 = `${chalk.blue('Dir:')} ${chalk.gray(dirDisplay)}`;\n  \n  // 打印状态栏\n  console.log('');\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 80))));\n  console.log(statusLine1);\n  console.log(statusLine2);\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 80))));\n}\n\nfunction showTaskSummary(): void {\n  const duration = Math.round((Date.now() - sessionStats.startTime.getTime()) / 1000);\n  const minutes = Math.floor(duration / 60);\n  const seconds = duration % 60;\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log(chalk.bold.cyan('           Task Summary'));\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log('');\n  \n  console.log(`${chalk.white('Duration:')} ${chalk.yellow(minutes + 'm ' + seconds + 's')}`);\n  console.log(`${chalk.white('Tool calls:')} ${chalk.yellow(sessionStats.toolCallsCount.toString())}`);\n  \n  if (sessionStats.filesRead.length > 0) {\n    console.log(`${chalk.white('Files read:')} ${chalk.yellow(sessionStats.filesRead.length.toString())}`);\n    sessionStats.filesRead.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesRead.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesRead.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.filesWritten.length > 0) {\n    console.log(`${chalk.white('Files modified:')} ${chalk.yellow(sessionStats.filesWritten.length.toString())}`);\n    sessionStats.filesWritten.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesWritten.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesWritten.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.commandsRun.length > 0) {\n    console.log(`${chalk.white('Commands run:')} ${chalk.yellow(sessionStats.commandsRun.length.toString())}`);\n  }\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  \n  sessionStats = {\n    toolCallsCount: 0,\n    filesRead: [],\n    filesWritten: [],\n    commandsRun: [],\n    startTime: new Date()\n  };\n}\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  const currentVersion = await getCurrentVersion();\n  const versionDisplay = 'v' + currentVersion;\n  console.log('');\n  console.log(chalk.bold.blue('  oflow CLI ' + chalk.white(versionDisplay)));\n  console.log(chalk.gray('  Type /help for commands, /exit to quit'));\n  console.log('');\n\n  // 后台检测更新（不阻塞当前 session）\n  checkForUpdates().then(updateInfo => {\n    if (updateInfo.hasUpdate) {\n      console.log(chalk.yellow('  New version available: ' + updateInfo.latestVersion));\n      console.log(chalk.gray('  Updating in background...'));\n      performBackgroundUpdate((success) => {\n        if (success) {\n          console.log('');\n          console.log(chalk.green('  Update completed! Restart oflow to use v' + updateInfo.latestVersion));\n        }\n      });\n    }\n  }).catch(() => {});\n\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\n  }\n\n  currentShowThinking = options.showThinking ?? configManager.getShowThinking();\n  currentModel = options.model || configManager.getDefaultModel() || 'gpt-4o';\n\n  if (currentModel.includes('gpt-4') || currentModel.includes('gpt-4o')) {\n    maxContextTokens = 128000;\n  } else if (currentModel.includes('deepseek')) {\n    maxContextTokens = 64000;\n  } else {\n    maxContextTokens = 128000;\n  }\n\n  let provider;\n  try {\n    provider = createAIProvider(auth, currentModel);\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      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      sessionStats.toolCallsCount++;\n      console.log(chalk.cyan('\\n[Tool: ' + toolCall.function.name + ']'));\n      try {\n        const args = JSON.parse(toolCall.function.arguments);\n        if (toolCall.function.name === 'read_file' && args.absolute_path) {\n          if (!sessionStats.filesRead.includes(args.absolute_path)) {\n            sessionStats.filesRead.push(args.absolute_path);\n          }\n        } else if ((toolCall.function.name === 'write_file' || toolCall.function.name === 'replace') && args.file_path) {\n          if (!sessionStats.filesWritten.includes(args.file_path)) {\n            sessionStats.filesWritten.push(args.file_path);\n          }\n        } else if (toolCall.function.name === 'run_shell_command' && args.command) {\n          sessionStats.commandsRun.push(args.command);\n        }\n      } catch {}\n    },\n    onToolResult: (result) => {\n      contextTokens += Math.ceil(result.length / 4);\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  /**\n   * 显示输入提示（状态栏在输入框上方）\n   * 布局顺序：\n   * [内容区域]\n   * [状态栏]\n   * > [输入框]\n   */\n  const showPrompt = () => {\n    showStatusBar();\n    rl.setPrompt(chalk.green('> '));\n    rl.prompt();\n  };\n\n  showPrompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      showPrompt();\n      return;\n    }\n\n    // 处理 slash 命令\n    if (isSlashCommand(input)) {\n      if (input.toLowerCase() === '/thinking') {\n        currentShowThinking = !currentShowThinking;\n        configManager.setShowThinking(currentShowThinking);\n        console.log(chalk.green('Thinking: ' + (currentShowThinking ? 'ON' : 'OFF')));\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/summary') {\n        showTaskSummary();\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/update') {\n        await performUpdate(false);\n        showPrompt();\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      showPrompt();\n      return;\n    }\n\n    // 处理 agent 调用\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider);\n      showPrompt();\n      return;\n    }\n\n    // 处理 shell 命令\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      showPrompt();\n      return;\n    }\n\n    // 处理普通对话\n    const processedInput = await processFileReferences(input);\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      console.log('');\n      \n      if (sessionStats.toolCallsCount >= 3) {\n        showTaskSummary();\n      } else {\n        contextTokens += Math.ceil(response.length / 4);\n      }\n      \n      showPrompt();\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      if (errorMessage.includes('400')) {\n        console.log(chalk.yellow('Check API key and model name, or run \"oflow auth\"'));\n      } else if (errorMessage.includes('401')) {\n        console.log(chalk.yellow('Authentication failed, run \"oflow auth\"'));\n      } else if (errorMessage.includes('429')) {\n        console.log(chalk.yellow('Rate limit, please wait and retry'));\n      }\n      \n      showPrompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(input: string, provider: any): Promise<void> {\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('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.'));\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[Agent: ' + agentType + ']'));\n    console.log(chalk.gray('Task: ' + task + '\\n'));\n\n    const spinner = ora('Agent working...').start();\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('\\nAgent 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        sessionStats.filesWritten.push(...result.filesModified);\n      }\n    } else {\n      console.log(chalk.red('\\nAgent 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    showTaskSummary();\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  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\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  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  sessionStats.commandsRun.push(command);\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      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', () => resolve());\n    proc.on('error', (err: Error) => {\n      console.log(chalk.red('Failed: ' + 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  let result = input;\n  const fs = require('fs');\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      sessionStats.filesRead.push(filePath);\n    } catch {\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# 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. After completing a complex task, provide a brief summary\n\nCurrent working directory: ${process.cwd()}\n`;\n}\n"]}
|
|
499
|
+
//# 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  AgentFactory,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\nimport { checkForUpdates, performUpdate, getCurrentVersion } from './updater';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\ninterface SessionStats {\n  toolCallsCount: number;\n  filesRead: string[];\n  filesWritten: string[];\n  commandsRun: string[];\n  startTime: Date;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet currentShowThinking = false;\nlet sessionStats: SessionStats = {\n  toolCallsCount: 0,\n  filesRead: [],\n  filesWritten: [],\n  commandsRun: [],\n  startTime: new Date()\n};\nlet contextTokens = 0;\nlet maxContextTokens = 128000;\nlet currentModel = 'gpt-4o';\n\n/**\n * 显示状态栏（固定在输入框上方）\n */\nfunction showStatusBar(): void {\n  const terminalWidth = process.stdout.columns || 80;\n  const contextPercent = Math.min(100, Math.round((contextTokens / maxContextTokens) * 100));\n  const contextColor = contextPercent > 80 ? chalk.red : contextPercent > 50 ? chalk.yellow : chalk.green;\n  const thinkingStatus = currentShowThinking ? chalk.cyan('ON') : chalk.gray('OFF');\n  \n  // 状态栏第一行\n  const statusParts = [\n    `${chalk.blue('Model:')} ${chalk.white(currentModel)}`,\n    `${chalk.blue('Context:')} ${contextColor(contextPercent + '%')}`,\n    `${chalk.blue('Thinking:')} ${thinkingStatus}`\n  ];\n  const statusLine1 = statusParts.join('  |  ');\n  \n  // 状态栏第二行 - 当前目录\n  const currentDir = process.cwd();\n  const maxDirLen = terminalWidth - 8;\n  const dirDisplay = currentDir.length > maxDirLen \n    ? '...' + currentDir.slice(-(maxDirLen - 3))\n    : currentDir;\n  const statusLine2 = `${chalk.blue('Dir:')} ${chalk.gray(dirDisplay)}`;\n  \n  // 打印状态栏\n  console.log('');\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 80))));\n  console.log(statusLine1);\n  console.log(statusLine2);\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 80))));\n}\n\nfunction showTaskSummary(): void {\n  const duration = Math.round((Date.now() - sessionStats.startTime.getTime()) / 1000);\n  const minutes = Math.floor(duration / 60);\n  const seconds = duration % 60;\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log(chalk.bold.cyan('           Task Summary'));\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log('');\n  \n  console.log(`${chalk.white('Duration:')} ${chalk.yellow(minutes + 'm ' + seconds + 's')}`);\n  console.log(`${chalk.white('Tool calls:')} ${chalk.yellow(sessionStats.toolCallsCount.toString())}`);\n  \n  if (sessionStats.filesRead.length > 0) {\n    console.log(`${chalk.white('Files read:')} ${chalk.yellow(sessionStats.filesRead.length.toString())}`);\n    sessionStats.filesRead.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesRead.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesRead.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.filesWritten.length > 0) {\n    console.log(`${chalk.white('Files modified:')} ${chalk.yellow(sessionStats.filesWritten.length.toString())}`);\n    sessionStats.filesWritten.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesWritten.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesWritten.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.commandsRun.length > 0) {\n    console.log(`${chalk.white('Commands run:')} ${chalk.yellow(sessionStats.commandsRun.length.toString())}`);\n  }\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  \n  sessionStats = {\n    toolCallsCount: 0,\n    filesRead: [],\n    filesWritten: [],\n    commandsRun: [],\n    startTime: new Date()\n  };\n}\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  const currentVersion = await getCurrentVersion();\n  const versionDisplay = 'v' + currentVersion;\n  console.log('');\n  console.log(chalk.bold.blue('  oflow CLI ' + chalk.white(versionDisplay)));\n  console.log(chalk.gray('  Type /help for commands, /exit to quit'));\n  console.log('');\n\n  // 检测更新\n  let updateInfo: { hasUpdate: boolean; latestVersion: string } | null = null;\n  try {\n    updateInfo = await checkForUpdates();\n  } catch {\n    // 忽略检测错误\n  }\n  \n  if (updateInfo && updateInfo.hasUpdate) {\n    console.log(chalk.yellow('  New version available: ' + updateInfo.latestVersion));\n    console.log(chalk.gray('  Run /update to install the latest version'));\n    console.log('');\n  }\n\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\n  }\n\n  currentShowThinking = options.showThinking ?? configManager.getShowThinking();\n  currentModel = options.model || configManager.getDefaultModel() || 'gpt-4o';\n\n  if (currentModel.includes('gpt-4') || currentModel.includes('gpt-4o')) {\n    maxContextTokens = 128000;\n  } else if (currentModel.includes('deepseek')) {\n    maxContextTokens = 64000;\n  } else {\n    maxContextTokens = 128000;\n  }\n\n  let provider;\n  try {\n    provider = createAIProvider(auth, currentModel);\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      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      sessionStats.toolCallsCount++;\n      console.log(chalk.cyan('\\n[Tool: ' + toolCall.function.name + ']'));\n      try {\n        const args = JSON.parse(toolCall.function.arguments);\n        if (toolCall.function.name === 'read_file' && args.absolute_path) {\n          if (!sessionStats.filesRead.includes(args.absolute_path)) {\n            sessionStats.filesRead.push(args.absolute_path);\n          }\n        } else if ((toolCall.function.name === 'write_file' || toolCall.function.name === 'replace') && args.file_path) {\n          if (!sessionStats.filesWritten.includes(args.file_path)) {\n            sessionStats.filesWritten.push(args.file_path);\n          }\n        } else if (toolCall.function.name === 'run_shell_command' && args.command) {\n          sessionStats.commandsRun.push(args.command);\n        }\n      } catch {}\n    },\n    onToolResult: (result) => {\n      contextTokens += Math.ceil(result.length / 4);\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  /**\n   * 显示输入提示（状态栏在输入框上方）\n   * 布局顺序：\n   * [内容区域]\n   * [状态栏]\n   * > [输入框]\n   */\n  const showPrompt = () => {\n    showStatusBar();\n    rl.setPrompt(chalk.green('> '));\n    rl.prompt();\n  };\n\n  showPrompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      showPrompt();\n      return;\n    }\n\n    // 处理 slash 命令\n    if (isSlashCommand(input)) {\n      if (input.toLowerCase() === '/thinking') {\n        currentShowThinking = !currentShowThinking;\n        configManager.setShowThinking(currentShowThinking);\n        console.log(chalk.green('Thinking: ' + (currentShowThinking ? 'ON' : 'OFF')));\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/summary') {\n        showTaskSummary();\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/update') {\n        await performUpdate(false);\n        showPrompt();\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      showPrompt();\n      return;\n    }\n\n    // 处理 agent 调用\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider);\n      showPrompt();\n      return;\n    }\n\n    // 处理 shell 命令\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      showPrompt();\n      return;\n    }\n\n    // 处理普通对话\n    const processedInput = await processFileReferences(input);\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      console.log('');\n      \n      if (sessionStats.toolCallsCount >= 3) {\n        showTaskSummary();\n      } else {\n        contextTokens += Math.ceil(response.length / 4);\n      }\n      \n      showPrompt();\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      if (errorMessage.includes('400')) {\n        console.log(chalk.yellow('Check API key and model name, or run \"oflow auth\"'));\n      } else if (errorMessage.includes('401')) {\n        console.log(chalk.yellow('Authentication failed, run \"oflow auth\"'));\n      } else if (errorMessage.includes('429')) {\n        console.log(chalk.yellow('Rate limit, please wait and retry'));\n      }\n      \n      showPrompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(input: string, provider: any): Promise<void> {\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('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.'));\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[Agent: ' + agentType + ']'));\n    console.log(chalk.gray('Task: ' + task + '\\n'));\n\n    const spinner = ora('Agent working...').start();\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('\\nAgent 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        sessionStats.filesWritten.push(...result.filesModified);\n      }\n    } else {\n      console.log(chalk.red('\\nAgent 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    showTaskSummary();\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  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\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  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  sessionStats.commandsRun.push(command);\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      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', () => resolve());\n    proc.on('error', (err: Error) => {\n      console.log(chalk.red('Failed: ' + 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  let result = input;\n  const fs = require('fs');\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      sessionStats.filesRead.push(filePath);\n    } catch {\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# 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. After completing a complex task, provide a brief summary\n\nCurrent working directory: ${process.cwd()}\n`;\n}\n"]}
|
package/dist/updater.d.ts
CHANGED
|
@@ -8,13 +8,16 @@ interface UpdateInfo {
|
|
|
8
8
|
*/
|
|
9
9
|
export declare function getCurrentVersion(): Promise<string>;
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
11
|
+
* 检查是否有更新(不使用缓存,每次都检查)
|
|
12
12
|
*/
|
|
13
13
|
export declare function checkForUpdates(): Promise<UpdateInfo>;
|
|
14
14
|
/**
|
|
15
|
-
*
|
|
15
|
+
* 后台执行更新
|
|
16
16
|
*/
|
|
17
|
-
export declare function performBackgroundUpdate(
|
|
17
|
+
export declare function performBackgroundUpdate(): Promise<{
|
|
18
|
+
success: boolean;
|
|
19
|
+
message: string;
|
|
20
|
+
}>;
|
|
18
21
|
/**
|
|
19
22
|
* 手动执行更新
|
|
20
23
|
*/
|
|
@@ -22,8 +25,4 @@ export declare function performUpdate(silent?: boolean): Promise<{
|
|
|
22
25
|
success: boolean;
|
|
23
26
|
message: string;
|
|
24
27
|
}>;
|
|
25
|
-
/**
|
|
26
|
-
* 检查更新是否已完成
|
|
27
|
-
*/
|
|
28
|
-
export declare function isUpdateCompleted(): boolean;
|
|
29
28
|
export {};
|
package/dist/updater.js
CHANGED
|
@@ -7,21 +7,17 @@ exports.getCurrentVersion = getCurrentVersion;
|
|
|
7
7
|
exports.checkForUpdates = checkForUpdates;
|
|
8
8
|
exports.performBackgroundUpdate = performBackgroundUpdate;
|
|
9
9
|
exports.performUpdate = performUpdate;
|
|
10
|
-
exports.isUpdateCompleted = isUpdateCompleted;
|
|
11
10
|
const chalk_1 = __importDefault(require("chalk"));
|
|
12
11
|
const child_process_1 = require("child_process");
|
|
13
12
|
const util_1 = require("util");
|
|
14
13
|
const execAsync = (0, util_1.promisify)(child_process_1.exec);
|
|
15
14
|
const PACKAGE_NAME = '@oflow-ai/oflow-cli';
|
|
16
15
|
const NPM_REGISTRY = 'https://registry.npmjs.org';
|
|
17
|
-
let updateInProgress = false;
|
|
18
|
-
let updateCompleted = false;
|
|
19
16
|
/**
|
|
20
17
|
* 获取当前安装的版本
|
|
21
18
|
*/
|
|
22
19
|
async function getCurrentVersion() {
|
|
23
20
|
try {
|
|
24
|
-
// 从已安装的包获取版本
|
|
25
21
|
const { stdout } = await execAsync(`npm list -g ${PACKAGE_NAME} --depth=0 --json`, {
|
|
26
22
|
timeout: 5000
|
|
27
23
|
});
|
|
@@ -32,9 +28,9 @@ async function getCurrentVersion() {
|
|
|
32
28
|
}
|
|
33
29
|
}
|
|
34
30
|
catch {
|
|
35
|
-
//
|
|
31
|
+
// 忽略错误
|
|
36
32
|
}
|
|
37
|
-
//
|
|
33
|
+
// 备用:从本地 package.json 读取
|
|
38
34
|
try {
|
|
39
35
|
const fs = require('fs');
|
|
40
36
|
const path = require('path');
|
|
@@ -44,9 +40,7 @@ async function getCurrentVersion() {
|
|
|
44
40
|
return packageJson.version;
|
|
45
41
|
}
|
|
46
42
|
}
|
|
47
|
-
catch {
|
|
48
|
-
// 忽略错误
|
|
49
|
-
}
|
|
43
|
+
catch { }
|
|
50
44
|
return '0.0.0';
|
|
51
45
|
}
|
|
52
46
|
/**
|
|
@@ -62,20 +56,25 @@ async function getLatestVersion() {
|
|
|
62
56
|
catch {
|
|
63
57
|
try {
|
|
64
58
|
const https = require('https');
|
|
65
|
-
return new Promise((resolve
|
|
66
|
-
https.get(`${NPM_REGISTRY}/${PACKAGE_NAME.replace('/', '%2F')}/latest`, (res) => {
|
|
59
|
+
return new Promise((resolve) => {
|
|
60
|
+
const req = https.get(`${NPM_REGISTRY}/${PACKAGE_NAME.replace('/', '%2F')}/latest`, (res) => {
|
|
67
61
|
let data = '';
|
|
68
62
|
res.on('data', (chunk) => { data += chunk; });
|
|
69
63
|
res.on('end', () => {
|
|
70
64
|
try {
|
|
71
65
|
const json = JSON.parse(data);
|
|
72
|
-
resolve(json.version);
|
|
66
|
+
resolve(json.version || '0.0.0');
|
|
73
67
|
}
|
|
74
68
|
catch {
|
|
75
|
-
|
|
69
|
+
resolve('0.0.0');
|
|
76
70
|
}
|
|
77
71
|
});
|
|
78
|
-
})
|
|
72
|
+
});
|
|
73
|
+
req.on('error', () => resolve('0.0.0'));
|
|
74
|
+
req.setTimeout(5000, () => {
|
|
75
|
+
req.destroy();
|
|
76
|
+
resolve('0.0.0');
|
|
77
|
+
});
|
|
79
78
|
});
|
|
80
79
|
}
|
|
81
80
|
catch {
|
|
@@ -84,7 +83,7 @@ async function getLatestVersion() {
|
|
|
84
83
|
}
|
|
85
84
|
}
|
|
86
85
|
/**
|
|
87
|
-
*
|
|
86
|
+
* 比较版本号,返回 -1 (v1 < v2), 0 (v1 == v2), 1 (v1 > v2)
|
|
88
87
|
*/
|
|
89
88
|
function compareVersions(v1, v2) {
|
|
90
89
|
const parts1 = v1.split('.').map(Number);
|
|
@@ -100,75 +99,32 @@ function compareVersions(v1, v2) {
|
|
|
100
99
|
return 0;
|
|
101
100
|
}
|
|
102
101
|
/**
|
|
103
|
-
*
|
|
102
|
+
* 检查是否有更新(不使用缓存,每次都检查)
|
|
104
103
|
*/
|
|
105
104
|
async function checkForUpdates() {
|
|
106
105
|
const currentVersion = await getCurrentVersion();
|
|
107
|
-
// 检查缓存(每天只检查一次)
|
|
108
|
-
const cacheKey = 'oflow_last_update_check';
|
|
109
|
-
const cachedData = getCachedUpdateInfo(cacheKey);
|
|
110
|
-
if (cachedData && Date.now() - cachedData.timestamp < 24 * 60 * 60 * 1000) {
|
|
111
|
-
return {
|
|
112
|
-
hasUpdate: compareVersions(currentVersion, cachedData.latestVersion) < 0,
|
|
113
|
-
currentVersion,
|
|
114
|
-
latestVersion: cachedData.latestVersion
|
|
115
|
-
};
|
|
116
|
-
}
|
|
117
106
|
const latestVersion = await getLatestVersion();
|
|
118
|
-
|
|
119
|
-
setCachedUpdateInfo(cacheKey, {
|
|
120
|
-
latestVersion,
|
|
121
|
-
timestamp: Date.now()
|
|
122
|
-
});
|
|
107
|
+
const hasUpdate = compareVersions(currentVersion, latestVersion) < 0;
|
|
123
108
|
return {
|
|
124
|
-
hasUpdate
|
|
109
|
+
hasUpdate,
|
|
125
110
|
currentVersion,
|
|
126
111
|
latestVersion
|
|
127
112
|
};
|
|
128
113
|
}
|
|
129
114
|
/**
|
|
130
|
-
*
|
|
115
|
+
* 后台执行更新
|
|
131
116
|
*/
|
|
132
|
-
function performBackgroundUpdate(
|
|
133
|
-
|
|
134
|
-
|
|
117
|
+
async function performBackgroundUpdate() {
|
|
118
|
+
try {
|
|
119
|
+
await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {
|
|
120
|
+
timeout: 60000
|
|
121
|
+
});
|
|
122
|
+
return { success: true, message: 'Update completed' };
|
|
123
|
+
}
|
|
124
|
+
catch (error) {
|
|
125
|
+
const errorMsg = error instanceof Error ? error.message : String(error);
|
|
126
|
+
return { success: false, message: errorMsg };
|
|
135
127
|
}
|
|
136
|
-
updateInProgress = true;
|
|
137
|
-
// 使用 spawn 在后台执行更新
|
|
138
|
-
const updateProcess = (0, child_process_1.spawn)('npm', ['install', '-g', `${PACKAGE_NAME}@latest`], {
|
|
139
|
-
detached: true,
|
|
140
|
-
stdio: 'ignore',
|
|
141
|
-
shell: true
|
|
142
|
-
});
|
|
143
|
-
updateProcess.unref();
|
|
144
|
-
updateProcess.on('error', () => {
|
|
145
|
-
updateInProgress = false;
|
|
146
|
-
onComplete?.(false);
|
|
147
|
-
});
|
|
148
|
-
// 设置超时检查
|
|
149
|
-
setTimeout(async () => {
|
|
150
|
-
try {
|
|
151
|
-
const { stdout } = await execAsync(`npm list -g ${PACKAGE_NAME} --depth=0 --json`, {
|
|
152
|
-
timeout: 5000
|
|
153
|
-
});
|
|
154
|
-
const data = JSON.parse(stdout);
|
|
155
|
-
const newVersion = data?.dependencies?.[PACKAGE_NAME]?.version;
|
|
156
|
-
if (newVersion) {
|
|
157
|
-
const updateInfo = await checkForUpdates();
|
|
158
|
-
if (!updateInfo.hasUpdate) {
|
|
159
|
-
updateCompleted = true;
|
|
160
|
-
updateInProgress = false;
|
|
161
|
-
onComplete?.(true);
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
catch {
|
|
167
|
-
// 忽略错误
|
|
168
|
-
}
|
|
169
|
-
updateInProgress = false;
|
|
170
|
-
onComplete?.(false);
|
|
171
|
-
}, 30000);
|
|
172
128
|
}
|
|
173
129
|
/**
|
|
174
130
|
* 手动执行更新
|
|
@@ -178,7 +134,7 @@ async function performUpdate(silent = false) {
|
|
|
178
134
|
console.log(chalk_1.default.cyan('\nUpdating oflow CLI...\n'));
|
|
179
135
|
}
|
|
180
136
|
try {
|
|
181
|
-
|
|
137
|
+
await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {
|
|
182
138
|
timeout: 60000
|
|
183
139
|
});
|
|
184
140
|
if (!silent) {
|
|
@@ -196,53 +152,4 @@ async function performUpdate(silent = false) {
|
|
|
196
152
|
return { success: false, message: errorMsg };
|
|
197
153
|
}
|
|
198
154
|
}
|
|
199
|
-
/**
|
|
200
|
-
* 检查更新是否已完成
|
|
201
|
-
*/
|
|
202
|
-
function isUpdateCompleted() {
|
|
203
|
-
return updateCompleted;
|
|
204
|
-
}
|
|
205
|
-
/**
|
|
206
|
-
* 获取缓存的更新信息
|
|
207
|
-
*/
|
|
208
|
-
function getCachedUpdateInfo(key) {
|
|
209
|
-
try {
|
|
210
|
-
const fs = require('fs');
|
|
211
|
-
const path = require('path');
|
|
212
|
-
const os = require('os');
|
|
213
|
-
const cacheFile = path.join(os.homedir(), '.oflow', 'update-cache.json');
|
|
214
|
-
if (fs.existsSync(cacheFile)) {
|
|
215
|
-
const data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));
|
|
216
|
-
return data[key] || null;
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
catch {
|
|
220
|
-
// Ignore cache errors
|
|
221
|
-
}
|
|
222
|
-
return null;
|
|
223
|
-
}
|
|
224
|
-
/**
|
|
225
|
-
* 缓存更新信息
|
|
226
|
-
*/
|
|
227
|
-
function setCachedUpdateInfo(key, value) {
|
|
228
|
-
try {
|
|
229
|
-
const fs = require('fs');
|
|
230
|
-
const path = require('path');
|
|
231
|
-
const os = require('os');
|
|
232
|
-
const cacheDir = path.join(os.homedir(), '.oflow');
|
|
233
|
-
const cacheFile = path.join(cacheDir, 'update-cache.json');
|
|
234
|
-
if (!fs.existsSync(cacheDir)) {
|
|
235
|
-
fs.mkdirSync(cacheDir, { recursive: true });
|
|
236
|
-
}
|
|
237
|
-
let data = {};
|
|
238
|
-
if (fs.existsSync(cacheFile)) {
|
|
239
|
-
data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));
|
|
240
|
-
}
|
|
241
|
-
data[key] = value;
|
|
242
|
-
fs.writeFileSync(cacheFile, JSON.stringify(data, null, 2));
|
|
243
|
-
}
|
|
244
|
-
catch {
|
|
245
|
-
// Ignore cache errors
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"updater.js","sourceRoot":"","sources":["../src/updater.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { exec, spawn } from 'child_process';\nimport { promisify } from 'util';\n\nconst execAsync = promisify(exec);\n\nconst PACKAGE_NAME = '@oflow-ai/oflow-cli';\nconst NPM_REGISTRY = 'https://registry.npmjs.org';\n\ninterface UpdateInfo {\n  hasUpdate: boolean;\n  currentVersion: string;\n  latestVersion: string;\n}\n\nlet updateInProgress = false;\nlet updateCompleted = false;\n\n/**\n * 获取当前安装的版本\n */\nexport async function getCurrentVersion(): Promise<string> {\n  try {\n    // 从已安装的包获取版本\n    const { stdout } = await execAsync(`npm list -g ${PACKAGE_NAME} --depth=0 --json`, {\n      timeout: 5000\n    });\n    const data = JSON.parse(stdout);\n    const version = data?.dependencies?.[PACKAGE_NAME]?.version;\n    if (version) {\n      return version;\n    }\n  } catch {\n    // 忽略错误，尝试其他方式\n  }\n\n  // 备用方案：从本地 package.json 读取\n  try {\n    const fs = require('fs');\n    const path = require('path');\n    const packageJsonPath = path.join(__dirname, '..', 'package.json');\n    if (fs.existsSync(packageJsonPath)) {\n      const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n      return packageJson.version;\n    }\n  } catch {\n    // 忽略错误\n  }\n\n  return '0.0.0';\n}\n\n/**\n * 从npm获取最新版本\n */\nasync function getLatestVersion(): Promise<string> {\n  try {\n    const { stdout } = await execAsync(`npm view ${PACKAGE_NAME} version`, {\n      timeout: 10000\n    });\n    return stdout.trim();\n  } catch {\n    try {\n      const https = require('https');\n      return new Promise((resolve, reject) => {\n        https.get(`${NPM_REGISTRY}/${PACKAGE_NAME.replace('/', '%2F')}/latest`, (res: any) => {\n          let data = '';\n          res.on('data', (chunk: string) => { data += chunk; });\n          res.on('end', () => {\n            try {\n              const json = JSON.parse(data);\n              resolve(json.version);\n            } catch {\n              reject(new Error('Failed to parse response'));\n            }\n          });\n        }).on('error', reject);\n      });\n    } catch {\n      return '0.0.0';\n    }\n  }\n}\n\n/**\n * 比较版本号\n */\nfunction compareVersions(v1: string, v2: string): number {\n  const parts1 = v1.split('.').map(Number);\n  const parts2 = v2.split('.').map(Number);\n\n  for (let i = 0; i < Math.max(parts1.length, parts2.length); i++) {\n    const p1 = parts1[i] || 0;\n    const p2 = parts2[i] || 0;\n    if (p1 > p2) return 1;\n    if (p1 < p2) return -1;\n  }\n  return 0;\n}\n\n/**\n * 检查是否有更新\n */\nexport async function checkForUpdates(): Promise<UpdateInfo> {\n  const currentVersion = await getCurrentVersion();\n  \n  // 检查缓存（每天只检查一次）\n  const cacheKey = 'oflow_last_update_check';\n  const cachedData = getCachedUpdateInfo(cacheKey);\n  \n  if (cachedData && Date.now() - cachedData.timestamp < 24 * 60 * 60 * 1000) {\n    return {\n      hasUpdate: compareVersions(currentVersion, cachedData.latestVersion) < 0,\n      currentVersion,\n      latestVersion: cachedData.latestVersion\n    };\n  }\n\n  const latestVersion = await getLatestVersion();\n  \n  // 缓存结果\n  setCachedUpdateInfo(cacheKey, { \n    latestVersion, \n    timestamp: Date.now() \n  });\n\n  return {\n    hasUpdate: compareVersions(currentVersion, latestVersion) < 0,\n    currentVersion,\n    latestVersion\n  };\n}\n\n/**\n * 后台执行更新（不阻塞当前 session）\n */\nexport function performBackgroundUpdate(onComplete?: (success: boolean) => void): void {\n  if (updateInProgress || updateCompleted) {\n    return;\n  }\n\n  updateInProgress = true;\n\n  // 使用 spawn 在后台执行更新\n  const updateProcess = spawn('npm', ['install', '-g', `${PACKAGE_NAME}@latest`], {\n    detached: true,\n    stdio: 'ignore',\n    shell: true\n  });\n\n  updateProcess.unref();\n\n  updateProcess.on('error', () => {\n    updateInProgress = false;\n    onComplete?.(false);\n  });\n\n  // 设置超时检查\n  setTimeout(async () => {\n    try {\n      const { stdout } = await execAsync(`npm list -g ${PACKAGE_NAME} --depth=0 --json`, {\n        timeout: 5000\n      });\n      const data = JSON.parse(stdout);\n      const newVersion = data?.dependencies?.[PACKAGE_NAME]?.version;\n      \n      if (newVersion) {\n        const updateInfo = await checkForUpdates();\n        if (!updateInfo.hasUpdate) {\n          updateCompleted = true;\n          updateInProgress = false;\n          onComplete?.(true);\n          return;\n        }\n      }\n    } catch {\n      // 忽略错误\n    }\n    updateInProgress = false;\n    onComplete?.(false);\n  }, 30000);\n}\n\n/**\n * 手动执行更新\n */\nexport async function performUpdate(silent: boolean = false): Promise<{ success: boolean; message: string }> {\n  if (!silent) {\n    console.log(chalk.cyan('\\nUpdating oflow CLI...\\n'));\n  }\n  \n  try {\n    const { stdout, stderr } = await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {\n      timeout: 60000\n    });\n    \n    if (!silent) {\n      console.log(chalk.green('\\noflow CLI updated successfully!'));\n      console.log(chalk.gray('Please restart oflow to use the new version.\\n'));\n    }\n    \n    return { success: true, message: 'Update completed' };\n  } catch (error) {\n    const errorMsg = error instanceof Error ? error.message : String(error);\n    if (!silent) {\n      console.log(chalk.red('\\nUpdate failed'));\n      console.log(chalk.gray('You can manually update with: npm install -g @oflow-ai/oflow-cli@latest\\n'));\n    }\n    \n    return { success: false, message: errorMsg };\n  }\n}\n\n/**\n * 检查更新是否已完成\n */\nexport function isUpdateCompleted(): boolean {\n  return updateCompleted;\n}\n\n/**\n * 获取缓存的更新信息\n */\nfunction getCachedUpdateInfo(key: string): { latestVersion: string; timestamp: number } | null {\n  try {\n    const fs = require('fs');\n    const path = require('path');\n    const os = require('os');\n    \n    const cacheFile = path.join(os.homedir(), '.oflow', 'update-cache.json');\n    \n    if (fs.existsSync(cacheFile)) {\n      const data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));\n      return data[key] || null;\n    }\n  } catch {\n    // Ignore cache errors\n  }\n  return null;\n}\n\n/**\n * 缓存更新信息\n */\nfunction setCachedUpdateInfo(key: string, value: { latestVersion: string; timestamp: number }): void {\n  try {\n    const fs = require('fs');\n    const path = require('path');\n    const os = require('os');\n    \n    const cacheDir = path.join(os.homedir(), '.oflow');\n    const cacheFile = path.join(cacheDir, 'update-cache.json');\n    \n    if (!fs.existsSync(cacheDir)) {\n      fs.mkdirSync(cacheDir, { recursive: true });\n    }\n    \n    let data: Record<string, any> = {};\n    if (fs.existsSync(cacheFile)) {\n      data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));\n    }\n    \n    data[key] = value;\n    fs.writeFileSync(cacheFile, JSON.stringify(data, null, 2));\n  } catch {\n    // Ignore cache errors\n  }\n}"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"updater.js","sourceRoot":"","sources":["../src/updater.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { exec, spawn } from 'child_process';\nimport { promisify } from 'util';\n\nconst execAsync = promisify(exec);\n\nconst PACKAGE_NAME = '@oflow-ai/oflow-cli';\nconst NPM_REGISTRY = 'https://registry.npmjs.org';\n\ninterface UpdateInfo {\n  hasUpdate: boolean;\n  currentVersion: string;\n  latestVersion: string;\n}\n\n/**\n * 获取当前安装的版本\n */\nexport async function getCurrentVersion(): Promise<string> {\n  try {\n    const { stdout } = await execAsync(`npm list -g ${PACKAGE_NAME} --depth=0 --json`, {\n      timeout: 5000\n    });\n    const data = JSON.parse(stdout);\n    const version = data?.dependencies?.[PACKAGE_NAME]?.version;\n    if (version) {\n      return version;\n    }\n  } catch {\n    // 忽略错误\n  }\n\n  // 备用：从本地 package.json 读取\n  try {\n    const fs = require('fs');\n    const path = require('path');\n    const packageJsonPath = path.join(__dirname, '..', 'package.json');\n    if (fs.existsSync(packageJsonPath)) {\n      const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n      return packageJson.version;\n    }\n  } catch {}\n\n  return '0.0.0';\n}\n\n/**\n * 从npm获取最新版本\n */\nasync function getLatestVersion(): Promise<string> {\n  try {\n    const { stdout } = await execAsync(`npm view ${PACKAGE_NAME} version`, {\n      timeout: 10000\n    });\n    return stdout.trim();\n  } catch {\n    try {\n      const https = require('https');\n      return new Promise((resolve) => {\n        const req = https.get(`${NPM_REGISTRY}/${PACKAGE_NAME.replace('/', '%2F')}/latest`, (res: any) => {\n          let data = '';\n          res.on('data', (chunk: string) => { data += chunk; });\n          res.on('end', () => {\n            try {\n              const json = JSON.parse(data);\n              resolve(json.version || '0.0.0');\n            } catch {\n              resolve('0.0.0');\n            }\n          });\n        });\n        req.on('error', () => resolve('0.0.0'));\n        req.setTimeout(5000, () => {\n          req.destroy();\n          resolve('0.0.0');\n        });\n      });\n    } catch {\n      return '0.0.0';\n    }\n  }\n}\n\n/**\n * 比较版本号，返回 -1 (v1 < v2), 0 (v1 == v2), 1 (v1 > v2)\n */\nfunction compareVersions(v1: string, v2: string): number {\n  const parts1 = v1.split('.').map(Number);\n  const parts2 = v2.split('.').map(Number);\n\n  for (let i = 0; i < Math.max(parts1.length, parts2.length); i++) {\n    const p1 = parts1[i] || 0;\n    const p2 = parts2[i] || 0;\n    if (p1 > p2) return 1;\n    if (p1 < p2) return -1;\n  }\n  return 0;\n}\n\n/**\n * 检查是否有更新（不使用缓存，每次都检查）\n */\nexport async function checkForUpdates(): Promise<UpdateInfo> {\n  const currentVersion = await getCurrentVersion();\n  const latestVersion = await getLatestVersion();\n  \n  const hasUpdate = compareVersions(currentVersion, latestVersion) < 0;\n\n  return {\n    hasUpdate,\n    currentVersion,\n    latestVersion\n  };\n}\n\n/**\n * 后台执行更新\n */\nexport async function performBackgroundUpdate(): Promise<{ success: boolean; message: string }> {\n  try {\n    await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {\n      timeout: 60000\n    });\n    return { success: true, message: 'Update completed' };\n  } catch (error) {\n    const errorMsg = error instanceof Error ? error.message : String(error);\n    return { success: false, message: errorMsg };\n  }\n}\n\n/**\n * 手动执行更新\n */\nexport async function performUpdate(silent: boolean = false): Promise<{ success: boolean; message: string }> {\n  if (!silent) {\n    console.log(chalk.cyan('\\nUpdating oflow CLI...\\n'));\n  }\n  \n  try {\n    await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {\n      timeout: 60000\n    });\n    \n    if (!silent) {\n      console.log(chalk.green('\\noflow CLI updated successfully!'));\n      console.log(chalk.gray('Please restart oflow to use the new version.\\n'));\n    }\n    \n    return { success: true, message: 'Update completed' };\n  } catch (error) {\n    const errorMsg = error instanceof Error ? error.message : String(error);\n    if (!silent) {\n      console.log(chalk.red('\\nUpdate failed'));\n      console.log(chalk.gray('You can manually update with: npm install -g @oflow-ai/oflow-cli@latest\\n'));\n    }\n    \n    return { success: false, message: errorMsg };\n  }\n}\n"]}
|