@holoscript/holoscript-agent 2.0.3 → 2.0.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/holomesh-client.d.ts +21 -1
- package/dist/holomesh-client.js +31 -0
- package/dist/holomesh-client.js.map +1 -1
- package/dist/index.js +149 -20
- package/dist/index.js.map +1 -1
- package/dist/runner.js +118 -20
- package/dist/runner.js.map +1 -1
- package/dist/supervisor.js +149 -20
- package/dist/supervisor.js.map +1 -1
- package/package.json +1 -1
package/dist/supervisor.js
CHANGED
|
@@ -109,6 +109,37 @@ var HolomeshClient = class {
|
|
|
109
109
|
async delegateTask(taskId, toAgentId) {
|
|
110
110
|
return this.req("PATCH", `/team/${this.teamId}/board/${taskId}`, await this.signBody({ action: "delegate", toAgentId }));
|
|
111
111
|
}
|
|
112
|
+
// ── Cognitive-verb knowledge surface (Phase 2.2 — recall / rag_query) ────────
|
|
113
|
+
/**
|
|
114
|
+
* Query the TEAM knowledge base (the `rag_query` cognitive verb). Bearer-only
|
|
115
|
+
* GET; `q` is the server-side search filter. Returns [] on any failure so a
|
|
116
|
+
* retrieval miss never breaks a tick.
|
|
117
|
+
*/
|
|
118
|
+
async queryTeamKnowledge(query, limit = 5) {
|
|
119
|
+
const qs = new URLSearchParams({ q: query, limit: String(limit) }).toString();
|
|
120
|
+
try {
|
|
121
|
+
const data = await this.req(
|
|
122
|
+
"GET",
|
|
123
|
+
`/team/${this.teamId}/knowledge?${qs}`
|
|
124
|
+
);
|
|
125
|
+
return data.entries ?? [];
|
|
126
|
+
} catch {
|
|
127
|
+
return [];
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Query this agent's PRIVATE workspace knowledge (the `recall` cognitive verb).
|
|
132
|
+
* The endpoint has no server-side search param, so the caller filters by query
|
|
133
|
+
* client-side. Returns [] on any failure.
|
|
134
|
+
*/
|
|
135
|
+
async queryPrivateKnowledge() {
|
|
136
|
+
try {
|
|
137
|
+
const data = await this.req("GET", `/knowledge/private`);
|
|
138
|
+
return data.entries ?? [];
|
|
139
|
+
} catch {
|
|
140
|
+
return [];
|
|
141
|
+
}
|
|
142
|
+
}
|
|
112
143
|
async req(method, path, body) {
|
|
113
144
|
const url = `${this.apiBase}${path}`;
|
|
114
145
|
const res = await this.fetchImpl(url, {
|
|
@@ -569,6 +600,109 @@ function errResult(id, message) {
|
|
|
569
600
|
return { type: "tool_result", tool_use_id: id, content: message, is_error: true };
|
|
570
601
|
}
|
|
571
602
|
|
|
603
|
+
// src/cognitive-verbs.ts
|
|
604
|
+
var DEFAULT_LIMIT = 5;
|
|
605
|
+
var MAX_ENTRY_CHARS = 320;
|
|
606
|
+
var MAX_INJECTED_CHARS = 2400;
|
|
607
|
+
function strField(config, ...keys) {
|
|
608
|
+
for (const k of keys) {
|
|
609
|
+
const v = config[k];
|
|
610
|
+
if (typeof v === "string" && v.trim()) return v.trim();
|
|
611
|
+
}
|
|
612
|
+
return "";
|
|
613
|
+
}
|
|
614
|
+
function numField(config, key, fallback) {
|
|
615
|
+
const v = config[key];
|
|
616
|
+
return typeof v === "number" && Number.isFinite(v) ? v : fallback;
|
|
617
|
+
}
|
|
618
|
+
function formatEntries(entries) {
|
|
619
|
+
let out = "";
|
|
620
|
+
for (const e of entries) {
|
|
621
|
+
const line = `- ${(e.content ?? "").replace(/\s+/g, " ").trim().slice(0, MAX_ENTRY_CHARS)}`;
|
|
622
|
+
if (out.length + line.length > MAX_INJECTED_CHARS) break;
|
|
623
|
+
out += (out ? "\n" : "") + line;
|
|
624
|
+
}
|
|
625
|
+
return out;
|
|
626
|
+
}
|
|
627
|
+
async function augmentWithOnTaskCognition(deps) {
|
|
628
|
+
let content = deps.systemPrompt;
|
|
629
|
+
if (!deps.onTaskActions || deps.onTaskActions.length === 0) return content;
|
|
630
|
+
for (const action of deps.onTaskActions) {
|
|
631
|
+
try {
|
|
632
|
+
switch (action.verb) {
|
|
633
|
+
case "llm_call": {
|
|
634
|
+
const prompt = strField(action.config, "prompt");
|
|
635
|
+
if (prompt) {
|
|
636
|
+
content += `
|
|
637
|
+
|
|
638
|
+
[Brain on_task directive]
|
|
639
|
+
${prompt}`;
|
|
640
|
+
deps.log({ ev: "on-task-llm-call", taskId: deps.task.id, promptLen: prompt.length });
|
|
641
|
+
}
|
|
642
|
+
break;
|
|
643
|
+
}
|
|
644
|
+
case "rag_query": {
|
|
645
|
+
const query = strField(action.config, "query", "q") || deps.task.title;
|
|
646
|
+
const limit = numField(action.config, "limit", DEFAULT_LIMIT);
|
|
647
|
+
const entries = await deps.queryTeamKnowledge(query, limit);
|
|
648
|
+
if (entries.length > 0) {
|
|
649
|
+
content += `
|
|
650
|
+
|
|
651
|
+
[Retrieved knowledge for "${query}"]
|
|
652
|
+
${formatEntries(entries)}`;
|
|
653
|
+
}
|
|
654
|
+
deps.log({ ev: "on-task-rag-query", taskId: deps.task.id, query, retrieved: entries.length });
|
|
655
|
+
break;
|
|
656
|
+
}
|
|
657
|
+
case "recall": {
|
|
658
|
+
const query = strField(action.config, "query", "q");
|
|
659
|
+
const limit = numField(action.config, "limit", DEFAULT_LIMIT);
|
|
660
|
+
const all = await deps.queryPrivateKnowledge();
|
|
661
|
+
const needle = query.toLowerCase();
|
|
662
|
+
const matched = (needle ? all.filter((e) => `${e.id ?? ""} ${e.content ?? ""}`.toLowerCase().includes(needle)) : all).slice(0, limit);
|
|
663
|
+
if (matched.length > 0) {
|
|
664
|
+
content += `
|
|
665
|
+
|
|
666
|
+
[Recalled memory${query ? ` for "${query}"` : ""}]
|
|
667
|
+
${formatEntries(matched)}`;
|
|
668
|
+
}
|
|
669
|
+
deps.log({ ev: "on-task-recall", taskId: deps.task.id, query, recalled: matched.length });
|
|
670
|
+
break;
|
|
671
|
+
}
|
|
672
|
+
case "plan": {
|
|
673
|
+
if (!deps.plan) break;
|
|
674
|
+
const goal = strField(action.config, "goal", "prompt", "of") || deps.task.title;
|
|
675
|
+
const planText = await deps.plan(
|
|
676
|
+
`Produce a short numbered plan (max 6 steps) to accomplish this task. Be concrete and specific to the goal; do not execute it.
|
|
677
|
+
|
|
678
|
+
Goal: ${goal}`
|
|
679
|
+
);
|
|
680
|
+
const trimmed = planText.trim().slice(0, MAX_INJECTED_CHARS);
|
|
681
|
+
if (trimmed) {
|
|
682
|
+
content += `
|
|
683
|
+
|
|
684
|
+
[Plan]
|
|
685
|
+
${trimmed}`;
|
|
686
|
+
deps.log({ ev: "on-task-plan", taskId: deps.task.id, planLen: trimmed.length });
|
|
687
|
+
}
|
|
688
|
+
break;
|
|
689
|
+
}
|
|
690
|
+
// `reflect` is handled post-artifact in runner.ts, not here.
|
|
691
|
+
default:
|
|
692
|
+
break;
|
|
693
|
+
}
|
|
694
|
+
} catch (err) {
|
|
695
|
+
deps.log({
|
|
696
|
+
ev: "on-task-verb-error",
|
|
697
|
+
taskId: deps.task.id,
|
|
698
|
+
verb: action.verb,
|
|
699
|
+
message: err instanceof Error ? err.message : String(err)
|
|
700
|
+
});
|
|
701
|
+
}
|
|
702
|
+
}
|
|
703
|
+
return content;
|
|
704
|
+
}
|
|
705
|
+
|
|
572
706
|
// src/runner.ts
|
|
573
707
|
var RUNTIME_VERSION = "1.0.0";
|
|
574
708
|
var AgentRunner = class {
|
|
@@ -651,26 +785,21 @@ var AgentRunner = class {
|
|
|
651
785
|
log({ ev: "claim", taskId: target.id, title: target.title });
|
|
652
786
|
await mesh.claim(target.id);
|
|
653
787
|
const start = Date.now();
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
[Brain on_task directive]
|
|
670
|
-
${llmCallAction.config.prompt}`;
|
|
671
|
-
log({ ev: "on-task-llm-call", taskId: target.id, promptLen: llmCallAction.config.prompt.length });
|
|
672
|
-
}
|
|
673
|
-
}
|
|
788
|
+
const systemContent = await augmentWithOnTaskCognition({
|
|
789
|
+
systemPrompt: brain.systemPrompt,
|
|
790
|
+
onTaskActions: brain.onTaskActions ?? [],
|
|
791
|
+
task: { id: target.id, title: target.title },
|
|
792
|
+
queryTeamKnowledge: (q, limit) => mesh.queryTeamKnowledge(q, limit),
|
|
793
|
+
queryPrivateKnowledge: () => mesh.queryPrivateKnowledge(),
|
|
794
|
+
plan: async (prompt) => {
|
|
795
|
+
const resp = await provider.complete(
|
|
796
|
+
{ messages: [{ role: "user", content: prompt }], maxTokens: 512, temperature: 0.3 },
|
|
797
|
+
identity.llmModel
|
|
798
|
+
);
|
|
799
|
+
return resp.content;
|
|
800
|
+
},
|
|
801
|
+
log
|
|
802
|
+
});
|
|
674
803
|
const messages = [
|
|
675
804
|
{ role: "system", content: systemContent },
|
|
676
805
|
{ role: "user", content: buildTaskPrompt(target) }
|