@zhixuan92/multi-model-agent 5.0.2 → 5.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -23
- package/dist/cli/index.d.ts +62 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +345 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/info.d.ts +22 -0
- package/dist/cli/info.d.ts.map +1 -0
- package/dist/cli/info.js +100 -0
- package/dist/cli/info.js.map +1 -0
- package/dist/cli/logs.d.ts +15 -0
- package/dist/cli/logs.d.ts.map +1 -0
- package/dist/cli/logs.js +102 -0
- package/dist/cli/logs.js.map +1 -0
- package/dist/cli/print-token.d.ts +18 -0
- package/dist/cli/print-token.d.ts.map +1 -0
- package/dist/cli/print-token.js +60 -0
- package/dist/cli/print-token.js.map +1 -0
- package/dist/cli/serve.d.ts +28 -0
- package/dist/cli/serve.d.ts.map +1 -0
- package/dist/cli/serve.js +405 -0
- package/dist/cli/serve.js.map +1 -0
- package/dist/cli/status.d.ts +49 -0
- package/dist/cli/status.d.ts.map +1 -0
- package/dist/cli/status.js +155 -0
- package/dist/cli/status.js.map +1 -0
- package/dist/cli/sync-skills.d.ts +58 -0
- package/dist/cli/sync-skills.d.ts.map +1 -0
- package/dist/cli/sync-skills.js +266 -0
- package/dist/cli/sync-skills.js.map +1 -0
- package/dist/cli/telemetry.d.ts +10 -0
- package/dist/cli/telemetry.d.ts.map +1 -0
- package/dist/cli/telemetry.js +161 -0
- package/dist/cli/telemetry.js.map +1 -0
- package/dist/cli/toggle.d.ts +26 -0
- package/dist/cli/toggle.d.ts.map +1 -0
- package/dist/cli/toggle.js +185 -0
- package/dist/cli/toggle.js.map +1 -0
- package/dist/http/async-dispatch.d.ts +44 -0
- package/dist/http/async-dispatch.d.ts.map +1 -0
- package/dist/http/async-dispatch.js +175 -0
- package/dist/http/async-dispatch.js.map +1 -0
- package/dist/http/auth.d.ts +20 -0
- package/dist/http/auth.d.ts.map +1 -0
- package/dist/http/auth.js +56 -0
- package/dist/http/auth.js.map +1 -0
- package/dist/http/canonicalize-file-paths.d.ts +8 -0
- package/dist/http/canonicalize-file-paths.d.ts.map +1 -0
- package/dist/http/canonicalize-file-paths.js +43 -0
- package/dist/http/canonicalize-file-paths.js.map +1 -0
- package/dist/http/cwd-validator.d.ts +11 -0
- package/dist/http/cwd-validator.d.ts.map +1 -0
- package/dist/http/cwd-validator.js +130 -0
- package/dist/http/cwd-validator.js.map +1 -0
- package/dist/http/errors.d.ts +4 -0
- package/dist/http/errors.d.ts.map +1 -0
- package/dist/http/errors.js +9 -0
- package/dist/http/errors.js.map +1 -0
- package/dist/http/execution-context.d.ts +18 -0
- package/dist/http/execution-context.d.ts.map +1 -0
- package/dist/http/execution-context.js +61 -0
- package/dist/http/execution-context.js.map +1 -0
- package/dist/http/handler-deps.d.ts +19 -0
- package/dist/http/handler-deps.d.ts.map +1 -0
- package/dist/http/handler-deps.js +2 -0
- package/dist/http/handler-deps.js.map +1 -0
- package/dist/http/handlers/control/batch-slice.d.ts +4 -0
- package/dist/http/handlers/control/batch-slice.d.ts.map +1 -0
- package/dist/http/handlers/control/batch-slice.js +40 -0
- package/dist/http/handlers/control/batch-slice.js.map +1 -0
- package/dist/http/handlers/control/batch.d.ts +23 -0
- package/dist/http/handlers/control/batch.d.ts.map +1 -0
- package/dist/http/handlers/control/batch.js +332 -0
- package/dist/http/handlers/control/batch.js.map +1 -0
- package/dist/http/handlers/control/context-blocks.d.ts +22 -0
- package/dist/http/handlers/control/context-blocks.d.ts.map +1 -0
- package/dist/http/handlers/control/context-blocks.js +111 -0
- package/dist/http/handlers/control/context-blocks.js.map +1 -0
- package/dist/http/handlers/introspection/health.d.ts +20 -0
- package/dist/http/handlers/introspection/health.d.ts.map +1 -0
- package/dist/http/handlers/introspection/health.js +18 -0
- package/dist/http/handlers/introspection/health.js.map +1 -0
- package/dist/http/handlers/introspection/status.d.ts +26 -0
- package/dist/http/handlers/introspection/status.d.ts.map +1 -0
- package/dist/http/handlers/introspection/status.js +136 -0
- package/dist/http/handlers/introspection/status.js.map +1 -0
- package/dist/http/handlers/tools/audit.d.ts +4 -0
- package/dist/http/handlers/tools/audit.d.ts.map +1 -0
- package/dist/http/handlers/tools/audit.js +43 -0
- package/dist/http/handlers/tools/audit.js.map +1 -0
- package/dist/http/handlers/tools/debug.d.ts +4 -0
- package/dist/http/handlers/tools/debug.d.ts.map +1 -0
- package/dist/http/handlers/tools/debug.js +43 -0
- package/dist/http/handlers/tools/debug.js.map +1 -0
- package/dist/http/handlers/tools/delegate.d.ts +4 -0
- package/dist/http/handlers/tools/delegate.d.ts.map +1 -0
- package/dist/http/handlers/tools/delegate.js +43 -0
- package/dist/http/handlers/tools/delegate.js.map +1 -0
- package/dist/http/handlers/tools/execute-plan.d.ts +4 -0
- package/dist/http/handlers/tools/execute-plan.d.ts.map +1 -0
- package/dist/http/handlers/tools/execute-plan.js +45 -0
- package/dist/http/handlers/tools/execute-plan.js.map +1 -0
- package/dist/http/handlers/tools/investigate.d.ts +4 -0
- package/dist/http/handlers/tools/investigate.d.ts.map +1 -0
- package/dist/http/handlers/tools/investigate.js +64 -0
- package/dist/http/handlers/tools/investigate.js.map +1 -0
- package/dist/http/handlers/tools/journal-recall.d.ts +4 -0
- package/dist/http/handlers/tools/journal-recall.d.ts.map +1 -0
- package/dist/http/handlers/tools/journal-recall.js +40 -0
- package/dist/http/handlers/tools/journal-recall.js.map +1 -0
- package/dist/http/handlers/tools/journal-record.d.ts +12 -0
- package/dist/http/handlers/tools/journal-record.d.ts.map +1 -0
- package/dist/http/handlers/tools/journal-record.js +43 -0
- package/dist/http/handlers/tools/journal-record.js.map +1 -0
- package/dist/http/handlers/tools/research.d.ts +4 -0
- package/dist/http/handlers/tools/research.d.ts.map +1 -0
- package/dist/http/handlers/tools/research.js +64 -0
- package/dist/http/handlers/tools/research.js.map +1 -0
- package/dist/http/handlers/tools/retry.d.ts +4 -0
- package/dist/http/handlers/tools/retry.d.ts.map +1 -0
- package/dist/http/handlers/tools/retry.js +49 -0
- package/dist/http/handlers/tools/retry.js.map +1 -0
- package/dist/http/handlers/tools/review.d.ts +4 -0
- package/dist/http/handlers/tools/review.d.ts.map +1 -0
- package/dist/http/handlers/tools/review.js +43 -0
- package/dist/http/handlers/tools/review.js.map +1 -0
- package/dist/http/middleware/body-reader.d.ts +16 -0
- package/dist/http/middleware/body-reader.d.ts.map +1 -0
- package/dist/http/middleware/body-reader.js +44 -0
- package/dist/http/middleware/body-reader.js.map +1 -0
- package/dist/http/middleware/caller-identity.d.ts +16 -0
- package/dist/http/middleware/caller-identity.d.ts.map +1 -0
- package/dist/http/middleware/caller-identity.js +16 -0
- package/dist/http/middleware/caller-identity.js.map +1 -0
- package/dist/http/middleware/decompress.d.ts +14 -0
- package/dist/http/middleware/decompress.d.ts.map +1 -0
- package/dist/http/middleware/decompress.js +51 -0
- package/dist/http/middleware/decompress.js.map +1 -0
- package/dist/http/project-registry.d.ts +54 -0
- package/dist/http/project-registry.d.ts.map +1 -0
- package/dist/http/project-registry.js +130 -0
- package/dist/http/project-registry.js.map +1 -0
- package/dist/http/request-observability.d.ts +8 -0
- package/dist/http/request-observability.d.ts.map +1 -0
- package/dist/http/request-observability.js +20 -0
- package/dist/http/request-observability.js.map +1 -0
- package/dist/http/request-pipeline.d.ts +16 -0
- package/dist/http/request-pipeline.d.ts.map +1 -0
- package/dist/http/request-pipeline.js +144 -0
- package/dist/http/request-pipeline.js.map +1 -0
- package/dist/http/server.d.ts +17 -0
- package/dist/http/server.d.ts.map +1 -0
- package/dist/http/server.js +300 -0
- package/dist/http/server.js.map +1 -0
- package/dist/http/types.d.ts +20 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +2 -0
- package/dist/http/types.js.map +1 -0
- package/dist/skill-install/disabled-state.d.ts +35 -0
- package/dist/skill-install/disabled-state.d.ts.map +1 -0
- package/dist/skill-install/disabled-state.js +96 -0
- package/dist/skill-install/disabled-state.js.map +1 -0
- package/dist/skill-install/discover.d.ts +29 -0
- package/dist/skill-install/discover.d.ts.map +1 -0
- package/dist/skill-install/discover.js +104 -0
- package/dist/skill-install/discover.js.map +1 -0
- package/dist/skill-install/include-utils.d.ts +27 -0
- package/dist/skill-install/include-utils.d.ts.map +1 -0
- package/dist/skill-install/include-utils.js +90 -0
- package/dist/skill-install/include-utils.js.map +1 -0
- package/dist/skill-install/manifest.d.ts +82 -0
- package/dist/skill-install/manifest.d.ts.map +1 -0
- package/dist/skill-install/manifest.js +215 -0
- package/dist/skill-install/manifest.js.map +1 -0
- package/dist/skill-install/skill-installer-common.d.ts +26 -0
- package/dist/skill-install/skill-installer-common.d.ts.map +1 -0
- package/dist/skill-install/skill-installer-common.js +139 -0
- package/dist/skill-install/skill-installer-common.js.map +1 -0
- package/dist/skill-install/skill-installers/claude-code.d.ts +43 -0
- package/dist/skill-install/skill-installers/claude-code.d.ts.map +1 -0
- package/dist/skill-install/skill-installers/claude-code.js +65 -0
- package/dist/skill-install/skill-installers/claude-code.js.map +1 -0
- package/dist/skill-install/skill-installers/codex-cli.d.ts +27 -0
- package/dist/skill-install/skill-installers/codex-cli.d.ts.map +1 -0
- package/dist/skill-install/skill-installers/codex-cli.js +84 -0
- package/dist/skill-install/skill-installers/codex-cli.js.map +1 -0
- package/dist/skill-install/skill-installers/cursor.d.ts +72 -0
- package/dist/skill-install/skill-installers/cursor.d.ts.map +1 -0
- package/dist/skill-install/skill-installers/cursor.js +81 -0
- package/dist/skill-install/skill-installers/cursor.js.map +1 -0
- package/dist/skill-install/skill-installers/gemini-cli.d.ts +50 -0
- package/dist/skill-install/skill-installers/gemini-cli.d.ts.map +1 -0
- package/dist/skill-install/skill-installers/gemini-cli.js +72 -0
- package/dist/skill-install/skill-installers/gemini-cli.js.map +1 -0
- package/dist/skill-install/skill-manifest-sync.d.ts +11 -0
- package/dist/skill-install/skill-manifest-sync.d.ts.map +1 -0
- package/dist/skill-install/skill-manifest-sync.js +65 -0
- package/dist/skill-install/skill-manifest-sync.js.map +1 -0
- package/dist/skills/_shared/auth.md +41 -0
- package/dist/skills/_shared/error-handling.md +31 -0
- package/dist/skills/_shared/polling.md +88 -0
- package/dist/skills/_shared/response-shape.md +55 -0
- package/dist/skills/_shared/review-policy.md +15 -0
- package/dist/skills/mma-audit/SKILL.md +270 -0
- package/dist/skills/mma-context-blocks/SKILL.md +148 -0
- package/dist/skills/mma-debug/SKILL.md +208 -0
- package/dist/skills/mma-delegate/SKILL.md +216 -0
- package/dist/skills/mma-execute-plan/SKILL.md +214 -0
- package/dist/skills/mma-explore/SKILL.md +190 -0
- package/dist/skills/mma-investigate/SKILL.md +258 -0
- package/dist/skills/mma-journal-recall/SKILL.md +242 -0
- package/dist/skills/mma-journal-record/SKILL.md +202 -0
- package/dist/skills/mma-research/SKILL.md +223 -0
- package/dist/skills/mma-retry/SKILL.md +221 -0
- package/dist/skills/mma-review/SKILL.md +209 -0
- package/dist/skills/multi-model-agent/SKILL.md +206 -0
- package/dist/telemetry/consent.d.ts +4 -0
- package/dist/telemetry/consent.d.ts.map +1 -0
- package/dist/telemetry/consent.js +40 -0
- package/dist/telemetry/consent.js.map +1 -0
- package/dist/telemetry/flusher.d.ts +19 -0
- package/dist/telemetry/flusher.d.ts.map +1 -0
- package/dist/telemetry/flusher.js +277 -0
- package/dist/telemetry/flusher.js.map +1 -0
- package/dist/telemetry/generation.d.ts +9 -0
- package/dist/telemetry/generation.d.ts.map +1 -0
- package/dist/telemetry/generation.js +33 -0
- package/dist/telemetry/generation.js.map +1 -0
- package/dist/telemetry/identity.d.ts +9 -0
- package/dist/telemetry/identity.d.ts.map +1 -0
- package/dist/telemetry/identity.js +35 -0
- package/dist/telemetry/identity.js.map +1 -0
- package/dist/telemetry/install-id.d.ts +13 -0
- package/dist/telemetry/install-id.d.ts.map +1 -0
- package/dist/telemetry/install-id.js +49 -0
- package/dist/telemetry/install-id.js.map +1 -0
- package/dist/telemetry/install-meta.d.ts +10 -0
- package/dist/telemetry/install-meta.d.ts.map +1 -0
- package/dist/telemetry/install-meta.js +15 -0
- package/dist/telemetry/install-meta.js.map +1 -0
- package/dist/telemetry/queue.d.ts +35 -0
- package/dist/telemetry/queue.d.ts.map +1 -0
- package/dist/telemetry/queue.js +287 -0
- package/dist/telemetry/queue.js.map +1 -0
- package/dist/telemetry/recorder.d.ts +39 -0
- package/dist/telemetry/recorder.d.ts.map +1 -0
- package/dist/telemetry/recorder.js +173 -0
- package/dist/telemetry/recorder.js.map +1 -0
- package/package.json +43 -24
- package/scripts/postinstall.js +36 -0
- package/bin/mmagent.mjs +0 -47
- package/postinstall.mjs +0 -8
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
// packages/server/src/http/handlers/introspection/status.ts
|
|
2
|
+
import { readFileSync } from 'node:fs';
|
|
3
|
+
import { homedir } from 'node:os';
|
|
4
|
+
import { join } from 'node:path';
|
|
5
|
+
import { sendJson } from '../../errors.js';
|
|
6
|
+
/**
|
|
7
|
+
* The skill manifest is installed by the `sync-skills` CLI.
|
|
8
|
+
* We read it at /status request time — if absent, skillVersion and
|
|
9
|
+
* skillCompatible are both null.
|
|
10
|
+
*/
|
|
11
|
+
const SKILL_MANIFEST_PATH = join(homedir(), '.multi-model', 'skills-install-manifest.json');
|
|
12
|
+
/**
|
|
13
|
+
* SemVer range this server is compatible with for installed skills.
|
|
14
|
+
* A manifest version that does NOT match means the skill is out of date.
|
|
15
|
+
*/
|
|
16
|
+
export const SKILL_VERSION_COMPATIBLE = '>=3.0.0 <4.0.0';
|
|
17
|
+
/** Simple semver range check: parses major.minor.patch and checks >=min <max. */
|
|
18
|
+
function checkSkillCompatible(version) {
|
|
19
|
+
// Parse the version string
|
|
20
|
+
const match = /^(\d+)\.(\d+)\.(\d+)/.exec(version);
|
|
21
|
+
if (!match)
|
|
22
|
+
return false;
|
|
23
|
+
const [, majorStr, minorStr, patchStr] = match;
|
|
24
|
+
const major = parseInt(majorStr, 10);
|
|
25
|
+
const minor = parseInt(minorStr, 10);
|
|
26
|
+
const patch = parseInt(patchStr, 10);
|
|
27
|
+
// Must be >= 3.0.0
|
|
28
|
+
if (major < 3)
|
|
29
|
+
return false;
|
|
30
|
+
if (major === 3 && minor === 0 && patch < 0)
|
|
31
|
+
return false;
|
|
32
|
+
// Must be < 4.0.0
|
|
33
|
+
if (major >= 4)
|
|
34
|
+
return false;
|
|
35
|
+
return true;
|
|
36
|
+
}
|
|
37
|
+
function readSkillManifest() {
|
|
38
|
+
try {
|
|
39
|
+
const raw = readFileSync(SKILL_MANIFEST_PATH, 'utf8');
|
|
40
|
+
const manifest = JSON.parse(raw);
|
|
41
|
+
const skillVersion = typeof manifest['skillVersion'] === 'string'
|
|
42
|
+
? manifest['skillVersion']
|
|
43
|
+
: null;
|
|
44
|
+
if (skillVersion === null) {
|
|
45
|
+
return { skillVersion: null, skillCompatible: null };
|
|
46
|
+
}
|
|
47
|
+
let skillCompatible;
|
|
48
|
+
try {
|
|
49
|
+
skillCompatible = checkSkillCompatible(skillVersion);
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
// Version parse failed — report incompatible
|
|
53
|
+
skillCompatible = false;
|
|
54
|
+
}
|
|
55
|
+
return { skillVersion, skillCompatible };
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
// File absent or unreadable
|
|
59
|
+
return { skillVersion: null, skillCompatible: null };
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* GET /status — operator introspection endpoint.
|
|
64
|
+
*
|
|
65
|
+
* Requires both:
|
|
66
|
+
* - Bearer auth (enforced by server pipeline, step 4)
|
|
67
|
+
* - Loopback origin (enforced by server pipeline, step 3 — LOOPBACK_ONLY_PATHS)
|
|
68
|
+
*
|
|
69
|
+
* Returns the §5.10 status shape.
|
|
70
|
+
*/
|
|
71
|
+
export function buildStatusHandler(deps) {
|
|
72
|
+
return (_req, res) => {
|
|
73
|
+
const { batchRegistry, projectRegistry, serverStartedAt, bind, version, } = deps;
|
|
74
|
+
const now = Date.now();
|
|
75
|
+
// ── Counters ──────────────────────────────────────────────────────────────
|
|
76
|
+
let activeRequests = 0;
|
|
77
|
+
let activeBatches = 0;
|
|
78
|
+
const projects = [];
|
|
79
|
+
for (const [, pc] of projectRegistry.entries()) {
|
|
80
|
+
const pcActiveBatches = batchRegistry.countActiveForProject(pc.cwd);
|
|
81
|
+
activeRequests += pc.activeRequests;
|
|
82
|
+
activeBatches += pcActiveBatches;
|
|
83
|
+
projects.push({
|
|
84
|
+
cwd: pc.cwd,
|
|
85
|
+
createdAt: pc.createdAt,
|
|
86
|
+
lastActivityAt: pc.lastActivityAt,
|
|
87
|
+
activeRequests: pc.activeRequests,
|
|
88
|
+
activeBatches: pcActiveBatches,
|
|
89
|
+
contextBlockCount: pc.contextBlocks.size,
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
// ── Batch lists ───────────────────────────────────────────────────────────
|
|
93
|
+
const inflight = [];
|
|
94
|
+
const recent = [];
|
|
95
|
+
for (const entry of batchRegistry.entries()) {
|
|
96
|
+
if (entry.state === 'pending') {
|
|
97
|
+
inflight.push({
|
|
98
|
+
batchId: entry.batchId,
|
|
99
|
+
tool: entry.tool,
|
|
100
|
+
cwd: entry.projectCwd,
|
|
101
|
+
startedAt: entry.startedAt,
|
|
102
|
+
state: entry.state,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
else if (entry.state === 'complete' || entry.state === 'failed') {
|
|
106
|
+
recent.push({
|
|
107
|
+
batchId: entry.batchId,
|
|
108
|
+
tool: entry.tool,
|
|
109
|
+
cwd: entry.projectCwd,
|
|
110
|
+
state: entry.state,
|
|
111
|
+
stateChangedAt: entry.stateChangedAt,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// ── Skill manifest ────────────────────────────────────────────────────────
|
|
116
|
+
const { skillVersion, skillCompatible } = readSkillManifest();
|
|
117
|
+
sendJson(res, 200, {
|
|
118
|
+
version,
|
|
119
|
+
pid: process.pid,
|
|
120
|
+
bind,
|
|
121
|
+
uptimeMs: now - serverStartedAt,
|
|
122
|
+
auth: { enabled: true },
|
|
123
|
+
counters: {
|
|
124
|
+
projectCount: projectRegistry.size,
|
|
125
|
+
activeRequests,
|
|
126
|
+
activeBatches,
|
|
127
|
+
},
|
|
128
|
+
projects,
|
|
129
|
+
inflight,
|
|
130
|
+
recent,
|
|
131
|
+
skillVersion,
|
|
132
|
+
skillCompatible,
|
|
133
|
+
});
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../../src/http/handlers/introspection/status.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/audit.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CAwC/D"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import * as audit from '@zhixuan92/multi-model-agent-core/tools/audit/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/audit/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
export function buildAuditHandler(deps) {
|
|
8
|
+
return async (_req, res, _params, ctx) => {
|
|
9
|
+
const parsed = audit.inputSchema.safeParse(ctx.body);
|
|
10
|
+
if (!parsed.success) {
|
|
11
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', {
|
|
12
|
+
fieldErrors: parsed.error.flatten(),
|
|
13
|
+
});
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const input = parsed.data;
|
|
17
|
+
const cwd = ctx.cwd;
|
|
18
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
19
|
+
if (!reserveResult.ok) {
|
|
20
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const pc = reserveResult.projectContext;
|
|
24
|
+
pc.lastActivityAt = Date.now();
|
|
25
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
26
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
27
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
28
|
+
tool: 'audit',
|
|
29
|
+
projectCwd: cwd,
|
|
30
|
+
blockIds,
|
|
31
|
+
batchRegistry: deps.batchRegistry,
|
|
32
|
+
projectContext: pc,
|
|
33
|
+
deps,
|
|
34
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
35
|
+
executor: async (executionCtx) => {
|
|
36
|
+
return executeTask(toolConfig, executionCtx, input);
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
40
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=audit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/audit.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,KAAK,MAAM,sDAAsD,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,2DAA2D,CAAC;AACvF,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAErE,MAAM,UAAU,iBAAiB,CAAC,IAAiB;IACjD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAA+B,EAAE,GAAG,EAAE,EAAE;QAChG,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE;gBACvE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;aACpC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAErB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,OAAO;YACb,UAAU,EAAE,GAAG;YACf,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,EAAE;YAClB,IAAI;YACJ,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;gBAC/B,OAAO,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAEhE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debug.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/debug.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CAwC/D"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import * as debug from '@zhixuan92/multi-model-agent-core/tools/debug/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/debug/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
export function buildDebugHandler(deps) {
|
|
8
|
+
return async (_req, res, _params, ctx) => {
|
|
9
|
+
const parsed = debug.inputSchema.safeParse(ctx.body);
|
|
10
|
+
if (!parsed.success) {
|
|
11
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', {
|
|
12
|
+
fieldErrors: parsed.error.flatten(),
|
|
13
|
+
});
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const input = parsed.data;
|
|
17
|
+
const cwd = ctx.cwd;
|
|
18
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
19
|
+
if (!reserveResult.ok) {
|
|
20
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const pc = reserveResult.projectContext;
|
|
24
|
+
pc.lastActivityAt = Date.now();
|
|
25
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
26
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
27
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
28
|
+
tool: 'debug',
|
|
29
|
+
projectCwd: cwd,
|
|
30
|
+
blockIds,
|
|
31
|
+
batchRegistry: deps.batchRegistry,
|
|
32
|
+
projectContext: pc,
|
|
33
|
+
deps,
|
|
34
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
35
|
+
executor: async (executionCtx) => {
|
|
36
|
+
return executeTask(toolConfig, executionCtx, input);
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
40
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=debug.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debug.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/debug.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,KAAK,MAAM,sDAAsD,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,2DAA2D,CAAC;AACvF,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAErE,MAAM,UAAU,iBAAiB,CAAC,IAAiB;IACjD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAA+B,EAAE,GAAG,EAAE,EAAE;QAChG,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE;gBACvE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;aACpC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAErB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,OAAO;YACb,UAAU,EAAE,GAAG;YACf,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,EAAE;YAClB,IAAI;YACJ,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;gBAC/B,OAAO,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAEhE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegate.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/delegate.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CAwClE"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import * as delegate from '@zhixuan92/multi-model-agent-core/tools/delegate/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/delegate/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
export function buildDelegateHandler(deps) {
|
|
8
|
+
return async (_req, res, _params, ctx) => {
|
|
9
|
+
const parsed = delegate.inputSchema.safeParse(ctx.body);
|
|
10
|
+
if (!parsed.success) {
|
|
11
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', {
|
|
12
|
+
fieldErrors: parsed.error.flatten(),
|
|
13
|
+
});
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const input = parsed.data;
|
|
17
|
+
const cwd = ctx.cwd;
|
|
18
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
19
|
+
if (!reserveResult.ok) {
|
|
20
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const pc = reserveResult.projectContext;
|
|
24
|
+
pc.lastActivityAt = Date.now();
|
|
25
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
26
|
+
const blockIds = input.tasks.flatMap(t => t.contextBlockIds ?? []);
|
|
27
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
28
|
+
tool: 'delegate',
|
|
29
|
+
projectCwd: cwd,
|
|
30
|
+
blockIds,
|
|
31
|
+
batchRegistry: deps.batchRegistry,
|
|
32
|
+
projectContext: pc,
|
|
33
|
+
deps,
|
|
34
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
35
|
+
executor: async (executionCtx) => {
|
|
36
|
+
return executeTask(toolConfig, executionCtx, input);
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
40
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=delegate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegate.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/delegate.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,QAAQ,MAAM,yDAAyD,CAAC;AACpF,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,8DAA8D,CAAC;AAC1F,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAGrE,MAAM,UAAU,oBAAoB,CAAC,IAAiB;IACpD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAA+B,EAAE,GAAG,EAAE,EAAE;QAChG,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE;gBACvE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;aACpC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAErB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;QACnE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,UAAU;YAChB,UAAU,EAAE,GAAG;YACf,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,EAAE;YAClB,IAAI;YACJ,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;gBAC/B,OAAO,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAEhE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-plan.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/execute-plan.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CA0CrE"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { executePlanInputSchema } from '@zhixuan92/multi-model-agent-core/tools/execute-plan/tool-config';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/execute-plan/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
export function buildExecutePlanHandler(deps) {
|
|
8
|
+
return async (_req, res, _params, ctx) => {
|
|
9
|
+
const parsed = executePlanInputSchema.safeParse(ctx.body);
|
|
10
|
+
if (!parsed.success) {
|
|
11
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', {
|
|
12
|
+
fieldErrors: parsed.error.flatten(),
|
|
13
|
+
});
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
// Carry the HTTP `?cwd=` value through to the brief slot via input.cwd.
|
|
17
|
+
// The schema marks cwd as optional; callers normally provide it via URL.
|
|
18
|
+
const cwd = ctx.cwd;
|
|
19
|
+
const input = { ...parsed.data, cwd };
|
|
20
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
21
|
+
if (!reserveResult.ok) {
|
|
22
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const pc = reserveResult.projectContext;
|
|
26
|
+
pc.lastActivityAt = Date.now();
|
|
27
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
28
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
29
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
30
|
+
tool: 'execute-plan',
|
|
31
|
+
projectCwd: cwd,
|
|
32
|
+
blockIds,
|
|
33
|
+
batchRegistry: deps.batchRegistry,
|
|
34
|
+
projectContext: pc,
|
|
35
|
+
deps,
|
|
36
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
37
|
+
executor: async (executionCtx) => {
|
|
38
|
+
return executeTask(toolConfig, executionCtx, input);
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
42
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=execute-plan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-plan.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/execute-plan.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,sBAAsB,EAAE,MAAM,kEAAkE,CAAC;AAE1G,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,kEAAkE,CAAC;AAC9F,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAGrE,MAAM,UAAU,uBAAuB,CAAC,IAAiB;IACvD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAA+B,EAAE,GAAG,EAAE,EAAE;QAChG,MAAM,MAAM,GAAG,sBAAsB,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE;gBACvE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;aACpC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,wEAAwE;QACxE,yEAAyE;QACzE,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QACrB,MAAM,KAAK,GAAyB,EAAE,GAAG,MAAM,CAAC,IAAI,EAAE,GAAG,EAA0B,CAAC;QAEpF,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,cAAc;YACpB,UAAU,EAAE,GAAG;YACf,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,EAAE;YAClB,IAAI;YACJ,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;gBAC/B,OAAO,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAEhE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"investigate.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/investigate.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGjD,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CA6DrE"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import * as investigate from '@zhixuan92/multi-model-agent-core/tools/investigate/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/investigate/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
import { canonicalizeFilePaths } from '../../canonicalize-file-paths.js';
|
|
8
|
+
export function buildInvestigateHandler(deps) {
|
|
9
|
+
return async (_req, res, _params, ctx) => {
|
|
10
|
+
const parsed = investigate.inputSchema.safeParse(ctx.body);
|
|
11
|
+
if (!parsed.success) {
|
|
12
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', {
|
|
13
|
+
fieldErrors: parsed.error.flatten(),
|
|
14
|
+
});
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const input = parsed.data;
|
|
18
|
+
const cwd = ctx.cwd;
|
|
19
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
20
|
+
if (!reserveResult.ok) {
|
|
21
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const pc = reserveResult.projectContext;
|
|
25
|
+
pc.lastActivityAt = Date.now();
|
|
26
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
27
|
+
// Validate context block IDs exist (content reaches the worker via the
|
|
28
|
+
// dispatch-time prepend keyed on TaskSpec.contextBlockIds).
|
|
29
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
30
|
+
const missingBlocks = blockIds.filter(id => pc.contextBlocks.get(id) === undefined);
|
|
31
|
+
if (missingBlocks.length > 0) {
|
|
32
|
+
sendError(res, 400, 'context_block_not_found', 'one or more context block IDs do not exist', { missingBlocks });
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
// Canonicalize file paths.
|
|
36
|
+
const rawPaths = input.filePaths ?? [];
|
|
37
|
+
const canonResult = canonicalizeFilePaths(rawPaths, cwd);
|
|
38
|
+
if (!Array.isArray(canonResult)) {
|
|
39
|
+
sendError(res, 400, 'invalid_request', 'one or more filePaths escape cwd', { fieldErrors: canonResult.fieldErrors });
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const canonicalizedFilePaths = canonResult;
|
|
43
|
+
// Build enriched input for the generic task executor.
|
|
44
|
+
const enrichedInput = {
|
|
45
|
+
...input,
|
|
46
|
+
canonicalizedFilePaths,
|
|
47
|
+
};
|
|
48
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
49
|
+
tool: 'investigate',
|
|
50
|
+
projectCwd: cwd,
|
|
51
|
+
blockIds,
|
|
52
|
+
batchRegistry: deps.batchRegistry,
|
|
53
|
+
projectContext: pc,
|
|
54
|
+
deps,
|
|
55
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
56
|
+
executor: async (executionCtx) => {
|
|
57
|
+
return executeTask(toolConfig, executionCtx, enrichedInput);
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
61
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=investigate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"investigate.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/investigate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,WAAW,MAAM,4DAA4D,CAAC;AAC1F,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAiC,MAAM,iEAAiE,CAAC;AAC5H,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAErE,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AAEzE,MAAM,UAAU,uBAAuB,CAAC,IAAiB;IACvD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE;QACxE,MAAM,MAAM,GAAG,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE;gBACvE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE;aACpC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAErB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,uEAAuE;QACvE,4DAA4D;QAC5D,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,SAAS,CAAC,CAAC;QACpF,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,yBAAyB,EAAE,4CAA4C,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;YAChH,OAAO;QACT,CAAC;QAED,2BAA2B;QAC3B,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC;QACvC,MAAM,WAAW,GAAG,qBAAqB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACzD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YAChC,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,kCAAkC,EAAE,EAAE,WAAW,EAAE,WAAW,CAAC,WAAW,EAAE,CAAC,CAAC;YACrH,OAAO;QACT,CAAC;QACD,MAAM,sBAAsB,GAAG,WAAW,CAAC;QAE3C,sDAAsD;QACtD,MAAM,aAAa,GAA6B;YAC9C,GAAG,KAAK;YACR,sBAAsB;SACvB,CAAC;QAEF,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,aAAa;YACnB,UAAU,EAAE,GAAG;YACf,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,EAAE;YAClB,IAAI;YACJ,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE;gBAC/B,OAAO,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,aAAa,CAAC,CAAC;YAC9D,CAAC;SACF,CAAC,CAAC;QAEH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAChE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"journal-recall.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/journal-recall.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CA8BvE"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import * as recall from '@zhixuan92/multi-model-agent-core/tools/journal/recall/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/journal/recall/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
export function buildJournalRecallHandler(deps) {
|
|
8
|
+
return async (_req, res, _params, ctx) => {
|
|
9
|
+
const parsed = recall.inputSchema.safeParse(ctx.body);
|
|
10
|
+
if (!parsed.success) {
|
|
11
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', { fieldErrors: parsed.error.flatten() });
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
const input = parsed.data;
|
|
15
|
+
const cwd = ctx.cwd;
|
|
16
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
17
|
+
if (!reserveResult.ok) {
|
|
18
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const pc = reserveResult.projectContext;
|
|
22
|
+
pc.lastActivityAt = Date.now();
|
|
23
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
24
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
25
|
+
const missingBlocks = blockIds.filter(id => pc.contextBlocks.get(id) === undefined);
|
|
26
|
+
if (missingBlocks.length > 0) {
|
|
27
|
+
sendError(res, 400, 'context_block_not_found', 'one or more context block IDs do not exist', { missingBlocks });
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
31
|
+
tool: 'journal-recall', projectCwd: cwd, blockIds,
|
|
32
|
+
batchRegistry: deps.batchRegistry, projectContext: pc, deps,
|
|
33
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
34
|
+
executor: async (executionCtx) => executeTask(toolConfig, executionCtx, input),
|
|
35
|
+
});
|
|
36
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
37
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=journal-recall.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"journal-recall.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/journal-recall.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,+DAA+D,CAAC;AACxF,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,oEAAoE,CAAC;AAChG,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAGrE,MAAM,UAAU,yBAAyB,CAAC,IAAiB;IACzD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE;QACxE,MAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE,EAAE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YAClH,OAAO;QACT,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QACrB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YAAC,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAAC,OAAO;QAAC,CAAC;QACnG,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,SAAS,CAAC,CAAC;QACpF,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,yBAAyB,EAAE,4CAA4C,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;YAChH,OAAO;QACT,CAAC;QACD,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,gBAAgB,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ;YACjD,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,cAAc,EAAE,EAAE,EAAE,IAAI;YAC3D,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC;SAC/E,CAAC,CAAC;QACH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAChE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as journal from '@zhixuan92/multi-model-agent-core/tools/journal/record/schema';
|
|
2
|
+
import type { ExecutionContext } from '@zhixuan92/multi-model-agent-core';
|
|
3
|
+
import type { HandlerDeps } from '../../handler-deps.js';
|
|
4
|
+
import type { RawHandler } from '../../types.js';
|
|
5
|
+
/**
|
|
6
|
+
* Executor for one journal-record dispatch. Per-cwd serialization is handled by
|
|
7
|
+
* the goal-set's `withWriteGoalLock` (in task-executor), which subsumes the old
|
|
8
|
+
* per-project journal lock — no separate lock here.
|
|
9
|
+
*/
|
|
10
|
+
export declare function journalRecordExecutor(input: journal.Input, _cwd: string): (executionCtx: ExecutionContext) => Promise<import("@zhixuan92/multi-model-agent-core/lifecycle/executor-output-types").ExecutorOutput>;
|
|
11
|
+
export declare function buildJournalRecordHandler(deps: HandlerDeps): RawHandler;
|
|
12
|
+
//# sourceMappingURL=journal-record.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"journal-record.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/journal-record.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,OAAO,MAAM,+DAA+D,CAAC;AAGzF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAG1E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD;;;;GAIG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,IAAI,EAAE,MAAM,IAC9D,cAAc,gBAAgB,yGAEvC;AAED,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CAyBvE"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import * as journal from '@zhixuan92/multi-model-agent-core/tools/journal/record/schema';
|
|
2
|
+
import { executeTask } from '@zhixuan92/multi-model-agent-core/lifecycle/task-executor';
|
|
3
|
+
import { toolConfig } from '@zhixuan92/multi-model-agent-core/tools/journal/record/tool-config';
|
|
4
|
+
import { sendError, sendJson } from '../../errors.js';
|
|
5
|
+
import { asyncDispatch } from '../../async-dispatch.js';
|
|
6
|
+
import { emitRequestReceived } from '../../request-observability.js';
|
|
7
|
+
/**
|
|
8
|
+
* Executor for one journal-record dispatch. Per-cwd serialization is handled by
|
|
9
|
+
* the goal-set's `withWriteGoalLock` (in task-executor), which subsumes the old
|
|
10
|
+
* per-project journal lock — no separate lock here.
|
|
11
|
+
*/
|
|
12
|
+
export function journalRecordExecutor(input, _cwd) {
|
|
13
|
+
return (executionCtx) => executeTask(toolConfig, executionCtx, input);
|
|
14
|
+
}
|
|
15
|
+
export function buildJournalRecordHandler(deps) {
|
|
16
|
+
return async (_req, res, _params, ctx) => {
|
|
17
|
+
const parsed = journal.inputSchema.safeParse(ctx.body);
|
|
18
|
+
if (!parsed.success) {
|
|
19
|
+
sendError(res, 400, 'invalid_request', 'Request body validation failed', { fieldErrors: parsed.error.flatten() });
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const input = parsed.data;
|
|
23
|
+
const cwd = ctx.cwd;
|
|
24
|
+
const reserveResult = deps.projectRegistry.reserveProject(cwd);
|
|
25
|
+
if (!reserveResult.ok) {
|
|
26
|
+
sendError(res, 503, reserveResult.error, reserveResult.message);
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const pc = reserveResult.projectContext;
|
|
30
|
+
pc.lastActivityAt = Date.now();
|
|
31
|
+
deps.projectRegistry.cancelReservation(cwd);
|
|
32
|
+
const blockIds = input.contextBlockIds ?? [];
|
|
33
|
+
const { batchId, statusUrl } = asyncDispatch({
|
|
34
|
+
tool: 'journal-record', projectCwd: cwd, blockIds,
|
|
35
|
+
batchRegistry: deps.batchRegistry, projectContext: pc, deps,
|
|
36
|
+
caller: { client: ctx.callerClient, mainModel: ctx.mainModel },
|
|
37
|
+
executor: journalRecordExecutor(input, cwd),
|
|
38
|
+
});
|
|
39
|
+
await emitRequestReceived(deps, batchId, _req.url ?? '', input);
|
|
40
|
+
sendJson(res, 202, { batchId, statusUrl });
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=journal-record.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"journal-record.js","sourceRoot":"","sources":["../../../../src/http/handlers/tools/journal-record.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,OAAO,MAAM,+DAA+D,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,MAAM,2DAA2D,CAAC;AACxF,OAAO,EAAE,UAAU,EAAE,MAAM,oEAAoE,CAAC;AAEhG,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAGrE;;;;GAIG;AACH,MAAM,UAAU,qBAAqB,CAAC,KAAoB,EAAE,IAAY;IACtE,OAAO,CAAC,YAA8B,EAAE,EAAE,CACxC,WAAW,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,IAAiB;IACzD,OAAO,KAAK,EAAE,IAAqB,EAAE,GAAmB,EAAE,OAA+B,EAAE,GAAG,EAAE,EAAE;QAChG,MAAM,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACvD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,gCAAgC,EAAE,EAAE,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YAClH,OAAO;QACT,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;QAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QACrB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC;YAAC,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YAAC,OAAO;QAAC,CAAC;QACnG,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,CAAC;QACxC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE,CAAC;QAC7C,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;YAC3C,IAAI,EAAE,gBAAgB,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ;YACjD,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,cAAc,EAAE,EAAE,EAAE,IAAI;YAC3D,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,CAAC,SAAS,EAAE;YAC9D,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,GAAG,CAAC;SAC5C,CAAC,CAAC;QACH,MAAM,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;QAChE,QAAQ,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"research.d.ts","sourceRoot":"","sources":["../../../../src/http/handlers/tools/research.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,CA4DlE"}
|