@boxes-dev/dvb 0.2.4
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/bin/dvb.cjs +28232 -0
- package/dist/bin/dvb.d.ts +2 -0
- package/dist/bin/dvb.d.ts.map +1 -0
- package/dist/bin/dvb.js +71 -0
- package/dist/bin/dvb.js.map +1 -0
- package/dist/bin/dvbd.cjs +11816 -0
- package/dist/bin/dvbd.d.ts +2 -0
- package/dist/bin/dvbd.d.ts.map +1 -0
- package/dist/bin/dvbd.js +20 -0
- package/dist/bin/dvbd.js.map +1 -0
- package/dist/codex/services-schema.json +59 -0
- package/dist/codex/setup-schema.json +176 -0
- package/dist/devbox/auth.d.ts +17 -0
- package/dist/devbox/auth.d.ts.map +1 -0
- package/dist/devbox/auth.js +302 -0
- package/dist/devbox/auth.js.map +1 -0
- package/dist/devbox/cli.d.ts +2 -0
- package/dist/devbox/cli.d.ts.map +1 -0
- package/dist/devbox/cli.js +142 -0
- package/dist/devbox/cli.js.map +1 -0
- package/dist/devbox/commands/agent.d.ts +21 -0
- package/dist/devbox/commands/agent.d.ts.map +1 -0
- package/dist/devbox/commands/agent.js +257 -0
- package/dist/devbox/commands/agent.js.map +1 -0
- package/dist/devbox/commands/boxSelect.d.ts +14 -0
- package/dist/devbox/commands/boxSelect.d.ts.map +1 -0
- package/dist/devbox/commands/boxSelect.js +82 -0
- package/dist/devbox/commands/boxSelect.js.map +1 -0
- package/dist/devbox/commands/connect.d.ts +8 -0
- package/dist/devbox/commands/connect.d.ts.map +1 -0
- package/dist/devbox/commands/connect.js +1369 -0
- package/dist/devbox/commands/connect.js.map +1 -0
- package/dist/devbox/commands/daemon.d.ts +4 -0
- package/dist/devbox/commands/daemon.d.ts.map +1 -0
- package/dist/devbox/commands/daemon.js +36 -0
- package/dist/devbox/commands/daemon.js.map +1 -0
- package/dist/devbox/commands/destroy.d.ts +2 -0
- package/dist/devbox/commands/destroy.d.ts.map +1 -0
- package/dist/devbox/commands/destroy.js +131 -0
- package/dist/devbox/commands/destroy.js.map +1 -0
- package/dist/devbox/commands/init/args.d.ts +12 -0
- package/dist/devbox/commands/init/args.d.ts.map +1 -0
- package/dist/devbox/commands/init/args.js +42 -0
- package/dist/devbox/commands/init/args.js.map +1 -0
- package/dist/devbox/commands/init/codex/artifacts.d.ts +26 -0
- package/dist/devbox/commands/init/codex/artifacts.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/artifacts.js +108 -0
- package/dist/devbox/commands/init/codex/artifacts.js.map +1 -0
- package/dist/devbox/commands/init/codex/index.d.ts +35 -0
- package/dist/devbox/commands/init/codex/index.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/index.js +147 -0
- package/dist/devbox/commands/init/codex/index.js.map +1 -0
- package/dist/devbox/commands/init/codex/local.d.ts +19 -0
- package/dist/devbox/commands/init/codex/local.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/local.js +189 -0
- package/dist/devbox/commands/init/codex/local.js.map +1 -0
- package/dist/devbox/commands/init/codex/plan.d.ts +61 -0
- package/dist/devbox/commands/init/codex/plan.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/plan.js +39 -0
- package/dist/devbox/commands/init/codex/plan.js.map +1 -0
- package/dist/devbox/commands/init/codex/prompts.d.ts +6 -0
- package/dist/devbox/commands/init/codex/prompts.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/prompts.js +26 -0
- package/dist/devbox/commands/init/codex/prompts.js.map +1 -0
- package/dist/devbox/commands/init/codex/remote.d.ts +56 -0
- package/dist/devbox/commands/init/codex/remote.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/remote.js +395 -0
- package/dist/devbox/commands/init/codex/remote.js.map +1 -0
- package/dist/devbox/commands/init/codex/template.d.ts +3 -0
- package/dist/devbox/commands/init/codex/template.d.ts.map +1 -0
- package/dist/devbox/commands/init/codex/template.js +3 -0
- package/dist/devbox/commands/init/codex/template.js.map +1 -0
- package/dist/devbox/commands/init/index.d.ts +2 -0
- package/dist/devbox/commands/init/index.d.ts.map +1 -0
- package/dist/devbox/commands/init/index.js +1117 -0
- package/dist/devbox/commands/init/index.js.map +1 -0
- package/dist/devbox/commands/init/packaging.d.ts +5 -0
- package/dist/devbox/commands/init/packaging.d.ts.map +1 -0
- package/dist/devbox/commands/init/packaging.js +86 -0
- package/dist/devbox/commands/init/packaging.js.map +1 -0
- package/dist/devbox/commands/init/registry.d.ts +14 -0
- package/dist/devbox/commands/init/registry.d.ts.map +1 -0
- package/dist/devbox/commands/init/registry.js +61 -0
- package/dist/devbox/commands/init/registry.js.map +1 -0
- package/dist/devbox/commands/init/remote.d.ts +38 -0
- package/dist/devbox/commands/init/remote.d.ts.map +1 -0
- package/dist/devbox/commands/init/remote.js +554 -0
- package/dist/devbox/commands/init/remote.js.map +1 -0
- package/dist/devbox/commands/init/repo.d.ts +31 -0
- package/dist/devbox/commands/init/repo.d.ts.map +1 -0
- package/dist/devbox/commands/init/repo.js +164 -0
- package/dist/devbox/commands/init/repo.js.map +1 -0
- package/dist/devbox/commands/init/scripts.d.ts +3 -0
- package/dist/devbox/commands/init/scripts.d.ts.map +1 -0
- package/dist/devbox/commands/init/scripts.js +15 -0
- package/dist/devbox/commands/init/scripts.js.map +1 -0
- package/dist/devbox/commands/init/ssh.d.ts +19 -0
- package/dist/devbox/commands/init/ssh.d.ts.map +1 -0
- package/dist/devbox/commands/init/ssh.js +270 -0
- package/dist/devbox/commands/init/ssh.js.map +1 -0
- package/dist/devbox/commands/init/state.d.ts +31 -0
- package/dist/devbox/commands/init/state.d.ts.map +1 -0
- package/dist/devbox/commands/init/state.js +25 -0
- package/dist/devbox/commands/init/state.js.map +1 -0
- package/dist/devbox/commands/list.d.ts +2 -0
- package/dist/devbox/commands/list.d.ts.map +1 -0
- package/dist/devbox/commands/list.js +213 -0
- package/dist/devbox/commands/list.js.map +1 -0
- package/dist/devbox/commands/listFormatting.d.ts +27 -0
- package/dist/devbox/commands/listFormatting.d.ts.map +1 -0
- package/dist/devbox/commands/listFormatting.js +155 -0
- package/dist/devbox/commands/listFormatting.js.map +1 -0
- package/dist/devbox/commands/logout.d.ts +2 -0
- package/dist/devbox/commands/logout.d.ts.map +1 -0
- package/dist/devbox/commands/logout.js +45 -0
- package/dist/devbox/commands/logout.js.map +1 -0
- package/dist/devbox/commands/mount.d.ts +3 -0
- package/dist/devbox/commands/mount.d.ts.map +1 -0
- package/dist/devbox/commands/mount.js +144 -0
- package/dist/devbox/commands/mount.js.map +1 -0
- package/dist/devbox/commands/mountSsh.d.ts +12 -0
- package/dist/devbox/commands/mountSsh.d.ts.map +1 -0
- package/dist/devbox/commands/mountSsh.js +137 -0
- package/dist/devbox/commands/mountSsh.js.map +1 -0
- package/dist/devbox/commands/ports.d.ts +2 -0
- package/dist/devbox/commands/ports.d.ts.map +1 -0
- package/dist/devbox/commands/ports.js +145 -0
- package/dist/devbox/commands/ports.js.map +1 -0
- package/dist/devbox/commands/services.d.ts +2 -0
- package/dist/devbox/commands/services.d.ts.map +1 -0
- package/dist/devbox/commands/services.js +552 -0
- package/dist/devbox/commands/services.js.map +1 -0
- package/dist/devbox/commands/servicesToml.d.ts +13 -0
- package/dist/devbox/commands/servicesToml.d.ts.map +1 -0
- package/dist/devbox/commands/servicesToml.js +198 -0
- package/dist/devbox/commands/servicesToml.js.map +1 -0
- package/dist/devbox/commands/sessionUtils.d.ts +10 -0
- package/dist/devbox/commands/sessionUtils.d.ts.map +1 -0
- package/dist/devbox/commands/sessionUtils.js +48 -0
- package/dist/devbox/commands/sessionUtils.js.map +1 -0
- package/dist/devbox/commands/sessions.d.ts +2 -0
- package/dist/devbox/commands/sessions.d.ts.map +1 -0
- package/dist/devbox/commands/sessions.js +425 -0
- package/dist/devbox/commands/sessions.js.map +1 -0
- package/dist/devbox/commands/setup.d.ts +2 -0
- package/dist/devbox/commands/setup.d.ts.map +1 -0
- package/dist/devbox/commands/setup.js +183 -0
- package/dist/devbox/commands/setup.js.map +1 -0
- package/dist/devbox/commands/wezterm.d.ts +3 -0
- package/dist/devbox/commands/wezterm.d.ts.map +1 -0
- package/dist/devbox/commands/wezterm.js +878 -0
- package/dist/devbox/commands/wezterm.js.map +1 -0
- package/dist/devbox/completions/cache.d.ts +59 -0
- package/dist/devbox/completions/cache.d.ts.map +1 -0
- package/dist/devbox/completions/cache.js +122 -0
- package/dist/devbox/completions/cache.js.map +1 -0
- package/dist/devbox/completions/index.d.ts +14 -0
- package/dist/devbox/completions/index.d.ts.map +1 -0
- package/dist/devbox/completions/index.js +796 -0
- package/dist/devbox/completions/index.js.map +1 -0
- package/dist/devbox/controlPlane.d.ts +44 -0
- package/dist/devbox/controlPlane.d.ts.map +1 -0
- package/dist/devbox/controlPlane.js +310 -0
- package/dist/devbox/controlPlane.js.map +1 -0
- package/dist/devbox/daemonClient.d.ts +28 -0
- package/dist/devbox/daemonClient.d.ts.map +1 -0
- package/dist/devbox/daemonClient.js +276 -0
- package/dist/devbox/daemonClient.js.map +1 -0
- package/dist/devbox/latency.d.ts +25 -0
- package/dist/devbox/latency.d.ts.map +1 -0
- package/dist/devbox/latency.js +186 -0
- package/dist/devbox/latency.js.map +1 -0
- package/dist/devbox/logger.d.ts +2 -0
- package/dist/devbox/logger.d.ts.map +1 -0
- package/dist/devbox/logger.js +3 -0
- package/dist/devbox/logger.js.map +1 -0
- package/dist/devbox/terminal/osc.d.ts +10 -0
- package/dist/devbox/terminal/osc.d.ts.map +1 -0
- package/dist/devbox/terminal/osc.js +88 -0
- package/dist/devbox/terminal/osc.js.map +1 -0
- package/dist/devbox/types.d.ts +4 -0
- package/dist/devbox/types.d.ts.map +1 -0
- package/dist/devbox/types.js +2 -0
- package/dist/devbox/types.js.map +1 -0
- package/dist/devbox/ui/colors.d.ts +19 -0
- package/dist/devbox/ui/colors.d.ts.map +1 -0
- package/dist/devbox/ui/colors.js +22 -0
- package/dist/devbox/ui/colors.js.map +1 -0
- package/dist/devbox/ui/statusLine.d.ts +14 -0
- package/dist/devbox/ui/statusLine.d.ts.map +1 -0
- package/dist/devbox/ui/statusLine.js +90 -0
- package/dist/devbox/ui/statusLine.js.map +1 -0
- package/dist/devbox/weztermMux.d.ts +11 -0
- package/dist/devbox/weztermMux.d.ts.map +1 -0
- package/dist/devbox/weztermMux.js +11 -0
- package/dist/devbox/weztermMux.js.map +1 -0
- package/dist/prompts/local-scan.md +32 -0
- package/dist/prompts/local-services-scan.md +17 -0
- package/dist/prompts/remote-apply.md +370 -0
- package/dist/scripts/fix-bashrc.sh +48 -0
- package/package.json +38 -0
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
import http from "node:http";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { spawn } from "node:child_process";
|
|
4
|
+
import { randomUUID } from "node:crypto";
|
|
5
|
+
import { access } from "node:fs/promises";
|
|
6
|
+
import { resolveSocketInfo } from "@boxes-dev/core";
|
|
7
|
+
import { getControlPlaneUrl, getConvexUrl } from "./controlPlane.js";
|
|
8
|
+
import { logger } from "./logger.js";
|
|
9
|
+
export const DAEMON_TIMEOUT_MS = {
|
|
10
|
+
health: 300,
|
|
11
|
+
quick: 500,
|
|
12
|
+
registry: 5000,
|
|
13
|
+
};
|
|
14
|
+
class DaemonConnectionError extends Error {
|
|
15
|
+
code;
|
|
16
|
+
socketPath;
|
|
17
|
+
constructor(socketPath, cause) {
|
|
18
|
+
super(cause.message);
|
|
19
|
+
this.name = "DaemonConnectionError";
|
|
20
|
+
this.code = cause.code;
|
|
21
|
+
this.socketPath = socketPath;
|
|
22
|
+
this.cause = cause;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
const isConnectionError = (error) => {
|
|
26
|
+
if (!(error instanceof Error))
|
|
27
|
+
return false;
|
|
28
|
+
const code = error.code;
|
|
29
|
+
return (code === "ENOENT" ||
|
|
30
|
+
code === "ECONNREFUSED" ||
|
|
31
|
+
code === "EPIPE" ||
|
|
32
|
+
code === "ENOTFOUND");
|
|
33
|
+
};
|
|
34
|
+
export const requestJson = async (socketPath, method, requestPath, timeoutMs, body) => {
|
|
35
|
+
const requestId = randomUUID();
|
|
36
|
+
logger.info("daemon_request", {
|
|
37
|
+
requestId,
|
|
38
|
+
method,
|
|
39
|
+
path: requestPath,
|
|
40
|
+
});
|
|
41
|
+
return new Promise((resolve, reject) => {
|
|
42
|
+
const payload = body ? JSON.stringify(body) : null;
|
|
43
|
+
const req = http.request({
|
|
44
|
+
method,
|
|
45
|
+
socketPath,
|
|
46
|
+
path: requestPath,
|
|
47
|
+
headers: {
|
|
48
|
+
"x-request-id": requestId,
|
|
49
|
+
...(payload
|
|
50
|
+
? {
|
|
51
|
+
"content-type": "application/json",
|
|
52
|
+
"content-length": Buffer.byteLength(payload).toString(),
|
|
53
|
+
}
|
|
54
|
+
: {}),
|
|
55
|
+
},
|
|
56
|
+
}, (res) => {
|
|
57
|
+
const chunks = [];
|
|
58
|
+
res.on("data", (chunk) => {
|
|
59
|
+
chunks.push(Buffer.from(chunk));
|
|
60
|
+
});
|
|
61
|
+
res.on("end", () => {
|
|
62
|
+
const payload = Buffer.concat(chunks).toString("utf8");
|
|
63
|
+
let parsedBody = {};
|
|
64
|
+
let parseError;
|
|
65
|
+
if (payload) {
|
|
66
|
+
try {
|
|
67
|
+
parsedBody = JSON.parse(payload);
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
parseError =
|
|
71
|
+
error instanceof Error ? error.message : "invalid_json";
|
|
72
|
+
logger.warn("daemon_response_invalid_json", {
|
|
73
|
+
requestId,
|
|
74
|
+
method,
|
|
75
|
+
path: requestPath,
|
|
76
|
+
status: res.statusCode,
|
|
77
|
+
error: parseError,
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
logger.info("daemon_response", {
|
|
82
|
+
requestId,
|
|
83
|
+
method,
|
|
84
|
+
path: requestPath,
|
|
85
|
+
status: res.statusCode,
|
|
86
|
+
});
|
|
87
|
+
resolve({
|
|
88
|
+
status: res.statusCode ?? 0,
|
|
89
|
+
body: parsedBody,
|
|
90
|
+
...(payload ? { rawBody: payload } : {}),
|
|
91
|
+
...(parseError ? { parseError } : {}),
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
req.on("error", (error) => {
|
|
96
|
+
if (isConnectionError(error)) {
|
|
97
|
+
reject(new DaemonConnectionError(socketPath, error));
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
reject(error);
|
|
101
|
+
});
|
|
102
|
+
req.setTimeout(timeoutMs, () => {
|
|
103
|
+
req.destroy(new Error("request_timeout"));
|
|
104
|
+
});
|
|
105
|
+
if (payload) {
|
|
106
|
+
req.write(payload);
|
|
107
|
+
}
|
|
108
|
+
req.end();
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
export const requireDaemonFeatures = async (socketPath, required) => {
|
|
112
|
+
if (!required.length)
|
|
113
|
+
return;
|
|
114
|
+
const response = await requestJson(socketPath, "GET", "/version", DAEMON_TIMEOUT_MS.quick);
|
|
115
|
+
if (response.status !== 200) {
|
|
116
|
+
throw new Error("dvbd does not support this command. Restart the daemon and try again.");
|
|
117
|
+
}
|
|
118
|
+
const features = Array.isArray(response.body.features)
|
|
119
|
+
? response.body.features
|
|
120
|
+
: [];
|
|
121
|
+
const available = new Set(features);
|
|
122
|
+
const missing = required.filter((feature) => !available.has(feature));
|
|
123
|
+
if (missing.length) {
|
|
124
|
+
throw new Error(`dvbd is missing required capabilities (${missing.join(", ")}). Restart the daemon and try again.`);
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
const resolveDaemonCommand = () => {
|
|
128
|
+
if (process.env.DEVBOXD_BIN_PATH) {
|
|
129
|
+
return {
|
|
130
|
+
command: process.execPath,
|
|
131
|
+
args: [process.env.DEVBOXD_BIN_PATH],
|
|
132
|
+
source: "env",
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
if (process.argv[1]) {
|
|
136
|
+
return {
|
|
137
|
+
command: process.execPath,
|
|
138
|
+
args: [process.argv[1], "--daemon"],
|
|
139
|
+
source: "self",
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
return {
|
|
143
|
+
command: process.execPath,
|
|
144
|
+
args: ["--daemon"],
|
|
145
|
+
source: "self",
|
|
146
|
+
};
|
|
147
|
+
};
|
|
148
|
+
const spawnDaemon = (socketPath) => {
|
|
149
|
+
const command = resolveDaemonCommand();
|
|
150
|
+
const controlPlaneUrl = getControlPlaneUrl();
|
|
151
|
+
const convexUrl = getConvexUrl();
|
|
152
|
+
logger.info("daemon_spawn", {
|
|
153
|
+
socketPath,
|
|
154
|
+
command: command.command,
|
|
155
|
+
args: command.args,
|
|
156
|
+
source: command.source,
|
|
157
|
+
});
|
|
158
|
+
const child = spawn(command.command, command.args, {
|
|
159
|
+
env: {
|
|
160
|
+
...process.env,
|
|
161
|
+
DEVBOX_SOCKET_PATH: socketPath,
|
|
162
|
+
...(controlPlaneUrl
|
|
163
|
+
? { DEVBOX_CONTROL_PLANE_URL: controlPlaneUrl }
|
|
164
|
+
: {}),
|
|
165
|
+
...(convexUrl ? { DEVBOX_CONVEX_URL: convexUrl } : {}),
|
|
166
|
+
},
|
|
167
|
+
stdio: "ignore",
|
|
168
|
+
detached: true,
|
|
169
|
+
});
|
|
170
|
+
child.unref();
|
|
171
|
+
};
|
|
172
|
+
const waitForHealth = async (socketPath, timeoutMs) => {
|
|
173
|
+
const deadline = Date.now() + timeoutMs;
|
|
174
|
+
while (Date.now() < deadline) {
|
|
175
|
+
try {
|
|
176
|
+
const response = await requestJson(socketPath, "GET", "/health", DAEMON_TIMEOUT_MS.quick);
|
|
177
|
+
if (response.status === 200 && response.body.ok)
|
|
178
|
+
return response.body;
|
|
179
|
+
}
|
|
180
|
+
catch {
|
|
181
|
+
// retry until timeout
|
|
182
|
+
}
|
|
183
|
+
await new Promise((resolve) => setTimeout(resolve, 150));
|
|
184
|
+
}
|
|
185
|
+
throw new Error("dvbd did not become healthy in time");
|
|
186
|
+
};
|
|
187
|
+
const listAlternateSocketPaths = (primary) => {
|
|
188
|
+
const candidates = new Set();
|
|
189
|
+
const envWithoutSocket = { ...process.env };
|
|
190
|
+
delete envWithoutSocket.DEVBOX_SOCKET_PATH;
|
|
191
|
+
const fallback = resolveSocketInfo(envWithoutSocket).socketPath;
|
|
192
|
+
candidates.add(fallback);
|
|
193
|
+
const homeDir = process.env.HOME?.trim();
|
|
194
|
+
if (homeDir) {
|
|
195
|
+
candidates.add(path.join(homeDir, ".devbox", "run", "devboxd.sock"));
|
|
196
|
+
}
|
|
197
|
+
candidates.delete(primary);
|
|
198
|
+
return [...candidates];
|
|
199
|
+
};
|
|
200
|
+
const pruneDuplicateDaemons = async (primary) => {
|
|
201
|
+
const candidates = listAlternateSocketPaths(primary);
|
|
202
|
+
for (const socketPath of candidates) {
|
|
203
|
+
try {
|
|
204
|
+
const health = await requestJson(socketPath, "GET", "/health", DAEMON_TIMEOUT_MS.health);
|
|
205
|
+
if (health.status === 200 && health.body.ok) {
|
|
206
|
+
logger.warn("daemon_duplicate_detected", {
|
|
207
|
+
socketPath,
|
|
208
|
+
pid: health.body.pid,
|
|
209
|
+
});
|
|
210
|
+
await stopDaemon(socketPath);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
catch (error) {
|
|
214
|
+
if (!isConnectionError(error)) {
|
|
215
|
+
logger.warn("daemon_duplicate_check_failed", {
|
|
216
|
+
socketPath,
|
|
217
|
+
error: String(error),
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
};
|
|
223
|
+
export const ensureDaemonRunning = async (socketPath) => {
|
|
224
|
+
try {
|
|
225
|
+
const response = await requestJson(socketPath, "GET", "/health", DAEMON_TIMEOUT_MS.health);
|
|
226
|
+
if (response.status === 200 && response.body.ok) {
|
|
227
|
+
await pruneDuplicateDaemons(socketPath);
|
|
228
|
+
return response.body;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
catch (error) {
|
|
232
|
+
if (!isConnectionError(error))
|
|
233
|
+
throw error;
|
|
234
|
+
}
|
|
235
|
+
await pruneDuplicateDaemons(socketPath);
|
|
236
|
+
spawnDaemon(socketPath);
|
|
237
|
+
return waitForHealth(socketPath, 5000);
|
|
238
|
+
};
|
|
239
|
+
const waitForSocketGone = async (socketPath, timeoutMs = 3000) => {
|
|
240
|
+
const deadline = Date.now() + timeoutMs;
|
|
241
|
+
while (Date.now() < deadline) {
|
|
242
|
+
try {
|
|
243
|
+
await access(socketPath);
|
|
244
|
+
}
|
|
245
|
+
catch {
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
249
|
+
}
|
|
250
|
+
throw new Error("dvbd did not shut down in time");
|
|
251
|
+
};
|
|
252
|
+
export const stopDaemon = async (socketPath) => {
|
|
253
|
+
try {
|
|
254
|
+
const health = await requestJson(socketPath, "GET", "/health", DAEMON_TIMEOUT_MS.health);
|
|
255
|
+
if (health.status === 200 && health.body.ok) {
|
|
256
|
+
try {
|
|
257
|
+
process.kill(health.body.pid, "SIGTERM");
|
|
258
|
+
}
|
|
259
|
+
catch (error) {
|
|
260
|
+
if (error instanceof Error &&
|
|
261
|
+
"code" in error &&
|
|
262
|
+
error.code !== "ESRCH") {
|
|
263
|
+
throw error;
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
await waitForSocketGone(socketPath);
|
|
267
|
+
return true;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
catch (error) {
|
|
271
|
+
if (!isConnectionError(error))
|
|
272
|
+
throw error;
|
|
273
|
+
}
|
|
274
|
+
return false;
|
|
275
|
+
};
|
|
276
|
+
//# sourceMappingURL=daemonClient.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemonClient.js","sourceRoot":"","sources":["../../src/devbox/daemonClient.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
type LatencyContext = {
|
|
2
|
+
box?: string;
|
|
3
|
+
session?: string;
|
|
4
|
+
tty?: boolean;
|
|
5
|
+
};
|
|
6
|
+
type DisconnectDetails = {
|
|
7
|
+
kind: "close" | "error";
|
|
8
|
+
closeCode?: number;
|
|
9
|
+
opened?: boolean;
|
|
10
|
+
};
|
|
11
|
+
export type LatencyTracker = {
|
|
12
|
+
enabled: true;
|
|
13
|
+
setContext: (context: LatencyContext) => void;
|
|
14
|
+
noteConnectStart: () => void;
|
|
15
|
+
noteConnectOpen: () => void;
|
|
16
|
+
notePingSent: (source: "heartbeat" | "input_probe") => void;
|
|
17
|
+
notePong: () => void;
|
|
18
|
+
noteSend: (bytes: number, bufferedAmount?: number) => (error?: Error) => void;
|
|
19
|
+
noteInputProbeTimeout: () => void;
|
|
20
|
+
noteDisconnect: (details: DisconnectDetails) => void;
|
|
21
|
+
flush: (exitCode?: number) => void;
|
|
22
|
+
};
|
|
23
|
+
export declare const createLatencyTracker: () => LatencyTracker | null;
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=latency.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"latency.d.ts","sourceRoot":"","sources":["../../src/devbox/latency.ts"],"names":[],"mappings":"AASA,KAAK,cAAc,GAAG;IACpB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,OAAO,CAAC;CACf,CAAC;AAEF,KAAK,iBAAiB,GAAG;IACvB,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,OAAO,EAAE,IAAI,CAAC;IACd,UAAU,EAAE,CAAC,OAAO,EAAE,cAAc,KAAK,IAAI,CAAC;IAC9C,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,eAAe,EAAE,MAAM,IAAI,CAAC;IAC5B,YAAY,EAAE,CAAC,MAAM,EAAE,WAAW,GAAG,aAAa,KAAK,IAAI,CAAC;IAC5D,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC;IAC9E,qBAAqB,EAAE,MAAM,IAAI,CAAC;IAClC,cAAc,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACrD,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC,CAAC;AA6DF,eAAO,MAAM,oBAAoB,QAAO,cAAc,GAAG,IA+HxD,CAAC"}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { monitorEventLoopDelay } from "node:perf_hooks";
|
|
2
|
+
const parseEnabled = (value) => {
|
|
3
|
+
if (!value)
|
|
4
|
+
return false;
|
|
5
|
+
const normalized = value.trim().toLowerCase();
|
|
6
|
+
if (!normalized)
|
|
7
|
+
return false;
|
|
8
|
+
return !["0", "false", "no", "off"].includes(normalized);
|
|
9
|
+
};
|
|
10
|
+
const createStats = () => ({
|
|
11
|
+
count: 0,
|
|
12
|
+
totalMs: 0,
|
|
13
|
+
minMs: Number.POSITIVE_INFINITY,
|
|
14
|
+
maxMs: 0,
|
|
15
|
+
});
|
|
16
|
+
const recordStat = (stats, valueMs) => {
|
|
17
|
+
stats.count += 1;
|
|
18
|
+
stats.totalMs += valueMs;
|
|
19
|
+
if (valueMs < stats.minMs)
|
|
20
|
+
stats.minMs = valueMs;
|
|
21
|
+
if (valueMs > stats.maxMs)
|
|
22
|
+
stats.maxMs = valueMs;
|
|
23
|
+
};
|
|
24
|
+
const formatMs = (value) => value.toFixed(1);
|
|
25
|
+
const formatSeconds = (valueMs) => (valueMs / 1000).toFixed(1);
|
|
26
|
+
const formatStats = (stats) => {
|
|
27
|
+
if (stats.count === 0)
|
|
28
|
+
return "count=0";
|
|
29
|
+
const avg = stats.totalMs / stats.count;
|
|
30
|
+
return [
|
|
31
|
+
`count=${stats.count}`,
|
|
32
|
+
`avg=${formatMs(avg)}`,
|
|
33
|
+
`min=${formatMs(stats.minMs)}`,
|
|
34
|
+
`max=${formatMs(stats.maxMs)}`,
|
|
35
|
+
].join(" ");
|
|
36
|
+
};
|
|
37
|
+
const formatDisconnect = (details) => {
|
|
38
|
+
if (!details)
|
|
39
|
+
return "";
|
|
40
|
+
const parts = [];
|
|
41
|
+
parts.push(`kind=${details.kind}`);
|
|
42
|
+
if (typeof details.opened === "boolean") {
|
|
43
|
+
parts.push(`opened=${details.opened ? "yes" : "no"}`);
|
|
44
|
+
}
|
|
45
|
+
if (typeof details.closeCode === "number") {
|
|
46
|
+
parts.push(`close_code=${details.closeCode}`);
|
|
47
|
+
}
|
|
48
|
+
return parts.length ? ` ${parts.join(" ")}` : "";
|
|
49
|
+
};
|
|
50
|
+
const formatEventLoopDelay = (histogram) => {
|
|
51
|
+
if (!histogram)
|
|
52
|
+
return "event_loop_delay_ms unavailable";
|
|
53
|
+
const meanMs = histogram.mean / 1e6;
|
|
54
|
+
const p95Ms = histogram.percentile(95) / 1e6;
|
|
55
|
+
const maxMs = histogram.max / 1e6;
|
|
56
|
+
return `event_loop_delay_ms mean=${formatMs(meanMs)} p95=${formatMs(p95Ms)} max=${formatMs(maxMs)}`;
|
|
57
|
+
};
|
|
58
|
+
export const createLatencyTracker = () => {
|
|
59
|
+
if (!parseEnabled(process.env.DEVBOX_LATENCY))
|
|
60
|
+
return null;
|
|
61
|
+
const startedAt = Date.now();
|
|
62
|
+
let firstConnectAt = null;
|
|
63
|
+
let connectPendingAt = null;
|
|
64
|
+
let pendingPingAt = null;
|
|
65
|
+
let hadSamples = false;
|
|
66
|
+
let context = {};
|
|
67
|
+
let eventLoopDelay = null;
|
|
68
|
+
const connectStats = createStats();
|
|
69
|
+
const pingStats = createStats();
|
|
70
|
+
const sendStats = createStats();
|
|
71
|
+
let sendBytes = 0;
|
|
72
|
+
let sendCount = 0;
|
|
73
|
+
let sendErrors = 0;
|
|
74
|
+
let maxBufferedAmount = 0;
|
|
75
|
+
let pingSent = 0;
|
|
76
|
+
let pingHeartbeat = 0;
|
|
77
|
+
let pingInputProbe = 0;
|
|
78
|
+
let inputProbeTimeouts = 0;
|
|
79
|
+
let disconnects = 0;
|
|
80
|
+
let lastDisconnect = null;
|
|
81
|
+
const ensureEventLoopDelay = () => {
|
|
82
|
+
if (eventLoopDelay)
|
|
83
|
+
return;
|
|
84
|
+
eventLoopDelay = monitorEventLoopDelay({ resolution: 20 });
|
|
85
|
+
eventLoopDelay.enable();
|
|
86
|
+
eventLoopDelay.reset();
|
|
87
|
+
};
|
|
88
|
+
const markSample = () => {
|
|
89
|
+
hadSamples = true;
|
|
90
|
+
};
|
|
91
|
+
return {
|
|
92
|
+
enabled: true,
|
|
93
|
+
setContext: (next) => {
|
|
94
|
+
context = { ...context, ...next };
|
|
95
|
+
},
|
|
96
|
+
noteConnectStart: () => {
|
|
97
|
+
ensureEventLoopDelay();
|
|
98
|
+
if (firstConnectAt === null)
|
|
99
|
+
firstConnectAt = Date.now();
|
|
100
|
+
connectPendingAt = Date.now();
|
|
101
|
+
},
|
|
102
|
+
noteConnectOpen: () => {
|
|
103
|
+
if (connectPendingAt === null)
|
|
104
|
+
return;
|
|
105
|
+
recordStat(connectStats, Date.now() - connectPendingAt);
|
|
106
|
+
connectPendingAt = null;
|
|
107
|
+
markSample();
|
|
108
|
+
},
|
|
109
|
+
notePingSent: (source) => {
|
|
110
|
+
ensureEventLoopDelay();
|
|
111
|
+
pingSent += 1;
|
|
112
|
+
if (source === "heartbeat")
|
|
113
|
+
pingHeartbeat += 1;
|
|
114
|
+
if (source === "input_probe")
|
|
115
|
+
pingInputProbe += 1;
|
|
116
|
+
if (pendingPingAt === null) {
|
|
117
|
+
pendingPingAt = Date.now();
|
|
118
|
+
}
|
|
119
|
+
},
|
|
120
|
+
notePong: () => {
|
|
121
|
+
if (pendingPingAt === null)
|
|
122
|
+
return;
|
|
123
|
+
recordStat(pingStats, Date.now() - pendingPingAt);
|
|
124
|
+
pendingPingAt = null;
|
|
125
|
+
markSample();
|
|
126
|
+
},
|
|
127
|
+
noteSend: (bytes, bufferedAmount) => {
|
|
128
|
+
ensureEventLoopDelay();
|
|
129
|
+
sendCount += 1;
|
|
130
|
+
sendBytes += bytes;
|
|
131
|
+
if (typeof bufferedAmount === "number") {
|
|
132
|
+
if (bufferedAmount > maxBufferedAmount) {
|
|
133
|
+
maxBufferedAmount = bufferedAmount;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
const started = Date.now();
|
|
137
|
+
return (error) => {
|
|
138
|
+
if (error)
|
|
139
|
+
sendErrors += 1;
|
|
140
|
+
recordStat(sendStats, Date.now() - started);
|
|
141
|
+
markSample();
|
|
142
|
+
};
|
|
143
|
+
},
|
|
144
|
+
noteInputProbeTimeout: () => {
|
|
145
|
+
inputProbeTimeouts += 1;
|
|
146
|
+
markSample();
|
|
147
|
+
},
|
|
148
|
+
noteDisconnect: (details) => {
|
|
149
|
+
disconnects += 1;
|
|
150
|
+
lastDisconnect = details;
|
|
151
|
+
markSample();
|
|
152
|
+
},
|
|
153
|
+
flush: (exitCode) => {
|
|
154
|
+
if (!hadSamples)
|
|
155
|
+
return;
|
|
156
|
+
if (eventLoopDelay) {
|
|
157
|
+
eventLoopDelay.disable();
|
|
158
|
+
}
|
|
159
|
+
const durationMs = Date.now() - (firstConnectAt ?? startedAt);
|
|
160
|
+
const headerParts = [];
|
|
161
|
+
if (context.box)
|
|
162
|
+
headerParts.push(`box=${context.box}`);
|
|
163
|
+
if (context.session)
|
|
164
|
+
headerParts.push(`session=${context.session}`);
|
|
165
|
+
if (context.tty !== undefined) {
|
|
166
|
+
headerParts.push(`tty=${context.tty ? "yes" : "no"}`);
|
|
167
|
+
}
|
|
168
|
+
headerParts.push(`duration_s=${formatSeconds(durationMs)}`);
|
|
169
|
+
if (typeof exitCode === "number") {
|
|
170
|
+
headerParts.push(`exit_code=${exitCode}`);
|
|
171
|
+
}
|
|
172
|
+
const lines = [
|
|
173
|
+
"dvb latency summary",
|
|
174
|
+
headerParts.join(" "),
|
|
175
|
+
`ws_handshake_ms ${formatStats(connectStats)}`,
|
|
176
|
+
`ping_rtt_ms ${formatStats(pingStats)} sent=${pingSent} heartbeat=${pingHeartbeat} input_probe=${pingInputProbe}`,
|
|
177
|
+
`send_flush_ms ${formatStats(sendStats)} sends=${sendCount} bytes=${sendBytes} send_errors=${sendErrors} max_buffered=${maxBufferedAmount}`,
|
|
178
|
+
`input_probe_timeouts ${inputProbeTimeouts}`,
|
|
179
|
+
`disconnects ${disconnects}${formatDisconnect(lastDisconnect)}`,
|
|
180
|
+
formatEventLoopDelay(eventLoopDelay),
|
|
181
|
+
];
|
|
182
|
+
console.error(lines.join("\n"));
|
|
183
|
+
},
|
|
184
|
+
};
|
|
185
|
+
};
|
|
186
|
+
//# sourceMappingURL=latency.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"latency.js","sourceRoot":"","sources":["../../src/devbox/latency.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/devbox/logger.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,kCAAyB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/devbox/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,MAAM,CAAC,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type OscMonitorResult = {
|
|
2
|
+
output: Buffer;
|
|
3
|
+
browserUrls: string[];
|
|
4
|
+
};
|
|
5
|
+
export declare class OscMonitor {
|
|
6
|
+
private pending;
|
|
7
|
+
write(chunk: Buffer): OscMonitorResult;
|
|
8
|
+
}
|
|
9
|
+
export declare const createOscMonitor: () => OscMonitor;
|
|
10
|
+
//# sourceMappingURL=osc.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"osc.d.ts","sourceRoot":"","sources":["../../../src/devbox/terminal/osc.ts"],"names":[],"mappings":"AAWA,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB,CAAC;AAkBF,qBAAa,UAAU;IACrB,OAAO,CAAC,OAAO,CAAmB;IAElC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,gBAAgB;CA2EvC;AAED,eAAO,MAAM,gBAAgB,kBAAyB,CAAC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
const ESC = 0x1b;
|
|
2
|
+
const OSC = 0x5d;
|
|
3
|
+
const BEL = 0x07;
|
|
4
|
+
const ST = 0x5c;
|
|
5
|
+
const BROWSER_PREFIX = "9999;browser-open;";
|
|
6
|
+
const findOscTerminator = (data, start) => {
|
|
7
|
+
for (let index = start; index < data.length; index += 1) {
|
|
8
|
+
const byte = data[index];
|
|
9
|
+
if (byte === BEL) {
|
|
10
|
+
return { termStart: index, termEnd: index + 1 };
|
|
11
|
+
}
|
|
12
|
+
if (byte === ESC && index + 1 < data.length && data[index + 1] === ST) {
|
|
13
|
+
return { termStart: index, termEnd: index + 2 };
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return null;
|
|
17
|
+
};
|
|
18
|
+
export class OscMonitor {
|
|
19
|
+
pending = Buffer.alloc(0);
|
|
20
|
+
write(chunk) {
|
|
21
|
+
if (chunk.length === 0) {
|
|
22
|
+
return { output: Buffer.alloc(0), browserUrls: [] };
|
|
23
|
+
}
|
|
24
|
+
const data = this.pending.length > 0
|
|
25
|
+
? Buffer.concat([this.pending, chunk])
|
|
26
|
+
: chunk;
|
|
27
|
+
const outputParts = [];
|
|
28
|
+
const browserUrls = [];
|
|
29
|
+
let cursor = 0;
|
|
30
|
+
while (cursor < data.length) {
|
|
31
|
+
const escIndex = data.indexOf(ESC, cursor);
|
|
32
|
+
if (escIndex === -1) {
|
|
33
|
+
outputParts.push(data.slice(cursor));
|
|
34
|
+
cursor = data.length;
|
|
35
|
+
break;
|
|
36
|
+
}
|
|
37
|
+
if (escIndex > cursor) {
|
|
38
|
+
outputParts.push(data.slice(cursor, escIndex));
|
|
39
|
+
}
|
|
40
|
+
if (escIndex + 1 >= data.length) {
|
|
41
|
+
this.pending = data.slice(escIndex);
|
|
42
|
+
return {
|
|
43
|
+
output: outputParts.length
|
|
44
|
+
? Buffer.concat(outputParts)
|
|
45
|
+
: Buffer.alloc(0),
|
|
46
|
+
browserUrls,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
if (data[escIndex + 1] !== OSC) {
|
|
50
|
+
outputParts.push(data.slice(escIndex, escIndex + 1));
|
|
51
|
+
cursor = escIndex + 1;
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
const terminator = findOscTerminator(data, escIndex + 2);
|
|
55
|
+
if (!terminator) {
|
|
56
|
+
this.pending = data.slice(escIndex);
|
|
57
|
+
return {
|
|
58
|
+
output: outputParts.length
|
|
59
|
+
? Buffer.concat(outputParts)
|
|
60
|
+
: Buffer.alloc(0),
|
|
61
|
+
browserUrls,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
const payload = data
|
|
65
|
+
.slice(escIndex + 2, terminator.termStart)
|
|
66
|
+
.toString("utf8");
|
|
67
|
+
if (payload.startsWith(BROWSER_PREFIX)) {
|
|
68
|
+
const url = payload.slice(BROWSER_PREFIX.length).trim();
|
|
69
|
+
if (url.length > 0) {
|
|
70
|
+
browserUrls.push(url);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
outputParts.push(data.slice(escIndex, terminator.termEnd));
|
|
75
|
+
}
|
|
76
|
+
cursor = terminator.termEnd;
|
|
77
|
+
}
|
|
78
|
+
this.pending = Buffer.alloc(0);
|
|
79
|
+
return {
|
|
80
|
+
output: outputParts.length
|
|
81
|
+
? Buffer.concat(outputParts)
|
|
82
|
+
: Buffer.alloc(0),
|
|
83
|
+
browserUrls,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
export const createOscMonitor = () => new OscMonitor();
|
|
88
|
+
//# sourceMappingURL=osc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"osc.js","sourceRoot":"","sources":["../../../src/devbox/terminal/osc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/devbox/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG;IAC1B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/devbox/types.ts"],"names":[],"mappings":""}
|