codebuff 1.0.256 → 1.0.258
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/background-process-manager.d.ts +50 -0
- package/dist/background-process-manager.js +359 -0
- package/dist/background-process-manager.js.map +1 -0
- package/dist/browser-runner.d.ts +35 -0
- package/dist/browser-runner.js +680 -0
- package/dist/browser-runner.js.map +1 -0
- package/dist/chat-storage.d.ts +2 -0
- package/dist/chat-storage.js +93 -0
- package/dist/chat-storage.js.map +1 -0
- package/dist/checkpoints/checkpoint-manager.d.ts +94 -0
- package/dist/checkpoints/checkpoint-manager.js +280 -0
- package/dist/checkpoints/checkpoint-manager.js.map +1 -0
- package/dist/checkpoints/file-manager.d.ts +72 -0
- package/dist/checkpoints/file-manager.js +294 -0
- package/dist/checkpoints/file-manager.js.map +1 -0
- package/dist/cli-handlers/api-key.d.ts +25 -0
- package/dist/cli-handlers/api-key.js +66 -0
- package/dist/cli-handlers/api-key.js.map +1 -0
- package/dist/cli-handlers/checkpoint.d.ts +18 -0
- package/dist/cli-handlers/checkpoint.js +195 -0
- package/dist/cli-handlers/checkpoint.js.map +1 -0
- package/dist/cli-handlers/diff.d.ts +2 -0
- package/dist/cli-handlers/diff.js +31 -0
- package/dist/cli-handlers/diff.js.map +1 -0
- package/dist/cli-handlers/easter-egg.d.ts +1 -0
- package/dist/cli-handlers/easter-egg.js +126 -0
- package/dist/cli-handlers/easter-egg.js.map +1 -0
- package/dist/cli-handlers/inititalization-flow.d.ts +1 -0
- package/dist/cli-handlers/inititalization-flow.js +24 -0
- package/dist/cli-handlers/inititalization-flow.js.map +1 -0
- package/dist/cli.d.ts +44 -0
- package/dist/cli.js +485 -0
- package/dist/cli.js.map +1 -0
- package/dist/client.d.ts +151 -0
- package/dist/client.js +833 -0
- package/dist/client.js.map +1 -0
- package/dist/common/constants/analytics-events.d.ts +2 -1
- package/dist/common/constants/analytics-events.js +2 -1
- package/dist/common/constants/analytics-events.js.map +1 -1
- package/dist/config.d.ts +4 -0
- package/dist/config.js +12 -0
- package/dist/config.js.map +1 -0
- package/dist/create-template-project.d.ts +1 -0
- package/dist/create-template-project.js +107 -0
- package/dist/create-template-project.js.map +1 -0
- package/dist/credentials.d.ts +4 -0
- package/dist/credentials.js +38 -0
- package/dist/credentials.js.map +1 -0
- package/dist/dev-process-manager.d.ts +10 -0
- package/dist/dev-process-manager.js +54 -0
- package/dist/dev-process-manager.js.map +1 -0
- package/dist/display.d.ts +9 -0
- package/dist/display.js +68 -0
- package/dist/display.js.map +1 -0
- package/dist/fingerprint.d.ts +1 -0
- package/dist/fingerprint.js +48 -0
- package/dist/fingerprint.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +119 -0
- package/dist/index.js.map +1 -0
- package/dist/menu.d.ts +3 -0
- package/dist/menu.js +126 -0
- package/dist/menu.js.map +1 -0
- package/dist/project-files.d.ts +114 -0
- package/dist/project-files.js +513 -0
- package/dist/project-files.js.map +1 -0
- package/dist/startup-process-handler.d.ts +2 -0
- package/dist/startup-process-handler.js +21 -0
- package/dist/startup-process-handler.js.map +1 -0
- package/dist/tool-handlers.d.ts +28 -0
- package/dist/tool-handlers.js +240 -0
- package/dist/tool-handlers.js.map +1 -0
- package/dist/types.d.ts +15 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/update-codebuff.d.ts +1 -0
- package/dist/update-codebuff.js +160 -0
- package/dist/update-codebuff.js.map +1 -0
- package/dist/utils/__tests__/background-process-manager.test.d.ts +1 -0
- package/dist/utils/__tests__/background-process-manager.test.js +289 -0
- package/dist/utils/__tests__/background-process-manager.test.js.map +1 -0
- package/dist/utils/__tests__/tool-renderers.test.d.ts +1 -0
- package/dist/utils/__tests__/tool-renderers.test.js +51 -0
- package/dist/utils/__tests__/tool-renderers.test.js.map +1 -0
- package/dist/utils/__tests__/xml-stream-parser.test.d.ts +1 -0
- package/dist/utils/__tests__/xml-stream-parser.test.js +229 -0
- package/dist/utils/__tests__/xml-stream-parser.test.js.map +1 -0
- package/dist/utils/analytics.d.ts +6 -0
- package/dist/utils/analytics.js +75 -0
- package/dist/utils/analytics.js.map +1 -0
- package/dist/utils/detect-shell.d.ts +1 -0
- package/dist/utils/detect-shell.js +60 -0
- package/dist/utils/detect-shell.js.map +1 -0
- package/dist/utils/git.d.ts +1 -0
- package/dist/utils/git.js +23 -0
- package/dist/utils/git.js.map +1 -0
- package/dist/utils/logger.d.ts +21 -0
- package/dist/utils/logger.js +105 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/spinner.d.ts +11 -0
- package/dist/utils/spinner.js +87 -0
- package/dist/utils/spinner.js.map +1 -0
- package/dist/utils/system-info.d.ts +8 -0
- package/dist/utils/system-info.js +22 -0
- package/dist/utils/system-info.js.map +1 -0
- package/dist/utils/terminal.d.ts +43 -0
- package/dist/utils/terminal.js +493 -0
- package/dist/utils/terminal.js.map +1 -0
- package/dist/utils/tool-renderers.d.ts +16 -0
- package/dist/utils/tool-renderers.js +148 -0
- package/dist/utils/tool-renderers.js.map +1 -0
- package/dist/utils/xml-stream-parser.d.ts +9 -0
- package/dist/utils/xml-stream-parser.js +128 -0
- package/dist/utils/xml-stream-parser.js.map +1 -0
- package/dist/web-scraper.d.ts +3 -0
- package/dist/web-scraper.js +57 -0
- package/dist/web-scraper.js.map +1 -0
- package/dist/workers/checkpoint-worker.d.ts +1 -0
- package/dist/workers/checkpoint-worker.js +48 -0
- package/dist/workers/checkpoint-worker.js.map +1 -0
- package/dist/workers/project-context.d.ts +1 -0
- package/dist/workers/project-context.js +17 -0
- package/dist/workers/project-context.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { ChildProcessByStdio, ChildProcessWithoutNullStreams, SpawnOptionsWithoutStdio } from 'child_process';
|
|
2
|
+
import { ToolResult } from './common/types/agent-state';
|
|
3
|
+
/**
|
|
4
|
+
* Interface describing the information stored for each background process.
|
|
5
|
+
*/
|
|
6
|
+
export interface BackgroundProcessInfo {
|
|
7
|
+
pid: number;
|
|
8
|
+
toolCallId: string;
|
|
9
|
+
command: string;
|
|
10
|
+
process: ChildProcessByStdio<any, any, any>;
|
|
11
|
+
stdoutBuffer: string[];
|
|
12
|
+
stderrBuffer: string[];
|
|
13
|
+
status: 'running' | 'completed' | 'error';
|
|
14
|
+
startTime: number;
|
|
15
|
+
endTime: number | null;
|
|
16
|
+
lastReportedStdoutLength: number;
|
|
17
|
+
lastReportedStderrLength: number;
|
|
18
|
+
lastReportedStatus: 'running' | 'completed' | 'error' | null;
|
|
19
|
+
stdoutFile?: string;
|
|
20
|
+
stderrFile?: string;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Global map storing information about active and completed background processes.
|
|
24
|
+
* Keyed by the OS-assigned Process ID (PID).
|
|
25
|
+
*/
|
|
26
|
+
export declare const backgroundProcesses: Map<number, BackgroundProcessInfo>;
|
|
27
|
+
/**
|
|
28
|
+
* Formats a single background process's info into a string
|
|
29
|
+
*/
|
|
30
|
+
export declare function getBackgroundProcessInfoString(info: BackgroundProcessInfo): string;
|
|
31
|
+
/**
|
|
32
|
+
* Gets updates from all background processes and updates tracking info
|
|
33
|
+
*/
|
|
34
|
+
export declare function getBackgroundProcessUpdates(): ToolResult[];
|
|
35
|
+
export declare function spawnAndTrack(command: string, args: string[] | undefined, options: SpawnOptionsWithoutStdio): ChildProcessWithoutNullStreams;
|
|
36
|
+
export declare function sendKillSignalToAllBackgroundProcesses(): void;
|
|
37
|
+
export declare function killAllBackgroundProcesses(): Promise<void>;
|
|
38
|
+
/**
|
|
39
|
+
* Cleans up stale lock files and attempts to kill orphaned processes found in the lock directory.
|
|
40
|
+
* This function is intended to run on startup to handle cases where the application might have
|
|
41
|
+
* exited uncleanly, leaving orphaned processes or lock files.
|
|
42
|
+
*
|
|
43
|
+
* @returns Object containing:
|
|
44
|
+
* - shouldStartNewProcesses: boolean indicating if it's safe to start new processes
|
|
45
|
+
* - cleanUpPromise: Promise that resolves when cleanup is complete
|
|
46
|
+
*/
|
|
47
|
+
export declare function cleanupStoredProcesses(): {
|
|
48
|
+
separateCodebuffInstanceRunning: boolean;
|
|
49
|
+
cleanUpPromise: Promise<any>;
|
|
50
|
+
};
|
|
@@ -0,0 +1,359 @@
|
|
|
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.backgroundProcesses = void 0;
|
|
7
|
+
exports.getBackgroundProcessInfoString = getBackgroundProcessInfoString;
|
|
8
|
+
exports.getBackgroundProcessUpdates = getBackgroundProcessUpdates;
|
|
9
|
+
exports.spawnAndTrack = spawnAndTrack;
|
|
10
|
+
exports.sendKillSignalToAllBackgroundProcesses = sendKillSignalToAllBackgroundProcesses;
|
|
11
|
+
exports.killAllBackgroundProcesses = killAllBackgroundProcesses;
|
|
12
|
+
exports.cleanupStoredProcesses = cleanupStoredProcesses;
|
|
13
|
+
const assert_1 = __importDefault(require("assert"));
|
|
14
|
+
const child_process_1 = require("child_process");
|
|
15
|
+
const fs_1 = require("fs");
|
|
16
|
+
const path_1 = __importDefault(require("path"));
|
|
17
|
+
const process_1 = __importDefault(require("process"));
|
|
18
|
+
const analytics_events_1 = require("./common/constants/analytics-events");
|
|
19
|
+
const array_1 = require("./common/util/array");
|
|
20
|
+
const string_1 = require("./common/util/string");
|
|
21
|
+
const picocolors_1 = require("picocolors");
|
|
22
|
+
const zod_1 = require("zod");
|
|
23
|
+
const credentials_1 = require("./credentials");
|
|
24
|
+
const logger_1 = require("./utils/logger");
|
|
25
|
+
const COMMAND_OUTPUT_LIMIT = 5000; // Limit output to 10KB per stream
|
|
26
|
+
const COMMAND_KILL_TIMEOUT_MS = 5000;
|
|
27
|
+
const POLLING_INTERVAL_MS = 200;
|
|
28
|
+
const LOCK_DIR = path_1.default.join(credentials_1.CONFIG_DIR, 'background_processes');
|
|
29
|
+
/**
|
|
30
|
+
* Global map storing information about active and completed background processes.
|
|
31
|
+
* Keyed by the OS-assigned Process ID (PID).
|
|
32
|
+
*/
|
|
33
|
+
exports.backgroundProcesses = new Map();
|
|
34
|
+
/**
|
|
35
|
+
* Gets output with context about whether there was previous content
|
|
36
|
+
*/
|
|
37
|
+
function getOutputWithContext(newContent, lastReportedLength) {
|
|
38
|
+
if (newContent) {
|
|
39
|
+
const hasOldContent = lastReportedLength > 0;
|
|
40
|
+
return hasOldContent ? '[PREVIOUS OUTPUT]\n' + newContent : newContent;
|
|
41
|
+
}
|
|
42
|
+
return '[NO NEW OUTPUT]';
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Formats a single background process's info into a string
|
|
46
|
+
*/
|
|
47
|
+
function getBackgroundProcessInfoString(info) {
|
|
48
|
+
const newStdout = info.stdoutBuffer
|
|
49
|
+
.join('')
|
|
50
|
+
.slice(info.lastReportedStdoutLength);
|
|
51
|
+
const newStderr = info.stderrBuffer
|
|
52
|
+
.join('')
|
|
53
|
+
.slice(info.lastReportedStderrLength);
|
|
54
|
+
// Only report finished processes if there are changes
|
|
55
|
+
if (info.status !== 'running' &&
|
|
56
|
+
!newStdout &&
|
|
57
|
+
!newStderr &&
|
|
58
|
+
info.status === info.lastReportedStatus) {
|
|
59
|
+
return '';
|
|
60
|
+
}
|
|
61
|
+
// Calculate duration in milliseconds
|
|
62
|
+
const duration = info.endTime
|
|
63
|
+
? info.endTime - info.startTime
|
|
64
|
+
: Date.now() - info.startTime;
|
|
65
|
+
return (0, array_1.buildArray)('<background_process>', `<process_id>${info.pid}</process_id>`, `<command>${info.command}</command>`, `<start_time_utc>${new Date(info.startTime).toISOString()}</start_time_utc>`, `<duration_ms>${duration}</duration_ms>`, newStdout &&
|
|
66
|
+
`<stdout>${(0, string_1.truncateStringWithMessage)({
|
|
67
|
+
str: getOutputWithContext(newStdout, info.lastReportedStdoutLength),
|
|
68
|
+
maxLength: COMMAND_OUTPUT_LIMIT,
|
|
69
|
+
remove: 'START',
|
|
70
|
+
})}</stdout>`, newStderr &&
|
|
71
|
+
`<stderr>${(0, string_1.truncateStringWithMessage)({
|
|
72
|
+
str: getOutputWithContext(newStderr, info.lastReportedStderrLength),
|
|
73
|
+
maxLength: COMMAND_OUTPUT_LIMIT,
|
|
74
|
+
remove: 'START',
|
|
75
|
+
})}</stderr>`, `<status>${info.status}</status>`, info.process.exitCode !== null &&
|
|
76
|
+
`<exit_code>${info.process.exitCode}</exit_code>`, info.process.signalCode &&
|
|
77
|
+
`<signal_code>${info.process.signalCode}</signal_code>`, '</background_process>').join('\n');
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Gets updates from all background processes and updates tracking info
|
|
81
|
+
*/
|
|
82
|
+
function getBackgroundProcessUpdates() {
|
|
83
|
+
const updates = Array.from(exports.backgroundProcesses.values())
|
|
84
|
+
.map((bgProcess) => {
|
|
85
|
+
return [getBackgroundProcessInfoString(bgProcess), bgProcess.toolCallId];
|
|
86
|
+
})
|
|
87
|
+
.filter(([update]) => Boolean(update));
|
|
88
|
+
// Update tracking info after getting updates
|
|
89
|
+
for (const process of exports.backgroundProcesses.values()) {
|
|
90
|
+
process.lastReportedStdoutLength = process.stdoutBuffer.join('').length;
|
|
91
|
+
process.lastReportedStderrLength = process.stderrBuffer.join('').length;
|
|
92
|
+
process.lastReportedStatus = process.status;
|
|
93
|
+
}
|
|
94
|
+
// Clean up completed processes that we've already reported
|
|
95
|
+
cleanupReportedProcesses();
|
|
96
|
+
return updates.map(([update, toolCallId]) => {
|
|
97
|
+
return {
|
|
98
|
+
name: 'background_process_updates',
|
|
99
|
+
result: update,
|
|
100
|
+
id: toolCallId,
|
|
101
|
+
};
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
function deleteFileIfExists(fileName) {
|
|
105
|
+
try {
|
|
106
|
+
(0, fs_1.unlinkSync)(fileName);
|
|
107
|
+
}
|
|
108
|
+
catch { }
|
|
109
|
+
}
|
|
110
|
+
const zodMaybeNumber = zod_1.z.preprocess((val) => {
|
|
111
|
+
const n = Number(val);
|
|
112
|
+
return typeof val === 'undefined' || isNaN(n) ? undefined : n;
|
|
113
|
+
}, zod_1.z.number().optional());
|
|
114
|
+
const lockFileSchema = zod_1.z.object({
|
|
115
|
+
parentPid: zodMaybeNumber,
|
|
116
|
+
});
|
|
117
|
+
/**
|
|
118
|
+
* Creates a lock file for a background process with the current process's PID.
|
|
119
|
+
* This allows tracking parent-child process relationships for cleanup.
|
|
120
|
+
*
|
|
121
|
+
* @param filePath - Path where the lock file should be created
|
|
122
|
+
*/
|
|
123
|
+
function createLockFile(filePath) {
|
|
124
|
+
const data = {
|
|
125
|
+
parentPid: process_1.default.pid,
|
|
126
|
+
};
|
|
127
|
+
(0, fs_1.writeFileSync)(filePath, JSON.stringify(data, null, 1));
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Checks if a process with the given PID is still running.
|
|
131
|
+
*
|
|
132
|
+
* @param pid - Process ID to check
|
|
133
|
+
* @returns true if the process is running, false otherwise
|
|
134
|
+
*/
|
|
135
|
+
function isRunning(pid) {
|
|
136
|
+
try {
|
|
137
|
+
process_1.default.kill(pid, 0);
|
|
138
|
+
}
|
|
139
|
+
catch (error) {
|
|
140
|
+
if (error.code === 'ESRCH') {
|
|
141
|
+
return false;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
return true;
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Determines whether the process associated with a given PID should be
|
|
148
|
+
* terminated, based on the lock file contents stored for that PID.
|
|
149
|
+
*
|
|
150
|
+
* If the parent process is no longer active or the file is invalid, the
|
|
151
|
+
* function assumes the process is orphaned and should be killed.
|
|
152
|
+
*
|
|
153
|
+
* @param lockFile - The path of the lock file.
|
|
154
|
+
* @returns `true` if the process should be killed (e.g. parent no longer exists or file is invalid),
|
|
155
|
+
* `false` if the parent process is still alive and the process should be kept running.
|
|
156
|
+
*/
|
|
157
|
+
function shouldKillProcessUsingLock(lockFile) {
|
|
158
|
+
const fileContents = String((0, fs_1.readFileSync)(lockFile));
|
|
159
|
+
let data;
|
|
160
|
+
try {
|
|
161
|
+
data = lockFileSchema.parse(JSON.parse(fileContents));
|
|
162
|
+
}
|
|
163
|
+
catch (error) {
|
|
164
|
+
data = {
|
|
165
|
+
parentPid: undefined,
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
if (data.parentPid && isRunning(data.parentPid)) {
|
|
169
|
+
return false;
|
|
170
|
+
}
|
|
171
|
+
return true;
|
|
172
|
+
}
|
|
173
|
+
function spawnAndTrack(command, args = [], options) {
|
|
174
|
+
const child = (0, child_process_1.spawn)(command, args, {
|
|
175
|
+
...options,
|
|
176
|
+
detached: true,
|
|
177
|
+
});
|
|
178
|
+
(0, assert_1.default)(child.pid !== undefined);
|
|
179
|
+
logger_1.logger.info({
|
|
180
|
+
eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_START,
|
|
181
|
+
pid: child.pid,
|
|
182
|
+
}, `Process start: \`${command} ${args.join(' ')}\``);
|
|
183
|
+
(0, fs_1.mkdirSync)(LOCK_DIR, { recursive: true });
|
|
184
|
+
const filePath = path_1.default.join(LOCK_DIR, `${child.pid}`);
|
|
185
|
+
createLockFile(filePath);
|
|
186
|
+
child.on('exit', () => {
|
|
187
|
+
deleteFileIfExists(filePath);
|
|
188
|
+
logger_1.logger.info({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_END, pid: child.pid }, `Graceful exit: \`${command} ${args.join(' ')}\``);
|
|
189
|
+
});
|
|
190
|
+
return child;
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Removes completed processes that have been fully reported
|
|
194
|
+
*/
|
|
195
|
+
function cleanupReportedProcesses() {
|
|
196
|
+
for (const [pid, info] of exports.backgroundProcesses.entries()) {
|
|
197
|
+
if ((info.status === 'completed' || info.status === 'error') &&
|
|
198
|
+
info.lastReportedStatus === info.status &&
|
|
199
|
+
info.lastReportedStdoutLength === info.stdoutBuffer.join('').length &&
|
|
200
|
+
info.lastReportedStderrLength === info.stderrBuffer.join('').length) {
|
|
201
|
+
exports.backgroundProcesses.delete(pid);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
function waitForProcessExit(pid) {
|
|
206
|
+
return new Promise((resolve) => {
|
|
207
|
+
let resolved = false;
|
|
208
|
+
const interval = setInterval(() => {
|
|
209
|
+
if (!isRunning(pid)) {
|
|
210
|
+
clearInterval(interval);
|
|
211
|
+
clearTimeout(timeout);
|
|
212
|
+
resolved = true;
|
|
213
|
+
resolve(true);
|
|
214
|
+
}
|
|
215
|
+
}, POLLING_INTERVAL_MS);
|
|
216
|
+
const timeout = setTimeout(() => {
|
|
217
|
+
if (!resolved) {
|
|
218
|
+
clearInterval(interval);
|
|
219
|
+
resolve(false);
|
|
220
|
+
}
|
|
221
|
+
}, COMMAND_KILL_TIMEOUT_MS);
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
function killProcessTreeSoftly(pid) {
|
|
225
|
+
if (process_1.default.platform === 'win32') {
|
|
226
|
+
// /T = kill tree, no /F = soft kill
|
|
227
|
+
(0, child_process_1.spawn)('taskkill', ['/PID', String(pid), '/T'], {
|
|
228
|
+
stdio: 'ignore',
|
|
229
|
+
detached: true,
|
|
230
|
+
}).unref();
|
|
231
|
+
}
|
|
232
|
+
else {
|
|
233
|
+
try {
|
|
234
|
+
process_1.default.kill(-pid, 'SIGTERM');
|
|
235
|
+
}
|
|
236
|
+
catch (err) {
|
|
237
|
+
if (err?.code !== 'ESRCH')
|
|
238
|
+
throw err;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
async function killAndWait(pid) {
|
|
243
|
+
try {
|
|
244
|
+
killProcessTreeSoftly(pid);
|
|
245
|
+
if (await waitForProcessExit(pid)) {
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
catch (error) {
|
|
250
|
+
if (error.code === 'ESRCH') {
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
else {
|
|
254
|
+
throw error;
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
throw new Error(`Unable to kill process ${pid}`);
|
|
258
|
+
}
|
|
259
|
+
// Only to be run on exit
|
|
260
|
+
function sendKillSignalToAllBackgroundProcesses() {
|
|
261
|
+
for (const [pid, p] of exports.backgroundProcesses.entries()) {
|
|
262
|
+
if (p.status !== 'running') {
|
|
263
|
+
continue;
|
|
264
|
+
}
|
|
265
|
+
try {
|
|
266
|
+
killProcessTreeSoftly(pid);
|
|
267
|
+
}
|
|
268
|
+
catch { }
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
async function killAllBackgroundProcesses() {
|
|
272
|
+
const killPromises = Array.from(exports.backgroundProcesses.entries())
|
|
273
|
+
.filter(([, p]) => p.status === 'running')
|
|
274
|
+
.map(async ([pid, processInfo]) => {
|
|
275
|
+
try {
|
|
276
|
+
await killAndWait(pid);
|
|
277
|
+
// console.log(gray(`Killed process: \`${processInfo.command}\``))
|
|
278
|
+
}
|
|
279
|
+
catch (error) {
|
|
280
|
+
console.error((0, picocolors_1.red)(`Failed to kill: \`${processInfo.command}\` (pid ${pid}): ${error?.message || error}`));
|
|
281
|
+
}
|
|
282
|
+
});
|
|
283
|
+
await Promise.all(killPromises);
|
|
284
|
+
exports.backgroundProcesses.clear();
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Cleans up stale lock files and attempts to kill orphaned processes found in the lock directory.
|
|
288
|
+
* This function is intended to run on startup to handle cases where the application might have
|
|
289
|
+
* exited uncleanly, leaving orphaned processes or lock files.
|
|
290
|
+
*
|
|
291
|
+
* @returns Object containing:
|
|
292
|
+
* - shouldStartNewProcesses: boolean indicating if it's safe to start new processes
|
|
293
|
+
* - cleanUpPromise: Promise that resolves when cleanup is complete
|
|
294
|
+
*/
|
|
295
|
+
function cleanupStoredProcesses() {
|
|
296
|
+
// Determine which processes to kill (sync)
|
|
297
|
+
let separateCodebuffInstanceRunning = false;
|
|
298
|
+
const locksToProcess = [];
|
|
299
|
+
try {
|
|
300
|
+
(0, fs_1.mkdirSync)(LOCK_DIR, { recursive: true });
|
|
301
|
+
const files = (0, fs_1.readdirSync)(LOCK_DIR);
|
|
302
|
+
for (const file of files) {
|
|
303
|
+
const lockFile = path_1.default.join(LOCK_DIR, file);
|
|
304
|
+
if (shouldKillProcessUsingLock(lockFile)) {
|
|
305
|
+
locksToProcess.push(file);
|
|
306
|
+
}
|
|
307
|
+
else {
|
|
308
|
+
separateCodebuffInstanceRunning = true;
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
catch { }
|
|
313
|
+
if (locksToProcess.length) {
|
|
314
|
+
console.log((0, picocolors_1.gray)('Detected running codebuff processes. Cleaning...\n'));
|
|
315
|
+
logger_1.logger.info({
|
|
316
|
+
eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_LEFTOVER_DETECTED,
|
|
317
|
+
pids: locksToProcess,
|
|
318
|
+
});
|
|
319
|
+
}
|
|
320
|
+
// Actually kill processes (async)
|
|
321
|
+
const processLockFile = async (pidName) => {
|
|
322
|
+
const lockFile = path_1.default.join(LOCK_DIR, pidName);
|
|
323
|
+
const pid = parseInt(pidName, 10);
|
|
324
|
+
if (isNaN(pid)) {
|
|
325
|
+
deleteFileIfExists(lockFile);
|
|
326
|
+
logger_1.logger.info({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_END, pid }, 'Lock found but process not running.');
|
|
327
|
+
return;
|
|
328
|
+
}
|
|
329
|
+
if (exports.backgroundProcesses.has(pid)) {
|
|
330
|
+
logger_1.logger.error({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_END, pid }, 'Process running in current session. Should not occur.');
|
|
331
|
+
return;
|
|
332
|
+
}
|
|
333
|
+
try {
|
|
334
|
+
killProcessTreeSoftly(pid);
|
|
335
|
+
if (await waitForProcessExit(pid)) {
|
|
336
|
+
deleteFileIfExists(lockFile);
|
|
337
|
+
logger_1.logger.info({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_END, pid }, 'Process successfully killed.');
|
|
338
|
+
}
|
|
339
|
+
else {
|
|
340
|
+
logger_1.logger.warn({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_CONTINUE, pid }, 'Process unable to be killed. Leaving lock file.');
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
catch (err) {
|
|
344
|
+
if (err.code === 'ESRCH') {
|
|
345
|
+
deleteFileIfExists(lockFile);
|
|
346
|
+
logger_1.logger.info({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_END, pid }, 'Leftover process (with lock) died naturally.');
|
|
347
|
+
}
|
|
348
|
+
else {
|
|
349
|
+
logger_1.logger.error({ eventId: analytics_events_1.AnalyticsEvent.BACKGROUND_PROCESS_CONTINUE, err, pid }, 'Error killing process');
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
};
|
|
353
|
+
const cleanUpPromise = Promise.all(locksToProcess.map(processLockFile));
|
|
354
|
+
return {
|
|
355
|
+
separateCodebuffInstanceRunning,
|
|
356
|
+
cleanUpPromise,
|
|
357
|
+
};
|
|
358
|
+
}
|
|
359
|
+
//# sourceMappingURL=background-process-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"background-process-manager.js","sourceRoot":"","sources":["../src/background-process-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { BrowserAction, BrowserResponse } from './common/browser-actions';
|
|
2
|
+
export declare class BrowserRunner {
|
|
3
|
+
getLogs(): BrowserResponse['logs'];
|
|
4
|
+
getNetworkEvents(): BrowserResponse['networkEvents'];
|
|
5
|
+
private browser;
|
|
6
|
+
private page;
|
|
7
|
+
private logs;
|
|
8
|
+
private jsErrorCount;
|
|
9
|
+
private retryCount;
|
|
10
|
+
private startTime;
|
|
11
|
+
private consecutiveErrors;
|
|
12
|
+
private totalErrors;
|
|
13
|
+
constructor();
|
|
14
|
+
private maxConsecutiveErrors;
|
|
15
|
+
private totalErrorThreshold;
|
|
16
|
+
private performanceMetrics;
|
|
17
|
+
private networkEvents;
|
|
18
|
+
private executeWithRetry;
|
|
19
|
+
private executeAction;
|
|
20
|
+
private logErrorForAnalysis;
|
|
21
|
+
private getBrowser;
|
|
22
|
+
private startBrowser;
|
|
23
|
+
private navigate;
|
|
24
|
+
private typeText;
|
|
25
|
+
private scroll;
|
|
26
|
+
private takeScreenshot;
|
|
27
|
+
private attachPageListeners;
|
|
28
|
+
private collectPerformanceMetrics;
|
|
29
|
+
private collectMetrics;
|
|
30
|
+
private filterLogs;
|
|
31
|
+
execute(action: BrowserAction): Promise<BrowserResponse>;
|
|
32
|
+
shutdown(): Promise<void>;
|
|
33
|
+
}
|
|
34
|
+
export declare const handleBrowserInstruction: (action: BrowserAction) => Promise<BrowserResponse>;
|
|
35
|
+
export declare const activeBrowserRunner: BrowserRunner;
|