nomoreide 0.1.14 → 0.1.16
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/README.md +20 -1
- package/dist/cli/commands.js +44 -9
- package/dist/cli/commands.js.map +1 -1
- package/dist/core/agent-context.d.ts +9 -0
- package/dist/core/agent-context.js +43 -0
- package/dist/core/agent-context.js.map +1 -0
- package/dist/core/config-store.js +29 -3
- package/dist/core/config-store.js.map +1 -1
- package/dist/core/docker-service-runner.d.ts +21 -0
- package/dist/core/docker-service-runner.js +80 -0
- package/dist/core/docker-service-runner.js.map +1 -0
- package/dist/core/git-manager.js +1 -1
- package/dist/core/git-manager.js.map +1 -1
- package/dist/core/http-inspector.d.ts +20 -0
- package/dist/core/http-inspector.js +106 -0
- package/dist/core/http-inspector.js.map +1 -0
- package/dist/core/log-store.d.ts +4 -0
- package/dist/core/log-store.js +34 -0
- package/dist/core/log-store.js.map +1 -1
- package/dist/core/port-utils.d.ts +6 -0
- package/dist/core/port-utils.js +44 -0
- package/dist/core/port-utils.js.map +1 -1
- package/dist/core/process-manager.d.ts +28 -2
- package/dist/core/process-manager.js +367 -14
- package/dist/core/process-manager.js.map +1 -1
- package/dist/core/service-health.d.ts +2 -1
- package/dist/core/service-health.js +9 -1
- package/dist/core/service-health.js.map +1 -1
- package/dist/core/ssh-service-runner.d.ts +7 -0
- package/dist/core/ssh-service-runner.js +31 -0
- package/dist/core/ssh-service-runner.js.map +1 -0
- package/dist/core/timeline-store.d.ts +16 -0
- package/dist/core/timeline-store.js +28 -0
- package/dist/core/timeline-store.js.map +1 -0
- package/dist/core/types.d.ts +28 -3
- package/dist/mcp/server.js +13 -3
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/tools.d.ts +3 -1
- package/dist/mcp/tools.js +86 -4
- package/dist/mcp/tools.js.map +1 -1
- package/dist/web/client/assets/index-Bkfrzz0V.js +14 -0
- package/dist/web/client/assets/index-DYCqol_D.css +1 -0
- package/dist/web/client/index.html +2 -2
- package/dist/web/dashboard.d.ts +4 -1
- package/dist/web/dashboard.js +4 -0
- package/dist/web/dashboard.js.map +1 -1
- package/dist/web/server.js +96 -18
- package/dist/web/server.js.map +1 -1
- package/package.json +2 -2
- package/dist/web/client/assets/index-BYk1ncPr.js +0 -12
- package/dist/web/client/assets/index-BbvMPKsZ.css +0 -1
package/README.md
CHANGED
|
@@ -307,12 +307,28 @@ The web dashboard is available at `http://127.0.0.1:4317` by default.
|
|
|
307
307
|
### Services
|
|
308
308
|
|
|
309
309
|
```bash
|
|
310
|
-
# Register a service
|
|
310
|
+
# Register a local service
|
|
311
311
|
nomoreide add service backend \
|
|
312
312
|
--command "npm run dev" \
|
|
313
313
|
--cwd /absolute/path/to/backend \
|
|
314
314
|
--port 3001
|
|
315
315
|
|
|
316
|
+
# Register a Docker Compose service
|
|
317
|
+
nomoreide add service api \
|
|
318
|
+
--kind docker-compose \
|
|
319
|
+
--cwd /absolute/path/to/infra \
|
|
320
|
+
--compose-file docker-compose.yml \
|
|
321
|
+
--compose-service api \
|
|
322
|
+
--port 3001
|
|
323
|
+
|
|
324
|
+
# Register a remote SSH service (uses your local SSH config and agent)
|
|
325
|
+
nomoreide add service staging-api \
|
|
326
|
+
--kind ssh \
|
|
327
|
+
--host devbox \
|
|
328
|
+
--cwd /srv/app \
|
|
329
|
+
--command "npm run dev" \
|
|
330
|
+
--port 3001
|
|
331
|
+
|
|
316
332
|
# Register a bundle (ordered group of services)
|
|
317
333
|
nomoreide add bundle full-stack db backend frontend
|
|
318
334
|
|
|
@@ -378,6 +394,9 @@ All tools are prefixed with `nomoreide_` and are available to any connected MCP
|
|
|
378
394
|
| `nomoreide_start_bundle` | Start all services in a bundle |
|
|
379
395
|
| `nomoreide_stop_bundle` | Stop all services in a bundle |
|
|
380
396
|
| `nomoreide_status` | Overall server status |
|
|
397
|
+
| `nomoreide_service_context` | Build a copy-paste agent context packet for a service |
|
|
398
|
+
| `nomoreide_service_health` | Computed health summaries (one service or all) |
|
|
399
|
+
| `nomoreide_timeline` | Recent debug timeline events (optionally per service) |
|
|
381
400
|
| `nomoreide_open_ui` | Open the local web UI |
|
|
382
401
|
| `nomoreide_close_ui` | Close the local web UI |
|
|
383
402
|
|
package/dist/cli/commands.js
CHANGED
|
@@ -50,16 +50,51 @@ export async function runCli(args, options = {}) {
|
|
|
50
50
|
if (!name) {
|
|
51
51
|
throw new UsageError("service name is required");
|
|
52
52
|
}
|
|
53
|
-
|
|
54
|
-
|
|
53
|
+
const kind = (flags.kind ?? "local");
|
|
54
|
+
const port = flags.port ? Number(flags.port) : undefined;
|
|
55
|
+
const description = flags.description;
|
|
56
|
+
if (kind === "docker-compose") {
|
|
57
|
+
if (!flags.composeService) {
|
|
58
|
+
throw new UsageError("--compose-service is required");
|
|
59
|
+
}
|
|
60
|
+
await configStore.registerService({
|
|
61
|
+
name,
|
|
62
|
+
kind: "docker-compose",
|
|
63
|
+
cwd: flags.cwd ?? process.cwd(),
|
|
64
|
+
composeFile: flags.composeFile,
|
|
65
|
+
composeService: flags.composeService,
|
|
66
|
+
port,
|
|
67
|
+
description,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else if (kind === "ssh") {
|
|
71
|
+
if (!flags.host)
|
|
72
|
+
throw new UsageError("--host is required");
|
|
73
|
+
if (!flags.command)
|
|
74
|
+
throw new UsageError("--command is required");
|
|
75
|
+
if (!flags.cwd)
|
|
76
|
+
throw new UsageError("--cwd is required");
|
|
77
|
+
await configStore.registerService({
|
|
78
|
+
name,
|
|
79
|
+
kind: "ssh",
|
|
80
|
+
host: flags.host,
|
|
81
|
+
cwd: flags.cwd,
|
|
82
|
+
command: flags.command,
|
|
83
|
+
port,
|
|
84
|
+
description,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
if (!flags.command)
|
|
89
|
+
throw new UsageError("--command is required");
|
|
90
|
+
await configStore.registerService({
|
|
91
|
+
name,
|
|
92
|
+
command: flags.command,
|
|
93
|
+
cwd: flags.cwd ?? process.cwd(),
|
|
94
|
+
port,
|
|
95
|
+
description,
|
|
96
|
+
});
|
|
55
97
|
}
|
|
56
|
-
await configStore.registerService({
|
|
57
|
-
name,
|
|
58
|
-
command: flags.command,
|
|
59
|
-
cwd: flags.cwd ?? process.cwd(),
|
|
60
|
-
port: flags.port ? Number(flags.port) : undefined,
|
|
61
|
-
description: flags.description,
|
|
62
|
-
});
|
|
63
98
|
stdout(`Registered service ${name}`);
|
|
64
99
|
return 0;
|
|
65
100
|
}
|
package/dist/cli/commands.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commands.js","sourceRoot":"","sources":["../../src/cli/commands.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EACL,WAAW,EACX,qBAAqB,EACrB,uBAAuB,GACxB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAErC,MAAM,KAAK,GACT,2EAA2E,CAAC;AAE9E,MAAM,eAAe,GAAG;IACtB,qBAAqB;IACrB,EAAE;IACF,cAAc;IACd,kEAAkE;IAClE,EAAE;IACF,YAAY;IACZ,+CAA+C;IAC/C,EAAE;IACF,aAAa;IACb,mCAAmC;IACnC,4EAA4E;IAC5E,EAAE;IACF,gCAAgC;IAChC,QAAQ;IACR,EAAE;IACF,kCAAkC;IAClC,oLAAoL;CACrL,CAAC;AASF,MAAM,CAAC,KAAK,UAAU,MAAM,CAC1B,IAAc,EACd,UAAsB,EAAE;IAExB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;IACvE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IACzE,MAAM,WAAW,GAAG,IAAI,WAAW,CACjC,OAAO,CAAC,UAAU,IAAI,uBAAuB,EAAE,CAChD,CAAC;IACF,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;QAC5B,OAAO,EAAE,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,iBAAiB,CAAC;KACrE,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC;IAE9D,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;QAE5C,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;YACxB,KAAK,MAAM,IAAI,IAAI,eAAe,EAAE,CAAC;gBACnC,MAAM,CAAC,IAAI,CAAC,CAAC;YACf,CAAC;YACD,OAAO,CAAC,CAAC;QACX,CAAC;QAED,IAAI,OAAO,KAAK,KAAK,EAAE,CAAC;YACtB,OAAO,MAAM,SAAS,CAAC,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,OAAO,KAAK,KAAK,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;YAClD,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YACxC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,MAAM,IAAI,UAAU,CAAC,0BAA0B,CAAC,CAAC;YACnD,CAAC;
|
|
1
|
+
{"version":3,"file":"commands.js","sourceRoot":"","sources":["../../src/cli/commands.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { LogEntry, ServiceDefinition, ServiceStatus, TimelineEvent } from "./types.js";
|
|
2
|
+
export interface BuildServiceAgentContextInput {
|
|
3
|
+
service: ServiceDefinition;
|
|
4
|
+
status?: ServiceStatus;
|
|
5
|
+
healthSummary: string;
|
|
6
|
+
recentLogs: LogEntry[];
|
|
7
|
+
timeline: TimelineEvent[];
|
|
8
|
+
}
|
|
9
|
+
export declare function buildServiceAgentContext(input: BuildServiceAgentContextInput): string;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export function buildServiceAgentContext(input) {
|
|
2
|
+
const lines = [
|
|
3
|
+
`Investigate NoMoreIDE service "${input.service.name}".`,
|
|
4
|
+
"",
|
|
5
|
+
"Service:",
|
|
6
|
+
`- command: ${input.service.command}`,
|
|
7
|
+
`- cwd: ${input.service.cwd}`,
|
|
8
|
+
`- configured port: ${input.service.port ?? "not configured"}`,
|
|
9
|
+
`- runtime url: ${input.status?.url ?? "not detected"}`,
|
|
10
|
+
`- state: ${input.status?.state ?? "unknown"}`,
|
|
11
|
+
`- pid: ${input.status?.pid ?? "n/a"}`,
|
|
12
|
+
"",
|
|
13
|
+
"Health:",
|
|
14
|
+
`- ${input.healthSummary}`,
|
|
15
|
+
"",
|
|
16
|
+
"Recent logs:",
|
|
17
|
+
...formatLogs(input.recentLogs),
|
|
18
|
+
"",
|
|
19
|
+
"Recent timeline:",
|
|
20
|
+
...formatTimeline(input.timeline),
|
|
21
|
+
];
|
|
22
|
+
return `${lines.join("\n")}\n`;
|
|
23
|
+
}
|
|
24
|
+
function formatLogs(logs) {
|
|
25
|
+
const significant = logs.filter((entry) => entry.stream === "stderr" || /error|warn|fail|exception/i.test(entry.text));
|
|
26
|
+
const source = significant.length > 0 ? significant : logs;
|
|
27
|
+
if (source.length === 0)
|
|
28
|
+
return ["- none"];
|
|
29
|
+
return source
|
|
30
|
+
.slice(-8)
|
|
31
|
+
.map((entry) => `- ${entry.timestamp} ${entry.stream}: ${entry.text}`);
|
|
32
|
+
}
|
|
33
|
+
function formatTimeline(events) {
|
|
34
|
+
if (events.length === 0)
|
|
35
|
+
return ["- none"];
|
|
36
|
+
return events
|
|
37
|
+
.slice(-10)
|
|
38
|
+
.map((event) => {
|
|
39
|
+
const detail = event.detail ? ` — ${event.detail}` : "";
|
|
40
|
+
return `- ${event.timestamp} [${event.severity}] ${event.title}${detail}`;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=agent-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-context.js","sourceRoot":"","sources":["../../src/core/agent-context.ts"],"names":[],"mappings":"AAeA,MAAM,UAAU,wBAAwB,CACtC,KAAoC;IAEpC,MAAM,KAAK,GAAG;QACZ,kCAAkC,KAAK,CAAC,OAAO,CAAC,IAAI,IAAI;QACxD,EAAE;QACF,UAAU;QACV,cAAc,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE;QACrC,UAAU,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC7B,sBAAsB,KAAK,CAAC,OAAO,CAAC,IAAI,IAAI,gBAAgB,EAAE;QAC9D,kBAAkB,KAAK,CAAC,MAAM,EAAE,GAAG,IAAI,cAAc,EAAE;QACvD,YAAY,KAAK,CAAC,MAAM,EAAE,KAAK,IAAI,SAAS,EAAE;QAC9C,UAAU,KAAK,CAAC,MAAM,EAAE,GAAG,IAAI,KAAK,EAAE;QACtC,EAAE;QACF,SAAS;QACT,KAAK,KAAK,CAAC,aAAa,EAAE;QAC1B,EAAE;QACF,cAAc;QACd,GAAG,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC;QAC/B,EAAE;QACF,kBAAkB;QAClB,GAAG,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC;KAClC,CAAC;IAEF,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;AACjC,CAAC;AAED,SAAS,UAAU,CAAC,IAAgB;IAClC,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAC7B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,QAAQ,IAAI,4BAA4B,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CACtF,CAAC;IACF,MAAM,MAAM,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3D,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC3C,OAAO,MAAM;SACV,KAAK,CAAC,CAAC,CAAC,CAAC;SACT,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;AAC3E,CAAC;AAED,SAAS,cAAc,CAAC,MAAuB;IAC7C,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC3C,OAAO,MAAM;SACV,KAAK,CAAC,CAAC,EAAE,CAAC;SACV,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACb,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACxD,OAAO,KAAK,KAAK,CAAC,SAAS,KAAK,KAAK,CAAC,QAAQ,KAAK,KAAK,CAAC,KAAK,GAAG,MAAM,EAAE,CAAC;IAC5E,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -2,14 +2,40 @@ import { mkdir, readFile, writeFile } from "node:fs/promises";
|
|
|
2
2
|
import { homedir } from "node:os";
|
|
3
3
|
import { dirname, isAbsolute, join } from "node:path";
|
|
4
4
|
import { z } from "zod";
|
|
5
|
-
const
|
|
5
|
+
const baseServiceSchema = z.object({
|
|
6
6
|
name: z.string().min(1),
|
|
7
|
+
port: z.number().int().positive().max(65535).optional(),
|
|
8
|
+
description: z.string().optional(),
|
|
9
|
+
});
|
|
10
|
+
const localServiceSchema = baseServiceSchema.extend({
|
|
11
|
+
kind: z.literal("local").optional(),
|
|
7
12
|
command: z.string().min(1),
|
|
8
13
|
cwd: z.string().min(1),
|
|
9
|
-
port: z.number().int().positive().max(65535).optional(),
|
|
10
14
|
env: z.record(z.string()).optional(),
|
|
11
|
-
description: z.string().optional(),
|
|
12
15
|
});
|
|
16
|
+
const dockerServiceSchema = baseServiceSchema.extend({
|
|
17
|
+
kind: z.literal("docker-compose"),
|
|
18
|
+
cwd: z.string().min(1),
|
|
19
|
+
composeFile: z.string().min(1).optional(),
|
|
20
|
+
composeService: z.string().min(1),
|
|
21
|
+
});
|
|
22
|
+
const sshServiceSchema = baseServiceSchema.extend({
|
|
23
|
+
kind: z.literal("ssh"),
|
|
24
|
+
host: z.string().min(1),
|
|
25
|
+
cwd: z.string().min(1),
|
|
26
|
+
command: z
|
|
27
|
+
.string()
|
|
28
|
+
.min(1)
|
|
29
|
+
.refine((value) => !value.includes("\0"), {
|
|
30
|
+
message: "SSH command contains invalid null byte.",
|
|
31
|
+
}),
|
|
32
|
+
env: z.record(z.string()).optional(),
|
|
33
|
+
});
|
|
34
|
+
const serviceSchema = z.union([
|
|
35
|
+
localServiceSchema,
|
|
36
|
+
dockerServiceSchema,
|
|
37
|
+
sshServiceSchema,
|
|
38
|
+
]);
|
|
13
39
|
const bundleSchema = z.object({
|
|
14
40
|
name: z.string().min(1),
|
|
15
41
|
services: z.array(z.string().min(1)),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config-store.js","sourceRoot":"","sources":["../../src/core/config-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAQxB,MAAM,
|
|
1
|
+
{"version":3,"file":"config-store.js","sourceRoot":"","sources":["../../src/core/config-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export interface DockerComposeTarget {
|
|
2
|
+
cwd: string;
|
|
3
|
+
composeFile?: string;
|
|
4
|
+
composeService: string;
|
|
5
|
+
}
|
|
6
|
+
export interface DockerComposeCommands {
|
|
7
|
+
start: [string, string[]];
|
|
8
|
+
stop: [string, string[]];
|
|
9
|
+
status: [string, string[]];
|
|
10
|
+
logs: [string, string[]];
|
|
11
|
+
}
|
|
12
|
+
export declare function createDockerComposeCommands(target: DockerComposeTarget, logTail?: number): DockerComposeCommands;
|
|
13
|
+
export interface DockerContainerInfo {
|
|
14
|
+
containerId?: string;
|
|
15
|
+
state?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare function startDockerService(target: DockerComposeTarget): Promise<DockerContainerInfo>;
|
|
18
|
+
export declare function stopDockerService(target: DockerComposeTarget): Promise<void>;
|
|
19
|
+
export declare function readDockerServiceStatus(target: DockerComposeTarget): Promise<DockerContainerInfo>;
|
|
20
|
+
export declare function readDockerServiceLogs(target: DockerComposeTarget, tail?: number): Promise<string>;
|
|
21
|
+
export declare function parseDockerPsOutput(stdout: string): DockerContainerInfo;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { execFile } from "node:child_process";
|
|
2
|
+
import { promisify } from "node:util";
|
|
3
|
+
const execFileAsync = promisify(execFile);
|
|
4
|
+
export function createDockerComposeCommands(target, logTail = 120) {
|
|
5
|
+
validateTarget(target);
|
|
6
|
+
const fileArgs = target.composeFile ? ["-f", target.composeFile] : [];
|
|
7
|
+
return {
|
|
8
|
+
start: ["docker", ["compose", ...fileArgs, "up", "-d", target.composeService]],
|
|
9
|
+
stop: ["docker", ["compose", ...fileArgs, "stop", target.composeService]],
|
|
10
|
+
status: [
|
|
11
|
+
"docker",
|
|
12
|
+
["compose", ...fileArgs, "ps", "--format", "json", target.composeService],
|
|
13
|
+
],
|
|
14
|
+
logs: [
|
|
15
|
+
"docker",
|
|
16
|
+
[
|
|
17
|
+
"compose",
|
|
18
|
+
...fileArgs,
|
|
19
|
+
"logs",
|
|
20
|
+
"--tail",
|
|
21
|
+
String(logTail),
|
|
22
|
+
target.composeService,
|
|
23
|
+
],
|
|
24
|
+
],
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
export async function startDockerService(target) {
|
|
28
|
+
const commands = createDockerComposeCommands(target);
|
|
29
|
+
await execFileAsync(commands.start[0], commands.start[1], { cwd: target.cwd });
|
|
30
|
+
return readDockerServiceStatus(target);
|
|
31
|
+
}
|
|
32
|
+
export async function stopDockerService(target) {
|
|
33
|
+
const commands = createDockerComposeCommands(target);
|
|
34
|
+
await execFileAsync(commands.stop[0], commands.stop[1], { cwd: target.cwd });
|
|
35
|
+
}
|
|
36
|
+
export async function readDockerServiceStatus(target) {
|
|
37
|
+
const commands = createDockerComposeCommands(target);
|
|
38
|
+
try {
|
|
39
|
+
const { stdout } = await execFileAsync(commands.status[0], commands.status[1], {
|
|
40
|
+
cwd: target.cwd,
|
|
41
|
+
});
|
|
42
|
+
return parseDockerPsOutput(stdout);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
return {};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
export async function readDockerServiceLogs(target, tail = 120) {
|
|
49
|
+
const commands = createDockerComposeCommands(target, tail);
|
|
50
|
+
const { stdout } = await execFileAsync(commands.logs[0], commands.logs[1], {
|
|
51
|
+
cwd: target.cwd,
|
|
52
|
+
});
|
|
53
|
+
return stdout;
|
|
54
|
+
}
|
|
55
|
+
export function parseDockerPsOutput(stdout) {
|
|
56
|
+
const lines = stdout
|
|
57
|
+
.split(/\r?\n/)
|
|
58
|
+
.map((line) => line.trim())
|
|
59
|
+
.filter((line) => line.length > 0);
|
|
60
|
+
for (const line of lines) {
|
|
61
|
+
try {
|
|
62
|
+
const parsed = JSON.parse(line);
|
|
63
|
+
if (parsed.ID) {
|
|
64
|
+
return { containerId: parsed.ID, state: parsed.State };
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch {
|
|
68
|
+
// ignore non-json line
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return {};
|
|
72
|
+
}
|
|
73
|
+
function validateTarget(target) {
|
|
74
|
+
if (!target.cwd.trim())
|
|
75
|
+
throw new Error("Docker compose cwd is required.");
|
|
76
|
+
if (!target.composeService.trim()) {
|
|
77
|
+
throw new Error("Docker compose service name is required.");
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=docker-service-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"docker-service-runner.js","sourceRoot":"","sources":["../../src/core/docker-service-runner.ts"],"names":[],"mappings":"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"}
|
package/dist/core/git-manager.js
CHANGED
|
@@ -11,7 +11,7 @@ export class GitManager {
|
|
|
11
11
|
async status() {
|
|
12
12
|
const [branch, porcelain] = await Promise.all([
|
|
13
13
|
this.git(["branch", "--show-current"]),
|
|
14
|
-
this.git(["status", "--porcelain=v1"]),
|
|
14
|
+
this.git(["status", "--porcelain=v1", "--untracked-files=all"]),
|
|
15
15
|
]);
|
|
16
16
|
return {
|
|
17
17
|
branch: branch.trim(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"git-manager.js","sourceRoot":"","sources":["../../src/core/git-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,MAAM,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;AAyB1C,MAAM,OAAO,UAAU;IACQ;IAA7B,YAA6B,MAAM,OAAO,CAAC,GAAG,EAAE;QAAnB,QAAG,GAAH,GAAG,CAAgB;IAAG,CAAC;IAEpD,KAAK,CAAC,MAAM;QACV,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC5C,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;YACtC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"git-manager.js","sourceRoot":"","sources":["../../src/core/git-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,MAAM,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;AAyB1C,MAAM,OAAO,UAAU;IACQ;IAA7B,YAA6B,MAAM,OAAO,CAAC,GAAG,EAAE;QAAnB,QAAG,GAAH,GAAG,CAAgB;IAAG,CAAC;IAEpD,KAAK,CAAC,MAAM;QACV,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC5C,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;YACtC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,CAAC,CAAC;SAChE,CAAC,CAAC;QAEH,OAAO;YACL,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE;YACrB,KAAK,EAAE,SAAS;iBACb,KAAK,CAAC,IAAI,CAAC;iBACX,MAAM,CAAC,OAAO,CAAC;iBACf,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBACd,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,GAAG;gBACrB,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,GAAG;gBAC3B,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;aACpB,CAAC,CAAC;SACN,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAa;QACtB,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,IAAa;QAC5B,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,IAAmB;QAChC,IAAI,IAAI,CAAC,KAAK,KAAK,GAAG,IAAI,IAAI,CAAC,WAAW,KAAK,GAAG,EAAE,CAAC;YACnD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC;YAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,KAAK,GAAG,EAAE;QAClB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC;YAC5B,KAAK;YACL,IAAI,KAAK,EAAE;YACX,0BAA0B;SAC3B,CAAC,CAAC;QAEH,OAAO,MAAM;aACV,KAAK,CAAC,IAAI,CAAC;aACX,MAAM,CAAC,OAAO,CAAC;aACf,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,CAAC,IAAI,GAAG,EAAE,EAAE,OAAO,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACnD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC;YAC5B,QAAQ;YACR,OAAO;YACP,mDAAmD;SACpD,CAAC,CAAC;QAEH,OAAO,MAAM;aACV,KAAK,CAAC,IAAI,CAAC;aACX,MAAM,CAAC,OAAO,CAAC;aACf,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,CAAC,OAAO,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,QAAQ,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAClE,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;YACnD,MAAM,IAAI,GAAG,MAAM;gBACjB,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC;gBACvC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC;YAC1C,OAAO;gBACL,IAAI;gBACJ,OAAO,EAAE,IAAI,KAAK,GAAG;gBACrB,MAAM;gBACN,QAAQ,EAAE,QAAQ,IAAI,SAAS;aAChC,CAAC;QACJ,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAc;QAC/B,MAAM,IAAI,GAAG,WAAW,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,cAAc,GAAG,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7E,MAAM,cAAc,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;QAEzE,OAAO,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;IACnF,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAc;QAC/B,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,EAAE,WAAW,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,KAAK,CAAC,KAAK;QACT,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,KAAe;QACzB,YAAY,CAAC,KAAK,CAAC,CAAC;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAe;QAC3B,YAAY,CAAC,KAAK,CAAC,CAAC;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAe;QAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QAED,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IAC7C,CAAC;IAEO,KAAK,CAAC,GAAG,CAAC,IAAc;QAC9B,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,aAAa,CAAC,KAAK,EAAE,IAAI,EAAE;gBAC1D,GAAG,EAAE,IAAI,CAAC,GAAG;aACd,CAAC,CAAC;YACH,OAAO,MAAM,IAAI,MAAM,CAAC;QAC1B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;gBACvB,MAAM,IAAI,KAAK,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;YAC1E,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,IAAY;QACtC,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,kBAAkB,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC;QAC1D,MAAM,YAAY,GAAG,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACrE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACpD,MAAM,SAAS,GAAG;YAChB,gBAAgB,IAAI,MAAM,IAAI,EAAE;YAChC,sBAAsB;YACtB,wBAAwB;YACxB,eAAe;YACf,SAAS,IAAI,EAAE;YACf,cAAc,UAAU,KAAK;YAC7B,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC;SAC1C,CAAC;QAEF,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,SAAS,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;QACjD,CAAC;QAED,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;IACrC,CAAC;CACF;AAED,SAAS,aAAa,CAAC,IAAY,EAAE,IAAY;IAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3C,IAAI,UAAU,KAAK,QAAQ,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,QAAQ,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC;QAC3E,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,SAAS,WAAW,CAAC,KAAa,EAAE,KAAa;IAC/C,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,GAAG,KAAK,cAAc,CAAC,CAAC;IAC1C,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,YAAY,CAAC,KAAe;IACnC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;QAC7D,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;IACxD,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAClB,KAAc;IAEd,OAAO,KAAK,YAAY,KAAK,CAAC;AAChC,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export interface HttpInspectorEvent {
|
|
2
|
+
id: string;
|
|
3
|
+
startedAt: string;
|
|
4
|
+
method: string;
|
|
5
|
+
path: string;
|
|
6
|
+
status: number;
|
|
7
|
+
durationMs: number;
|
|
8
|
+
reqBytes: number;
|
|
9
|
+
resBytes: number;
|
|
10
|
+
}
|
|
11
|
+
export interface HttpInspectorHandle {
|
|
12
|
+
port: number;
|
|
13
|
+
stop(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
export interface StartInspectorOptions {
|
|
16
|
+
upstreamPort: number;
|
|
17
|
+
upstreamHost?: string;
|
|
18
|
+
onEvent: (event: HttpInspectorEvent) => void;
|
|
19
|
+
}
|
|
20
|
+
export declare function startHttpInspector(options: StartInspectorOptions): Promise<HttpInspectorHandle>;
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { createServer, request as httpRequest, } from "node:http";
|
|
2
|
+
import { connect as netConnect } from "node:net";
|
|
3
|
+
import { randomUUID } from "node:crypto";
|
|
4
|
+
export async function startHttpInspector(options) {
|
|
5
|
+
const upstreamHost = options.upstreamHost ?? "127.0.0.1";
|
|
6
|
+
const server = createServer((clientReq, clientRes) => {
|
|
7
|
+
handleRequest(clientReq, clientRes, upstreamHost, options.upstreamPort, options.onEvent);
|
|
8
|
+
});
|
|
9
|
+
server.on("upgrade", (clientReq, clientSocket, head) => {
|
|
10
|
+
handleUpgrade(clientReq, clientSocket, head, upstreamHost, options.upstreamPort);
|
|
11
|
+
});
|
|
12
|
+
await new Promise((resolve, reject) => {
|
|
13
|
+
server.once("error", reject);
|
|
14
|
+
server.listen(0, "127.0.0.1", () => resolve());
|
|
15
|
+
});
|
|
16
|
+
const address = server.address();
|
|
17
|
+
const port = typeof address === "object" && address ? address.port : 0;
|
|
18
|
+
return {
|
|
19
|
+
port,
|
|
20
|
+
async stop() {
|
|
21
|
+
await new Promise((resolve) => {
|
|
22
|
+
server.closeAllConnections?.();
|
|
23
|
+
server.close(() => resolve());
|
|
24
|
+
});
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
function handleRequest(clientReq, clientRes, upstreamHost, upstreamPort, onEvent) {
|
|
29
|
+
const startedAt = new Date();
|
|
30
|
+
const startTime = process.hrtime.bigint();
|
|
31
|
+
const id = randomUUID();
|
|
32
|
+
let reqBytes = 0;
|
|
33
|
+
let resBytes = 0;
|
|
34
|
+
clientReq.on("data", (chunk) => {
|
|
35
|
+
reqBytes += chunk.length;
|
|
36
|
+
});
|
|
37
|
+
const upstream = httpRequest({
|
|
38
|
+
host: upstreamHost,
|
|
39
|
+
port: upstreamPort,
|
|
40
|
+
method: clientReq.method,
|
|
41
|
+
path: clientReq.url,
|
|
42
|
+
headers: rewriteHeaders(clientReq.headers, upstreamHost, upstreamPort),
|
|
43
|
+
}, (upstreamRes) => {
|
|
44
|
+
clientRes.writeHead(upstreamRes.statusCode ?? 502, upstreamRes.headers);
|
|
45
|
+
upstreamRes.on("data", (chunk) => {
|
|
46
|
+
resBytes += chunk.length;
|
|
47
|
+
});
|
|
48
|
+
upstreamRes.pipe(clientRes);
|
|
49
|
+
upstreamRes.on("end", () => {
|
|
50
|
+
const durationMs = Number(process.hrtime.bigint() - startTime) / 1_000_000;
|
|
51
|
+
onEvent({
|
|
52
|
+
id,
|
|
53
|
+
startedAt: startedAt.toISOString(),
|
|
54
|
+
method: clientReq.method ?? "GET",
|
|
55
|
+
path: clientReq.url ?? "/",
|
|
56
|
+
status: upstreamRes.statusCode ?? 0,
|
|
57
|
+
durationMs: Math.round(durationMs * 10) / 10,
|
|
58
|
+
reqBytes,
|
|
59
|
+
resBytes,
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
upstream.on("error", (error) => {
|
|
64
|
+
if (!clientRes.headersSent) {
|
|
65
|
+
clientRes.writeHead(502, { "content-type": "text/plain" });
|
|
66
|
+
clientRes.end(`Inspector upstream error: ${error.message}`);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
clientRes.end();
|
|
70
|
+
}
|
|
71
|
+
const durationMs = Number(process.hrtime.bigint() - startTime) / 1_000_000;
|
|
72
|
+
onEvent({
|
|
73
|
+
id,
|
|
74
|
+
startedAt: startedAt.toISOString(),
|
|
75
|
+
method: clientReq.method ?? "GET",
|
|
76
|
+
path: clientReq.url ?? "/",
|
|
77
|
+
status: 502,
|
|
78
|
+
durationMs: Math.round(durationMs * 10) / 10,
|
|
79
|
+
reqBytes,
|
|
80
|
+
resBytes,
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
clientReq.pipe(upstream);
|
|
84
|
+
}
|
|
85
|
+
function handleUpgrade(clientReq, clientSocket, head, upstreamHost, upstreamPort) {
|
|
86
|
+
const upstreamSocket = netConnect({ host: upstreamHost, port: upstreamPort });
|
|
87
|
+
upstreamSocket.on("connect", () => {
|
|
88
|
+
const requestLine = `${clientReq.method} ${clientReq.url} HTTP/${clientReq.httpVersion}\r\n`;
|
|
89
|
+
const headerLines = Object.entries(rewriteHeaders(clientReq.headers, upstreamHost, upstreamPort))
|
|
90
|
+
.map(([key, value]) => `${key}: ${Array.isArray(value) ? value.join(", ") : value}\r\n`)
|
|
91
|
+
.join("");
|
|
92
|
+
upstreamSocket.write(`${requestLine}${headerLines}\r\n`);
|
|
93
|
+
if (head && head.length > 0)
|
|
94
|
+
upstreamSocket.write(head);
|
|
95
|
+
upstreamSocket.pipe(clientSocket);
|
|
96
|
+
clientSocket.pipe(upstreamSocket);
|
|
97
|
+
});
|
|
98
|
+
upstreamSocket.on("error", () => clientSocket.destroy());
|
|
99
|
+
clientSocket.on("error", () => upstreamSocket.destroy());
|
|
100
|
+
}
|
|
101
|
+
function rewriteHeaders(headers, upstreamHost, upstreamPort) {
|
|
102
|
+
const out = { ...headers };
|
|
103
|
+
out.host = `${upstreamHost}:${upstreamPort}`;
|
|
104
|
+
return out;
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=http-inspector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-inspector.js","sourceRoot":"","sources":["../../src/core/http-inspector.ts"],"names":[],"mappings":"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"}
|
package/dist/core/log-store.d.ts
CHANGED
|
@@ -1,14 +1,18 @@
|
|
|
1
|
+
import type { TimelineStore } from "./timeline-store.js";
|
|
1
2
|
import type { LogEntry, LogStream } from "./types.js";
|
|
2
3
|
interface LogStoreOptions {
|
|
3
4
|
baseDir?: string;
|
|
4
5
|
maxLinesPerService?: number;
|
|
6
|
+
timelineStore?: TimelineStore;
|
|
5
7
|
}
|
|
6
8
|
export declare class LogStore {
|
|
7
9
|
private readonly entriesByService;
|
|
8
10
|
private readonly baseDir;
|
|
9
11
|
private readonly maxLinesPerService;
|
|
12
|
+
private readonly timelineStore?;
|
|
10
13
|
constructor(options?: LogStoreOptions);
|
|
11
14
|
append(service: string, stream: LogStream, text: string): Promise<LogEntry>;
|
|
12
15
|
read(service: string, limit?: number): LogEntry[];
|
|
16
|
+
private appendTimelineEvent;
|
|
13
17
|
}
|
|
14
18
|
export {};
|
package/dist/core/log-store.js
CHANGED
|
@@ -4,9 +4,11 @@ export class LogStore {
|
|
|
4
4
|
entriesByService = new Map();
|
|
5
5
|
baseDir;
|
|
6
6
|
maxLinesPerService;
|
|
7
|
+
timelineStore;
|
|
7
8
|
constructor(options = {}) {
|
|
8
9
|
this.baseDir = options.baseDir ?? ".nomoreide/logs";
|
|
9
10
|
this.maxLinesPerService = options.maxLinesPerService ?? 500;
|
|
11
|
+
this.timelineStore = options.timelineStore;
|
|
10
12
|
}
|
|
11
13
|
async append(service, stream, text) {
|
|
12
14
|
const entry = {
|
|
@@ -20,13 +22,45 @@ export class LogStore {
|
|
|
20
22
|
this.entriesByService.set(service, entries.slice(-this.maxLinesPerService));
|
|
21
23
|
await mkdir(this.baseDir, { recursive: true });
|
|
22
24
|
await appendFile(join(this.baseDir, `${safeFileName(service)}.log`), `${JSON.stringify(entry)}\n`);
|
|
25
|
+
await this.appendTimelineEvent(entry);
|
|
23
26
|
return entry;
|
|
24
27
|
}
|
|
25
28
|
read(service, limit = this.maxLinesPerService) {
|
|
26
29
|
return (this.entriesByService.get(service) ?? []).slice(-limit);
|
|
27
30
|
}
|
|
31
|
+
async appendTimelineEvent(entry) {
|
|
32
|
+
if (!this.timelineStore)
|
|
33
|
+
return;
|
|
34
|
+
const severity = classifyLogSeverity(entry.text);
|
|
35
|
+
const isReadiness = isReadinessLine(entry.text);
|
|
36
|
+
if (severity === null && !isReadiness)
|
|
37
|
+
return;
|
|
38
|
+
await this.timelineStore.append({
|
|
39
|
+
kind: "service.log",
|
|
40
|
+
service: entry.service,
|
|
41
|
+
severity: severity ?? "info",
|
|
42
|
+
title: `${entry.service} ${entry.stream}`,
|
|
43
|
+
detail: entry.text,
|
|
44
|
+
timestamp: entry.timestamp,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
28
47
|
}
|
|
29
48
|
function safeFileName(input) {
|
|
30
49
|
return input.replace(/[^a-zA-Z0-9._-]/g, "_");
|
|
31
50
|
}
|
|
51
|
+
function isReadinessLine(text) {
|
|
52
|
+
return /\b(ready|listening|local:|server started)\b/i.test(text);
|
|
53
|
+
}
|
|
54
|
+
function classifyLogSeverity(text) {
|
|
55
|
+
if (/\b(panic|fatal|traceback|uncaught|unhandled|EADDRINUSE|ECONNREFUSED|segmentation fault)\b/i.test(text)) {
|
|
56
|
+
return "error";
|
|
57
|
+
}
|
|
58
|
+
if (/\berror\b/i.test(text) && !/0 errors?\b/i.test(text)) {
|
|
59
|
+
return "error";
|
|
60
|
+
}
|
|
61
|
+
if (/\b(warn|warning|deprecated)\b/i.test(text)) {
|
|
62
|
+
return "warning";
|
|
63
|
+
}
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
32
66
|
//# sourceMappingURL=log-store.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log-store.js","sourceRoot":"","sources":["../../src/core/log-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"log-store.js","sourceRoot":"","sources":["../../src/core/log-store.ts"],"names":[],"mappings":"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"}
|