zilmate 1.3.5 → 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.
Files changed (270) hide show
  1. package/.env.example +2 -0
  2. package/dist/agents/automation-planner.agent.d.ts +108 -0
  3. package/dist/agents/automation-planner.agent.d.ts.map +1 -1
  4. package/dist/agents/automation-planner.agent.js +13 -4
  5. package/dist/agents/automation-planner.agent.js.map +1 -1
  6. package/dist/agents/coding.agent.d.ts +352 -0
  7. package/dist/agents/coding.agent.d.ts.map +1 -0
  8. package/dist/agents/coding.agent.js +34 -0
  9. package/dist/agents/coding.agent.js.map +1 -0
  10. package/dist/agents/goal-manager.agent.d.ts +125 -0
  11. package/dist/agents/goal-manager.agent.d.ts.map +1 -0
  12. package/dist/agents/goal-manager.agent.js +32 -0
  13. package/dist/agents/goal-manager.agent.js.map +1 -0
  14. package/dist/agents/manager.d.ts +378 -0
  15. package/dist/agents/manager.d.ts.map +1 -1
  16. package/dist/agents/manager.js +113 -18
  17. package/dist/agents/manager.js.map +1 -1
  18. package/dist/agents/security.agent.d.ts +340 -0
  19. package/dist/agents/security.agent.d.ts.map +1 -0
  20. package/dist/agents/security.agent.js +76 -0
  21. package/dist/agents/security.agent.js.map +1 -0
  22. package/dist/cli/ask.d.ts +5 -0
  23. package/dist/cli/ask.d.ts.map +1 -0
  24. package/dist/cli/ask.js +33 -0
  25. package/dist/cli/ask.js.map +1 -0
  26. package/dist/cli/confirm.d.ts.map +1 -1
  27. package/dist/cli/confirm.js +8 -14
  28. package/dist/cli/confirm.js.map +1 -1
  29. package/dist/cli/doctor.d.ts.map +1 -1
  30. package/dist/cli/doctor.js +61 -1
  31. package/dist/cli/doctor.js.map +1 -1
  32. package/dist/cli/format.d.ts +1 -0
  33. package/dist/cli/format.d.ts.map +1 -1
  34. package/dist/cli/format.js +41 -2
  35. package/dist/cli/format.js.map +1 -1
  36. package/dist/cli/interactive.d.ts.map +1 -1
  37. package/dist/cli/interactive.js +6 -2
  38. package/dist/cli/interactive.js.map +1 -1
  39. package/dist/cli/jobs.d.ts +4 -0
  40. package/dist/cli/jobs.d.ts.map +1 -1
  41. package/dist/cli/jobs.js +26 -0
  42. package/dist/cli/jobs.js.map +1 -1
  43. package/dist/cli/prompt.d.ts +9 -0
  44. package/dist/cli/prompt.d.ts.map +1 -0
  45. package/dist/cli/prompt.js +116 -0
  46. package/dist/cli/prompt.js.map +1 -0
  47. package/dist/cli/setup.d.ts.map +1 -1
  48. package/dist/cli/setup.js +95 -20
  49. package/dist/cli/setup.js.map +1 -1
  50. package/dist/cli/spinner.d.ts +6 -0
  51. package/dist/cli/spinner.d.ts.map +1 -0
  52. package/dist/cli/spinner.js +39 -0
  53. package/dist/cli/spinner.js.map +1 -0
  54. package/dist/cli/triggers.d.ts.map +1 -1
  55. package/dist/cli/triggers.js +12 -4
  56. package/dist/cli/triggers.js.map +1 -1
  57. package/dist/cli/tunnel.d.ts +12 -0
  58. package/dist/cli/tunnel.d.ts.map +1 -0
  59. package/dist/cli/tunnel.js +64 -0
  60. package/dist/cli/tunnel.js.map +1 -0
  61. package/dist/cli/voice.d.ts.map +1 -1
  62. package/dist/cli/voice.js +13 -2
  63. package/dist/cli/voice.js.map +1 -1
  64. package/dist/config/env.d.ts +5 -0
  65. package/dist/config/env.d.ts.map +1 -1
  66. package/dist/config/env.js +7 -2
  67. package/dist/config/env.js.map +1 -1
  68. package/dist/config/models.d.ts +1 -0
  69. package/dist/config/models.d.ts.map +1 -1
  70. package/dist/config/models.js +1 -0
  71. package/dist/config/models.js.map +1 -1
  72. package/dist/documents/pdf.d.ts +11 -0
  73. package/dist/documents/pdf.d.ts.map +1 -0
  74. package/dist/documents/pdf.js +64 -0
  75. package/dist/documents/pdf.js.map +1 -0
  76. package/dist/documents/slides.d.ts +13 -0
  77. package/dist/documents/slides.d.ts.map +1 -0
  78. package/dist/documents/slides.js +82 -0
  79. package/dist/documents/slides.js.map +1 -0
  80. package/dist/index.js +72 -3
  81. package/dist/index.js.map +1 -1
  82. package/dist/jobs/anomaly.d.ts +10 -0
  83. package/dist/jobs/anomaly.d.ts.map +1 -0
  84. package/dist/jobs/anomaly.js +52 -0
  85. package/dist/jobs/anomaly.js.map +1 -0
  86. package/dist/jobs/runner.d.ts.map +1 -1
  87. package/dist/jobs/runner.js +6 -0
  88. package/dist/jobs/runner.js.map +1 -1
  89. package/dist/jobs/trigger-orchestrator.d.ts +26 -0
  90. package/dist/jobs/trigger-orchestrator.d.ts.map +1 -0
  91. package/dist/jobs/trigger-orchestrator.js +252 -0
  92. package/dist/jobs/trigger-orchestrator.js.map +1 -0
  93. package/dist/jobs/trigger-policies.d.ts +36 -0
  94. package/dist/jobs/trigger-policies.d.ts.map +1 -0
  95. package/dist/jobs/trigger-policies.js +68 -0
  96. package/dist/jobs/trigger-policies.js.map +1 -0
  97. package/dist/jobs/trigger-router.d.ts +14 -0
  98. package/dist/jobs/trigger-router.d.ts.map +1 -0
  99. package/dist/jobs/trigger-router.js +114 -0
  100. package/dist/jobs/trigger-router.js.map +1 -0
  101. package/dist/jobs/webhook-server.d.ts +7 -0
  102. package/dist/jobs/webhook-server.d.ts.map +1 -0
  103. package/dist/jobs/webhook-server.js +56 -0
  104. package/dist/jobs/webhook-server.js.map +1 -0
  105. package/dist/jobs/workflows.d.ts +4 -1
  106. package/dist/jobs/workflows.d.ts.map +1 -1
  107. package/dist/jobs/workflows.js +18 -42
  108. package/dist/jobs/workflows.js.map +1 -1
  109. package/dist/memory/heal.d.ts +19 -0
  110. package/dist/memory/heal.d.ts.map +1 -0
  111. package/dist/memory/heal.js +253 -0
  112. package/dist/memory/heal.js.map +1 -0
  113. package/dist/memory/knowledge-graph.d.ts +32 -0
  114. package/dist/memory/knowledge-graph.d.ts.map +1 -0
  115. package/dist/memory/knowledge-graph.js +103 -0
  116. package/dist/memory/knowledge-graph.js.map +1 -0
  117. package/dist/memory/local-store.d.ts +1 -0
  118. package/dist/memory/local-store.d.ts.map +1 -1
  119. package/dist/memory/local-store.js +41 -8
  120. package/dist/memory/local-store.js.map +1 -1
  121. package/dist/memory/notebook.d.ts +29 -0
  122. package/dist/memory/notebook.d.ts.map +1 -0
  123. package/dist/memory/notebook.js +64 -0
  124. package/dist/memory/notebook.js.map +1 -0
  125. package/dist/memory/personal-context.d.ts +45 -0
  126. package/dist/memory/personal-context.d.ts.map +1 -0
  127. package/dist/memory/personal-context.js +103 -0
  128. package/dist/memory/personal-context.js.map +1 -0
  129. package/dist/memory/scratchpad.d.ts.map +1 -1
  130. package/dist/memory/scratchpad.js +30 -4
  131. package/dist/memory/scratchpad.js.map +1 -1
  132. package/dist/runtime/ask.d.ts +15 -0
  133. package/dist/runtime/ask.d.ts.map +1 -0
  134. package/dist/runtime/ask.js +23 -0
  135. package/dist/runtime/ask.js.map +1 -0
  136. package/dist/runtime/confirm.d.ts +3 -0
  137. package/dist/runtime/confirm.d.ts.map +1 -1
  138. package/dist/runtime/confirm.js +38 -12
  139. package/dist/runtime/confirm.js.map +1 -1
  140. package/dist/runtime/progress.d.ts +2 -1
  141. package/dist/runtime/progress.d.ts.map +1 -1
  142. package/dist/runtime/progress.js +3 -0
  143. package/dist/runtime/progress.js.map +1 -1
  144. package/dist/runtime/voice-confirm.d.ts +8 -0
  145. package/dist/runtime/voice-confirm.d.ts.map +1 -0
  146. package/dist/runtime/voice-confirm.js +67 -0
  147. package/dist/runtime/voice-confirm.js.map +1 -0
  148. package/dist/safety/trust-log.d.ts +23 -0
  149. package/dist/safety/trust-log.d.ts.map +1 -0
  150. package/dist/safety/trust-log.js +57 -0
  151. package/dist/safety/trust-log.js.map +1 -0
  152. package/dist/server.d.ts +2 -0
  153. package/dist/server.d.ts.map +1 -1
  154. package/dist/server.js +2 -0
  155. package/dist/server.js.map +1 -1
  156. package/dist/skills/loader.d.ts +14 -0
  157. package/dist/skills/loader.d.ts.map +1 -0
  158. package/dist/skills/loader.js +108 -0
  159. package/dist/skills/loader.js.map +1 -0
  160. package/dist/skills/registry.d.ts +22 -0
  161. package/dist/skills/registry.d.ts.map +1 -0
  162. package/dist/skills/registry.js +120 -0
  163. package/dist/skills/registry.js.map +1 -0
  164. package/dist/tools/ask.tool.d.ts +23 -0
  165. package/dist/tools/ask.tool.d.ts.map +1 -0
  166. package/dist/tools/ask.tool.js +47 -0
  167. package/dist/tools/ask.tool.js.map +1 -0
  168. package/dist/tools/cli-runner.d.ts +13 -0
  169. package/dist/tools/cli-runner.d.ts.map +1 -0
  170. package/dist/tools/cli-runner.js +75 -0
  171. package/dist/tools/cli-runner.js.map +1 -0
  172. package/dist/tools/computer-use.tool.d.ts +159 -0
  173. package/dist/tools/computer-use.tool.d.ts.map +1 -0
  174. package/dist/tools/computer-use.tool.js +357 -0
  175. package/dist/tools/computer-use.tool.js.map +1 -0
  176. package/dist/tools/desktop.tool.d.ts.map +1 -1
  177. package/dist/tools/desktop.tool.js +3 -2
  178. package/dist/tools/desktop.tool.js.map +1 -1
  179. package/dist/tools/documents.tool.d.ts +31 -0
  180. package/dist/tools/documents.tool.d.ts.map +1 -0
  181. package/dist/tools/documents.tool.js +62 -0
  182. package/dist/tools/documents.tool.js.map +1 -0
  183. package/dist/tools/git.tool.d.ts +77 -0
  184. package/dist/tools/git.tool.d.ts.map +1 -0
  185. package/dist/tools/git.tool.js +189 -0
  186. package/dist/tools/git.tool.js.map +1 -0
  187. package/dist/tools/heal.tool.d.ts +13 -0
  188. package/dist/tools/heal.tool.d.ts.map +1 -0
  189. package/dist/tools/heal.tool.js +34 -0
  190. package/dist/tools/heal.tool.js.map +1 -0
  191. package/dist/tools/image-generate.tool.d.ts.map +1 -1
  192. package/dist/tools/image-generate.tool.js +2 -1
  193. package/dist/tools/image-generate.tool.js.map +1 -1
  194. package/dist/tools/knowledge.tool.d.ts +24 -0
  195. package/dist/tools/knowledge.tool.d.ts.map +1 -0
  196. package/dist/tools/knowledge.tool.js +52 -0
  197. package/dist/tools/knowledge.tool.js.map +1 -0
  198. package/dist/tools/notebook.tool.d.ts +32 -0
  199. package/dist/tools/notebook.tool.d.ts.map +1 -0
  200. package/dist/tools/notebook.tool.js +50 -0
  201. package/dist/tools/notebook.tool.js.map +1 -0
  202. package/dist/tools/notify.tool.d.ts +26 -0
  203. package/dist/tools/notify.tool.d.ts.map +1 -0
  204. package/dist/tools/notify.tool.js +65 -0
  205. package/dist/tools/notify.tool.js.map +1 -0
  206. package/dist/tools/orchestration.tool.d.ts +83 -0
  207. package/dist/tools/orchestration.tool.d.ts.map +1 -0
  208. package/dist/tools/orchestration.tool.js +154 -0
  209. package/dist/tools/orchestration.tool.js.map +1 -0
  210. package/dist/tools/osint-install.tool.d.ts +35 -0
  211. package/dist/tools/osint-install.tool.d.ts.map +1 -0
  212. package/dist/tools/osint-install.tool.js +334 -0
  213. package/dist/tools/osint-install.tool.js.map +1 -0
  214. package/dist/tools/osint.tool.d.ts +445 -0
  215. package/dist/tools/osint.tool.d.ts.map +1 -0
  216. package/dist/tools/osint.tool.js +633 -0
  217. package/dist/tools/osint.tool.js.map +1 -0
  218. package/dist/tools/pentest-install.tool.d.ts +32 -0
  219. package/dist/tools/pentest-install.tool.d.ts.map +1 -0
  220. package/dist/tools/pentest-install.tool.js +201 -0
  221. package/dist/tools/pentest-install.tool.js.map +1 -0
  222. package/dist/tools/pentest.tool.d.ts +595 -0
  223. package/dist/tools/pentest.tool.d.ts.map +1 -0
  224. package/dist/tools/pentest.tool.js +844 -0
  225. package/dist/tools/pentest.tool.js.map +1 -0
  226. package/dist/tools/personal-context.tool.d.ts +32 -0
  227. package/dist/tools/personal-context.tool.d.ts.map +1 -0
  228. package/dist/tools/personal-context.tool.js +76 -0
  229. package/dist/tools/personal-context.tool.js.map +1 -0
  230. package/dist/tools/setup-assistant.tool.d.ts +49 -0
  231. package/dist/tools/setup-assistant.tool.d.ts.map +1 -0
  232. package/dist/tools/setup-assistant.tool.js +139 -0
  233. package/dist/tools/setup-assistant.tool.js.map +1 -0
  234. package/dist/tools/skills.tool.d.ts +38 -0
  235. package/dist/tools/skills.tool.d.ts.map +1 -0
  236. package/dist/tools/skills.tool.js +77 -0
  237. package/dist/tools/skills.tool.js.map +1 -0
  238. package/dist/tools/trust.tool.d.ts +16 -0
  239. package/dist/tools/trust.tool.d.ts.map +1 -0
  240. package/dist/tools/trust.tool.js +34 -0
  241. package/dist/tools/trust.tool.js.map +1 -0
  242. package/dist/tools/update.tool.d.ts +25 -0
  243. package/dist/tools/update.tool.d.ts.map +1 -0
  244. package/dist/tools/update.tool.js +64 -0
  245. package/dist/tools/update.tool.js.map +1 -0
  246. package/dist/tools/workspace.tool.d.ts +24 -0
  247. package/dist/tools/workspace.tool.d.ts.map +1 -0
  248. package/dist/tools/workspace.tool.js +64 -0
  249. package/dist/tools/workspace.tool.js.map +1 -0
  250. package/dist/voice/cascade.d.ts.map +1 -1
  251. package/dist/voice/cascade.js +75 -24
  252. package/dist/voice/cascade.js.map +1 -1
  253. package/dist/voice/deepgram.d.ts.map +1 -1
  254. package/dist/voice/deepgram.js +8 -1
  255. package/dist/voice/deepgram.js.map +1 -1
  256. package/dist/voice/types.d.ts +4 -0
  257. package/dist/voice/types.d.ts.map +1 -1
  258. package/dist/workspace/init.d.ts +3 -0
  259. package/dist/workspace/init.d.ts.map +1 -0
  260. package/dist/workspace/init.js +75 -0
  261. package/dist/workspace/init.js.map +1 -0
  262. package/dist/workspace/output-paths.d.ts +3 -0
  263. package/dist/workspace/output-paths.d.ts.map +1 -0
  264. package/dist/workspace/output-paths.js +18 -0
  265. package/dist/workspace/output-paths.js.map +1 -0
  266. package/dist/workspace/paths.d.ts +26 -0
  267. package/dist/workspace/paths.d.ts.map +1 -0
  268. package/dist/workspace/paths.js +48 -0
  269. package/dist/workspace/paths.js.map +1 -0
  270. package/package.json +5 -1
