zilmate 1.4.0 → 1.6.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/.env.example +2 -0
- package/dist/agents/coding.agent.d.ts +352 -0
- package/dist/agents/coding.agent.d.ts.map +1 -0
- package/dist/agents/coding.agent.js +34 -0
- package/dist/agents/coding.agent.js.map +1 -0
- package/dist/agents/goal-manager.agent.d.ts +125 -0
- package/dist/agents/goal-manager.agent.d.ts.map +1 -0
- package/dist/agents/goal-manager.agent.js +32 -0
- package/dist/agents/goal-manager.agent.js.map +1 -0
- package/dist/agents/manager.d.ts +261 -0
- package/dist/agents/manager.d.ts.map +1 -1
- package/dist/agents/manager.js +90 -19
- package/dist/agents/manager.js.map +1 -1
- package/dist/agents/security.agent.js +1 -1
- package/dist/agents/security.agent.js.map +1 -1
- package/dist/cli/ask.d.ts +5 -0
- package/dist/cli/ask.d.ts.map +1 -0
- package/dist/cli/ask.js +33 -0
- package/dist/cli/ask.js.map +1 -0
- package/dist/cli/doctor.d.ts.map +1 -1
- package/dist/cli/doctor.js +61 -1
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/format.d.ts +1 -0
- package/dist/cli/format.d.ts.map +1 -1
- package/dist/cli/format.js +40 -1
- package/dist/cli/format.js.map +1 -1
- package/dist/cli/interactive.d.ts.map +1 -1
- package/dist/cli/interactive.js +4 -2
- package/dist/cli/interactive.js.map +1 -1
- package/dist/cli/jobs.d.ts +4 -0
- package/dist/cli/jobs.d.ts.map +1 -1
- package/dist/cli/jobs.js +26 -0
- package/dist/cli/jobs.js.map +1 -1
- package/dist/cli/prompt.d.ts +9 -0
- package/dist/cli/prompt.d.ts.map +1 -0
- package/dist/cli/prompt.js +116 -0
- package/dist/cli/prompt.js.map +1 -0
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +95 -20
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli/spinner.d.ts +6 -0
- package/dist/cli/spinner.d.ts.map +1 -0
- package/dist/cli/spinner.js +39 -0
- package/dist/cli/spinner.js.map +1 -0
- package/dist/cli/tunnel.d.ts +12 -0
- package/dist/cli/tunnel.d.ts.map +1 -0
- package/dist/cli/tunnel.js +64 -0
- package/dist/cli/tunnel.js.map +1 -0
- package/dist/cli/voice.d.ts.map +1 -1
- package/dist/cli/voice.js +13 -4
- package/dist/cli/voice.js.map +1 -1
- package/dist/config/env.d.ts +1 -0
- package/dist/config/env.d.ts.map +1 -1
- package/dist/config/env.js +3 -2
- package/dist/config/env.js.map +1 -1
- package/dist/config/models.d.ts +1 -0
- package/dist/config/models.d.ts.map +1 -1
- package/dist/config/models.js +1 -0
- package/dist/config/models.js.map +1 -1
- package/dist/documents/pdf.d.ts +11 -0
- package/dist/documents/pdf.d.ts.map +1 -0
- package/dist/documents/pdf.js +64 -0
- package/dist/documents/pdf.js.map +1 -0
- package/dist/documents/slides.d.ts +13 -0
- package/dist/documents/slides.d.ts.map +1 -0
- package/dist/documents/slides.js +82 -0
- package/dist/documents/slides.js.map +1 -0
- package/dist/index.js +72 -3
- package/dist/index.js.map +1 -1
- package/dist/jobs/anomaly.d.ts +10 -0
- package/dist/jobs/anomaly.d.ts.map +1 -0
- package/dist/jobs/anomaly.js +52 -0
- package/dist/jobs/anomaly.js.map +1 -0
- package/dist/jobs/runner.d.ts.map +1 -1
- package/dist/jobs/runner.js +6 -0
- package/dist/jobs/runner.js.map +1 -1
- package/dist/jobs/webhook-server.d.ts +7 -0
- package/dist/jobs/webhook-server.d.ts.map +1 -0
- package/dist/jobs/webhook-server.js +56 -0
- package/dist/jobs/webhook-server.js.map +1 -0
- package/dist/memory/heal.d.ts +19 -0
- package/dist/memory/heal.d.ts.map +1 -0
- package/dist/memory/heal.js +253 -0
- package/dist/memory/heal.js.map +1 -0
- package/dist/memory/knowledge-graph.d.ts +32 -0
- package/dist/memory/knowledge-graph.d.ts.map +1 -0
- package/dist/memory/knowledge-graph.js +103 -0
- package/dist/memory/knowledge-graph.js.map +1 -0
- package/dist/memory/local-store.d.ts +1 -0
- package/dist/memory/local-store.d.ts.map +1 -1
- package/dist/memory/local-store.js +41 -8
- package/dist/memory/local-store.js.map +1 -1
- package/dist/memory/notebook.d.ts +29 -0
- package/dist/memory/notebook.d.ts.map +1 -0
- package/dist/memory/notebook.js +64 -0
- package/dist/memory/notebook.js.map +1 -0
- package/dist/memory/scratchpad.d.ts.map +1 -1
- package/dist/memory/scratchpad.js +30 -4
- package/dist/memory/scratchpad.js.map +1 -1
- package/dist/runtime/ask.d.ts +15 -0
- package/dist/runtime/ask.d.ts.map +1 -0
- package/dist/runtime/ask.js +23 -0
- package/dist/runtime/ask.js.map +1 -0
- package/dist/runtime/progress.d.ts +2 -1
- package/dist/runtime/progress.d.ts.map +1 -1
- package/dist/runtime/progress.js.map +1 -1
- package/dist/runtime/voice-confirm.d.ts +8 -0
- package/dist/runtime/voice-confirm.d.ts.map +1 -0
- package/dist/runtime/voice-confirm.js +67 -0
- package/dist/runtime/voice-confirm.js.map +1 -0
- package/dist/safety/trust-log.d.ts +23 -0
- package/dist/safety/trust-log.d.ts.map +1 -0
- package/dist/safety/trust-log.js +57 -0
- package/dist/safety/trust-log.js.map +1 -0
- package/dist/skills/loader.d.ts.map +1 -1
- package/dist/skills/loader.js +3 -0
- package/dist/skills/loader.js.map +1 -1
- package/dist/skills/registry.d.ts +22 -0
- package/dist/skills/registry.d.ts.map +1 -0
- package/dist/skills/registry.js +120 -0
- package/dist/skills/registry.js.map +1 -0
- package/dist/tools/ask.tool.d.ts +23 -0
- package/dist/tools/ask.tool.d.ts.map +1 -0
- package/dist/tools/ask.tool.js +47 -0
- package/dist/tools/ask.tool.js.map +1 -0
- package/dist/tools/computer-use.tool.d.ts.map +1 -1
- package/dist/tools/computer-use.tool.js +2 -1
- package/dist/tools/computer-use.tool.js.map +1 -1
- package/dist/tools/desktop.tool.d.ts.map +1 -1
- package/dist/tools/desktop.tool.js +3 -2
- package/dist/tools/desktop.tool.js.map +1 -1
- package/dist/tools/documents.tool.d.ts +31 -0
- package/dist/tools/documents.tool.d.ts.map +1 -0
- package/dist/tools/documents.tool.js +62 -0
- package/dist/tools/documents.tool.js.map +1 -0
- package/dist/tools/git.tool.d.ts +77 -0
- package/dist/tools/git.tool.d.ts.map +1 -0
- package/dist/tools/git.tool.js +189 -0
- package/dist/tools/git.tool.js.map +1 -0
- package/dist/tools/heal.tool.d.ts +13 -0
- package/dist/tools/heal.tool.d.ts.map +1 -0
- package/dist/tools/heal.tool.js +34 -0
- package/dist/tools/heal.tool.js.map +1 -0
- package/dist/tools/image-generate.tool.d.ts.map +1 -1
- package/dist/tools/image-generate.tool.js +2 -1
- package/dist/tools/image-generate.tool.js.map +1 -1
- package/dist/tools/knowledge.tool.d.ts +24 -0
- package/dist/tools/knowledge.tool.d.ts.map +1 -0
- package/dist/tools/knowledge.tool.js +52 -0
- package/dist/tools/knowledge.tool.js.map +1 -0
- package/dist/tools/notebook.tool.d.ts +32 -0
- package/dist/tools/notebook.tool.d.ts.map +1 -0
- package/dist/tools/notebook.tool.js +50 -0
- package/dist/tools/notebook.tool.js.map +1 -0
- package/dist/tools/notify.tool.d.ts +26 -0
- package/dist/tools/notify.tool.d.ts.map +1 -0
- package/dist/tools/notify.tool.js +65 -0
- package/dist/tools/notify.tool.js.map +1 -0
- package/dist/tools/osint.tool.d.ts.map +1 -1
- package/dist/tools/osint.tool.js +6 -3
- package/dist/tools/osint.tool.js.map +1 -1
- package/dist/tools/pentest.tool.d.ts.map +1 -1
- package/dist/tools/pentest.tool.js +5 -2
- package/dist/tools/pentest.tool.js.map +1 -1
- package/dist/tools/setup-assistant.tool.d.ts +49 -0
- package/dist/tools/setup-assistant.tool.d.ts.map +1 -0
- package/dist/tools/setup-assistant.tool.js +139 -0
- package/dist/tools/setup-assistant.tool.js.map +1 -0
- package/dist/tools/skills.tool.d.ts +21 -0
- package/dist/tools/skills.tool.d.ts.map +1 -1
- package/dist/tools/skills.tool.js +43 -10
- package/dist/tools/skills.tool.js.map +1 -1
- package/dist/tools/trust.tool.d.ts +16 -0
- package/dist/tools/trust.tool.d.ts.map +1 -0
- package/dist/tools/trust.tool.js +34 -0
- package/dist/tools/trust.tool.js.map +1 -0
- package/dist/tools/update.tool.d.ts +25 -0
- package/dist/tools/update.tool.d.ts.map +1 -0
- package/dist/tools/update.tool.js +64 -0
- package/dist/tools/update.tool.js.map +1 -0
- package/dist/tools/workspace.tool.d.ts +24 -0
- package/dist/tools/workspace.tool.d.ts.map +1 -0
- package/dist/tools/workspace.tool.js +64 -0
- package/dist/tools/workspace.tool.js.map +1 -0
- package/dist/voice/cascade.d.ts.map +1 -1
- package/dist/voice/cascade.js +4 -0
- package/dist/voice/cascade.js.map +1 -1
- package/dist/workspace/init.d.ts +3 -0
- package/dist/workspace/init.d.ts.map +1 -0
- package/dist/workspace/init.js +75 -0
- package/dist/workspace/init.js.map +1 -0
- package/dist/workspace/output-paths.d.ts +3 -0
- package/dist/workspace/output-paths.d.ts.map +1 -0
- package/dist/workspace/output-paths.js +18 -0
- package/dist/workspace/output-paths.js.map +1 -0
- package/dist/workspace/paths.d.ts +26 -0
- package/dist/workspace/paths.d.ts.map +1 -0
- package/dist/workspace/paths.js +48 -0
- package/dist/workspace/paths.js.map +1 -0
- package/package.json +5 -1
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export type NotebookEntry = {
|
|
2
|
+
id: string;
|
|
3
|
+
title: string;
|
|
4
|
+
body: string;
|
|
5
|
+
tags: string[];
|
|
6
|
+
createdAt: string;
|
|
7
|
+
updatedAt: string;
|
|
8
|
+
};
|
|
9
|
+
export type NotesStore = {
|
|
10
|
+
entries: NotebookEntry[];
|
|
11
|
+
};
|
|
12
|
+
export declare function appendNotebookMarkdown(section: string, content: string): Promise<{
|
|
13
|
+
path: string;
|
|
14
|
+
section: string;
|
|
15
|
+
appendedAt: string;
|
|
16
|
+
}>;
|
|
17
|
+
export declare function readNotebookMarkdown(): Promise<string>;
|
|
18
|
+
export declare function addNotebookEntry(input: {
|
|
19
|
+
title: string;
|
|
20
|
+
body: string;
|
|
21
|
+
tags?: string[];
|
|
22
|
+
}): Promise<NotebookEntry>;
|
|
23
|
+
export declare function listNotebookEntries(limit?: number): Promise<NotebookEntry[]>;
|
|
24
|
+
export declare function searchNotebook(query: string, limit?: number): Promise<NotebookEntry[]>;
|
|
25
|
+
export declare function getNotebookPaths(): Promise<{
|
|
26
|
+
markdown: string;
|
|
27
|
+
json: string;
|
|
28
|
+
}>;
|
|
29
|
+
//# sourceMappingURL=notebook.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notebook.d.ts","sourceRoot":"","sources":["../../src/memory/notebook.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG;IACvB,OAAO,EAAE,aAAa,EAAE,CAAC;CAC1B,CAAC;AAgBF,wBAAsB,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;;;;GAM5E;AAED,wBAAsB,oBAAoB,oBAIzC;AAED,wBAAsB,gBAAgB,CAAC,KAAK,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAAE,0BAe7F;AAED,wBAAsB,mBAAmB,CAAC,KAAK,SAAK,4BAGnD;AAED,wBAAsB,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,SAAK,4BAS7D;AAED,wBAAsB,gBAAgB;;;GAGrC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { readFile, writeFile, appendFile } from 'node:fs/promises';
|
|
2
|
+
import { existsSync } from 'node:fs';
|
|
3
|
+
import { workspaceLayout } from '../workspace/paths.js';
|
|
4
|
+
async function readNotesJson() {
|
|
5
|
+
const path = workspaceLayout().notesJson;
|
|
6
|
+
if (!existsSync(path))
|
|
7
|
+
return { entries: [] };
|
|
8
|
+
try {
|
|
9
|
+
return JSON.parse(await readFile(path, 'utf8'));
|
|
10
|
+
}
|
|
11
|
+
catch {
|
|
12
|
+
return { entries: [] };
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
async function writeNotesJson(store) {
|
|
16
|
+
await writeFile(workspaceLayout().notesJson, JSON.stringify(store, null, 2), 'utf8');
|
|
17
|
+
}
|
|
18
|
+
export async function appendNotebookMarkdown(section, content) {
|
|
19
|
+
const layout = workspaceLayout();
|
|
20
|
+
const stamp = new Date().toISOString();
|
|
21
|
+
const block = `\n## ${section}\n_${stamp}_\n\n${content.trim()}\n`;
|
|
22
|
+
await appendFile(layout.notebook, block, 'utf8');
|
|
23
|
+
return { path: layout.notebook, section, appendedAt: stamp };
|
|
24
|
+
}
|
|
25
|
+
export async function readNotebookMarkdown() {
|
|
26
|
+
const path = workspaceLayout().notebook;
|
|
27
|
+
if (!existsSync(path))
|
|
28
|
+
return '';
|
|
29
|
+
return readFile(path, 'utf8');
|
|
30
|
+
}
|
|
31
|
+
export async function addNotebookEntry(input) {
|
|
32
|
+
const store = await readNotesJson();
|
|
33
|
+
const now = new Date().toISOString();
|
|
34
|
+
const entry = {
|
|
35
|
+
id: `note_${Date.now()}`,
|
|
36
|
+
title: input.title.trim(),
|
|
37
|
+
body: input.body.trim(),
|
|
38
|
+
tags: input.tags ?? [],
|
|
39
|
+
createdAt: now,
|
|
40
|
+
updatedAt: now,
|
|
41
|
+
};
|
|
42
|
+
store.entries.unshift(entry);
|
|
43
|
+
await writeNotesJson(store);
|
|
44
|
+
await appendNotebookMarkdown(entry.title, entry.body);
|
|
45
|
+
return entry;
|
|
46
|
+
}
|
|
47
|
+
export async function listNotebookEntries(limit = 20) {
|
|
48
|
+
const store = await readNotesJson();
|
|
49
|
+
return store.entries.slice(0, limit);
|
|
50
|
+
}
|
|
51
|
+
export async function searchNotebook(query, limit = 10) {
|
|
52
|
+
const q = query.trim().toLowerCase();
|
|
53
|
+
const store = await readNotesJson();
|
|
54
|
+
return store.entries
|
|
55
|
+
.filter((entry) => entry.title.toLowerCase().includes(q)
|
|
56
|
+
|| entry.body.toLowerCase().includes(q)
|
|
57
|
+
|| entry.tags.some((tag) => tag.toLowerCase().includes(q)))
|
|
58
|
+
.slice(0, limit);
|
|
59
|
+
}
|
|
60
|
+
export async function getNotebookPaths() {
|
|
61
|
+
const layout = workspaceLayout();
|
|
62
|
+
return { markdown: layout.notebook, json: layout.notesJson };
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=notebook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notebook.js","sourceRoot":"","sources":["../../src/memory/notebook.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scratchpad.d.ts","sourceRoot":"","sources":["../../src/memory/scratchpad.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"scratchpad.d.ts","sourceRoot":"","sources":["../../src/memory/scratchpad.ts"],"names":[],"mappings":"AAiBA,wBAAsB,cAAc,CAAC,KAAK,EAAE,MAAM,mBAYjD;AAED,wBAAsB,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,mBAmBjE"}
|
|
@@ -1,12 +1,29 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { writeFile, readFile } from 'node:fs/promises';
|
|
2
|
+
import { mkdir } from 'node:fs/promises';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
import { readJson } from './local-store.js';
|
|
2
5
|
import { getRedis } from './redis.js';
|
|
6
|
+
import { workspaceLayout } from '../workspace/paths.js';
|
|
3
7
|
const scratchTtlSeconds = 60 * 60 * 24;
|
|
8
|
+
function scratchFile(runId) {
|
|
9
|
+
return path.join(workspaceLayout().scratch, `${runId}.json`);
|
|
10
|
+
}
|
|
11
|
+
async function ensureScratchDir() {
|
|
12
|
+
await mkdir(workspaceLayout().scratch, { recursive: true });
|
|
13
|
+
}
|
|
4
14
|
export async function readScratchpad(runId) {
|
|
5
15
|
const redis = getRedis();
|
|
6
16
|
if (redis)
|
|
7
17
|
return (await redis.get(`zilo-manager:scratch:${runId}`)) || '(empty)';
|
|
8
|
-
const
|
|
9
|
-
|
|
18
|
+
const file = scratchFile(runId);
|
|
19
|
+
try {
|
|
20
|
+
const note = JSON.parse(await readFile(file, 'utf8'));
|
|
21
|
+
return note.text || '(empty)';
|
|
22
|
+
}
|
|
23
|
+
catch {
|
|
24
|
+
const legacy = await readJson(`scratch-${runId}.json`, { text: '' });
|
|
25
|
+
return legacy.text || '(empty)';
|
|
26
|
+
}
|
|
10
27
|
}
|
|
11
28
|
export async function appendScratchpad(runId, text) {
|
|
12
29
|
const redis = getRedis();
|
|
@@ -16,7 +33,16 @@ export async function appendScratchpad(runId, text) {
|
|
|
16
33
|
await redis.expire(key, scratchTtlSeconds);
|
|
17
34
|
return 'Appended.';
|
|
18
35
|
}
|
|
19
|
-
await
|
|
36
|
+
await ensureScratchDir();
|
|
37
|
+
const file = scratchFile(runId);
|
|
38
|
+
let current = '';
|
|
39
|
+
try {
|
|
40
|
+
current = JSON.parse(await readFile(file, 'utf8')).text || '';
|
|
41
|
+
}
|
|
42
|
+
catch {
|
|
43
|
+
current = (await readJson(`scratch-${runId}.json`, { text: '' })).text || '';
|
|
44
|
+
}
|
|
45
|
+
await writeFile(file, JSON.stringify({ text: `${current}\n${text}`.trim() }, null, 2), 'utf8');
|
|
20
46
|
return 'Appended.';
|
|
21
47
|
}
|
|
22
48
|
//# sourceMappingURL=scratchpad.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scratchpad.js","sourceRoot":"","sources":["../../src/memory/scratchpad.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"scratchpad.js","sourceRoot":"","sources":["../../src/memory/scratchpad.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,MAAM,iBAAiB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAEvC,SAAS,WAAW,CAAC,KAAa;IAChC,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,OAAO,CAAC,CAAC;AAC/D,CAAC;AAED,KAAK,UAAU,gBAAgB;IAC7B,MAAM,KAAK,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;AAC9D,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,KAAa;IAChD,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,IAAI,KAAK;QAAE,OAAO,CAAC,MAAM,KAAK,CAAC,GAAG,CAAS,wBAAwB,KAAK,EAAE,CAAC,CAAC,IAAI,SAAS,CAAC;IAE1F,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;IAChC,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAqB,CAAC;QAC1E,OAAO,IAAI,CAAC,IAAI,IAAI,SAAS,CAAC;IAChC,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAmB,WAAW,KAAK,OAAO,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;QACvF,OAAO,MAAM,CAAC,IAAI,IAAI,SAAS,CAAC;IAClC,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,KAAa,EAAE,IAAY;IAChE,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,GAAG,GAAG,wBAAwB,KAAK,EAAE,CAAC;QAC5C,MAAM,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;QACrC,MAAM,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;QAC3C,OAAO,WAAW,CAAC;IACrB,CAAC;IAED,MAAM,gBAAgB,EAAE,CAAC;IACzB,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;IAChC,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,IAAI,CAAC;QACH,OAAO,GAAI,IAAI,CAAC,KAAK,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAsB,CAAC,IAAI,IAAI,EAAE,CAAC;IACtF,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,GAAG,CAAC,MAAM,QAAQ,CAAmB,WAAW,KAAK,OAAO,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;IACjG,CAAC;IACD,MAAM,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,GAAG,OAAO,KAAK,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAC/F,OAAO,WAAW,CAAC;AACrB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export type AskQuestionRequest = {
|
|
2
|
+
question: string;
|
|
3
|
+
options: Array<{
|
|
4
|
+
id: string;
|
|
5
|
+
label: string;
|
|
6
|
+
description?: string;
|
|
7
|
+
}>;
|
|
8
|
+
allowMultiple?: boolean;
|
|
9
|
+
required?: boolean;
|
|
10
|
+
};
|
|
11
|
+
export type AskHandler = (request: AskQuestionRequest) => Promise<string[] | null>;
|
|
12
|
+
export declare function setAskHandler(next?: AskHandler): void;
|
|
13
|
+
export declare function askUser(request: AskQuestionRequest): Promise<string[] | null>;
|
|
14
|
+
export declare function withAskHandler<T>(ask: AskHandler | undefined, run: () => Promise<T>): Promise<T>;
|
|
15
|
+
//# sourceMappingURL=ask.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ask.d.ts","sourceRoot":"","sources":["../../src/runtime/ask.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACpE,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,EAAE,kBAAkB,KAAK,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;AAInF,wBAAgB,aAAa,CAAC,IAAI,CAAC,EAAE,UAAU,QAE9C;AAED,wBAAsB,OAAO,CAAC,OAAO,EAAE,kBAAkB,GAAG,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAInF;AAED,wBAAsB,cAAc,CAAC,CAAC,EAAE,GAAG,EAAE,UAAU,GAAG,SAAS,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,cAQzF"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { isConfirmationActive } from './confirm.js';
|
|
2
|
+
let handler;
|
|
3
|
+
export function setAskHandler(next) {
|
|
4
|
+
handler = next;
|
|
5
|
+
}
|
|
6
|
+
export async function askUser(request) {
|
|
7
|
+
if (isConfirmationActive())
|
|
8
|
+
return null;
|
|
9
|
+
if (!handler)
|
|
10
|
+
return null;
|
|
11
|
+
return handler(request);
|
|
12
|
+
}
|
|
13
|
+
export async function withAskHandler(ask, run) {
|
|
14
|
+
const previous = handler;
|
|
15
|
+
handler = ask;
|
|
16
|
+
try {
|
|
17
|
+
return await run();
|
|
18
|
+
}
|
|
19
|
+
finally {
|
|
20
|
+
handler = ask ?? previous;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=ask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ask.js","sourceRoot":"","sources":["../../src/runtime/ask.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAWpD,IAAI,OAA+B,CAAC;AAEpC,MAAM,UAAU,aAAa,CAAC,IAAiB;IAC7C,OAAO,GAAG,IAAI,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,OAA2B;IACvD,IAAI,oBAAoB,EAAE;QAAE,OAAO,IAAI,CAAC;IACxC,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAC1B,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAI,GAA2B,EAAE,GAAqB;IACxF,MAAM,QAAQ,GAAG,OAAO,CAAC;IACzB,OAAO,GAAG,GAAG,CAAC;IACd,IAAI,CAAC;QACH,OAAO,MAAM,GAAG,EAAE,CAAC;IACrB,CAAC;YAAS,CAAC;QACT,OAAO,GAAG,GAAG,IAAI,QAAQ,CAAC;IAC5B,CAAC;AACH,CAAC"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
export type ProgressEvent = {
|
|
2
|
-
type: 'thinking' | 'step' | 'tool:start' | 'tool:end' | 'tool:error' | 'search:start' | 'search:end' | 'fetch:start' | 'fetch:end' | 'done';
|
|
2
|
+
type: 'thinking' | 'step' | 'tool:start' | 'tool:end' | 'tool:error' | 'search:start' | 'search:end' | 'fetch:start' | 'fetch:end' | 'done' | 'subagent:start' | 'subagent:step' | 'subagent:end';
|
|
3
3
|
label: string;
|
|
4
4
|
detail?: string;
|
|
5
|
+
agent?: string;
|
|
5
6
|
};
|
|
6
7
|
export declare function emitProgress(event: ProgressEvent): void;
|
|
7
8
|
export declare function withProgressListener<T>(progress: ((event: ProgressEvent) => void) | undefined, run: () => Promise<T>): Promise<T>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/runtime/progress.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,YAAY,GAAG,UAAU,GAAG,YAAY,GAAG,cAAc,GAAG,YAAY,GAAG,aAAa,GAAG,WAAW,GAAG,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/runtime/progress.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,YAAY,GAAG,UAAU,GAAG,YAAY,GAAG,cAAc,GAAG,YAAY,GAAG,aAAa,GAAG,WAAW,GAAG,MAAM,GAAG,gBAAgB,GAAG,eAAe,GAAG,cAAc,CAAC;IAClM,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAIF,wBAAgB,YAAY,CAAC,KAAK,EAAE,aAAa,QAGhD;AAED,wBAAsB,oBAAoB,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC,GAAG,SAAS,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,cAQ1H"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../src/runtime/progress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../src/runtime/progress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AASpD,IAAI,QAAsD,CAAC;AAE3D,MAAM,UAAU,YAAY,CAAC,KAAoB;IAC/C,IAAI,oBAAoB,EAAE;QAAE,OAAO;IACnC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC;AACpB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAI,QAAsD,EAAE,GAAqB;IACzH,MAAM,QAAQ,GAAG,QAAQ,CAAC;IAC1B,QAAQ,GAAG,QAAQ,CAAC;IACpB,IAAI,CAAC;QACH,OAAO,MAAM,GAAG,EAAE,CAAC;IACrB,CAAC;YAAS,CAAC;QACT,QAAQ,GAAG,QAAQ,CAAC;IACtB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ConfirmationHandler } from './confirm.js';
|
|
2
|
+
export declare function isWaitingForVoiceApproval(): boolean;
|
|
3
|
+
/** Route a final user transcript to an in-flight voice approval prompt. Returns true if consumed. */
|
|
4
|
+
export declare function deliverVoiceUtterance(text: string): boolean;
|
|
5
|
+
export declare function waitForVoiceUtterance(timeoutMs?: number): Promise<string>;
|
|
6
|
+
export declare function parseVoiceApproval(text: string): boolean | 'session' | null;
|
|
7
|
+
export declare function createVoiceConfirmation(speak: (text: string) => Promise<void>): ConfirmationHandler;
|
|
8
|
+
//# sourceMappingURL=voice-confirm.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voice-confirm.d.ts","sourceRoot":"","sources":["../../src/runtime/voice-confirm.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAuB,MAAM,cAAc,CAAC;AAK7E,wBAAgB,yBAAyB,YAExC;AAED,qGAAqG;AACrG,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,WAOjD;AAED,wBAAgB,qBAAqB,CAAC,SAAS,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,CAczE;AAED,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,IAAI,CAM3E;AAQD,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,mBAAmB,CAmBnG"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
let utteranceWaiter;
|
|
2
|
+
let waitingForApproval = false;
|
|
3
|
+
export function isWaitingForVoiceApproval() {
|
|
4
|
+
return waitingForApproval;
|
|
5
|
+
}
|
|
6
|
+
/** Route a final user transcript to an in-flight voice approval prompt. Returns true if consumed. */
|
|
7
|
+
export function deliverVoiceUtterance(text) {
|
|
8
|
+
if (!utteranceWaiter)
|
|
9
|
+
return false;
|
|
10
|
+
const resolve = utteranceWaiter;
|
|
11
|
+
utteranceWaiter = undefined;
|
|
12
|
+
waitingForApproval = false;
|
|
13
|
+
resolve(text);
|
|
14
|
+
return true;
|
|
15
|
+
}
|
|
16
|
+
export function waitForVoiceUtterance(timeoutMs = 20_000) {
|
|
17
|
+
return new Promise((resolve, reject) => {
|
|
18
|
+
waitingForApproval = true;
|
|
19
|
+
const timer = setTimeout(() => {
|
|
20
|
+
utteranceWaiter = undefined;
|
|
21
|
+
waitingForApproval = false;
|
|
22
|
+
reject(new Error('Voice approval timed out. Say yes, no, or session.'));
|
|
23
|
+
}, timeoutMs);
|
|
24
|
+
utteranceWaiter = (text) => {
|
|
25
|
+
clearTimeout(timer);
|
|
26
|
+
waitingForApproval = false;
|
|
27
|
+
resolve(text);
|
|
28
|
+
};
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
export function parseVoiceApproval(text) {
|
|
32
|
+
const normalized = text.toLowerCase().replace(/[^\w\s]/g, ' ').trim();
|
|
33
|
+
if (/^(yes|yeah|yep|yup|sure|ok|okay|approve|approved|proceed|go ahead|do it|affirmative)\b/.test(normalized))
|
|
34
|
+
return true;
|
|
35
|
+
if (/^(no|nope|nah|cancel|stop|deny|denied|don't|do not|negative)\b/.test(normalized))
|
|
36
|
+
return false;
|
|
37
|
+
if (/^(session|always|for session|this session)\b/.test(normalized))
|
|
38
|
+
return 'session';
|
|
39
|
+
return null;
|
|
40
|
+
}
|
|
41
|
+
function spokenSummary(request) {
|
|
42
|
+
const action = request.action || request.summary;
|
|
43
|
+
const tool = request.targetTools?.[0] || request.toolSlug;
|
|
44
|
+
return `${action} using ${tool}`;
|
|
45
|
+
}
|
|
46
|
+
export function createVoiceConfirmation(speak) {
|
|
47
|
+
return async (request) => {
|
|
48
|
+
await speak(`ZilMate needs permission to ${spokenSummary(request)}. Say yes, no, or session.`);
|
|
49
|
+
for (let attempt = 0; attempt < 4; attempt += 1) {
|
|
50
|
+
const utterance = await waitForVoiceUtterance();
|
|
51
|
+
const decision = parseVoiceApproval(utterance);
|
|
52
|
+
if (decision === null) {
|
|
53
|
+
await speak('Say yes, no, or session.');
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
if (decision === true)
|
|
57
|
+
await speak('Approved.');
|
|
58
|
+
if (decision === false)
|
|
59
|
+
await speak('Cancelled.');
|
|
60
|
+
if (decision === 'session')
|
|
61
|
+
await speak('Approved for this session.');
|
|
62
|
+
return decision;
|
|
63
|
+
}
|
|
64
|
+
return false;
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=voice-confirm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voice-confirm.js","sourceRoot":"","sources":["../../src/runtime/voice-confirm.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export type TrustAction = {
|
|
2
|
+
id: string;
|
|
3
|
+
action: string;
|
|
4
|
+
category: 'destructive' | 'outbound' | 'os-control' | 'other';
|
|
5
|
+
reversible: boolean;
|
|
6
|
+
undoHint?: string;
|
|
7
|
+
metadata?: Record<string, unknown>;
|
|
8
|
+
createdAt: string;
|
|
9
|
+
expiresAt: string;
|
|
10
|
+
undoneAt?: string;
|
|
11
|
+
};
|
|
12
|
+
export declare function logTrustAction(input: {
|
|
13
|
+
action: string;
|
|
14
|
+
category?: TrustAction['category'];
|
|
15
|
+
reversible?: boolean;
|
|
16
|
+
undoHint?: string;
|
|
17
|
+
metadata?: Record<string, unknown>;
|
|
18
|
+
undoWindowMs?: number;
|
|
19
|
+
}): Promise<TrustAction>;
|
|
20
|
+
export declare function listActiveTrustActions(): Promise<TrustAction[]>;
|
|
21
|
+
export declare function markTrustActionUndone(id: string): Promise<null>;
|
|
22
|
+
export declare function trustUndoWindowMs(): number;
|
|
23
|
+
//# sourceMappingURL=trust-log.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trust-log.d.ts","sourceRoot":"","sources":["../../src/safety/trust-log.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,aAAa,GAAG,UAAU,GAAG,YAAY,GAAG,OAAO,CAAC;IAC9D,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAQF,wBAAsB,cAAc,CAAC,KAAK,EAAE;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC;IACnC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,wBAeA;AAED,wBAAsB,sBAAsB,2BAQ3C;AAED,wBAAsB,qBAAqB,CAAC,EAAE,EAAE,MAAM,iBAkBrD;AAED,wBAAgB,iBAAiB,WAEhC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { appendFile, readFile } from 'node:fs/promises';
|
|
2
|
+
import { existsSync } from 'node:fs';
|
|
3
|
+
import { workspaceLayout } from '../workspace/paths.js';
|
|
4
|
+
const DEFAULT_UNDO_MS = Number(process.env.ZILMATE_UNDO_WINDOW_MS || 30_000);
|
|
5
|
+
async function appendTrust(action) {
|
|
6
|
+
await appendFile(workspaceLayout().trustLog, `${JSON.stringify(action)}\n`, 'utf8');
|
|
7
|
+
}
|
|
8
|
+
export async function logTrustAction(input) {
|
|
9
|
+
const now = Date.now();
|
|
10
|
+
const windowMs = input.undoWindowMs ?? DEFAULT_UNDO_MS;
|
|
11
|
+
const entry = {
|
|
12
|
+
id: `trust_${now}`,
|
|
13
|
+
action: input.action,
|
|
14
|
+
category: input.category ?? 'other',
|
|
15
|
+
reversible: input.reversible ?? false,
|
|
16
|
+
...(input.undoHint ? { undoHint: input.undoHint } : {}),
|
|
17
|
+
...(input.metadata ? { metadata: input.metadata } : {}),
|
|
18
|
+
createdAt: new Date(now).toISOString(),
|
|
19
|
+
expiresAt: new Date(now + windowMs).toISOString(),
|
|
20
|
+
};
|
|
21
|
+
await appendTrust(entry);
|
|
22
|
+
return entry;
|
|
23
|
+
}
|
|
24
|
+
export async function listActiveTrustActions() {
|
|
25
|
+
const path = workspaceLayout().trustLog;
|
|
26
|
+
if (!existsSync(path))
|
|
27
|
+
return [];
|
|
28
|
+
const now = Date.now();
|
|
29
|
+
const lines = (await readFile(path, 'utf8')).trim().split('\n').filter(Boolean);
|
|
30
|
+
return lines
|
|
31
|
+
.map((line) => JSON.parse(line))
|
|
32
|
+
.filter((action) => !action.undoneAt && new Date(action.expiresAt).getTime() > now);
|
|
33
|
+
}
|
|
34
|
+
export async function markTrustActionUndone(id) {
|
|
35
|
+
const path = workspaceLayout().trustLog;
|
|
36
|
+
if (!existsSync(path))
|
|
37
|
+
return null;
|
|
38
|
+
const lines = (await readFile(path, 'utf8')).trim().split('\n').filter(Boolean);
|
|
39
|
+
let updated = null;
|
|
40
|
+
const next = lines.map((line) => {
|
|
41
|
+
const action = JSON.parse(line);
|
|
42
|
+
if (action.id === id && !action.undoneAt) {
|
|
43
|
+
updated = { ...action, undoneAt: new Date().toISOString() };
|
|
44
|
+
return JSON.stringify(updated);
|
|
45
|
+
}
|
|
46
|
+
return line;
|
|
47
|
+
});
|
|
48
|
+
if (updated) {
|
|
49
|
+
const { writeFile } = await import('node:fs/promises');
|
|
50
|
+
await writeFile(path, `${next.join('\n')}\n`, 'utf8');
|
|
51
|
+
}
|
|
52
|
+
return updated;
|
|
53
|
+
}
|
|
54
|
+
export function trustUndoWindowMs() {
|
|
55
|
+
return DEFAULT_UNDO_MS;
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=trust-log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trust-log.js","sourceRoot":"","sources":["../../src/safety/trust-log.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,YAAY,GAAG;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG,YAAY,GAAG;IACxC,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAgDF,wBAAsB,cAAc,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC,CAmB9D;AAED,wBAAsB,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CAY7E;AAED,wBAAsB,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,SAAI,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAcpF;AAED,wBAAgB,cAAc,aAE7B"}
|
package/dist/skills/loader.js
CHANGED
|
@@ -2,6 +2,7 @@ import { readdir, readFile } from 'node:fs/promises';
|
|
|
2
2
|
import path from 'node:path';
|
|
3
3
|
import { existsSync } from 'node:fs';
|
|
4
4
|
import { homedir } from 'node:os';
|
|
5
|
+
import { workspaceLayout } from '../workspace/paths.js';
|
|
5
6
|
function parseFrontmatter(raw) {
|
|
6
7
|
const match = /^---\r?\n([\s\S]*?)\r?\n---\r?\n([\s\S]*)$/m.exec(raw);
|
|
7
8
|
if (!match)
|
|
@@ -37,7 +38,9 @@ async function findSkillFiles(root, found = []) {
|
|
|
37
38
|
return found;
|
|
38
39
|
}
|
|
39
40
|
function skillRoots() {
|
|
41
|
+
const layout = workspaceLayout();
|
|
40
42
|
const roots = [
|
|
43
|
+
layout.skills,
|
|
41
44
|
path.resolve('.agents', 'skills'),
|
|
42
45
|
path.resolve('plugins'),
|
|
43
46
|
path.resolve('skills'),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export type RegistrySkill = {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
packageRef: string;
|
|
5
|
+
url?: string;
|
|
6
|
+
source: 'skills.sh' | 'npx-skills' | 'local';
|
|
7
|
+
};
|
|
8
|
+
export declare function searchSkillsRegistry(query: string, limit?: number): Promise<RegistrySkill[]>;
|
|
9
|
+
export declare function installRegistrySkill(packageRef: string, global?: boolean): Promise<{
|
|
10
|
+
ok: boolean;
|
|
11
|
+
packageRef: string;
|
|
12
|
+
installPath: string;
|
|
13
|
+
output: string;
|
|
14
|
+
browse: string;
|
|
15
|
+
}>;
|
|
16
|
+
export declare function skillsRegistryDoctor(): Promise<{
|
|
17
|
+
name: string;
|
|
18
|
+
ok: boolean;
|
|
19
|
+
detail: string;
|
|
20
|
+
}>;
|
|
21
|
+
export declare function saveSkillSearchLog(query: string, results: RegistrySkill[]): Promise<void>;
|
|
22
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/skills/registry.ts"],"names":[],"mappings":"AASA,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC;CAC9C,CAAC;AAgCF,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,SAAI,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CA6C7F;AAED,wBAAsB,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,UAAO;;;;;;GAqB3E;AAED,wBAAsB,oBAAoB;;;;GASzC;AAED,wBAAsB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE,iBAI/E"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { execFile } from 'node:child_process';
|
|
2
|
+
import { promisify } from 'node:util';
|
|
3
|
+
import { mkdir, writeFile } from 'node:fs/promises';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
import { workspaceLayout } from '../workspace/paths.js';
|
|
6
|
+
import { initWorkspace } from '../workspace/init.js';
|
|
7
|
+
const execFileAsync = promisify(execFile);
|
|
8
|
+
function parseSkillsFindOutput(stdout) {
|
|
9
|
+
const results = [];
|
|
10
|
+
const lines = stdout.split('\n');
|
|
11
|
+
for (const line of lines) {
|
|
12
|
+
const pkg = line.match(/([A-Za-z0-9_.-]+\/[A-Za-z0-9_.-]+@[A-Za-z0-9_.-]+)/);
|
|
13
|
+
if (pkg) {
|
|
14
|
+
const packageRef = pkg[1];
|
|
15
|
+
const urlMatch = line.match(/https:\/\/skills\.sh\/[^\s]+/);
|
|
16
|
+
results.push({
|
|
17
|
+
id: packageRef.split('@').pop() || packageRef,
|
|
18
|
+
name: packageRef,
|
|
19
|
+
packageRef,
|
|
20
|
+
...(urlMatch ? { url: urlMatch[0] } : {}),
|
|
21
|
+
source: 'npx-skills',
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return results;
|
|
26
|
+
}
|
|
27
|
+
async function commandExists(command) {
|
|
28
|
+
const probe = process.platform === 'win32' ? 'where.exe' : 'which';
|
|
29
|
+
try {
|
|
30
|
+
await execFileAsync(probe, [command], { windowsHide: true, timeout: 5000 });
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
catch {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
export async function searchSkillsRegistry(query, limit = 8) {
|
|
38
|
+
const results = [];
|
|
39
|
+
try {
|
|
40
|
+
const npx = process.platform === 'win32' ? 'npx.cmd' : 'npx';
|
|
41
|
+
const { stdout } = await execFileAsync(npx, ['--yes', 'skills', 'find', query], {
|
|
42
|
+
windowsHide: true,
|
|
43
|
+
timeout: 60_000,
|
|
44
|
+
env: { ...process.env, npm_config_yes: 'true' },
|
|
45
|
+
});
|
|
46
|
+
results.push(...parseSkillsFindOutput(stdout));
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
// fall through to skills.sh fetch
|
|
50
|
+
}
|
|
51
|
+
if (results.length < limit) {
|
|
52
|
+
try {
|
|
53
|
+
const response = await fetch(`https://skills.sh/api/search?q=${encodeURIComponent(query)}`, {
|
|
54
|
+
headers: { accept: 'application/json' },
|
|
55
|
+
});
|
|
56
|
+
if (response.ok) {
|
|
57
|
+
const data = await response.json();
|
|
58
|
+
for (const item of data.results ?? []) {
|
|
59
|
+
if (!item.slug && !item.package)
|
|
60
|
+
continue;
|
|
61
|
+
results.push({
|
|
62
|
+
id: item.slug || item.name || 'skill',
|
|
63
|
+
name: item.name || item.slug || 'skill',
|
|
64
|
+
packageRef: item.package || item.slug || '',
|
|
65
|
+
...(item.url ? { url: item.url } : item.slug ? { url: `https://skills.sh/${item.slug}` } : {}),
|
|
66
|
+
source: 'skills.sh',
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
// ignore network errors
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
const seen = new Set();
|
|
76
|
+
return results.filter((item) => {
|
|
77
|
+
const key = item.packageRef || item.name;
|
|
78
|
+
if (seen.has(key))
|
|
79
|
+
return false;
|
|
80
|
+
seen.add(key);
|
|
81
|
+
return true;
|
|
82
|
+
}).slice(0, limit);
|
|
83
|
+
}
|
|
84
|
+
export async function installRegistrySkill(packageRef, global = true) {
|
|
85
|
+
await initWorkspace();
|
|
86
|
+
const layout = workspaceLayout();
|
|
87
|
+
const npx = process.platform === 'win32' ? 'npx.cmd' : 'npx';
|
|
88
|
+
const args = ['--yes', 'skills', 'add', packageRef, '-y'];
|
|
89
|
+
if (global)
|
|
90
|
+
args.push('-g');
|
|
91
|
+
args.push('--path', layout.skills);
|
|
92
|
+
const { stdout, stderr } = await execFileAsync(npx, args, {
|
|
93
|
+
windowsHide: true,
|
|
94
|
+
timeout: 120_000,
|
|
95
|
+
env: { ...process.env, npm_config_yes: 'true' },
|
|
96
|
+
});
|
|
97
|
+
return {
|
|
98
|
+
ok: true,
|
|
99
|
+
packageRef,
|
|
100
|
+
installPath: layout.skills,
|
|
101
|
+
output: `${stdout}\n${stderr}`.trim(),
|
|
102
|
+
browse: `https://skills.sh/`,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
export async function skillsRegistryDoctor() {
|
|
106
|
+
const hasNpx = await commandExists(process.platform === 'win32' ? 'npx.cmd' : 'npx');
|
|
107
|
+
return {
|
|
108
|
+
name: 'Skills registry',
|
|
109
|
+
ok: hasNpx,
|
|
110
|
+
detail: hasNpx
|
|
111
|
+
? 'npx skills find/add available (skills.sh ecosystem)'
|
|
112
|
+
: 'Install Node.js/npm to search skills.sh via npx skills',
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
export async function saveSkillSearchLog(query, results) {
|
|
116
|
+
const logPath = path.join(workspaceLayout().logs, 'skill-search.jsonl');
|
|
117
|
+
await mkdir(path.dirname(logPath), { recursive: true });
|
|
118
|
+
await writeFile(logPath, `${JSON.stringify({ query, results, at: new Date().toISOString() })}\n`, { flag: 'a' });
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/skills/registry.ts"],"names":[],"mappings":"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"}
|