@oflow-ai/oflow-cli 0.1.1 → 0.1.2
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 +171 -99
- package/dist/commands/index.js +7 -1
- package/dist/updater.d.ts +17 -0
- package/dist/updater.js +167 -0
- package/package.json +1 -1
package/dist/cli.js
CHANGED
|
@@ -43,8 +43,78 @@ const chalk_1 = __importDefault(require("chalk"));
|
|
|
43
43
|
const ora_1 = __importDefault(require("ora"));
|
|
44
44
|
const core_1 = require("@oflow-ai/core");
|
|
45
45
|
const commands_1 = require("./commands");
|
|
46
|
+
const updater_1 = require("./updater");
|
|
46
47
|
let sandboxExecutor = null;
|
|
47
48
|
let currentShowThinking = false;
|
|
49
|
+
let sessionStats = {
|
|
50
|
+
toolCallsCount: 0,
|
|
51
|
+
filesRead: [],
|
|
52
|
+
filesWritten: [],
|
|
53
|
+
commandsRun: [],
|
|
54
|
+
startTime: new Date()
|
|
55
|
+
};
|
|
56
|
+
let contextTokens = 0;
|
|
57
|
+
let maxContextTokens = 128000;
|
|
58
|
+
function drawStatusBar(model) {
|
|
59
|
+
const terminalWidth = process.stdout.columns || 80;
|
|
60
|
+
const contextPercent = Math.min(100, Math.round((contextTokens / maxContextTokens) * 100));
|
|
61
|
+
const contextColor = contextPercent > 80 ? chalk_1.default.red : contextPercent > 50 ? chalk_1.default.yellow : chalk_1.default.green;
|
|
62
|
+
const thinkingStatus = currentShowThinking ? chalk_1.default.cyan('ON') : chalk_1.default.gray('OFF');
|
|
63
|
+
const statusLine1 = [
|
|
64
|
+
`${chalk_1.default.blue('Model:')} ${chalk_1.default.white(model)}`,
|
|
65
|
+
`${chalk_1.default.blue('Context:')} ${contextColor(contextPercent + '%')}`,
|
|
66
|
+
`${chalk_1.default.blue('Thinking:')} ${thinkingStatus}`
|
|
67
|
+
].join(' | ');
|
|
68
|
+
const currentDir = process.cwd();
|
|
69
|
+
const dirDisplay = currentDir.length > terminalWidth - 10
|
|
70
|
+
? '...' + currentDir.slice(-(terminalWidth - 13))
|
|
71
|
+
: currentDir;
|
|
72
|
+
const statusLine2 = `${chalk_1.default.blue('Dir:')} ${chalk_1.default.gray(dirDisplay)}`;
|
|
73
|
+
console.log('');
|
|
74
|
+
console.log(chalk_1.default.gray('─'.repeat(Math.min(terminalWidth, 60))));
|
|
75
|
+
console.log(statusLine1);
|
|
76
|
+
console.log(statusLine2);
|
|
77
|
+
console.log(chalk_1.default.gray('─'.repeat(Math.min(terminalWidth, 60))));
|
|
78
|
+
}
|
|
79
|
+
function showTaskSummary() {
|
|
80
|
+
const duration = Math.round((Date.now() - sessionStats.startTime.getTime()) / 1000);
|
|
81
|
+
const minutes = Math.floor(duration / 60);
|
|
82
|
+
const seconds = duration % 60;
|
|
83
|
+
console.log('');
|
|
84
|
+
console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
|
|
85
|
+
console.log(chalk_1.default.bold.cyan(' Task Summary'));
|
|
86
|
+
console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
|
|
87
|
+
console.log('');
|
|
88
|
+
console.log(`${chalk_1.default.white('Duration:')} ${chalk_1.default.yellow(minutes + 'm ' + seconds + 's')}`);
|
|
89
|
+
console.log(`${chalk_1.default.white('Tool calls:')} ${chalk_1.default.yellow(sessionStats.toolCallsCount.toString())}`);
|
|
90
|
+
if (sessionStats.filesRead.length > 0) {
|
|
91
|
+
console.log(`${chalk_1.default.white('Files read:')} ${chalk_1.default.yellow(sessionStats.filesRead.length.toString())}`);
|
|
92
|
+
sessionStats.filesRead.slice(0, 5).forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
|
|
93
|
+
if (sessionStats.filesRead.length > 5) {
|
|
94
|
+
console.log(chalk_1.default.gray(' ... and ' + (sessionStats.filesRead.length - 5) + ' more'));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
if (sessionStats.filesWritten.length > 0) {
|
|
98
|
+
console.log(`${chalk_1.default.white('Files modified:')} ${chalk_1.default.yellow(sessionStats.filesWritten.length.toString())}`);
|
|
99
|
+
sessionStats.filesWritten.slice(0, 5).forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
|
|
100
|
+
if (sessionStats.filesWritten.length > 5) {
|
|
101
|
+
console.log(chalk_1.default.gray(' ... and ' + (sessionStats.filesWritten.length - 5) + ' more'));
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (sessionStats.commandsRun.length > 0) {
|
|
105
|
+
console.log(`${chalk_1.default.white('Commands run:')} ${chalk_1.default.yellow(sessionStats.commandsRun.length.toString())}`);
|
|
106
|
+
}
|
|
107
|
+
console.log('');
|
|
108
|
+
console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
|
|
109
|
+
console.log('');
|
|
110
|
+
sessionStats = {
|
|
111
|
+
toolCallsCount: 0,
|
|
112
|
+
filesRead: [],
|
|
113
|
+
filesWritten: [],
|
|
114
|
+
commandsRun: [],
|
|
115
|
+
startTime: new Date()
|
|
116
|
+
};
|
|
117
|
+
}
|
|
48
118
|
async function startInteractiveMode(options) {
|
|
49
119
|
const configManager = (0, core_1.getConfigManager)();
|
|
50
120
|
const auth = configManager.getAuth();
|
|
@@ -52,25 +122,37 @@ async function startInteractiveMode(options) {
|
|
|
52
122
|
console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
|
|
53
123
|
return;
|
|
54
124
|
}
|
|
55
|
-
//
|
|
125
|
+
// Check for updates
|
|
126
|
+
const updateInfo = await (0, updater_1.checkForUpdates)();
|
|
127
|
+
if (updateInfo.hasUpdate) {
|
|
128
|
+
console.log('');
|
|
129
|
+
console.log(chalk_1.default.yellow('New version available: ' + updateInfo.latestVersion));
|
|
130
|
+
console.log(chalk_1.default.yellow('Run /update to update'));
|
|
131
|
+
console.log('');
|
|
132
|
+
}
|
|
56
133
|
if (options.sandbox || configManager.get('sandbox')) {
|
|
57
134
|
try {
|
|
58
135
|
sandboxExecutor = await (0, core_1.createSandboxExecutor)();
|
|
59
|
-
console.log(chalk_1.default.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));
|
|
60
|
-
}
|
|
61
|
-
catch (error) {
|
|
62
|
-
console.log(chalk_1.default.yellow('Sandbox mode: unavailable'));
|
|
63
136
|
}
|
|
137
|
+
catch { }
|
|
64
138
|
}
|
|
65
|
-
// 获取思考过程显示设置
|
|
66
139
|
currentShowThinking = options.showThinking ?? configManager.getShowThinking();
|
|
67
140
|
const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
|
|
141
|
+
if (model.includes('gpt-4') || model.includes('gpt-4o')) {
|
|
142
|
+
maxContextTokens = 128000;
|
|
143
|
+
}
|
|
144
|
+
else if (model.includes('deepseek')) {
|
|
145
|
+
maxContextTokens = 64000;
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
maxContextTokens = 128000;
|
|
149
|
+
}
|
|
68
150
|
let provider;
|
|
69
151
|
try {
|
|
70
152
|
provider = (0, core_1.createAIProvider)(auth, model);
|
|
71
153
|
}
|
|
72
154
|
catch (error) {
|
|
73
|
-
console.log(chalk_1.default.red('Failed to create AI provider:'
|
|
155
|
+
console.log(chalk_1.default.red('Failed to create AI provider: ' + (error instanceof Error ? error.message : String(error))));
|
|
74
156
|
return;
|
|
75
157
|
}
|
|
76
158
|
const conversation = new core_1.Conversation({
|
|
@@ -83,59 +165,71 @@ async function startInteractiveMode(options) {
|
|
|
83
165
|
process.stdout.write(chalk_1.default.white(content));
|
|
84
166
|
},
|
|
85
167
|
onThinking: (thinking) => {
|
|
86
|
-
// 显示思考过程,使用不同的颜色
|
|
87
168
|
if (currentShowThinking) {
|
|
88
169
|
process.stdout.write(chalk_1.default.magenta(thinking));
|
|
89
170
|
}
|
|
90
171
|
},
|
|
91
172
|
onToolCall: (toolCall) => {
|
|
92
|
-
|
|
173
|
+
sessionStats.toolCallsCount++;
|
|
174
|
+
console.log(chalk_1.default.cyan('\nUsing tool: ' + toolCall.function.name));
|
|
175
|
+
try {
|
|
176
|
+
const args = JSON.parse(toolCall.function.arguments);
|
|
177
|
+
if (toolCall.function.name === 'read_file' && args.absolute_path) {
|
|
178
|
+
if (!sessionStats.filesRead.includes(args.absolute_path)) {
|
|
179
|
+
sessionStats.filesRead.push(args.absolute_path);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
else if ((toolCall.function.name === 'write_file' || toolCall.function.name === 'replace') && args.file_path) {
|
|
183
|
+
if (!sessionStats.filesWritten.includes(args.file_path)) {
|
|
184
|
+
sessionStats.filesWritten.push(args.file_path);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
else if (toolCall.function.name === 'run_shell_command' && args.command) {
|
|
188
|
+
sessionStats.commandsRun.push(args.command);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
catch { }
|
|
93
192
|
},
|
|
94
193
|
onToolResult: (result) => {
|
|
95
|
-
|
|
194
|
+
contextTokens += Math.ceil(result.length / 4);
|
|
96
195
|
}
|
|
97
196
|
});
|
|
98
|
-
// Set system prompt
|
|
99
197
|
conversation.setSystemPrompt(getSystemPrompt());
|
|
100
|
-
console.log(chalk_1.default.bold.blue('\
|
|
101
|
-
console.log(chalk_1.default.
|
|
102
|
-
console.log(chalk_1.default.bold.blue('╚═══════════════════════════════════════╝'));
|
|
103
|
-
console.log('');
|
|
104
|
-
console.log(chalk_1.default.gray(`Provider: ${auth.provider}`));
|
|
105
|
-
console.log(chalk_1.default.gray(`Model: ${model}`));
|
|
106
|
-
console.log(chalk_1.default.gray(`Working directory: ${process.cwd()}`));
|
|
107
|
-
if (sandboxExecutor) {
|
|
108
|
-
console.log(chalk_1.default.gray(`Sandbox: enabled`));
|
|
109
|
-
}
|
|
110
|
-
console.log(chalk_1.default.gray(`Thinking: ${currentShowThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));
|
|
111
|
-
console.log('');
|
|
112
|
-
console.log(chalk_1.default.gray('Type your message and press Enter to chat.'));
|
|
113
|
-
console.log(chalk_1.default.gray('Type /help for available commands.'));
|
|
114
|
-
console.log(chalk_1.default.gray('Type $agent-name to call a sub-agent.'));
|
|
115
|
-
console.log(chalk_1.default.gray('Type /exit or press Ctrl+C to exit.'));
|
|
198
|
+
console.log(chalk_1.default.bold.blue('\nWelcome to oflow CLI'));
|
|
199
|
+
console.log(chalk_1.default.gray('Type /help for commands, /exit to quit'));
|
|
116
200
|
console.log('');
|
|
117
201
|
const rl = readline.createInterface({
|
|
118
202
|
input: process.stdin,
|
|
119
|
-
output: process.stdout
|
|
120
|
-
prompt: chalk_1.default.green('> ')
|
|
203
|
+
output: process.stdout
|
|
121
204
|
});
|
|
122
|
-
|
|
205
|
+
const showPrompt = () => {
|
|
206
|
+
drawStatusBar(model);
|
|
207
|
+
rl.setPrompt(chalk_1.default.green('\n> '));
|
|
208
|
+
rl.prompt();
|
|
209
|
+
};
|
|
210
|
+
showPrompt();
|
|
123
211
|
rl.on('line', async (line) => {
|
|
124
212
|
const input = line.trim();
|
|
125
213
|
if (!input) {
|
|
126
|
-
|
|
214
|
+
showPrompt();
|
|
127
215
|
return;
|
|
128
216
|
}
|
|
129
|
-
// Check for slash commands
|
|
130
217
|
if ((0, commands_1.isSlashCommand)(input)) {
|
|
131
|
-
// 特殊处理 /thinking 命令
|
|
132
218
|
if (input.toLowerCase() === '/thinking') {
|
|
133
219
|
currentShowThinking = !currentShowThinking;
|
|
134
220
|
configManager.setShowThinking(currentShowThinking);
|
|
135
|
-
console.log('');
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
221
|
+
console.log(chalk_1.default.green('Thinking: ' + (currentShowThinking ? 'ON' : 'OFF')));
|
|
222
|
+
showPrompt();
|
|
223
|
+
return;
|
|
224
|
+
}
|
|
225
|
+
if (input.toLowerCase() === '/summary') {
|
|
226
|
+
showTaskSummary();
|
|
227
|
+
showPrompt();
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
if (input.toLowerCase() === '/update') {
|
|
231
|
+
await (0, updater_1.performUpdate)();
|
|
232
|
+
showPrompt();
|
|
139
233
|
return;
|
|
140
234
|
}
|
|
141
235
|
const shouldContinue = await (0, commands_1.executeSlashCommand)(input, {
|
|
@@ -147,80 +241,76 @@ async function startInteractiveMode(options) {
|
|
|
147
241
|
rl.close();
|
|
148
242
|
return;
|
|
149
243
|
}
|
|
150
|
-
|
|
244
|
+
showPrompt();
|
|
151
245
|
return;
|
|
152
246
|
}
|
|
153
|
-
// Check for agent calls (starting with $)
|
|
154
247
|
if (input.startsWith('$')) {
|
|
155
|
-
await handleAgentCall(input, provider
|
|
156
|
-
|
|
248
|
+
await handleAgentCall(input, provider);
|
|
249
|
+
showPrompt();
|
|
157
250
|
return;
|
|
158
251
|
}
|
|
159
|
-
// Check for shell commands (starting with !)
|
|
160
252
|
if (input.startsWith('!')) {
|
|
161
253
|
await executeShellCommand(input.slice(1), sandboxExecutor);
|
|
162
|
-
|
|
254
|
+
showPrompt();
|
|
163
255
|
return;
|
|
164
256
|
}
|
|
165
|
-
// Check for file reference (starting with @)
|
|
166
257
|
const processedInput = await processFileReferences(input);
|
|
167
|
-
// Send to AI
|
|
168
258
|
const spinner = (0, ora_1.default)('Thinking...').start();
|
|
169
259
|
try {
|
|
170
260
|
const response = await conversation.sendMessage(processedInput);
|
|
171
261
|
spinner.stop();
|
|
172
|
-
console.log('');
|
|
173
|
-
|
|
262
|
+
console.log('');
|
|
263
|
+
if (sessionStats.toolCallsCount >= 3) {
|
|
264
|
+
showTaskSummary();
|
|
265
|
+
}
|
|
266
|
+
else {
|
|
267
|
+
contextTokens += Math.ceil(response.length / 4);
|
|
268
|
+
}
|
|
269
|
+
showPrompt();
|
|
174
270
|
}
|
|
175
271
|
catch (error) {
|
|
176
272
|
spinner.fail('Error');
|
|
177
273
|
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
178
274
|
console.log(chalk_1.default.red(errorMessage));
|
|
179
|
-
// 提供更详细的错误信息
|
|
180
275
|
if (errorMessage.includes('400')) {
|
|
181
|
-
console.log(chalk_1.default.yellow('
|
|
182
|
-
console.log(chalk_1.default.gray(' 1. 检查API Key是否正确'));
|
|
183
|
-
console.log(chalk_1.default.gray(' 2. 检查模型名称是否正确'));
|
|
184
|
-
console.log(chalk_1.default.gray(' 3. 运行 "oflow auth" 重新配置'));
|
|
276
|
+
console.log(chalk_1.default.yellow('Check API key and model name, or run "oflow auth"'));
|
|
185
277
|
}
|
|
186
|
-
else if (errorMessage.includes('401')
|
|
187
|
-
console.log(chalk_1.default.yellow('
|
|
278
|
+
else if (errorMessage.includes('401')) {
|
|
279
|
+
console.log(chalk_1.default.yellow('Authentication failed, run "oflow auth"'));
|
|
188
280
|
}
|
|
189
281
|
else if (errorMessage.includes('429')) {
|
|
190
|
-
console.log(chalk_1.default.yellow('
|
|
282
|
+
console.log(chalk_1.default.yellow('Rate limit, please wait and retry'));
|
|
191
283
|
}
|
|
192
|
-
|
|
284
|
+
showPrompt();
|
|
193
285
|
}
|
|
194
286
|
});
|
|
195
287
|
rl.on('close', () => {
|
|
196
|
-
console.log(chalk_1.default.bold('\nGoodbye
|
|
288
|
+
console.log(chalk_1.default.bold('\nGoodbye!\n'));
|
|
197
289
|
process.exit(0);
|
|
198
290
|
});
|
|
199
|
-
// Handle Ctrl+C
|
|
200
291
|
process.on('SIGINT', () => {
|
|
201
|
-
console.log(chalk_1.default.bold('\nGoodbye
|
|
292
|
+
console.log(chalk_1.default.bold('\nGoodbye!\n'));
|
|
202
293
|
process.exit(0);
|
|
203
294
|
});
|
|
204
295
|
}
|
|
205
|
-
async function handleAgentCall(input, provider
|
|
206
|
-
// Parse agent call: $agent-type "task description"
|
|
296
|
+
async function handleAgentCall(input, provider) {
|
|
207
297
|
const match = input.match(/^\$(\w+(?:-\w+)*)\s*(.*)$/);
|
|
208
298
|
if (!match) {
|
|
209
|
-
console.log(chalk_1.default.yellow('Invalid
|
|
210
|
-
console.log(chalk_1.default.gray('
|
|
299
|
+
console.log(chalk_1.default.yellow('Invalid format. Use: $agent-type "task"'));
|
|
300
|
+
console.log(chalk_1.default.gray('Agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));
|
|
211
301
|
return;
|
|
212
302
|
}
|
|
213
303
|
const agentType = match[1];
|
|
214
304
|
const task = match[2].replace(/^["']|["']$/g, '');
|
|
215
305
|
if (!task) {
|
|
216
|
-
console.log(chalk_1.default.yellow('Please provide a task
|
|
306
|
+
console.log(chalk_1.default.yellow('Please provide a task.'));
|
|
217
307
|
return;
|
|
218
308
|
}
|
|
219
309
|
try {
|
|
220
310
|
const agentFactory = new core_1.AgentFactory(provider, process.cwd());
|
|
221
311
|
const agent = agentFactory.createAgent(agentType);
|
|
222
|
-
console.log(chalk_1.default.cyan(
|
|
223
|
-
console.log(chalk_1.default.gray(
|
|
312
|
+
console.log(chalk_1.default.cyan('\nStarting ' + agentType + ' agent...'));
|
|
313
|
+
console.log(chalk_1.default.gray('Task: ' + task + '\n'));
|
|
224
314
|
const spinner = (0, ora_1.default)('Agent working...').start();
|
|
225
315
|
const result = await agent.execute(task, (update) => {
|
|
226
316
|
spinner.stop();
|
|
@@ -229,20 +319,22 @@ async function handleAgentCall(input, provider, options) {
|
|
|
229
319
|
});
|
|
230
320
|
spinner.stop();
|
|
231
321
|
if (result.success) {
|
|
232
|
-
console.log(chalk_1.default.green('\
|
|
322
|
+
console.log(chalk_1.default.green('\nAgent completed successfully'));
|
|
233
323
|
if (result.filesModified && result.filesModified.length > 0) {
|
|
234
324
|
console.log(chalk_1.default.gray('Files modified:'));
|
|
235
|
-
result.filesModified.forEach(f => console.log(chalk_1.default.gray(
|
|
325
|
+
result.filesModified.forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
|
|
326
|
+
sessionStats.filesWritten.push(...result.filesModified);
|
|
236
327
|
}
|
|
237
328
|
}
|
|
238
329
|
else {
|
|
239
|
-
console.log(chalk_1.default.red('\
|
|
240
|
-
result.errors?.forEach(e => console.log(chalk_1.default.red(
|
|
330
|
+
console.log(chalk_1.default.red('\nAgent encountered errors:'));
|
|
331
|
+
result.errors?.forEach(e => console.log(chalk_1.default.red(' - ' + e)));
|
|
241
332
|
}
|
|
242
333
|
if (result.output) {
|
|
243
334
|
console.log(chalk_1.default.gray('\nOutput:'));
|
|
244
335
|
console.log(result.output);
|
|
245
336
|
}
|
|
337
|
+
showTaskSummary();
|
|
246
338
|
}
|
|
247
339
|
catch (error) {
|
|
248
340
|
console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
|
|
@@ -255,14 +347,11 @@ async function runSingleCommand(prompt, options) {
|
|
|
255
347
|
console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
|
|
256
348
|
return;
|
|
257
349
|
}
|
|
258
|
-
// 初始化沙箱执行器
|
|
259
350
|
if (options.sandbox || configManager.get('sandbox')) {
|
|
260
351
|
try {
|
|
261
352
|
sandboxExecutor = await (0, core_1.createSandboxExecutor)();
|
|
262
353
|
}
|
|
263
|
-
catch {
|
|
264
|
-
// Ignore sandbox errors for single command
|
|
265
|
-
}
|
|
354
|
+
catch { }
|
|
266
355
|
}
|
|
267
356
|
const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
|
|
268
357
|
const provider = (0, core_1.createAIProvider)(auth, model);
|
|
@@ -290,6 +379,7 @@ async function runSingleCommand(prompt, options) {
|
|
|
290
379
|
}
|
|
291
380
|
async function executeShellCommand(command, sandbox) {
|
|
292
381
|
const { spawn } = require('child_process');
|
|
382
|
+
sessionStats.commandsRun.push(command);
|
|
293
383
|
if (sandbox && sandbox['config']?.backend !== 'none') {
|
|
294
384
|
try {
|
|
295
385
|
const result = await sandbox.execute(command, process.cwd());
|
|
@@ -297,8 +387,6 @@ async function executeShellCommand(command, sandbox) {
|
|
|
297
387
|
console.log(result.stdout);
|
|
298
388
|
if (result.stderr)
|
|
299
389
|
console.error(result.stderr);
|
|
300
|
-
if (result.timedOut)
|
|
301
|
-
console.log(chalk_1.default.yellow('Command timed out'));
|
|
302
390
|
return;
|
|
303
391
|
}
|
|
304
392
|
catch (error) {
|
|
@@ -314,11 +402,9 @@ async function executeShellCommand(command, sandbox) {
|
|
|
314
402
|
stdio: 'inherit',
|
|
315
403
|
cwd: process.cwd()
|
|
316
404
|
});
|
|
317
|
-
proc.on('close', () =>
|
|
318
|
-
resolve();
|
|
319
|
-
});
|
|
405
|
+
proc.on('close', () => resolve());
|
|
320
406
|
proc.on('error', (err) => {
|
|
321
|
-
console.log(chalk_1.default.red(
|
|
407
|
+
console.log(chalk_1.default.red('Failed: ' + err.message));
|
|
322
408
|
resolve();
|
|
323
409
|
});
|
|
324
410
|
});
|
|
@@ -328,16 +414,15 @@ async function processFileReferences(input) {
|
|
|
328
414
|
const matches = input.matchAll(fileRefRegex);
|
|
329
415
|
let result = input;
|
|
330
416
|
const fs = require('fs');
|
|
331
|
-
const path = require('path');
|
|
332
417
|
for (const match of matches) {
|
|
333
418
|
const filePath = match[1];
|
|
334
419
|
try {
|
|
335
420
|
const content = fs.readFileSync(filePath, 'utf-8');
|
|
336
|
-
result = result.replace(match[0],
|
|
421
|
+
result = result.replace(match[0], '\n[File: ' + filePath + ']\n' + content + '\n[End of file]\n');
|
|
422
|
+
sessionStats.filesRead.push(filePath);
|
|
337
423
|
}
|
|
338
424
|
catch {
|
|
339
|
-
|
|
340
|
-
console.log(chalk_1.default.yellow(`Warning: Could not read file ${filePath}`));
|
|
425
|
+
console.log(chalk_1.default.yellow('Warning: Could not read file ' + filePath));
|
|
341
426
|
}
|
|
342
427
|
}
|
|
343
428
|
return result;
|
|
@@ -371,13 +456,6 @@ Your primary goal is to help users safely and efficiently complete programming t
|
|
|
371
456
|
- task: Launch sub-agents
|
|
372
457
|
- save_memory: Save information for future sessions
|
|
373
458
|
|
|
374
|
-
# Sub-Agents (use $agent-name to call)
|
|
375
|
-
- general-purpose: Complex multi-step tasks
|
|
376
|
-
- plan-agent: Planning and analysis
|
|
377
|
-
- explore-agent: Codebase exploration
|
|
378
|
-
- code-reviewer: Code review
|
|
379
|
-
- frontend-tester: UI testing
|
|
380
|
-
|
|
381
459
|
# Guidelines
|
|
382
460
|
1. Be concise and helpful
|
|
383
461
|
2. Always explain what you're doing before using tools
|
|
@@ -385,15 +463,9 @@ Your primary goal is to help users safely and efficiently complete programming t
|
|
|
385
463
|
4. Prefer editing existing files over creating new ones
|
|
386
464
|
5. Use appropriate tools for each task
|
|
387
465
|
6. Verify changes after making them
|
|
388
|
-
7.
|
|
389
|
-
|
|
390
|
-
# Important Rules
|
|
391
|
-
- When you need to use tools, first explain what you're going to do
|
|
392
|
-
- After using tools, summarize the results
|
|
393
|
-
- If a tool call fails, explain what went wrong and suggest alternatives
|
|
394
|
-
- Always provide clear, actionable responses
|
|
466
|
+
7. After completing a complex task, provide a brief summary
|
|
395
467
|
|
|
396
468
|
Current working directory: ${process.cwd()}
|
|
397
469
|
`;
|
|
398
470
|
}
|
|
399
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import * as readline from 'readline';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n  getConfigManager,\n  createAIProvider,\n  Conversation,\n  Message,\n  AgentFactory,\n  Agent,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet currentShowThinking = false;\n\nexport async function startInteractiveMode(options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n      console.log(chalk.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));\n    } catch (error) {\n      console.log(chalk.yellow('Sandbox mode: unavailable'));\n    }\n  }\n\n  // 获取思考过程显示设置\n  currentShowThinking = options.showThinking ?? configManager.getShowThinking();\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  \n  let provider;\n  try {\n    provider = createAIProvider(auth, model);\n  } catch (error) {\n    console.log(chalk.red('Failed to create AI provider:', error instanceof Error ? error.message : String(error)));\n    return;\n  }\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: currentShowThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      // 显示思考过程，使用不同的颜色\n      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      console.log(chalk.cyan(`\\n🔧 Using tool: ${toolCall.function.name}`));\n    },\n    onToolResult: (result) => {\n      // Tool result is handled silently\n    }\n  });\n\n  // Set system prompt\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  console.log(chalk.bold.blue('\\n╔═══════════════════════════════════════╗'));\n  console.log(chalk.bold.blue('║         Welcome to oflow CLI          ║'));\n  console.log(chalk.bold.blue('╚═══════════════════════════════════════╝'));\n  console.log('');\n  console.log(chalk.gray(`Provider: ${auth.provider}`));\n  console.log(chalk.gray(`Model: ${model}`));\n  console.log(chalk.gray(`Working directory: ${process.cwd()}`));\n  if (sandboxExecutor) {\n    console.log(chalk.gray(`Sandbox: enabled`));\n  }\n  console.log(chalk.gray(`Thinking: ${currentShowThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));\n  console.log('');\n  console.log(chalk.gray('Type your message and press Enter to chat.'));\n  console.log(chalk.gray('Type /help for available commands.'));\n  console.log(chalk.gray('Type $agent-name to call a sub-agent.'));\n  console.log(chalk.gray('Type /exit or press Ctrl+C to exit.'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n    prompt: chalk.green('> ')\n  });\n\n  rl.prompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      rl.prompt();\n      return;\n    }\n\n    // Check for slash commands\n    if (isSlashCommand(input)) {\n      // 特殊处理 /thinking 命令\n      if (input.toLowerCase() === '/thinking') {\n        currentShowThinking = !currentShowThinking;\n        configManager.setShowThinking(currentShowThinking);\n        console.log('');\n        console.log(chalk.green(`✓ Thinking process display: ${currentShowThinking ? chalk.cyan('ON') : chalk.gray('OFF')}`));\n        console.log('');\n        rl.prompt();\n        return;\n      }\n\n      const shouldContinue = await executeSlashCommand(input, {\n        conversation,\n        rl,\n        configManager\n      });\n      \n      if (!shouldContinue) {\n        rl.close();\n        return;\n      }\n      \n      rl.prompt();\n      return;\n    }\n\n    // Check for agent calls (starting with $)\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider, options);\n      rl.prompt();\n      return;\n    }\n\n    // Check for shell commands (starting with !)\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      rl.prompt();\n      return;\n    }\n\n    // Check for file reference (starting with @)\n    const processedInput = await processFileReferences(input);\n\n    // Send to AI\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      \n      console.log(''); // New line after response\n      rl.prompt();\n    } catch (error) {\n      spinner.fail('Error');\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      console.log(chalk.red(errorMessage));\n      \n      // 提供更详细的错误信息\n      if (errorMessage.includes('400')) {\n        console.log(chalk.yellow('\\n可能的解决方案:'));\n        console.log(chalk.gray('  1. 检查API Key是否正确'));\n        console.log(chalk.gray('  2. 检查模型名称是否正确'));\n        console.log(chalk.gray('  3. 运行 \"oflow auth\" 重新配置'));\n      } else if (errorMessage.includes('401') || errorMessage.includes('Unauthorized')) {\n        console.log(chalk.yellow('\\n认证失败，请运行 \"oflow auth\" 重新配置'));\n      } else if (errorMessage.includes('429')) {\n        console.log(chalk.yellow('\\n请求过于频繁，请稍后再试'));\n      }\n      \n      rl.prompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n\n  // Handle Ctrl+C\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(\n  input: string, \n  provider: any,\n  options: CLIOptions\n): Promise<void> {\n  // Parse agent call: $agent-type \"task description\"\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid agent call format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('Available agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));\n    return;\n  }\n\n  const agentType = match[1] as AgentType;\n  const task = match[2].replace(/^[\"']|[\"']$/g, '');\n\n  if (!task) {\n    console.log(chalk.yellow('Please provide a task for the agent.'));\n    return;\n  }\n\n  try {\n    const agentFactory = new AgentFactory(provider, process.cwd());\n    const agent = agentFactory.createAgent(agentType);\n    console.log(chalk.cyan(`\\n🤖 Starting ${agentType} agent...`));\n    console.log(chalk.gray(`Task: ${task}\\n`));\n\n    const spinner = ora('Agent working...').start();\n    \n    const result = await agent.execute(task, (update) => {\n      spinner.stop();\n      process.stdout.write(update);\n      spinner.start();\n    });\n\n    spinner.stop();\n    \n    if (result.success) {\n      console.log(chalk.green('\\n\\n✓ Agent completed successfully'));\n      if (result.filesModified && result.filesModified.length > 0) {\n        console.log(chalk.gray('Files modified:'));\n        result.filesModified.forEach(f => console.log(chalk.gray(`  - ${f}`)));\n      }\n    } else {\n      console.log(chalk.red('\\n\\n✗ Agent encountered errors:'));\n      result.errors?.forEach(e => console.log(chalk.red(`  - ${e}`)));\n    }\n\n    if (result.output) {\n      console.log(chalk.gray('\\nOutput:'));\n      console.log(result.output);\n    }\n\n  } catch (error) {\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nexport async function runSingleCommand(prompt: string, options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {\n      // Ignore sandbox errors for single command\n    }\n  }\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const processedInput = await processFileReferences(prompt);\n  const spinner = ora('Processing...').start();\n\n  try {\n    await conversation.sendMessage(processedInput);\n    spinner.stop();\n    console.log('');\n  } catch (error) {\n    spinner.fail('Error');\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nasync function executeShellCommand(command: string, sandbox?: SandboxExecutor | null): Promise<void> {\n  const { spawn } = require('child_process');\n  \n  if (sandbox && sandbox['config']?.backend !== 'none') {\n    try {\n      const result = await sandbox.execute(command, process.cwd());\n      if (result.stdout) console.log(result.stdout);\n      if (result.stderr) console.error(result.stderr);\n      if (result.timedOut) console.log(chalk.yellow('Command timed out'));\n      return;\n    } catch (error) {\n      console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n      return;\n    }\n  }\n  \n  return new Promise((resolve) => {\n    const isWindows = process.platform === 'win32';\n    const shell = isWindows ? 'powershell.exe' : '/bin/bash';\n    const args = isWindows ? ['-NoProfile', '-Command', command] : ['-c', command];\n\n    const proc = spawn(shell, args, {\n      stdio: 'inherit',\n      cwd: process.cwd()\n    });\n\n    proc.on('close', () => {\n      resolve();\n    });\n\n    proc.on('error', (err: Error) => {\n      console.log(chalk.red(`Failed to execute command: ${err.message}`));\n      resolve();\n    });\n  });\n}\n\nasync function processFileReferences(input: string): Promise<string> {\n  const fileRefRegex = /@([^\\s]+)/g;\n  const matches = input.matchAll(fileRefRegex);\n  \n  let result = input;\n  const fs = require('fs');\n  const path = require('path');\n\n  for (const match of matches) {\n    const filePath = match[1];\n    try {\n      const content = fs.readFileSync(filePath, 'utf-8');\n      result = result.replace(match[0], `\\n[File: ${filePath}]\\n${content}\\n[End of file]\\n`);\n    } catch {\n      // File not found, keep original reference\n      console.log(chalk.yellow(`Warning: Could not read file ${filePath}`));\n    }\n  }\n\n  return result;\n}\n\nfunction getSystemPrompt(): string {\n  return `You are oflow CLI, an interactive CLI agent specializing in software engineering tasks.\n\nYour primary goal is to help users safely and efficiently complete programming tasks.\n\n# Core Capabilities\n- Read, write, and edit files\n- Execute shell commands\n- Search and analyze code\n- Web search and fetch content\n- Manage project structure\n- Launch specialized sub-agents\n\n# Tools Available\n- read_file: Read file contents\n- write_file: Write to files\n- list_directory: List directory contents\n- glob: Find files by pattern\n- search_file_content: Search within files\n- run_shell_command: Execute shell commands\n- web_search: Search the web\n- web_fetch: Fetch web content\n- replace: Replace text in files\n- image_read: Analyze images\n- pdf_extract: Extract content from PDFs\n- ask_user_question: Ask user for input\n- task: Launch sub-agents\n- save_memory: Save information for future sessions\n\n# Sub-Agents (use $agent-name to call)\n- general-purpose: Complex multi-step tasks\n- plan-agent: Planning and analysis\n- explore-agent: Codebase exploration\n- code-reviewer: Code review\n- frontend-tester: UI testing\n\n# Guidelines\n1. Be concise and helpful\n2. Always explain what you're doing before using tools\n3. Ask for clarification when needed\n4. Prefer editing existing files over creating new ones\n5. Use appropriate tools for each task\n6. Verify changes after making them\n7. Provide actionable suggestions\n\n# Important Rules\n- When you need to use tools, first explain what you're going to do\n- After using tools, summarize the results\n- If a tool call fails, explain what went wrong and suggest alternatives\n- Always provide clear, actionable responses\n\nCurrent working directory: ${process.cwd()}\n`;\n}\n"]}
|
|
471
|
+
//# 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 } 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;\n\nfunction drawStatusBar(model: string): 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  const statusLine1 = [\n    `${chalk.blue('Model:')} ${chalk.white(model)}`,\n    `${chalk.blue('Context:')} ${contextColor(contextPercent + '%')}`,\n    `${chalk.blue('Thinking:')} ${thinkingStatus}`\n  ].join('  |  ');\n  \n  const currentDir = process.cwd();\n  const dirDisplay = currentDir.length > terminalWidth - 10 \n    ? '...' + currentDir.slice(-(terminalWidth - 13))\n    : currentDir;\n  const statusLine2 = `${chalk.blue('Dir:')} ${chalk.gray(dirDisplay)}`;\n  \n  console.log('');\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 60))));\n  console.log(statusLine1);\n  console.log(statusLine2);\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 60))));\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  console.log('');\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  // Check for updates\n  const updateInfo = await checkForUpdates();\n  if (updateInfo.hasUpdate) {\n    console.log('');\n    console.log(chalk.yellow('New version available: ' + updateInfo.latestVersion));\n    console.log(chalk.yellow('Run /update to update'));\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  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n\n  if (model.includes('gpt-4') || model.includes('gpt-4o')) {\n    maxContextTokens = 128000;\n  } else if (model.includes('deepseek')) {\n    maxContextTokens = 64000;\n  } else {\n    maxContextTokens = 128000;\n  }\n\n  let provider;\n  try {\n    provider = createAIProvider(auth, model);\n  } catch (error) {\n    console.log(chalk.red('Failed to create AI provider: ' + (error instanceof Error ? error.message : String(error))));\n    return;\n  }\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: currentShowThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      sessionStats.toolCallsCount++;\n      console.log(chalk.cyan('\\nUsing 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  console.log(chalk.bold.blue('\\nWelcome to oflow CLI'));\n  console.log(chalk.gray('Type /help for commands, /exit to quit'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  const showPrompt = () => {\n    drawStatusBar(model);\n    rl.setPrompt(chalk.green('\\n> '));\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    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();\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    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider);\n      showPrompt();\n      return;\n    }\n\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      showPrompt();\n      return;\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('\\nStarting ' + agentType + ' agent...'));\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/commands/index.js
CHANGED
|
@@ -87,6 +87,10 @@ async function executeSlashCommand(input, context) {
|
|
|
87
87
|
return reviewCode(context);
|
|
88
88
|
case '/thinking':
|
|
89
89
|
return toggleThinking(context);
|
|
90
|
+
case '/summary':
|
|
91
|
+
return true; // Handled in cli.ts
|
|
92
|
+
case '/update':
|
|
93
|
+
return true; // Handled in cli.ts
|
|
90
94
|
default:
|
|
91
95
|
console.log(chalk_1.default.yellow(`Unknown command: ${command}`));
|
|
92
96
|
console.log(chalk_1.default.gray('Type /help for available commands.'));
|
|
@@ -104,6 +108,8 @@ function showHelp() {
|
|
|
104
108
|
{ cmd: '/init', desc: 'Analyze and initialize current project' },
|
|
105
109
|
{ cmd: '/model [name]', desc: 'Show or set the current model' },
|
|
106
110
|
{ cmd: '/thinking', desc: 'Toggle thinking process display (ON/OFF)' },
|
|
111
|
+
{ cmd: '/summary', desc: 'Show task summary for current session' },
|
|
112
|
+
{ cmd: '/update', desc: 'Update oflow CLI to latest version' },
|
|
107
113
|
{ cmd: '/config', desc: 'Show current configuration' },
|
|
108
114
|
{ cmd: '/reset', desc: 'Reset configuration to defaults' },
|
|
109
115
|
{ cmd: '/history', desc: 'Show conversation history' },
|
|
@@ -464,4 +470,4 @@ function toggleThinking(context) {
|
|
|
464
470
|
}
|
|
465
471
|
return true;
|
|
466
472
|
}
|
|
467
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { Conversation, ConfigManager, AgentFactory, AGENT_DEFINITIONS, createSandboxExecutor } from '@oflow-ai/core';\nimport * as readline from 'readline';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nexport interface CommandContext {\n  conversation: Conversation;\n  rl: readline.Interface;\n  configManager: ConfigManager;\n}\n\nexport function isSlashCommand(input: string): boolean {\n  return input.startsWith('/');\n}\n\nexport async function executeSlashCommand(\n  input: string,\n  context: CommandContext\n): Promise<boolean> {\n  const [command, ...args] = input.split(' ');\n  const argString = args.join(' ');\n\n  switch (command.toLowerCase()) {\n    case '/help':\n      return showHelp();\n    \n    case '/exit':\n    case '/quit':\n    case '/q':\n      return false;\n    \n    case '/clear':\n      return clearConversation(context);\n    \n    case '/init':\n      return initProject(context);\n    \n    case '/model':\n      return showOrSetModel(argString, context);\n    \n    case '/config':\n      return showConfig(context);\n    \n    case '/reset':\n      return resetConfig(context);\n    \n    case '/history':\n      return showHistory(context);\n    \n    case '/tools':\n      return showTools();\n    \n    case '/version':\n      return showVersion();\n    \n    case '/agents':\n      return showAgents();\n    \n    case '/sandbox':\n      return showSandboxInfo();\n    \n    case '/skills':\n      return showSkills(argString);\n    \n    case '/mcp':\n      return showMCPInfo();\n    \n    case '/memory':\n      return showMemory();\n    \n    case '/commit':\n      return generateCommit(context);\n    \n    case '/review':\n      return reviewCode(context);\n    \n    case '/thinking':\n      return toggleThinking(context);\n    \n    default:\n      console.log(chalk.yellow(`Unknown command: ${command}`));\n      console.log(chalk.gray('Type /help for available commands.'));\n      return true;\n  }\n}\n\nfunction showHelp(): boolean {\n  console.log('');\n  console.log(chalk.bold('Available Commands:'));\n  console.log('');\n  \n  const commands = [\n    { cmd: '/help', desc: 'Show this help message' },\n    { cmd: '/exit, /quit, /q', desc: 'Exit oflow CLI' },\n    { cmd: '/clear', desc: 'Clear conversation history' },\n    { cmd: '/init', desc: 'Analyze and initialize current project' },\n    { cmd: '/model [name]', desc: 'Show or set the current model' },\n    { cmd: '/thinking', desc: 'Toggle thinking process display (ON/OFF)' },\n    { cmd: '/config', desc: 'Show current configuration' },\n    { cmd: '/reset', desc: 'Reset configuration to defaults' },\n    { cmd: '/history', desc: 'Show conversation history' },\n    { cmd: '/tools', desc: 'List available tools' },\n    { cmd: '/agents', desc: 'List available sub-agents' },\n    { cmd: '/sandbox', desc: 'Show sandbox status' },\n    { cmd: '/skills [list|refresh]', desc: 'Manage skills' },\n    { cmd: '/mcp', desc: 'Show MCP server status' },\n    { cmd: '/memory', desc: 'Show saved memories' },\n    { cmd: '/commit', desc: 'Generate commit message' },\n    { cmd: '/review', desc: 'Review recent code changes' },\n    { cmd: '/version', desc: 'Show version information' }\n  ];\n\n  commands.forEach(({ cmd, desc }) => {\n    console.log(`  ${chalk.cyan(cmd.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  console.log(chalk.bold('Special Syntax:'));\n  console.log(`  ${chalk.cyan('!command')}    ${chalk.gray('Execute a shell command')}`);\n  console.log(`  ${chalk.cyan('@filepath')}   ${chalk.gray('Reference a file in your message')}`);\n  console.log(`  ${chalk.cyan('$agent')}      ${chalk.gray('Call a sub-agent (e.g., $explore-agent \"task\")')}`);\n  console.log('');\n  \n  return true;\n}\n\nfunction clearConversation(context: CommandContext): boolean {\n  context.conversation.clear();\n  console.log(chalk.green('✓ Conversation history cleared.'));\n  return true;\n}\n\nasync function initProject(context: CommandContext): Promise<boolean> {\n  const workingDir = process.cwd();\n  const projectName = path.basename(workingDir);\n  \n  console.log(chalk.cyan(`\\nAnalyzing project: ${projectName}\\n`));\n  \n  // Check for common project files\n  const checks = [\n    { file: 'package.json', type: 'Node.js' },\n    { file: 'tsconfig.json', type: 'TypeScript' },\n    { file: 'pyproject.toml', type: 'Python (modern)' },\n    { file: 'requirements.txt', type: 'Python' },\n    { file: 'Cargo.toml', type: 'Rust' },\n    { file: 'go.mod', type: 'Go' },\n    { file: 'pom.xml', type: 'Java (Maven)' },\n    { file: 'build.gradle', type: 'Java (Gradle)' },\n    { file: '.git', type: 'Git repository' }\n  ];\n\n  const detected: string[] = [];\n  \n  for (const check of checks) {\n    const filePath = path.join(workingDir, check.file);\n    if (fs.existsSync(filePath)) {\n      detected.push(check.type);\n    }\n  }\n\n  if (detected.length > 0) {\n    console.log(chalk.bold('Detected project types:'));\n    detected.forEach(t => console.log(`  • ${t}`));\n  } else {\n    console.log(chalk.yellow('No recognized project type detected.'));\n  }\n\n  // List top-level files and directories\n  console.log(chalk.bold('\\nProject structure:'));\n  const entries = fs.readdirSync(workingDir, { withFileTypes: true });\n  entries.slice(0, 20).forEach(entry => {\n    const prefix = entry.isDirectory() ? '📁 ' : '📄 ';\n    console.log(`  ${prefix}${entry.name}`);\n  });\n\n  if (entries.length > 20) {\n    console.log(chalk.gray(`  ... and ${entries.length - 20} more items`));\n  }\n\n  console.log('');\n\n  // Add init context to conversation\n  const initMessage = `Please analyze the current project structure and provide:\n1. A brief overview of the project type and purpose\n2. Key files and their roles\n3. Suggestions for improvements or best practices\n\nWorking directory: ${workingDir}\nDetected types: ${detected.join(', ')}`;\n\n  try {\n    await context.conversation.sendMessage(initMessage);\n  } catch (error) {\n    console.log(chalk.red('Error during analysis.'));\n  }\n\n  return true;\n}\n\nfunction showOrSetModel(modelName: string, context: CommandContext): boolean {\n  if (modelName) {\n    context.configManager.setDefaultModel(modelName);\n    console.log(chalk.green(`✓ Model set to: ${modelName}`));\n  } else {\n    const currentModel = context.configManager.getDefaultModel();\n    console.log(chalk.cyan(`Current model: ${currentModel}`));\n    console.log('');\n    console.log('Available models:');\n    const models = ['gpt-4o', 'gpt-4o-mini', 'gpt-4-turbo', 'gpt-3.5-turbo', 'o1-preview', 'o1-mini'];\n    models.forEach(m => {\n      if (m === currentModel) {\n        console.log(chalk.green(`  * ${m} (current)`));\n      } else {\n        console.log(`    ${m}`);\n      }\n    });\n  }\n  return true;\n}\n\nfunction showConfig(context: CommandContext): boolean {\n  const config = context.configManager.getAll();\n  console.log(chalk.bold('\\nCurrent Configuration:'));\n  console.log(JSON.stringify(config, null, 2));\n  console.log('');\n  console.log(chalk.gray(`Config file: ${context.configManager.getConfigPath()}`));\n  return true;\n}\n\nfunction resetConfig(context: CommandContext): boolean {\n  context.configManager.clear();\n  console.log(chalk.green('✓ Configuration reset to defaults.'));\n  console.log(chalk.yellow('You will need to run `oflow auth` to reconfigure authentication.'));\n  return false; // Exit to force re-auth\n}\n\nfunction showHistory(context: CommandContext): boolean {\n  const messages = context.conversation.getMessages();\n  \n  if (messages.length === 0) {\n    console.log(chalk.gray('No conversation history.'));\n    return true;\n  }\n\n  console.log(chalk.bold('\\nConversation History:'));\n  console.log('');\n  \n  messages.forEach((msg, index) => {\n    if (msg.role === 'system') return;\n    \n    const roleColors: Record<string, chalk.Chalk> = {\n      user: chalk.green,\n      assistant: chalk.blue,\n      tool: chalk.gray\n    };\n    \n    const color = roleColors[msg.role] || chalk.white;\n    const preview = typeof msg.content === 'string' \n      ? msg.content.substring(0, 100) + (msg.content.length > 100 ? '...' : '')\n      : '[complex content]';\n    \n    console.log(`${index}. ${color(msg.role)}: ${preview}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showTools(): boolean {\n  console.log(chalk.bold('\\nAvailable Tools:'));\n  console.log('');\n  \n  const tools = [\n    { name: 'read_file', desc: 'Read file contents' },\n    { name: 'write_file', desc: 'Write to files' },\n    { name: 'list_directory', desc: 'List directory contents' },\n    { name: 'glob', desc: 'Find files by pattern' },\n    { name: 'search_file_content', desc: 'Search within files' },\n    { name: 'run_shell_command', desc: 'Execute shell commands' },\n    { name: 'web_search', desc: 'Search the web' },\n    { name: 'web_fetch', desc: 'Fetch web content' },\n    { name: 'replace', desc: 'Replace text in files' },\n    { name: 'image_read', desc: 'Analyze images with VL models' },\n    { name: 'pdf_extract', desc: 'Extract content from PDFs' },\n    { name: 'ask_user_question', desc: 'Ask user for input' },\n    { name: 'task', desc: 'Launch sub-agents' },\n    { name: 'save_memory', desc: 'Save information for future' }\n  ];\n\n  tools.forEach(({ name, desc }) => {\n    console.log(`  ${chalk.cyan(name.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showVersion(): boolean {\n  const packageJsonPath = path.join(__dirname, '..', '..', 'package.json');\n  try {\n    const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n    console.log(chalk.cyan(`oflow CLI v${packageJson.version}`));\n  } catch {\n    console.log(chalk.cyan('oflow CLI (version unknown)'));\n  }\n  return true;\n}\n\nfunction showAgents(): boolean {\n  console.log(chalk.bold('\\nAvailable Sub-Agents:'));\n  console.log('');\n  \n  const agents = Object.values(AGENT_DEFINITIONS);\n  agents.forEach(agent => {\n    console.log(`  ${chalk.cyan(`$${agent.type}`)}`);\n    console.log(`    ${chalk.gray(agent.description)}`);\n    console.log(`    Tools: ${agent.allowedTools === '*' ? 'all' : agent.allowedTools.join(', ')}`);\n    console.log('');\n  });\n\n  console.log(chalk.gray('Usage: $agent-type \"your task here\"'));\n  console.log('');\n  return true;\n}\n\nasync function showSandboxInfo(): Promise<boolean> {\n  console.log(chalk.bold('\\nSandbox Status:'));\n  console.log('');\n  \n  try {\n    const backend = await createSandboxExecutor();\n    console.log(`  Backend: ${chalk.cyan(backend ? 'available' : 'unavailable')}`);\n    console.log(`  Mode: ${chalk.cyan(backend ? backend['config']?.backend || 'none' : 'none')}`);\n  } catch {\n    console.log('  Backend: ' + chalk.yellow('not available'));\n  }\n\n  console.log('');\n  console.log(chalk.gray('Enable with: oflow --sandbox'));\n  console.log('');\n  return true;\n}\n\nfunction showSkills(subCommand: string): boolean {\n  console.log(chalk.bold('\\nSkills System:'));\n  console.log('');\n  \n  if (subCommand === 'list' || !subCommand) {\n    console.log('Skills allow extending oflow with specialized capabilities.');\n    console.log('');\n    console.log(chalk.bold('Available Skill Categories:'));\n    console.log('  • Document Processing (pdf, docx, pptx)');\n    console.log('  • Creative Tools (algorithmic-art, canvas-design)');\n    console.log('  • Development Tools (mcp-builder, skill-creator)');\n    console.log('');\n    console.log(chalk.gray('Skills are stored in:'));\n    console.log(chalk.gray('  Global: ~/.oflow/skills/'));\n    console.log(chalk.gray('  Project: ./.oflow/skills/'));\n  } else if (subCommand === 'refresh') {\n    console.log(chalk.green('✓ Skills registry refreshed.'));\n  } else {\n    console.log(chalk.yellow(`Unknown subcommand: ${subCommand}`));\n    console.log(chalk.gray('Usage: /skills [list|refresh]'));\n  }\n\n  console.log('');\n  return true;\n}\n\nfunction showMCPInfo(): boolean {\n  console.log(chalk.bold('\\nMCP (Model Context Protocol) Status:'));\n  console.log('');\n  \n  console.log('MCP allows extending oflow with external tool servers.');\n  console.log('');\n  console.log(chalk.bold('Configuration:'));\n  console.log(chalk.gray('Add servers to ~/.oflow/settings.json:'));\n  console.log('');\n  console.log(chalk.cyan(`{\n  \"mcpServers\": {\n    \"my_server\": {\n      \"command\": \"npx\",\n      \"args\": [\"-y\", \"my-mcp-server\"]\n    }\n  }\n}`));\n  console.log('');\n  return true;\n}\n\nfunction showMemory(): boolean {\n  console.log(chalk.bold('\\nSaved Memories:'));\n  console.log('');\n  \n  const homeDir = process.env.HOME || process.env.USERPROFILE || '';\n  const memoryFile = path.join(homeDir, '.oflow', 'memory.json');\n  \n  try {\n    if (fs.existsSync(memoryFile)) {\n      const content = fs.readFileSync(memoryFile, 'utf-8');\n      const memories = JSON.parse(content);\n      \n      if (memories.length === 0) {\n        console.log(chalk.gray('No memories saved.'));\n      } else {\n        memories.forEach((m: { fact: string; createdAt: string }, i: number) => {\n          console.log(`${i + 1}. ${chalk.white(m.fact)}`);\n          console.log(`   ${chalk.gray(new Date(m.createdAt).toLocaleString())}`);\n          console.log('');\n        });\n      }\n    } else {\n      console.log(chalk.gray('No memories saved.'));\n    }\n  } catch {\n    console.log(chalk.yellow('Could not read memory file.'));\n  }\n\n  console.log('');\n  return true;\n}\n\nasync function generateCommit(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nGenerating commit message...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const commitPrompt = `Please analyze the current git repository state and generate an appropriate commit message.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git status' to see changed files\n2. Run 'git diff --staged' to see staged changes (if any)\n3. Run 'git diff' to see unstaged changes\n4. Generate a clear, concise commit message following conventional commit format\n\nProvide the commit message as your response.`;\n\n  try {\n    await context.conversation.sendMessage(commitPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error generating commit message.'));\n  }\n\n  return true;\n}\n\nasync function reviewCode(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nReviewing recent changes...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const reviewPrompt = `Please review the recent code changes in this repository.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git log -5 --oneline' to see recent commits\n2. Run 'git diff HEAD~1 HEAD' to see the latest changes\n3. Review the code for:\n   - Potential bugs\n   - Security vulnerabilities\n   - Code style issues\n   - Performance concerns\n   - Best practice violations\n\nProvide a structured review with specific findings and suggestions.`;\n\n  try {\n    await context.conversation.sendMessage(reviewPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error during code review.'));\n  }\n\n  return true;\n}\n\nfunction toggleThinking(context: CommandContext): boolean {\n  const newValue = context.configManager.toggleShowThinking();\n  console.log('');\n  console.log(chalk.green(`✓ Thinking process display: ${newValue ? chalk.cyan('ON') : chalk.gray('OFF')}`));\n  console.log('');\n  \n  if (newValue) {\n    console.log(chalk.gray('The AI will now show its thinking/reasoning process (for supported models like DeepSeek Reasoner).'));\n  } else {\n    console.log(chalk.gray('The AI thinking process is now hidden.'));\n  }\n  \n  return true;\n}\n"]}
|
|
473
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { Conversation, ConfigManager, AgentFactory, AGENT_DEFINITIONS, createSandboxExecutor } from '@oflow-ai/core';\nimport * as readline from 'readline';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nexport interface CommandContext {\n  conversation: Conversation;\n  rl: readline.Interface;\n  configManager: ConfigManager;\n}\n\nexport function isSlashCommand(input: string): boolean {\n  return input.startsWith('/');\n}\n\nexport async function executeSlashCommand(\n  input: string,\n  context: CommandContext\n): Promise<boolean> {\n  const [command, ...args] = input.split(' ');\n  const argString = args.join(' ');\n\n  switch (command.toLowerCase()) {\n    case '/help':\n      return showHelp();\n    \n    case '/exit':\n    case '/quit':\n    case '/q':\n      return false;\n    \n    case '/clear':\n      return clearConversation(context);\n    \n    case '/init':\n      return initProject(context);\n    \n    case '/model':\n      return showOrSetModel(argString, context);\n    \n    case '/config':\n      return showConfig(context);\n    \n    case '/reset':\n      return resetConfig(context);\n    \n    case '/history':\n      return showHistory(context);\n    \n    case '/tools':\n      return showTools();\n    \n    case '/version':\n      return showVersion();\n    \n    case '/agents':\n      return showAgents();\n    \n    case '/sandbox':\n      return showSandboxInfo();\n    \n    case '/skills':\n      return showSkills(argString);\n    \n    case '/mcp':\n      return showMCPInfo();\n    \n    case '/memory':\n      return showMemory();\n    \n    case '/commit':\n      return generateCommit(context);\n    \n    case '/review':\n      return reviewCode(context);\n    \n    case '/thinking':\n      return toggleThinking(context);\n    \n    case '/summary':\n      return true; // Handled in cli.ts\n    \n    case '/update':\n      return true; // Handled in cli.ts\n    \n    default:\n      console.log(chalk.yellow(`Unknown command: ${command}`));\n      console.log(chalk.gray('Type /help for available commands.'));\n      return true;\n  }\n}\n\nfunction showHelp(): boolean {\n  console.log('');\n  console.log(chalk.bold('Available Commands:'));\n  console.log('');\n  \n  const commands = [\n    { cmd: '/help', desc: 'Show this help message' },\n    { cmd: '/exit, /quit, /q', desc: 'Exit oflow CLI' },\n    { cmd: '/clear', desc: 'Clear conversation history' },\n    { cmd: '/init', desc: 'Analyze and initialize current project' },\n    { cmd: '/model [name]', desc: 'Show or set the current model' },\n    { cmd: '/thinking', desc: 'Toggle thinking process display (ON/OFF)' },\n    { cmd: '/summary', desc: 'Show task summary for current session' },\n    { cmd: '/update', desc: 'Update oflow CLI to latest version' },\n    { cmd: '/config', desc: 'Show current configuration' },\n    { cmd: '/reset', desc: 'Reset configuration to defaults' },\n    { cmd: '/history', desc: 'Show conversation history' },\n    { cmd: '/tools', desc: 'List available tools' },\n    { cmd: '/agents', desc: 'List available sub-agents' },\n    { cmd: '/sandbox', desc: 'Show sandbox status' },\n    { cmd: '/skills [list|refresh]', desc: 'Manage skills' },\n    { cmd: '/mcp', desc: 'Show MCP server status' },\n    { cmd: '/memory', desc: 'Show saved memories' },\n    { cmd: '/commit', desc: 'Generate commit message' },\n    { cmd: '/review', desc: 'Review recent code changes' },\n    { cmd: '/version', desc: 'Show version information' }\n  ];\n\n  commands.forEach(({ cmd, desc }) => {\n    console.log(`  ${chalk.cyan(cmd.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  console.log(chalk.bold('Special Syntax:'));\n  console.log(`  ${chalk.cyan('!command')}    ${chalk.gray('Execute a shell command')}`);\n  console.log(`  ${chalk.cyan('@filepath')}   ${chalk.gray('Reference a file in your message')}`);\n  console.log(`  ${chalk.cyan('$agent')}      ${chalk.gray('Call a sub-agent (e.g., $explore-agent \"task\")')}`);\n  console.log('');\n  \n  return true;\n}\n\nfunction clearConversation(context: CommandContext): boolean {\n  context.conversation.clear();\n  console.log(chalk.green('✓ Conversation history cleared.'));\n  return true;\n}\n\nasync function initProject(context: CommandContext): Promise<boolean> {\n  const workingDir = process.cwd();\n  const projectName = path.basename(workingDir);\n  \n  console.log(chalk.cyan(`\\nAnalyzing project: ${projectName}\\n`));\n  \n  // Check for common project files\n  const checks = [\n    { file: 'package.json', type: 'Node.js' },\n    { file: 'tsconfig.json', type: 'TypeScript' },\n    { file: 'pyproject.toml', type: 'Python (modern)' },\n    { file: 'requirements.txt', type: 'Python' },\n    { file: 'Cargo.toml', type: 'Rust' },\n    { file: 'go.mod', type: 'Go' },\n    { file: 'pom.xml', type: 'Java (Maven)' },\n    { file: 'build.gradle', type: 'Java (Gradle)' },\n    { file: '.git', type: 'Git repository' }\n  ];\n\n  const detected: string[] = [];\n  \n  for (const check of checks) {\n    const filePath = path.join(workingDir, check.file);\n    if (fs.existsSync(filePath)) {\n      detected.push(check.type);\n    }\n  }\n\n  if (detected.length > 0) {\n    console.log(chalk.bold('Detected project types:'));\n    detected.forEach(t => console.log(`  • ${t}`));\n  } else {\n    console.log(chalk.yellow('No recognized project type detected.'));\n  }\n\n  // List top-level files and directories\n  console.log(chalk.bold('\\nProject structure:'));\n  const entries = fs.readdirSync(workingDir, { withFileTypes: true });\n  entries.slice(0, 20).forEach(entry => {\n    const prefix = entry.isDirectory() ? '📁 ' : '📄 ';\n    console.log(`  ${prefix}${entry.name}`);\n  });\n\n  if (entries.length > 20) {\n    console.log(chalk.gray(`  ... and ${entries.length - 20} more items`));\n  }\n\n  console.log('');\n\n  // Add init context to conversation\n  const initMessage = `Please analyze the current project structure and provide:\n1. A brief overview of the project type and purpose\n2. Key files and their roles\n3. Suggestions for improvements or best practices\n\nWorking directory: ${workingDir}\nDetected types: ${detected.join(', ')}`;\n\n  try {\n    await context.conversation.sendMessage(initMessage);\n  } catch (error) {\n    console.log(chalk.red('Error during analysis.'));\n  }\n\n  return true;\n}\n\nfunction showOrSetModel(modelName: string, context: CommandContext): boolean {\n  if (modelName) {\n    context.configManager.setDefaultModel(modelName);\n    console.log(chalk.green(`✓ Model set to: ${modelName}`));\n  } else {\n    const currentModel = context.configManager.getDefaultModel();\n    console.log(chalk.cyan(`Current model: ${currentModel}`));\n    console.log('');\n    console.log('Available models:');\n    const models = ['gpt-4o', 'gpt-4o-mini', 'gpt-4-turbo', 'gpt-3.5-turbo', 'o1-preview', 'o1-mini'];\n    models.forEach(m => {\n      if (m === currentModel) {\n        console.log(chalk.green(`  * ${m} (current)`));\n      } else {\n        console.log(`    ${m}`);\n      }\n    });\n  }\n  return true;\n}\n\nfunction showConfig(context: CommandContext): boolean {\n  const config = context.configManager.getAll();\n  console.log(chalk.bold('\\nCurrent Configuration:'));\n  console.log(JSON.stringify(config, null, 2));\n  console.log('');\n  console.log(chalk.gray(`Config file: ${context.configManager.getConfigPath()}`));\n  return true;\n}\n\nfunction resetConfig(context: CommandContext): boolean {\n  context.configManager.clear();\n  console.log(chalk.green('✓ Configuration reset to defaults.'));\n  console.log(chalk.yellow('You will need to run `oflow auth` to reconfigure authentication.'));\n  return false; // Exit to force re-auth\n}\n\nfunction showHistory(context: CommandContext): boolean {\n  const messages = context.conversation.getMessages();\n  \n  if (messages.length === 0) {\n    console.log(chalk.gray('No conversation history.'));\n    return true;\n  }\n\n  console.log(chalk.bold('\\nConversation History:'));\n  console.log('');\n  \n  messages.forEach((msg, index) => {\n    if (msg.role === 'system') return;\n    \n    const roleColors: Record<string, chalk.Chalk> = {\n      user: chalk.green,\n      assistant: chalk.blue,\n      tool: chalk.gray\n    };\n    \n    const color = roleColors[msg.role] || chalk.white;\n    const preview = typeof msg.content === 'string' \n      ? msg.content.substring(0, 100) + (msg.content.length > 100 ? '...' : '')\n      : '[complex content]';\n    \n    console.log(`${index}. ${color(msg.role)}: ${preview}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showTools(): boolean {\n  console.log(chalk.bold('\\nAvailable Tools:'));\n  console.log('');\n  \n  const tools = [\n    { name: 'read_file', desc: 'Read file contents' },\n    { name: 'write_file', desc: 'Write to files' },\n    { name: 'list_directory', desc: 'List directory contents' },\n    { name: 'glob', desc: 'Find files by pattern' },\n    { name: 'search_file_content', desc: 'Search within files' },\n    { name: 'run_shell_command', desc: 'Execute shell commands' },\n    { name: 'web_search', desc: 'Search the web' },\n    { name: 'web_fetch', desc: 'Fetch web content' },\n    { name: 'replace', desc: 'Replace text in files' },\n    { name: 'image_read', desc: 'Analyze images with VL models' },\n    { name: 'pdf_extract', desc: 'Extract content from PDFs' },\n    { name: 'ask_user_question', desc: 'Ask user for input' },\n    { name: 'task', desc: 'Launch sub-agents' },\n    { name: 'save_memory', desc: 'Save information for future' }\n  ];\n\n  tools.forEach(({ name, desc }) => {\n    console.log(`  ${chalk.cyan(name.padEnd(20))} ${chalk.gray(desc)}`);\n  });\n\n  console.log('');\n  return true;\n}\n\nfunction showVersion(): boolean {\n  const packageJsonPath = path.join(__dirname, '..', '..', 'package.json');\n  try {\n    const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));\n    console.log(chalk.cyan(`oflow CLI v${packageJson.version}`));\n  } catch {\n    console.log(chalk.cyan('oflow CLI (version unknown)'));\n  }\n  return true;\n}\n\nfunction showAgents(): boolean {\n  console.log(chalk.bold('\\nAvailable Sub-Agents:'));\n  console.log('');\n  \n  const agents = Object.values(AGENT_DEFINITIONS);\n  agents.forEach(agent => {\n    console.log(`  ${chalk.cyan(`$${agent.type}`)}`);\n    console.log(`    ${chalk.gray(agent.description)}`);\n    console.log(`    Tools: ${agent.allowedTools === '*' ? 'all' : agent.allowedTools.join(', ')}`);\n    console.log('');\n  });\n\n  console.log(chalk.gray('Usage: $agent-type \"your task here\"'));\n  console.log('');\n  return true;\n}\n\nasync function showSandboxInfo(): Promise<boolean> {\n  console.log(chalk.bold('\\nSandbox Status:'));\n  console.log('');\n  \n  try {\n    const backend = await createSandboxExecutor();\n    console.log(`  Backend: ${chalk.cyan(backend ? 'available' : 'unavailable')}`);\n    console.log(`  Mode: ${chalk.cyan(backend ? backend['config']?.backend || 'none' : 'none')}`);\n  } catch {\n    console.log('  Backend: ' + chalk.yellow('not available'));\n  }\n\n  console.log('');\n  console.log(chalk.gray('Enable with: oflow --sandbox'));\n  console.log('');\n  return true;\n}\n\nfunction showSkills(subCommand: string): boolean {\n  console.log(chalk.bold('\\nSkills System:'));\n  console.log('');\n  \n  if (subCommand === 'list' || !subCommand) {\n    console.log('Skills allow extending oflow with specialized capabilities.');\n    console.log('');\n    console.log(chalk.bold('Available Skill Categories:'));\n    console.log('  • Document Processing (pdf, docx, pptx)');\n    console.log('  • Creative Tools (algorithmic-art, canvas-design)');\n    console.log('  • Development Tools (mcp-builder, skill-creator)');\n    console.log('');\n    console.log(chalk.gray('Skills are stored in:'));\n    console.log(chalk.gray('  Global: ~/.oflow/skills/'));\n    console.log(chalk.gray('  Project: ./.oflow/skills/'));\n  } else if (subCommand === 'refresh') {\n    console.log(chalk.green('✓ Skills registry refreshed.'));\n  } else {\n    console.log(chalk.yellow(`Unknown subcommand: ${subCommand}`));\n    console.log(chalk.gray('Usage: /skills [list|refresh]'));\n  }\n\n  console.log('');\n  return true;\n}\n\nfunction showMCPInfo(): boolean {\n  console.log(chalk.bold('\\nMCP (Model Context Protocol) Status:'));\n  console.log('');\n  \n  console.log('MCP allows extending oflow with external tool servers.');\n  console.log('');\n  console.log(chalk.bold('Configuration:'));\n  console.log(chalk.gray('Add servers to ~/.oflow/settings.json:'));\n  console.log('');\n  console.log(chalk.cyan(`{\n  \"mcpServers\": {\n    \"my_server\": {\n      \"command\": \"npx\",\n      \"args\": [\"-y\", \"my-mcp-server\"]\n    }\n  }\n}`));\n  console.log('');\n  return true;\n}\n\nfunction showMemory(): boolean {\n  console.log(chalk.bold('\\nSaved Memories:'));\n  console.log('');\n  \n  const homeDir = process.env.HOME || process.env.USERPROFILE || '';\n  const memoryFile = path.join(homeDir, '.oflow', 'memory.json');\n  \n  try {\n    if (fs.existsSync(memoryFile)) {\n      const content = fs.readFileSync(memoryFile, 'utf-8');\n      const memories = JSON.parse(content);\n      \n      if (memories.length === 0) {\n        console.log(chalk.gray('No memories saved.'));\n      } else {\n        memories.forEach((m: { fact: string; createdAt: string }, i: number) => {\n          console.log(`${i + 1}. ${chalk.white(m.fact)}`);\n          console.log(`   ${chalk.gray(new Date(m.createdAt).toLocaleString())}`);\n          console.log('');\n        });\n      }\n    } else {\n      console.log(chalk.gray('No memories saved.'));\n    }\n  } catch {\n    console.log(chalk.yellow('Could not read memory file.'));\n  }\n\n  console.log('');\n  return true;\n}\n\nasync function generateCommit(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nGenerating commit message...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const commitPrompt = `Please analyze the current git repository state and generate an appropriate commit message.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git status' to see changed files\n2. Run 'git diff --staged' to see staged changes (if any)\n3. Run 'git diff' to see unstaged changes\n4. Generate a clear, concise commit message following conventional commit format\n\nProvide the commit message as your response.`;\n\n  try {\n    await context.conversation.sendMessage(commitPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error generating commit message.'));\n  }\n\n  return true;\n}\n\nasync function reviewCode(context: CommandContext): Promise<boolean> {\n  console.log(chalk.cyan('\\nReviewing recent changes...'));\n  console.log('');\n  \n  // 检查是否是git仓库\n  const gitDir = path.join(process.cwd(), '.git');\n  if (!fs.existsSync(gitDir)) {\n    console.log(chalk.yellow('Not a git repository.'));\n    return true;\n  }\n\n  const reviewPrompt = `Please review the recent code changes in this repository.\n\nWorking directory: ${process.cwd()}\n\nSteps:\n1. Run 'git log -5 --oneline' to see recent commits\n2. Run 'git diff HEAD~1 HEAD' to see the latest changes\n3. Review the code for:\n   - Potential bugs\n   - Security vulnerabilities\n   - Code style issues\n   - Performance concerns\n   - Best practice violations\n\nProvide a structured review with specific findings and suggestions.`;\n\n  try {\n    await context.conversation.sendMessage(reviewPrompt);\n  } catch (error) {\n    console.log(chalk.red('Error during code review.'));\n  }\n\n  return true;\n}\n\nfunction toggleThinking(context: CommandContext): boolean {\n  const newValue = context.configManager.toggleShowThinking();\n  console.log('');\n  console.log(chalk.green(`✓ Thinking process display: ${newValue ? chalk.cyan('ON') : chalk.gray('OFF')}`));\n  console.log('');\n  \n  if (newValue) {\n    console.log(chalk.gray('The AI will now show its thinking/reasoning process (for supported models like DeepSeek Reasoner).'));\n  } else {\n    console.log(chalk.gray('The AI thinking process is now hidden.'));\n  }\n  \n  return true;\n}\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
interface UpdateInfo {
|
|
2
|
+
hasUpdate: boolean;
|
|
3
|
+
currentVersion: string;
|
|
4
|
+
latestVersion: string;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* 检查是否有更新
|
|
8
|
+
*/
|
|
9
|
+
export declare function checkForUpdates(): Promise<UpdateInfo>;
|
|
10
|
+
/**
|
|
11
|
+
* 执行更新
|
|
12
|
+
*/
|
|
13
|
+
export declare function performUpdate(): Promise<{
|
|
14
|
+
success: boolean;
|
|
15
|
+
message: string;
|
|
16
|
+
}>;
|
|
17
|
+
export {};
|
package/dist/updater.js
ADDED
|
@@ -0,0 +1,167 @@
|
|
|
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.checkForUpdates = checkForUpdates;
|
|
7
|
+
exports.performUpdate = performUpdate;
|
|
8
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
9
|
+
const child_process_1 = require("child_process");
|
|
10
|
+
const util_1 = require("util");
|
|
11
|
+
const execAsync = (0, util_1.promisify)(child_process_1.exec);
|
|
12
|
+
const PACKAGE_NAME = '@oflow-ai/oflow-cli';
|
|
13
|
+
const NPM_REGISTRY = 'https://registry.npmjs.org';
|
|
14
|
+
/**
|
|
15
|
+
* 获取当前安装的版本
|
|
16
|
+
*/
|
|
17
|
+
async function getCurrentVersion() {
|
|
18
|
+
try {
|
|
19
|
+
const packageJson = require('../../package.json');
|
|
20
|
+
return packageJson.version;
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return '0.0.0';
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 从npm获取最新版本
|
|
28
|
+
*/
|
|
29
|
+
async function getLatestVersion() {
|
|
30
|
+
try {
|
|
31
|
+
const { stdout } = await execAsync(`npm view ${PACKAGE_NAME} version`, {
|
|
32
|
+
timeout: 10000
|
|
33
|
+
});
|
|
34
|
+
return stdout.trim();
|
|
35
|
+
}
|
|
36
|
+
catch {
|
|
37
|
+
// 如果npm命令失败,尝试直接访问registry
|
|
38
|
+
try {
|
|
39
|
+
const https = require('https');
|
|
40
|
+
return new Promise((resolve, reject) => {
|
|
41
|
+
https.get(`${NPM_REGISTRY}/${PACKAGE_NAME.replace('/', '%2F')}/latest`, (res) => {
|
|
42
|
+
let data = '';
|
|
43
|
+
res.on('data', (chunk) => { data += chunk; });
|
|
44
|
+
res.on('end', () => {
|
|
45
|
+
try {
|
|
46
|
+
const json = JSON.parse(data);
|
|
47
|
+
resolve(json.version);
|
|
48
|
+
}
|
|
49
|
+
catch {
|
|
50
|
+
reject(new Error('Failed to parse response'));
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}).on('error', reject);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return '0.0.0';
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* 比较版本号
|
|
63
|
+
*/
|
|
64
|
+
function compareVersions(v1, v2) {
|
|
65
|
+
const parts1 = v1.split('.').map(Number);
|
|
66
|
+
const parts2 = v2.split('.').map(Number);
|
|
67
|
+
for (let i = 0; i < Math.max(parts1.length, parts2.length); i++) {
|
|
68
|
+
const p1 = parts1[i] || 0;
|
|
69
|
+
const p2 = parts2[i] || 0;
|
|
70
|
+
if (p1 > p2)
|
|
71
|
+
return 1;
|
|
72
|
+
if (p1 < p2)
|
|
73
|
+
return -1;
|
|
74
|
+
}
|
|
75
|
+
return 0;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* 检查是否有更新
|
|
79
|
+
*/
|
|
80
|
+
async function checkForUpdates() {
|
|
81
|
+
const currentVersion = await getCurrentVersion();
|
|
82
|
+
// 检查缓存(每天只检查一次)
|
|
83
|
+
const cacheKey = 'oflow_last_update_check';
|
|
84
|
+
const cachedData = getCachedUpdateInfo(cacheKey);
|
|
85
|
+
if (cachedData && Date.now() - cachedData.timestamp < 24 * 60 * 60 * 1000) {
|
|
86
|
+
return {
|
|
87
|
+
hasUpdate: compareVersions(currentVersion, cachedData.latestVersion) < 0,
|
|
88
|
+
currentVersion,
|
|
89
|
+
latestVersion: cachedData.latestVersion
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
const latestVersion = await getLatestVersion();
|
|
93
|
+
// 缓存结果
|
|
94
|
+
setCachedUpdateInfo(cacheKey, {
|
|
95
|
+
latestVersion,
|
|
96
|
+
timestamp: Date.now()
|
|
97
|
+
});
|
|
98
|
+
return {
|
|
99
|
+
hasUpdate: compareVersions(currentVersion, latestVersion) < 0,
|
|
100
|
+
currentVersion,
|
|
101
|
+
latestVersion
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* 执行更新
|
|
106
|
+
*/
|
|
107
|
+
async function performUpdate() {
|
|
108
|
+
console.log(chalk_1.default.cyan('\n🔄 Updating oflow CLI...\n'));
|
|
109
|
+
try {
|
|
110
|
+
const { stdout, stderr } = await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {
|
|
111
|
+
timeout: 60000
|
|
112
|
+
});
|
|
113
|
+
console.log(chalk_1.default.green('\n✓ oflow CLI updated successfully!'));
|
|
114
|
+
console.log(chalk_1.default.gray('Please restart oflow to use the new version.\n'));
|
|
115
|
+
return { success: true, message: 'Update completed' };
|
|
116
|
+
}
|
|
117
|
+
catch (error) {
|
|
118
|
+
const errorMsg = error instanceof Error ? error.message : String(error);
|
|
119
|
+
console.log(chalk_1.default.red('\n✗ Update failed'));
|
|
120
|
+
console.log(chalk_1.default.gray('You can manually update with: npm install -g @oflow-ai/oflow-cli@latest\n'));
|
|
121
|
+
return { success: false, message: errorMsg };
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* 获取缓存的更新信息
|
|
126
|
+
*/
|
|
127
|
+
function getCachedUpdateInfo(key) {
|
|
128
|
+
try {
|
|
129
|
+
const fs = require('fs');
|
|
130
|
+
const path = require('path');
|
|
131
|
+
const os = require('os');
|
|
132
|
+
const cacheFile = path.join(os.homedir(), '.oflow', 'update-cache.json');
|
|
133
|
+
if (fs.existsSync(cacheFile)) {
|
|
134
|
+
const data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));
|
|
135
|
+
return data[key] || null;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
catch {
|
|
139
|
+
// Ignore cache errors
|
|
140
|
+
}
|
|
141
|
+
return null;
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* 缓存更新信息
|
|
145
|
+
*/
|
|
146
|
+
function setCachedUpdateInfo(key, value) {
|
|
147
|
+
try {
|
|
148
|
+
const fs = require('fs');
|
|
149
|
+
const path = require('path');
|
|
150
|
+
const os = require('os');
|
|
151
|
+
const cacheDir = path.join(os.homedir(), '.oflow');
|
|
152
|
+
const cacheFile = path.join(cacheDir, 'update-cache.json');
|
|
153
|
+
if (!fs.existsSync(cacheDir)) {
|
|
154
|
+
fs.mkdirSync(cacheDir, { recursive: true });
|
|
155
|
+
}
|
|
156
|
+
let data = {};
|
|
157
|
+
if (fs.existsSync(cacheFile)) {
|
|
158
|
+
data = JSON.parse(fs.readFileSync(cacheFile, 'utf-8'));
|
|
159
|
+
}
|
|
160
|
+
data[key] = value;
|
|
161
|
+
fs.writeFileSync(cacheFile, JSON.stringify(data, null, 2));
|
|
162
|
+
}
|
|
163
|
+
catch {
|
|
164
|
+
// Ignore cache errors
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
//# 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 } 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 */\nasync function getCurrentVersion(): Promise<string> {\n  try {\n    const packageJson = require('../../package.json');\n    return packageJson.version;\n  } catch {\n    return '0.0.0';\n  }\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    // 如果npm命令失败，尝试直接访问registry\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 * 执行更新\n */\nexport async function performUpdate(): Promise<{ success: boolean; message: string }> {\n  console.log(chalk.cyan('\\n🔄 Updating oflow CLI...\\n'));\n  \n  try {\n    const { stdout, stderr } = await execAsync(`npm install -g ${PACKAGE_NAME}@latest`, {\n      timeout: 60000\n    });\n    \n    console.log(chalk.green('\\n✓ oflow CLI updated successfully!'));\n    console.log(chalk.gray('Please restart oflow to use the new version.\\n'));\n    \n    return { success: true, message: 'Update completed' };\n  } catch (error) {\n    const errorMsg = error instanceof Error ? error.message : String(error);\n    console.log(chalk.red('\\n✗ Update failed'));\n    console.log(chalk.gray('You can manually update with: npm install -g @oflow-ai/oflow-cli@latest\\n'));\n    \n    return { success: false, message: errorMsg };\n  }\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}\n"]}
|