package/.env.example CHANGED
@@ -24,6 +24,8 @@ ZILMATE_VOICE_INPUT_DEVICE=
24
24
  ZILMATE_SCREENSHOT_MODEL=google/gemini-3.1-flash-lite
25
25
  ZILMATE_CAMERA_DEVICE=
26
26
  ZILMATE_FILE_ROOTS=
27
+ ZILMATE_WORKSPACE=
28
+ ZILMATE_WEBHOOK_PORT=8787
27
29
  ZILO_MANAGER_MODEL=minimax/minimax-m3
28
30
  ZILO_HELP_MODEL=alibaba/qwen3.7-plus
29
31
  ZILO_POST_MODEL=alibaba/qwen3.7-plus
@@ -3,6 +3,114 @@ export declare function createAutomationPlannerAgent(): ToolLoopAgent<never, {
3
3
  appKnowledge: import("ai").Tool<{
4
4
  key: "agent-docs" | "readme";
5
5
  }, string>;
6
+ getPersonalContext: import("ai").Tool<Record<string, never>, {
7
+ context: import("../memory/personal-context.js").PersonalContext;
8
+ summary: string;
9
+ }>;
10
+ updatePersonalContext: import("ai").Tool<{
11
+ ownerName?: string | undefined;
12
+ businessName?: string | undefined;
13
+ urgencyRule?: string | undefined;
14
+ workflow?: string | undefined;
15
+ contact?: {
16
+ name: string;
17
+ vip: boolean;
18
+ id?: string | undefined;
19
+ email?: string | undefined;
20
+ handle?: string | undefined;
21
+ role?: string | undefined;
22
+ notes?: string | undefined;
23
+ } | undefined;
24
+ project?: {
25
+ name: string;
26
+ status: "done" | "active" | "paused";
27
+ tags: string[];
28
+ id?: string | undefined;
29
+ description?: string | undefined;
30
+ } | undefined;
31
+ }, {
32
+ updated: boolean;
33
+ summary: string;
34
+ }>;
35
+ listTriggerPolicies: import("ai").Tool<Record<string, never>, import("../jobs/trigger-policies.js").TriggerRoutingPolicy[]>;
36
+ getTriggerPolicy: import("ai").Tool<Record<string, never>, import("../jobs/trigger-policies.js").TriggerRoutingPolicy>;
37
+ saveTriggerPolicy: import("ai").Tool<{
38
+ policy: {
39
+ name: string;
40
+ enabled: boolean;
41
+ vipSenders: string[];
42
+ urgentKeywords: string[];
43
+ lowPriorityKeywords: string[];
44
+ customInstructions: string;
45
+ id?: string | undefined;
46
+ };
47
+ }, {
48
+ updatedAt: string;
49
+ id: string;
50
+ name: string;
51
+ enabled: boolean;
52
+ vipSenders: string[];
53
+ urgentKeywords: string[];
54
+ lowPriorityKeywords: string[];
55
+ customInstructions: string;
56
+ routes: Partial<Record<import("../jobs/trigger-orchestrator.js").TriggerRoute, import("../jobs/trigger-policies.js").RoutePolicy>>;
57
+ createdAt: string;
58
+ }>;
59
+ proposeTriggerOrchestration: import("ai").Tool<{
60
+ triggerSlug: string;
61
+ toolkitSlug: string;
62
+ payload?: Record<string, unknown> | undefined;
63
+ }, {
64
+ proposal: string;
65
+ plan: {
66
+ chainId: string;
67
+ priority: import("../jobs/trigger-orchestrator.js").TriggerPriority;
68
+ route: import("../jobs/trigger-orchestrator.js").TriggerRoute;
69
+ category: string;
70
+ followUpCount: number;
71
+ followUps: import("../jobs/trigger-orchestrator.js").TriggerFollowUp[];
72
+ };
73
+ }>;
74
+ applyTriggerOrchestration: import("ai").Tool<{
75
+ triggerSlug: string;
76
+ toolkitSlug: string;
77
+ payload?: Record<string, unknown> | undefined;
78
+ triggerId?: string | undefined;
79
+ userId?: string | undefined;
80
+ dryRun?: boolean | undefined;
81
+ }, {
82
+ dryRun: boolean;
83
+ proposal: string;
84
+ plan: import("../jobs/trigger-orchestrator.js").TriggerOrchestrationPlan;
85
+ applied?: never;
86
+ blocked?: never;
87
+ message?: never;
88
+ jobs?: never;
89
+ report?: never;
90
+ } | {
91
+ applied: boolean;
92
+ blocked: boolean;
93
+ proposal: string;
94
+ message: string;
95
+ dryRun?: never;
96
+ plan?: never;
97
+ jobs?: never;
98
+ report?: never;
99
+ } | {
100
+ applied: boolean;
101
+ proposal: string;
102
+ jobs: {
103
+ id: string;
104
+ status: import("../server.js").JobStatus;
105
+ schedule: string | undefined;
106
+ role: unknown;
107
+ }[];
108
+ report: string;
109
+ dryRun?: never;
110
+ plan?: never;
111
+ blocked?: never;
112
+ message?: never;
113
+ }>;
6
114
  listTriggerTypes: import("ai").Tool<{
7
115
  toolkit?: string | undefined;
8
116
  limit?: number | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"automation-planner.agent.d.ts","sourceRoot":"","sources":["../../src/agents/automation-planner.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,aAAa,EAAE,MAAM,IAAI,CAAC;AAQhD,wBAAgB,4BAA4B;;;;;;;;;;;;;;;;;;;mBAoBw7zG,CAAC;wBAAsC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAAz2S,CAAC;uBAAqC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UADzshG"}
1
+ {"version":3,"file":"automation-planner.agent.d.ts","sourceRoot":"","sources":["../../src/agents/automation-planner.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,aAAa,EAAE,MAAM,IAAI,CAAC;AAUhD,wBAAgB,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBA2BksyG,CAAC;wBAAsC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAAz2S,CAAC;uBAAqC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UADn9/F"}
@@ -4,22 +4,31 @@ import { appKnowledgeTool } from '../tools/app-knowledge.tool.js';
4
4
  import { jobTools } from '../tools/jobs.tool.js';
5
5
  import { timeTools } from '../tools/time.tool.js';
6
6
  import { triggerTools } from '../tools/triggers.tool.js';
7
+ import { orchestrationTools } from '../tools/orchestration.tool.js';
8
+ import { personalContextTools } from '../tools/personal-context.tool.js';
7
9
  import { limits } from '../safety/limits.js';
8
10
  export function createAutomationPlannerAgent() {
9
11
  return new ToolLoopAgent({
10
12
  model: models.manager,
11
13
  instructions: [
12
- 'You are ZilMate Automation Planner. Design practical automations, schedules, background jobs, trigger workflows, and follow-up flows.',
14
+ 'You are ZilMate Automation Planner. Design practical automations, schedules, background jobs, trigger workflows, and follow-up chains.',
15
+ 'Use getPersonalContext and updatePersonalContext so routing reflects the user\'s VIP contacts, projects, and urgency rules.',
16
+ 'Use listTriggerPolicies, getTriggerPolicy, and saveTriggerPolicy to manage routing behavior.',
17
+ 'Always use proposeTriggerOrchestration to preview what will happen before applyTriggerOrchestration creates jobs.',
18
+ 'When applyTriggerOrchestration needs approval, tell the user exactly what primary and follow-up jobs will be created. The confirmation prompt handles yes/no.',
19
+ 'After applying orchestration, report job ids, route, priority, and any skipped follow-ups waiting for approval.',
13
20
  'Use time tools for current date/time and schedule-relative wording.',
14
- 'Use job tools to inspect existing jobs and logs. Create or cancel jobs only when the user clearly asks and approval is available through the manager.',
15
- 'Use trigger tools to discover Composio trigger types, inspect schemas, and reason about trigger setup. Prefer dry-run thinking before real creation.',
16
- 'Explain local worker limits clearly: local jobs need `zilmate jobs worker`; laptop-closed automation needs QStash plus a public job webhook.',
21
+ 'Use job tools to inspect existing jobs and logs. Create or cancel jobs only when the user clearly asks.',
22
+ 'Use trigger tools to discover Composio trigger types and inspect schemas. Prefer dry-run before real creation.',
23
+ 'Explain local worker limits: local jobs need `zilmate jobs worker`; laptop-closed automation needs QStash plus a public job webhook.',
17
24
  'Return concise plans with exact commands or setup steps when useful.',
18
25
  ].join(' '),
19
26
  tools: {
20
27
  ...timeTools,
21
28
  ...jobTools,
22
29
  ...triggerTools,
30
+ ...orchestrationTools,
31
+ ...personalContextTools,
23
32
  appKnowledge: appKnowledgeTool,
24
33
  },
25
34
  stopWhen: stepCountIs(limits.subagentSteps),
@@ -1 +1 @@
1
- {"version":3,"file":"automation-planner.agent.js","sourceRoot":"","sources":["../../src/agents/automation-planner.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,MAAM,UAAU,4BAA4B;IAC1C,OAAO,IAAI,aAAa,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC,OAAO;QACrB,YAAY,EAAE;YACZ,uIAAuI;YACvI,qEAAqE;YACrE,uJAAuJ;YACvJ,sJAAsJ;YACtJ,8IAA8I;YAC9I,sEAAsE;SACvE,CAAC,IAAI,CAAC,GAAG,CAAC;QACX,KAAK,EAAE;YACL,GAAG,SAAS;YACZ,GAAG,QAAQ;YACX,GAAG,YAAY;YACf,YAAY,EAAE,gBAAgB;SAC/B;QACD,QAAQ,EAAE,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC;KAC5C,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"automation-planner.agent.js","sourceRoot":"","sources":["../../src/agents/automation-planner.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,MAAM,UAAU,4BAA4B;IAC1C,OAAO,IAAI,aAAa,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC,OAAO;QACrB,YAAY,EAAE;YACZ,wIAAwI;YACxI,6HAA6H;YAC7H,8FAA8F;YAC9F,mHAAmH;YACnH,+JAA+J;YAC/J,iHAAiH;YACjH,qEAAqE;YACrE,yGAAyG;YACzG,gHAAgH;YAChH,sIAAsI;YACtI,sEAAsE;SACvE,CAAC,IAAI,CAAC,GAAG,CAAC;QACX,KAAK,EAAE;YACL,GAAG,SAAS;YACZ,GAAG,QAAQ;YACX,GAAG,YAAY;YACf,GAAG,kBAAkB;YACrB,GAAG,oBAAoB;YACvB,YAAY,EAAE,gBAAgB;SAC/B;QACD,QAAQ,EAAE,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC;KAC5C,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,352 @@
1
+ import { ToolLoopAgent } from 'ai';
2
+ export declare function createCodingAgent(runId?: string): ToolLoopAgent<never, {
3
+ readScratchpad: import("ai").Tool<Record<string, never>, string>;
4
+ appendScratchpad: import("ai").Tool<{
5
+ note: string;
6
+ }, string>;
7
+ listSkills: import("ai").Tool<Record<string, never>, {
8
+ skills: import("../skills/loader.js").SkillSummary[];
9
+ searchPaths: string[];
10
+ registry: string;
11
+ }>;
12
+ searchSkills: import("ai").Tool<{
13
+ query: string;
14
+ limit?: number | undefined;
15
+ }, {
16
+ query: string;
17
+ skills: import("../skills/loader.js").SkillSummary[];
18
+ scope: string;
19
+ }>;
20
+ searchSkillsRegistry: import("ai").Tool<{
21
+ query: string;
22
+ limit?: number | undefined;
23
+ }, {
24
+ query: string;
25
+ results: import("../skills/registry.js").RegistrySkill[];
26
+ installHint: string;
27
+ browse: string;
28
+ }>;
29
+ installRegistrySkill: import("ai").Tool<{
30
+ packageRef: string;
31
+ global?: boolean | undefined;
32
+ }, {
33
+ ok: boolean;
34
+ packageRef: string;
35
+ installPath: string;
36
+ output: string;
37
+ browse: string;
38
+ }>;
39
+ readSkill: import("ai").Tool<{
40
+ skillId: string;
41
+ }, import("../skills/loader.js").SkillContent>;
42
+ executeCommand: import("ai").Tool<{
43
+ command: string;
44
+ cwd?: string | undefined;
45
+ timeout?: number | undefined;
46
+ env?: Record<string, string> | undefined;
47
+ }, {
48
+ success: boolean;
49
+ exit: any;
50
+ stdout: any;
51
+ stderr: any;
52
+ command: string;
53
+ }>;
54
+ installDependencies: import("ai").Tool<{
55
+ command: string;
56
+ manager?: "npm" | "pnpm" | "yarn" | undefined;
57
+ cwd?: string | undefined;
58
+ timeout?: number | undefined;
59
+ }, {
60
+ success: boolean;
61
+ exit: any;
62
+ manager: string;
63
+ stdout: any;
64
+ stderr: any;
65
+ }>;
66
+ runPipeline: import("ai").Tool<{
67
+ commands: string[];
68
+ cwd?: string | undefined;
69
+ timeout?: number | undefined;
70
+ }, {
71
+ success: boolean;
72
+ exit: any;
73
+ stdout: any;
74
+ stderr: any;
75
+ pipeline: string;
76
+ }>;
77
+ pythonScript: import("ai").Tool<{
78
+ code: string;
79
+ cwd?: string | undefined;
80
+ timeout?: number | undefined;
81
+ }, {
82
+ success: boolean;
83
+ exit: any;
84
+ stdout: any;
85
+ stderr: any;
86
+ }>;
87
+ getSystemInfo: import("ai").Tool<Record<string, never>, {
88
+ platform: NodeJS.Platform;
89
+ arch: NodeJS.Architecture;
90
+ release: string;
91
+ cpuCores: number;
92
+ totalMemoryGB: string;
93
+ freeMemoryGB: string;
94
+ nodeVersion: string;
95
+ currentUser: string;
96
+ uptime: string;
97
+ homeDir: string;
98
+ } | {
99
+ platform: NodeJS.Platform;
100
+ arch: NodeJS.Architecture;
101
+ error: any;
102
+ }>;
103
+ listProcesses: import("ai").Tool<{
104
+ filter?: string | undefined;
105
+ limit?: number | undefined;
106
+ }, {
107
+ processes: string[];
108
+ count: number;
109
+ filtered: boolean;
110
+ error?: never;
111
+ } | {
112
+ error: any;
113
+ processes: never[];
114
+ count: number;
115
+ filtered?: never;
116
+ }>;
117
+ findInPath: import("ai").Tool<{
118
+ command: string;
119
+ }, {
120
+ found: boolean;
121
+ command: string;
122
+ path: string;
123
+ suggestion?: never;
124
+ } | {
125
+ found: boolean;
126
+ command: string;
127
+ suggestion: string;
128
+ path?: never;
129
+ }>;
130
+ searchFiles: import("ai").Tool<{
131
+ query: string;
132
+ root?: string | undefined;
133
+ includeContent?: boolean | undefined;
134
+ maxDepth?: number | undefined;
135
+ maxResults?: number | undefined;
136
+ }, {
137
+ match: string;
138
+ excerpt: string;
139
+ path: string;
140
+ absolutePath: string;
141
+ type: "file" | "directory";
142
+ size: number;
143
+ modifiedAt: string;
144
+ }[]>;
145
+ readFile: import("ai").Tool<{
146
+ path: string;
147
+ maxBytes?: number | undefined;
148
+ }, {
149
+ path: string;
150
+ size: number;
151
+ modifiedAt: string;
152
+ truncated: boolean;
153
+ content: string;
154
+ }>;
155
+ writeFile: import("ai").Tool<{
156
+ path: string;
157
+ content: string;
158
+ mode?: "append" | "overwrite" | undefined;
159
+ }, {
160
+ path: string;
161
+ bytes: number;
162
+ mode: "append" | "overwrite";
163
+ }>;
164
+ createFolder: import("ai").Tool<{
165
+ path: string;
166
+ }, {
167
+ path: string;
168
+ created: boolean;
169
+ }>;
170
+ moveCopyRename: import("ai").Tool<{
171
+ operation: "move" | "copy" | "rename";
172
+ from: string;
173
+ to: string;
174
+ overwrite?: boolean | undefined;
175
+ }, {
176
+ operation: "move" | "copy" | "rename";
177
+ from: string;
178
+ to: string;
179
+ }>;
180
+ summarizeDocument: import("ai").Tool<{
181
+ path: string;
182
+ maxBytes?: number | undefined;
183
+ }, {
184
+ characters: number;
185
+ words: number;
186
+ summary: string;
187
+ path: string;
188
+ truncated: boolean;
189
+ }>;
190
+ watchFolderChanges: import("ai").Tool<{
191
+ path?: string | undefined;
192
+ watchName?: string | undefined;
193
+ reset?: boolean | undefined;
194
+ maxDepth?: number | undefined;
195
+ }, {
196
+ watchName: string;
197
+ baselineSaved: boolean;
198
+ added: string[];
199
+ changed: string[];
200
+ removed: string[];
201
+ }>;
202
+ findDuplicateLargeFiles: import("ai").Tool<{
203
+ root?: string | undefined;
204
+ minSizeBytes?: number | undefined;
205
+ maxDepth?: number | undefined;
206
+ maxResults?: number | undefined;
207
+ }, {
208
+ large: {
209
+ path: string;
210
+ absolutePath: string;
211
+ type: "file" | "directory";
212
+ size: number;
213
+ modifiedAt: string;
214
+ }[];
215
+ duplicateSizeGroups: {
216
+ size: number;
217
+ files: string[];
218
+ }[];
219
+ }>;
220
+ deleteFile: import("ai").Tool<{
221
+ path: string;
222
+ confirm: boolean;
223
+ }, {
224
+ deleted: boolean;
225
+ path: string;
226
+ size: number;
227
+ }>;
228
+ deleteFolder: import("ai").Tool<{
229
+ path: string;
230
+ confirm: boolean;
231
+ }, {
232
+ deleted: boolean;
233
+ path: string;
234
+ }>;
235
+ listDirectory: import("ai").Tool<{
236
+ path: string;
237
+ filter?: string | undefined;
238
+ includeHidden?: boolean | undefined;
239
+ maxDepth?: number | undefined;
240
+ limit?: number | undefined;
241
+ }, {
242
+ directory: string;
243
+ entries: {
244
+ path: string;
245
+ absolutePath: string;
246
+ type: "file" | "directory";
247
+ size: number;
248
+ modifiedAt: string;
249
+ }[];
250
+ count: number;
251
+ filtered: boolean;
252
+ }>;
253
+ getFileInfo: import("ai").Tool<{
254
+ path: string;
255
+ }, {
256
+ path: string;
257
+ type: string;
258
+ size: number;
259
+ sizeKB: string;
260
+ sizeMB: string;
261
+ created: string;
262
+ modified: string;
263
+ accessed: string;
264
+ isFile: boolean;
265
+ isDirectory: boolean;
266
+ isSymlink: boolean;
267
+ mode: string;
268
+ }>;
269
+ gitStatus: import("ai").Tool<{
270
+ short: boolean;
271
+ cwd?: string | undefined;
272
+ }, {
273
+ cwd: string;
274
+ output: string;
275
+ }>;
276
+ gitDiff: import("ai").Tool<{
277
+ staged: boolean;
278
+ cwd?: string | undefined;
279
+ path?: string | undefined;
280
+ commit?: string | undefined;
281
+ }, {
282
+ cwd: string;
283
+ output: string;
284
+ }>;
285
+ gitLog: import("ai").Tool<{
286
+ limit: number;
287
+ cwd?: string | undefined;
288
+ path?: string | undefined;
289
+ }, {
290
+ cwd: string;
291
+ output: string;
292
+ }>;
293
+ gitBranch: import("ai").Tool<{
294
+ action: "list" | "create" | "checkout";
295
+ cwd?: string | undefined;
296
+ name?: string | undefined;
297
+ }, {
298
+ cwd: string;
299
+ branches: string;
300
+ action?: never;
301
+ name?: never;
302
+ output?: never;
303
+ } | {
304
+ cwd: string;
305
+ action: "create" | "checkout";
306
+ name: string;
307
+ output: string;
308
+ branches?: never;
309
+ }>;
310
+ gitStage: import("ai").Tool<{
311
+ paths: string[];
312
+ cwd?: string | undefined;
313
+ }, {
314
+ cwd: string;
315
+ staged: string[];
316
+ output: string;
317
+ }>;
318
+ gitCommit: import("ai").Tool<{
319
+ message: string;
320
+ cwd?: string | undefined;
321
+ }, {
322
+ cwd: string;
323
+ message: string;
324
+ output: string;
325
+ }>;
326
+ applyUnifiedPatch: import("ai").Tool<{
327
+ patch: string;
328
+ dryRun: boolean;
329
+ cwd?: string | undefined;
330
+ }, {
331
+ dryRun: boolean;
332
+ cwd: string;
333
+ check: string;
334
+ applied?: never;
335
+ output?: never;
336
+ } | {
337
+ cwd: string;
338
+ applied: boolean;
339
+ output: string;
340
+ dryRun?: never;
341
+ check?: never;
342
+ }>;
343
+ getCurrentTime: import("ai").Tool<{
344
+ timeZone?: string | undefined;
345
+ }, {
346
+ iso: string;
347
+ unixMs: number;
348
+ timeZone: string;
349
+ formatted: string;
350
+ }>;
351
+ }, never>;
352
+ //# sourceMappingURL=coding.agent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coding.agent.d.ts","sourceRoot":"","sources":["../../src/agents/coding.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,aAAa,EAAE,MAAM,IAAI,CAAC;AAUhD,wBAAgB,iBAAiB,CAAC,KAAK,SAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAwBlD"}
@@ -0,0 +1,34 @@
1
+ import { stepCountIs, ToolLoopAgent } from 'ai';
2
+ import { models } from '../config/models.js';
3
+ import { createScratchpadTools } from '../tools/scratchpad.tool.js';
4
+ import { fileSystemTools } from '../tools/filesystem.tool.js';
5
+ import { gitTools } from '../tools/git.tool.js';
6
+ import { shellTools } from '../tools/shell.tool.js';
7
+ import { skillTools } from '../tools/skills.tool.js';
8
+ import { timeTools } from '../tools/time.tool.js';
9
+ import { limits } from '../safety/limits.js';
10
+ export function createCodingAgent(runId = 'default') {
11
+ const scratchpadTools = createScratchpadTools(runId);
12
+ return new ToolLoopAgent({
13
+ model: models.coding,
14
+ instructions: [
15
+ 'You are ZilMate Coding Agent — a focused software engineering partner for this machine.',
16
+ 'Prefer small, reviewable changes: read files, use gitDiff, applyUnifiedPatch for surgical edits instead of rewriting entire files.',
17
+ 'Workflow: gitStatus → read affected files → gitDiff → patch or targeted writeFile → run tests via executeCommand → gitStage → gitCommit (only when user asked to commit).',
18
+ 'Use git tools for branch awareness, diffs, staging, and commits. Never force-push unless the user explicitly requests it.',
19
+ 'Use searchSkills/readSkill when a repo skill documents conventions.',
20
+ 'Report what you changed, which files, and test/build output. Keep scratchpad notes for multi-file refactors.',
21
+ 'Do not claim tests passed unless executeCommand output shows success.',
22
+ ].join(' '),
23
+ tools: {
24
+ ...timeTools,
25
+ ...gitTools,
26
+ ...fileSystemTools,
27
+ ...shellTools,
28
+ ...skillTools,
29
+ ...scratchpadTools,
30
+ },
31
+ stopWhen: stepCountIs(limits.subagentSteps),
32
+ });
33
+ }
34
+ //# sourceMappingURL=coding.agent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coding.agent.js","sourceRoot":"","sources":["../../src/agents/coding.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,MAAM,UAAU,iBAAiB,CAAC,KAAK,GAAG,SAAS;IACjD,MAAM,eAAe,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAErD,OAAO,IAAI,aAAa,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC,MAAM;QACpB,YAAY,EAAE;YACZ,yFAAyF;YACzF,oIAAoI;YACpI,2KAA2K;YAC3K,2HAA2H;YAC3H,qEAAqE;YACrE,8GAA8G;YAC9G,uEAAuE;SACxE,CAAC,IAAI,CAAC,GAAG,CAAC;QACX,KAAK,EAAE;YACL,GAAG,SAAS;YACZ,GAAG,QAAQ;YACX,GAAG,eAAe;YAClB,GAAG,UAAU;YACb,GAAG,UAAU;YACb,GAAG,eAAe;SACnB;QACD,QAAQ,EAAE,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC;KAC5C,CAAC,CAAC;AACL,CAAC"}