@oflow-ai/oflow-cli 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js ADDED
@@ -0,0 +1,320 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k;
5
+ var desc = Object.getOwnPropertyDescriptor(m, k);
6
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
+ desc = { enumerable: true, get: function() { return m[k]; } };
8
+ }
9
+ Object.defineProperty(o, k2, desc);
10
+ }) : (function(o, m, k, k2) {
11
+ if (k2 === undefined) k2 = k;
12
+ o[k2] = m[k];
13
+ }));
14
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
16
+ }) : function(o, v) {
17
+ o["default"] = v;
18
+ });
19
+ var __importStar = (this && this.__importStar) || (function () {
20
+ var ownKeys = function(o) {
21
+ ownKeys = Object.getOwnPropertyNames || function (o) {
22
+ var ar = [];
23
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
24
+ return ar;
25
+ };
26
+ return ownKeys(o);
27
+ };
28
+ return function (mod) {
29
+ if (mod && mod.__esModule) return mod;
30
+ var result = {};
31
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
32
+ __setModuleDefault(result, mod);
33
+ return result;
34
+ };
35
+ })();
36
+ var __importDefault = (this && this.__importDefault) || function (mod) {
37
+ return (mod && mod.__esModule) ? mod : { "default": mod };
38
+ };
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ const commander_1 = require("commander");
41
+ const cli_1 = require("./cli");
42
+ const core_1 = require("@oflow-ai/core");
43
+ const chalk_1 = __importDefault(require("chalk"));
44
+ const fs = __importStar(require("fs"));
45
+ const path = __importStar(require("path"));
46
+ // Read package.json for version
47
+ const packageJsonPath = path.join(__dirname, '..', 'package.json');
48
+ const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
49
+ // Simple update check (without update-notifier due to type issues)
50
+ try {
51
+ const updateNotifier = require('update-notifier');
52
+ const notifier = updateNotifier({ pkg: packageJson });
53
+ if (notifier.notify) {
54
+ notifier.notify();
55
+ }
56
+ }
57
+ catch {
58
+ // Ignore update check errors
59
+ }
60
+ const program = new commander_1.Command();
61
+ program
62
+ .name('oflow')
63
+ .description('AI-powered CLI assistant for terminal')
64
+ .version(packageJson.version)
65
+ .option('-m, --model <model>', 'Specify the AI model to use')
66
+ .option('-d, --directory <dir>', 'Working directory')
67
+ .option('--yolo', 'Run in yolo mode (auto-approve all operations)')
68
+ .option('--thinking', 'Show AI thinking/reasoning process')
69
+ .option('--no-thinking', 'Hide AI thinking/reasoning process')
70
+ .argument('[prompt]', 'Prompt to send to AI (starts interactive mode if not provided)')
71
+ .action(async (prompt, options) => {
72
+ const configManager = (0, core_1.getConfigManager)();
73
+ // Check authentication
74
+ if (!configManager.isAuthenticated()) {
75
+ console.log(chalk_1.default.yellow('Welcome to oflow! Let\'s get you set up.'));
76
+ console.log('');
77
+ await runAuthFlow();
78
+ return;
79
+ }
80
+ // Set model if specified
81
+ if (options.model) {
82
+ configManager.setDefaultModel(options.model);
83
+ }
84
+ // Set thinking mode if specified
85
+ if (options.thinking === true) {
86
+ configManager.setShowThinking(true);
87
+ }
88
+ else if (options.thinking === false) {
89
+ configManager.setShowThinking(false);
90
+ }
91
+ // Set working directory
92
+ const workingDir = options.directory || process.cwd();
93
+ process.chdir(workingDir);
94
+ if (prompt) {
95
+ // Single command mode
96
+ await (0, cli_1.runSingleCommand)(prompt, {
97
+ model: options.model,
98
+ yolo: options.yolo
99
+ });
100
+ }
101
+ else {
102
+ // Interactive mode
103
+ await (0, cli_1.startInteractiveMode)({
104
+ model: options.model,
105
+ yolo: options.yolo
106
+ });
107
+ }
108
+ });
109
+ // Auth command
110
+ program
111
+ .command('auth')
112
+ .description('Configure authentication')
113
+ .option('--provider <provider>', 'Provider (openai, deepseek, qwen, etc.)')
114
+ .action(async (options) => {
115
+ await runAuthFlow(options.provider);
116
+ });
117
+ // Config command
118
+ program
119
+ .command('config')
120
+ .description('View or edit configuration')
121
+ .option('--list', 'List current configuration')
122
+ .option('--set <key=value>', 'Set a configuration value')
123
+ .option('--thinking', 'Toggle thinking process display')
124
+ .action(async (options) => {
125
+ const configManager = (0, core_1.getConfigManager)();
126
+ if (options.list) {
127
+ console.log(chalk_1.default.bold('Current Configuration:'));
128
+ console.log(JSON.stringify(configManager.getAll(), null, 2));
129
+ console.log('');
130
+ console.log(chalk_1.default.gray(`Config file: ${configManager.getConfigPath()}`));
131
+ }
132
+ else if (options.thinking) {
133
+ const newValue = configManager.toggleShowThinking();
134
+ console.log(chalk_1.default.green(`✓ Thinking process display: ${newValue ? 'ON' : 'OFF'}`));
135
+ }
136
+ else if (options.set) {
137
+ const [key, value] = options.set.split('=');
138
+ configManager.set(key, value);
139
+ console.log(chalk_1.default.green(`Set ${key} = ${value}`));
140
+ }
141
+ else {
142
+ console.log(`Config file: ${configManager.getConfigPath()}`);
143
+ console.log(`Thinking display: ${configManager.getShowThinking() ? 'ON' : 'OFF'}`);
144
+ }
145
+ });
146
+ // Models command
147
+ program
148
+ .command('models')
149
+ .description('List available AI models')
150
+ .action(async () => {
151
+ await listModels();
152
+ });
153
+ async function runAuthFlow(provider) {
154
+ const inquirer = require('inquirer');
155
+ const configManager = (0, core_1.getConfigManager)();
156
+ if (!provider) {
157
+ const answers = await inquirer.prompt([
158
+ {
159
+ type: 'list',
160
+ name: 'provider',
161
+ message: 'Select AI provider:',
162
+ choices: [
163
+ { name: '🌐 OpenAI (Official API)', value: 'openai' },
164
+ { name: '🔧 Custom (OpenAI-compatible)', value: 'custom' },
165
+ { name: '────────── 国内模型 ──────────', value: 'separator', disabled: true },
166
+ { name: '🇨🇳 DeepSeek (深度求索) - 推荐推理模型', value: 'deepseek' },
167
+ { name: '🇨🇳 Qwen (通义千问)', value: 'qwen' },
168
+ { name: '🇨🇳 GLM (智谱)', value: 'zhipu' },
169
+ { name: '🇨🇳 Baichuan (百川)', value: 'baichuan' },
170
+ { name: '🇨🇳 Yi (零一万物)', value: 'yi' },
171
+ { name: '🇨🇳 Moonshot (月之暗面/Kimi)', value: 'moonshot' },
172
+ { name: '🇨🇳 SiliconFlow (硅基流动)', value: 'siliconflow' }
173
+ ]
174
+ }
175
+ ]);
176
+ provider = answers.provider;
177
+ }
178
+ // OpenAI
179
+ if (provider === 'openai') {
180
+ const answers = await inquirer.prompt([
181
+ {
182
+ type: 'password',
183
+ name: 'apiKey',
184
+ message: 'Enter your OpenAI API key:',
185
+ mask: '*'
186
+ },
187
+ {
188
+ type: 'list',
189
+ name: 'model',
190
+ message: 'Select default model:',
191
+ choices: [
192
+ 'gpt-4o',
193
+ 'gpt-4o-mini',
194
+ 'gpt-4-turbo',
195
+ 'gpt-3.5-turbo',
196
+ 'o1-preview',
197
+ 'o1-mini'
198
+ ],
199
+ default: 'gpt-4o'
200
+ }
201
+ ]);
202
+ configManager.setAuth({
203
+ provider: 'openai',
204
+ apiKey: answers.apiKey,
205
+ model: answers.model
206
+ });
207
+ configManager.setDefaultModel(answers.model);
208
+ console.log(chalk_1.default.green('\n✓ Authentication configured successfully!'));
209
+ }
210
+ // Custom
211
+ else if (provider === 'custom') {
212
+ const answers = await inquirer.prompt([
213
+ {
214
+ type: 'input',
215
+ name: 'baseUrl',
216
+ message: 'Enter API base URL:',
217
+ default: 'https://api.openai.com/v1'
218
+ },
219
+ {
220
+ type: 'password',
221
+ name: 'apiKey',
222
+ message: 'Enter your API key:',
223
+ mask: '*'
224
+ },
225
+ {
226
+ type: 'input',
227
+ name: 'model',
228
+ message: 'Enter default model name:',
229
+ default: 'gpt-4o'
230
+ }
231
+ ]);
232
+ configManager.setAuth({
233
+ provider: 'custom',
234
+ apiKey: answers.apiKey,
235
+ baseUrl: answers.baseUrl,
236
+ model: answers.model
237
+ });
238
+ configManager.setDefaultModel(answers.model);
239
+ console.log(chalk_1.default.green('\n✓ Authentication configured successfully!'));
240
+ }
241
+ // 国内模型
242
+ else if (core_1.CHINESE_MODELS[provider]) {
243
+ const modelConfig = core_1.CHINESE_MODELS[provider];
244
+ console.log(chalk_1.default.cyan(`\n配置 ${modelConfig.name}`));
245
+ const answers = await inquirer.prompt([
246
+ {
247
+ type: 'password',
248
+ name: 'apiKey',
249
+ message: `Enter your ${modelConfig.name} API key:`,
250
+ mask: '*'
251
+ },
252
+ {
253
+ type: 'list',
254
+ name: 'model',
255
+ message: 'Select default model:',
256
+ choices: modelConfig.models,
257
+ default: modelConfig.models[0]
258
+ }
259
+ ]);
260
+ configManager.setAuth({
261
+ provider: provider,
262
+ apiKey: answers.apiKey,
263
+ baseUrl: modelConfig.baseUrl,
264
+ model: answers.model
265
+ });
266
+ configManager.setDefaultModel(answers.model);
267
+ console.log(chalk_1.default.green(`\n✓ ${modelConfig.name} 配置成功!`));
268
+ // DeepSeek特殊提示
269
+ if (provider === 'deepseek' && answers.model === 'deepseek-reasoner') {
270
+ console.log(chalk_1.default.yellow('💡 提示: deepseek-reasoner 支持显示思考过程,使用 --thinking 开启'));
271
+ }
272
+ }
273
+ }
274
+ async function listModels() {
275
+ const configManager = (0, core_1.getConfigManager)();
276
+ const auth = configManager.getAuth();
277
+ if (!auth) {
278
+ console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
279
+ return;
280
+ }
281
+ console.log(chalk_1.default.bold('\n═══════════════════════════════════════════════════════════'));
282
+ console.log(chalk_1.default.bold(' Available Models '));
283
+ console.log(chalk_1.default.bold('═══════════════════════════════════════════════════════════\n'));
284
+ // OpenAI Models
285
+ console.log(chalk_1.default.cyan('🌐 OpenAI Models:'));
286
+ const openaiModels = [
287
+ { id: 'gpt-4o', desc: 'Most capable GPT-4 model' },
288
+ { id: 'gpt-4o-mini', desc: 'Fast and affordable' },
289
+ { id: 'gpt-4-turbo', desc: 'Previous GPT-4 version' },
290
+ { id: 'gpt-3.5-turbo', desc: 'Fast and cheap' },
291
+ { id: 'o1-preview', desc: 'Advanced reasoning' },
292
+ { id: 'o1-mini', desc: 'Efficient reasoning' }
293
+ ];
294
+ openaiModels.forEach(m => {
295
+ const current = m.id === configManager.getDefaultModel() ? chalk_1.default.green('* ') : ' ';
296
+ console.log(`${current}${m.id} - ${chalk_1.default.gray(m.desc)}`);
297
+ });
298
+ // 国内模型
299
+ console.log('');
300
+ console.log(chalk_1.default.cyan('🇨🇳 国内开源模型:\n'));
301
+ for (const [key, config] of Object.entries(core_1.CHINESE_MODELS)) {
302
+ console.log(chalk_1.default.bold(` ${config.name}`));
303
+ console.log(chalk_1.default.gray(` API: ${config.baseUrl}`));
304
+ for (const m of config.models) {
305
+ const modelId = typeof m === 'string' ? m : m.id;
306
+ const modelName = typeof m === 'string' ? m : m.name;
307
+ const modelDesc = typeof m === 'string' ? '' : m.desc;
308
+ const current = modelId === configManager.getDefaultModel() ? chalk_1.default.green('* ') : ' ';
309
+ console.log(`${current}${modelId} - ${chalk_1.default.gray(modelName)}${modelDesc ? chalk_1.default.gray(` (${modelDesc})`) : ''}`);
310
+ }
311
+ console.log('');
312
+ }
313
+ // 显示当前配置
314
+ console.log(chalk_1.default.bold('───────────────────────────────────────────────────────────'));
315
+ console.log(`Current model: ${chalk_1.default.green(configManager.getDefaultModel())}`);
316
+ console.log(`Thinking display: ${configManager.getShowThinking() ? chalk_1.default.green('ON') : chalk_1.default.gray('OFF')}`);
317
+ console.log('');
318
+ }
319
+ 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();"]}
@@ -0,0 +1,10 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Post-install script for @oflow-ai/oflow-cli
4
+ * Runs after npm install to display welcome message and instructions
5
+ */
6
+ declare const chalk: any;
7
+ declare const fs: any;
8
+ declare const path: any;
9
+ declare const nodeVersion: string;
10
+ declare const majorVersion: number;
@@ -0,0 +1,58 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+ /**
4
+ * Post-install script for @oflow-ai/oflow-cli
5
+ * Runs after npm install to display welcome message and instructions
6
+ */
7
+ const chalk = require('chalk');
8
+ const fs = require('fs');
9
+ const path = require('path');
10
+ // Check if running in CI or npm install --ignore-scripts
11
+ if (process.env.CI || process.env.npm_config_ignore_scripts) {
12
+ process.exit(0);
13
+ }
14
+ // Display welcome message
15
+ console.log('');
16
+ console.log(chalk.bold.blue('╔════════════════════════════════════════════════════════════╗'));
17
+ console.log(chalk.bold.blue('║ Welcome to oFlow CLI ║'));
18
+ console.log(chalk.bold.blue('╚════════════════════════════════════════════════════════════╝'));
19
+ console.log('');
20
+ console.log(chalk.green('✓ oFlow CLI installed successfully!'));
21
+ console.log('');
22
+ console.log(chalk.bold('Quick Start:'));
23
+ console.log('');
24
+ console.log(chalk.cyan(' 1. Run the CLI:'));
25
+ console.log(chalk.white(' oflow'));
26
+ console.log('');
27
+ console.log(chalk.cyan(' 2. Configure authentication:'));
28
+ console.log(chalk.white(' oflow auth'));
29
+ console.log('');
30
+ console.log(chalk.cyan(' 3. Available AI Providers:'));
31
+ console.log(chalk.gray(' • OpenAI (GPT-4o, GPT-4-turbo, etc.)'));
32
+ console.log(chalk.gray(' • DeepSeek (深度求索) - Recommended'));
33
+ console.log(chalk.gray(' • Qwen (通义千问)'));
34
+ console.log(chalk.gray(' • GLM (智谱)'));
35
+ console.log(chalk.gray(' • Baichuan (百川)'));
36
+ console.log(chalk.gray(' • Yi (零一万物)'));
37
+ console.log(chalk.gray(' • Moonshot (月之暗面/Kimi)'));
38
+ console.log(chalk.gray(' • SiliconFlow (硅基流动)'));
39
+ console.log('');
40
+ console.log(chalk.bold('Options:'));
41
+ console.log(chalk.gray(' oflow --help Show help'));
42
+ console.log(chalk.gray(' oflow --thinking Show AI reasoning process'));
43
+ console.log(chalk.gray(' oflow models List available models'));
44
+ console.log(chalk.gray(' oflow config View configuration'));
45
+ console.log('');
46
+ console.log(chalk.bold('Documentation:'));
47
+ console.log(chalk.blue(' https://github.com/oflow-ai/oflow-cli'));
48
+ console.log('');
49
+ // Check Node.js version
50
+ const nodeVersion = process.version;
51
+ const majorVersion = parseInt(nodeVersion.slice(1).split('.')[0], 10);
52
+ if (majorVersion < 18) {
53
+ console.log(chalk.yellow('⚠ Warning: Node.js 18 or higher is recommended.'));
54
+ console.log(chalk.yellow(` Current version: ${nodeVersion}`));
55
+ console.log('');
56
+ }
57
+ process.exit(0);
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdGluc3RhbGwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcG9zdGluc3RhbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7O0dBR0c7QUFFSCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDL0IsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3pCLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUU3Qix5REFBeUQ7QUFDekQsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLHlCQUF5QixFQUFFLENBQUM7SUFDNUQsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNsQixDQUFDO0FBRUQsMEJBQTBCO0FBQzFCLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDaEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnRUFBZ0UsQ0FBQyxDQUFDLENBQUM7QUFDL0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnRUFBZ0UsQ0FBQyxDQUFDLENBQUM7QUFDL0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnRUFBZ0UsQ0FBQyxDQUFDLENBQUM7QUFDL0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNoQixPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMscUNBQXFDLENBQUMsQ0FBQyxDQUFDO0FBQ2hFLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDaEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxD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WSxHQUFHLEVBQUUsRUFBRSxDQUFDO0lBQ3RCLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxpREFBaUQsQ0FBQyxDQUFDLENBQUM7SUFDN0UsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLHNCQUFzQixXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDL0QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNsQixDQUFDO0FBRUQsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcblxuLyoqXG4gKiBQb3N0LWluc3RhbGwgc2NyaXB0IGZvciBAb2Zsb3ctYWkvb2Zsb3ctY2xpXG4gKiBSdW5zIGFmdGVyIG5wbSBpbnN0YWxsIHRvIGRpc3BsYXkgd2VsY29tZSBtZXNzYWdlIGFuZCBpbnN0cnVjdGlvbnNcbiAqL1xuXG5jb25zdCBjaGFsayA9IHJlcXVpcmUoJ2NoYWxrJyk7XG5jb25zdCBmcyA9IHJlcXVpcmUoJ2ZzJyk7XG5jb25zdCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuXG4vLyBDaGVjayBpZiBydW5uaW5nIGluIENJIG9yIG5wbSBpbnN0YWxsIC0taWdub3JlLXNjcmlwdHNcbmlmIChwcm9jZXNzLmVudi5DSSB8fCBwcm9jZXNzLmVudi5ucG1fY29uZmlnX2lnbm9yZV9zY3JpcHRzKSB7XG4gIHByb2Nlc3MuZXhpdCgwKTtcbn1cblxuLy8gRGlzcGxheSB3ZWxjb21lIG1lc3NhZ2VcbmNvbnNvbGUubG9nKCcnKTtcbmNvbnNvbGUubG9nKGNoYWxrLmJvbGQuYmx1ZSgn4pWU4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWQ4pWXJykpO1xuY29uc29sZS5sb2coY2hhbGsuYm9sZC5ibHVlKCfilZEgICAgICAgICAgICAgICAgICAgIFdlbGNvbWUgdG8gb0Zsb3cgQ0xJICAgICAgICAgICAgICAgICAgICDilZEnKSk7XG5jb25zb2xlLmxvZyhjaGFsay5ib2xkLmJsdWUoJ+KVmuKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVkOKVnScpKTtcbmNvbnNvbGUubG9nKCcnKTtcbmNvbnNvbGUubG9nKGNoYWxrLmdyZWVuKCfinJMgb0Zsb3cgQ0xJIGluc3RhbGxlZCBzdWNjZXNzZnVsbHkhJykpO1xuY29uc29sZS5sb2coJycpO1xuY29uc29sZS5sb2coY2hhbGsuYm9sZCgnUXVpY2sgU3RhcnQ6JykpO1xuY29uc29sZS5sb2coJycpO1xuY29uc29sZS5sb2coY2hhbGsuY3lhbignICAxLiBSdW4gdGhlIENMSTonKSk7XG5jb25zb2xlLmxvZyhjaGFsay53aGl0ZSgnICAgICBvZmxvdycpKTtcbmNvbnNvbGUubG9nKCcnKTtcbmNvbnNvbGUubG9nKGNoYWxrLmN5YW4oJyAgMi4gQ29uZmlndXJlIGF1dGhlbnRpY2F0aW9uOicpKTtcbmNvbnNvbGUubG9nKGNoYWxrLndoaXRlKCcgICAgIG9mbG93IGF1dGgnKSk7XG5jb25zb2xlLmxvZygnJyk7XG5jb25zb2xlLmxvZyhjaGFsay5jeWFuKCcgIDMuIEF2YWlsYWJsZSBBSSBQcm92aWRlcnM6JykpO1xuY29uc29sZS5sb2coY2hhbGsuZ3JheSgnICAgICDigKIgT3BlbkFJIChHUFQtNG8sIEdQVC00LXR1cmJvLCBldGMuKScpKTtcbmNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJyAgICAg4oCiIERlZXBTZWVrICjmt7HluqbmsYLntKIpIC0gUmVjb21tZW5kZWQnKSk7XG5jb25zb2xlLmxvZyhjaGFsay5ncmF5KCcgICAgIOKAoiBRd2VuICjpgJrkuYnljYPpl64pJykpO1xuY29uc29sZS5sb2coY2hhbGsuZ3JheSgnICAgICDigKIgR0xNICjmmbrosLEpJykpO1xuY29uc29sZS5sb2coY2hhbGsuZ3JheSgnICAgICDigKIgQmFpY2h1YW4gKOeZvuW3nSknKSk7XG5jb25zb2xlLmxvZyhjaGFsay5ncmF5KCcgICAgIOKAoiBZaSAo6Zu25LiA5LiH54mpKScpKTtcbmNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJyAgICAg4oCiIE1vb25zaG90ICjmnIjkuYvmmpfpnaIvS2ltaSknKSk7XG5jb25zb2xlLmxvZyhjaGFsay5ncmF5KCcgICAgIOKAoiBTaWxpY29uRmxvdyAo56GF5Z+65rWB5YqoKScpKTtcbmNvbnNvbGUubG9nKCcnKTtcbmNvbnNvbGUubG9nKGNoYWxrLmJvbGQoJ09wdGlvbnM6JykpO1xuY29uc29sZS5sb2coY2hhbGsuZ3JheSgnICBvZmxvdyAtLWhlbHAgICAgICAgICAgU2hvdyBoZWxwJykpO1xuY29uc29sZS5sb2coY2hhbGsuZ3JheSgnICBvZmxvdyAtLXRoaW5raW5nICAgICAgU2hvdyBBSSByZWFzb25pbmcgcHJvY2VzcycpKTtcbmNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJyAgb2Zsb3cgbW9kZWxzICAgICAgICAgIExpc3QgYXZhaWxhYmxlIG1vZGVscycpKTtcbmNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJyAgb2Zsb3cgY29uZmlnICAgICAgICAgIFZpZXcgY29uZmlndXJhdGlvbicpKTtcbmNvbnNvbGUubG9nKCcnKTtcbmNvbnNvbGUubG9nKGNoYWxrLmJvbGQoJ0RvY3VtZW50YXRpb246JykpO1xuY29uc29sZS5sb2coY2hhbGsuYmx1ZSgnICBodHRwczovL2dpdGh1Yi5jb20vb2Zsb3ctYWkvb2Zsb3ctY2xpJykpO1xuY29uc29sZS5sb2coJycpO1xuXG4vLyBDaGVjayBOb2RlLmpzIHZlcnNpb25cbmNvbnN0IG5vZGVWZXJzaW9uID0gcHJvY2Vzcy52ZXJzaW9uO1xuY29uc3QgbWFqb3JWZXJzaW9uID0gcGFyc2VJbnQobm9kZVZlcnNpb24uc2xpY2UoMSkuc3BsaXQoJy4nKVswXSwgMTApO1xuXG5pZiAobWFqb3JWZXJzaW9uIDwgMTgpIHtcbiAgY29uc29sZS5sb2coY2hhbGsueWVsbG93KCfimqAgV2FybmluZzogTm9kZS5qcyAxOCBvciBoaWdoZXIgaXMgcmVjb21tZW5kZWQuJykpO1xuICBjb25zb2xlLmxvZyhjaGFsay55ZWxsb3coYCAgQ3VycmVudCB2ZXJzaW9uOiAke25vZGVWZXJzaW9ufWApKTtcbiAgY29uc29sZS5sb2coJycpO1xufVxuXG5wcm9jZXNzLmV4aXQoMCk7XG4iXX0=
@@ -0,0 +1,10 @@
1
+ export declare function renderMarkdown(content: string): string;
2
+ export declare function formatCodeBlock(code: string, language?: string): string;
3
+ export declare function formatInlineCode(code: string): string;
4
+ export declare function formatLink(text: string, url: string): string;
5
+ export declare function formatBullet(text: string, level?: number): string;
6
+ export declare function formatNumberedList(items: string[]): string;
7
+ export declare function formatError(message: string): string;
8
+ export declare function formatSuccess(message: string): string;
9
+ export declare function formatWarning(message: string): string;
10
+ export declare function formatInfo(message: string): string;
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.renderMarkdown = renderMarkdown;
7
+ exports.formatCodeBlock = formatCodeBlock;
8
+ exports.formatInlineCode = formatInlineCode;
9
+ exports.formatLink = formatLink;
10
+ exports.formatBullet = formatBullet;
11
+ exports.formatNumberedList = formatNumberedList;
12
+ exports.formatError = formatError;
13
+ exports.formatSuccess = formatSuccess;
14
+ exports.formatWarning = formatWarning;
15
+ exports.formatInfo = formatInfo;
16
+ const chalk_1 = __importDefault(require("chalk"));
17
+ function renderMarkdown(content) {
18
+ // Simple markdown rendering
19
+ let result = content;
20
+ // Bold
21
+ result = result.replace(/\*\*(.*?)\*\*/g, (_, text) => chalk_1.default.bold(text));
22
+ // Italic
23
+ result = result.replace(/\*(.*?)\*/g, (_, text) => chalk_1.default.italic(text));
24
+ // Code blocks
25
+ result = result.replace(/```(\w*)\n([\s\S]*?)```/g, (_, lang, code) => {
26
+ return chalk_1.default.cyan(code);
27
+ });
28
+ // Inline code
29
+ result = result.replace(/`([^`]+)`/g, (_, code) => chalk_1.default.cyan(code));
30
+ // Headers
31
+ result = result.replace(/^### (.+)$/gm, (_, text) => chalk_1.default.bold.green(text));
32
+ result = result.replace(/^## (.+)$/gm, (_, text) => chalk_1.default.bold.green(text));
33
+ result = result.replace(/^# (.+)$/gm, (_, text) => chalk_1.default.bold.green(text));
34
+ // Links
35
+ result = result.replace(/\[([^\]]+)\]\(([^)]+)\)/g, (_, text, url) => `${chalk_1.default.blue.underline(text)} ${chalk_1.default.gray(`(${url})`)}`);
36
+ return result;
37
+ }
38
+ function formatCodeBlock(code, language) {
39
+ const header = language ? chalk_1.default.gray(`\`\`\`${language}\n`) : chalk_1.default.gray('```\n');
40
+ const footer = chalk_1.default.gray('\n```');
41
+ return header + chalk_1.default.cyan(code) + footer;
42
+ }
43
+ function formatInlineCode(code) {
44
+ return chalk_1.default.cyan(`\`${code}\``);
45
+ }
46
+ function formatLink(text, url) {
47
+ return `${chalk_1.default.blue.underline(text)} ${chalk_1.default.gray(`(${url})`)}`;
48
+ }
49
+ function formatBullet(text, level = 0) {
50
+ const indent = ' '.repeat(level);
51
+ const bullet = level === 0 ? '•' : '◦';
52
+ return `${indent}${chalk_1.default.cyan(bullet)} ${text}`;
53
+ }
54
+ function formatNumberedList(items) {
55
+ return items.map((item, index) => `${chalk_1.default.cyan(`${index + 1}.`)} ${item}`).join('\n');
56
+ }
57
+ function formatError(message) {
58
+ return chalk_1.default.red(`✗ Error: ${message}`);
59
+ }
60
+ function formatSuccess(message) {
61
+ return chalk_1.default.green(`✓ ${message}`);
62
+ }
63
+ function formatWarning(message) {
64
+ return chalk_1.default.yellow(`⚠ ${message}`);
65
+ }
66
+ function formatInfo(message) {
67
+ return chalk_1.default.blue(`ℹ ${message}`);
68
+ }
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvbWFya2Rvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFFQSx3Q0E2QkM7QUFFRCwwQ0FJQztBQUVELDRDQUVDO0FBRUQsZ0NBRUM7QUFFRCxvQ0FJQztBQUVELGdEQUlDO0FBRUQsa0NBRUM7QUFFRCxzQ0FFQztBQUVELHNDQUVDO0FBRUQsZ0NBRUM7QUF6RUQsa0RBQTBCO0FBRTFCLFNBQWdCLGNBQWMsQ0FBQyxPQUFlO0lBQzVDLDRCQUE0QjtJQUM1QixJQUFJLE1BQU0sR0FBRyxPQUFPLENBQUM7SUFFckIsT0FBTztJQUNQLE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBRXpFLFNBQVM7SUFDVCxNQUFNLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxlQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFFdkUsY0FBYztJQUNkLE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLDBCQUEwQixFQUFFLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRTtRQUNwRSxPQUFPLGVBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFFSCxjQUFjO0lBQ2QsTUFBTSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBRXJFLFVBQVU7SUFDVixNQUFNLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxlQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQzdFLE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDNUUsTUFBTSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUUzRSxRQUFRO0lBQ1IsTUFBTSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsMEJBQTBCLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQ25FLEdBQUcsZUFBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksZUFBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLEVBQUUsQ0FDMUQsQ0FBQztJQUVGLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUFFRCxTQUFnQixlQUFlLENBQUMsSUFBWSxFQUFFLFFBQWlCO0lBQzdELE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxTQUFTLFFBQVEsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbEYsTUFBTSxNQUFNLEdBQUcsZUFBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNuQyxPQUFPLE1BQU0sR0FBRyxlQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLE1BQU0sQ0FBQztBQUM1QyxDQUFDO0FBRUQsU0FBZ0IsZ0JBQWdCLENBQUMsSUFBWTtJQUMzQyxPQUFPLGVBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFFRCxTQUFnQixVQUFVLENBQUMsSUFBWSxFQUFFLEdBQVc7SUFDbEQsT0FBTyxHQUFHLGVBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLGVBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQUM7QUFDbkUsQ0FBQztBQUVELFNBQWdCLFlBQVksQ0FBQyxJQUFZLEVBQUUsUUFBZ0IsQ0FBQztJQUMxRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLE1BQU0sTUFBTSxHQUFHLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO0lBQ3ZDLE9BQU8sR0FBRyxNQUFNLEdBQUcsZUFBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQztBQUNsRCxDQUFDO0FBRUQsU0FBZ0Isa0JBQWtCLENBQUMsS0FBZTtJQUNoRCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FDL0IsR0FBRyxlQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxHQUFHLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQ3pDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ2YsQ0FBQztBQUVELFNBQWdCLFdBQVcsQ0FBQyxPQUFlO0lBQ3pDLE9BQU8sZUFBSyxDQUFDLEdBQUcsQ0FBQyxZQUFZLE9BQU8sRUFBRSxDQUFDLENBQUM7QUFDMUMsQ0FBQztBQUVELFNBQWdCLGFBQWEsQ0FBQyxPQUFlO0lBQzNDLE9BQU8sZUFBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLE9BQU8sRUFBRSxDQUFDLENBQUM7QUFDckMsQ0FBQztBQUVELFNBQWdCLGFBQWEsQ0FBQyxPQUFlO0lBQzNDLE9BQU8sZUFBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLE9BQU8sRUFBRSxDQUFDLENBQUM7QUFDdEMsQ0FBQztBQUVELFNBQWdCLFVBQVUsQ0FBQyxPQUFlO0lBQ3hDLE9BQU8sZUFBSyxDQUFDLElBQUksQ0FBQyxLQUFLLE9BQU8sRUFBRSxDQUFDLENBQUM7QUFDcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjaGFsayBmcm9tICdjaGFsayc7XG5cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJNYXJrZG93bihjb250ZW50OiBzdHJpbmcpOiBzdHJpbmcge1xuICAvLyBTaW1wbGUgbWFya2Rvd24gcmVuZGVyaW5nXG4gIGxldCByZXN1bHQgPSBjb250ZW50O1xuICBcbiAgLy8gQm9sZFxuICByZXN1bHQgPSByZXN1bHQucmVwbGFjZSgvXFwqXFwqKC4qPylcXCpcXCovZywgKF8sIHRleHQpID0+IGNoYWxrLmJvbGQodGV4dCkpO1xuICBcbiAgLy8gSXRhbGljXG4gIHJlc3VsdCA9IHJlc3VsdC5yZXBsYWNlKC9cXCooLio/KVxcKi9nLCAoXywgdGV4dCkgPT4gY2hhbGsuaXRhbGljKHRleHQpKTtcbiAgXG4gIC8vIENvZGUgYmxvY2tzXG4gIHJlc3VsdCA9IHJlc3VsdC5yZXBsYWNlKC9gYGAoXFx3KilcXG4oW1xcc1xcU10qPylgYGAvZywgKF8sIGxhbmcsIGNvZGUpID0+IHtcbiAgICByZXR1cm4gY2hhbGsuY3lhbihjb2RlKTtcbiAgfSk7XG4gIFxuICAvLyBJbmxpbmUgY29kZVxuICByZXN1bHQgPSByZXN1bHQucmVwbGFjZSgvYChbXmBdKylgL2csIChfLCBjb2RlKSA9PiBjaGFsay5jeWFuKGNvZGUpKTtcbiAgXG4gIC8vIEhlYWRlcnNcbiAgcmVzdWx0ID0gcmVzdWx0LnJlcGxhY2UoL14jIyMgKC4rKSQvZ20sIChfLCB0ZXh0KSA9PiBjaGFsay5ib2xkLmdyZWVuKHRleHQpKTtcbiAgcmVzdWx0ID0gcmVzdWx0LnJlcGxhY2UoL14jIyAoLispJC9nbSwgKF8sIHRleHQpID0+IGNoYWxrLmJvbGQuZ3JlZW4odGV4dCkpO1xuICByZXN1bHQgPSByZXN1bHQucmVwbGFjZSgvXiMgKC4rKSQvZ20sIChfLCB0ZXh0KSA9PiBjaGFsay5ib2xkLmdyZWVuKHRleHQpKTtcbiAgXG4gIC8vIExpbmtzXG4gIHJlc3VsdCA9IHJlc3VsdC5yZXBsYWNlKC9cXFsoW15cXF1dKylcXF1cXCgoW14pXSspXFwpL2csIChfLCB0ZXh0LCB1cmwpID0+IFxuICAgIGAke2NoYWxrLmJsdWUudW5kZXJsaW5lKHRleHQpfSAke2NoYWxrLmdyYXkoYCgke3VybH0pYCl9YFxuICApO1xuICBcbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdENvZGVCbG9jayhjb2RlOiBzdHJpbmcsIGxhbmd1YWdlPzogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3QgaGVhZGVyID0gbGFuZ3VhZ2UgPyBjaGFsay5ncmF5KGBcXGBcXGBcXGAke2xhbmd1YWdlfVxcbmApIDogY2hhbGsuZ3JheSgnYGBgXFxuJyk7XG4gIGNvbnN0IGZvb3RlciA9IGNoYWxrLmdyYXkoJ1xcbmBgYCcpO1xuICByZXR1cm4gaGVhZGVyICsgY2hhbGsuY3lhbihjb2RlKSArIGZvb3Rlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdElubGluZUNvZGUoY29kZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGNoYWxrLmN5YW4oYFxcYCR7Y29kZX1cXGBgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdExpbmsodGV4dDogc3RyaW5nLCB1cmw6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtjaGFsay5ibHVlLnVuZGVybGluZSh0ZXh0KX0gJHtjaGFsay5ncmF5KGAoJHt1cmx9KWApfWA7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRCdWxsZXQodGV4dDogc3RyaW5nLCBsZXZlbDogbnVtYmVyID0gMCk6IHN0cmluZyB7XG4gIGNvbnN0IGluZGVudCA9ICcgICcucmVwZWF0KGxldmVsKTtcbiAgY29uc3QgYnVsbGV0ID0gbGV2ZWwgPT09IDAgPyAn4oCiJyA6ICfil6YnO1xuICByZXR1cm4gYCR7aW5kZW50fSR7Y2hhbGsuY3lhbihidWxsZXQpfSAke3RleHR9YDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdE51bWJlcmVkTGlzdChpdGVtczogc3RyaW5nW10pOiBzdHJpbmcge1xuICByZXR1cm4gaXRlbXMubWFwKChpdGVtLCBpbmRleCkgPT4gXG4gICAgYCR7Y2hhbGsuY3lhbihgJHtpbmRleCArIDF9LmApfSAke2l0ZW19YFxuICApLmpvaW4oJ1xcbicpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0RXJyb3IobWVzc2FnZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGNoYWxrLnJlZChg4pyXIEVycm9yOiAke21lc3NhZ2V9YCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRTdWNjZXNzKG1lc3NhZ2U6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBjaGFsay5ncmVlbihg4pyTICR7bWVzc2FnZX1gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdFdhcm5pbmcobWVzc2FnZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGNoYWxrLnllbGxvdyhg4pqgICR7bWVzc2FnZX1gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdEluZm8obWVzc2FnZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGNoYWxrLmJsdWUoYOKEuSAke21lc3NhZ2V9YCk7XG59Il19
package/package.json ADDED
@@ -0,0 +1,69 @@
1
+ {
2
+ "name": "@oflow-ai/oflow-cli",
3
+ "version": "0.1.0",
4
+ "description": "oFlow CLI - AI-powered terminal assistant for developers",
5
+ "keywords": [
6
+ "ai",
7
+ "cli",
8
+ "assistant",
9
+ "terminal",
10
+ "code-assistant",
11
+ "gpt",
12
+ "openai",
13
+ "deepseek",
14
+ "qwen",
15
+ "developer-tools"
16
+ ],
17
+ "homepage": "https://github.com/oflow-ai/oflow-cli#readme",
18
+ "bugs": {
19
+ "url": "https://github.com/oflow-ai/oflow-cli/issues"
20
+ },
21
+ "repository": {
22
+ "type": "git",
23
+ "url": "git+https://github.com/oflow-ai/oflow-cli.git"
24
+ },
25
+ "main": "dist/index.js",
26
+ "types": "dist/index.d.ts",
27
+ "bin": {
28
+ "oflow": "dist/index.js"
29
+ },
30
+ "files": [
31
+ "dist",
32
+ "scripts",
33
+ "README.md",
34
+ "LICENSE"
35
+ ],
36
+ "scripts": {
37
+ "build": "tsc -b",
38
+ "dev": "tsc -b --watch",
39
+ "test": "echo \"No tests yet\"",
40
+ "prepublishOnly": "npm run build",
41
+ "postinstall": "node scripts/postinstall.js"
42
+ },
43
+ "dependencies": {
44
+ "@oflow-ai/core": "^0.1.0",
45
+ "commander": "^11.1.0",
46
+ "chalk": "^4.1.2",
47
+ "ora": "^5.4.1",
48
+ "inquirer": "^8.2.6",
49
+ "conf": "^10.2.0",
50
+ "marked": "^11.1.0",
51
+ "marked-terminal": "^6.0.0",
52
+ "update-notifier": "^6.0.2",
53
+ "open": "^8.4.2"
54
+ },
55
+ "devDependencies": {
56
+ "@types/inquirer": "^8.2.10",
57
+ "@types/node": "^20.10.0",
58
+ "@types/update-notifier": "^6.0.5",
59
+ "typescript": "^5.3.2"
60
+ },
61
+ "engines": {
62
+ "node": ">=18.0.0"
63
+ },
64
+ "author": "oFlow Team",
65
+ "license": "MIT",
66
+ "publishConfig": {
67
+ "access": "public"
68
+ }
69
+ }