@hailer/mcp 1.1.16 → 1.1.17-beta.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 (313) hide show
  1. package/.claude/CLAUDE.md +117 -320
  2. package/.claude/commands/app-squad.md +86 -90
  3. package/.claude/commands/audit-squad.md +19 -19
  4. package/.claude/commands/autoplan.md +3 -3
  5. package/.claude/commands/cleanup-squad.md +16 -16
  6. package/.claude/commands/config-squad.md +30 -30
  7. package/.claude/commands/crud-squad.md +23 -23
  8. package/.claude/commands/data-squad.md +21 -21
  9. package/.claude/commands/debug-squad.md +44 -44
  10. package/.claude/commands/doc-squad.md +16 -16
  11. package/.claude/commands/help:agents.md +130 -99
  12. package/.claude/commands/help:commands.md +15 -15
  13. package/.claude/commands/help:faq.md +17 -17
  14. package/.claude/commands/help:plugins.md +1 -1
  15. package/.claude/commands/help:skills.md +18 -24
  16. package/.claude/commands/hotfix-squad.md +22 -22
  17. package/.claude/commands/integration-squad.md +22 -22
  18. package/.claude/commands/janitor-squad.md +31 -31
  19. package/.claude/commands/learn-auto.md +5 -5
  20. package/.claude/commands/learn.md +12 -20
  21. package/.claude/commands/onboard-squad.md +39 -49
  22. package/.claude/commands/plan-workspace.md +2 -2
  23. package/.claude/commands/publish.md +32 -37
  24. package/.claude/commands/review-squad.md +27 -27
  25. package/.claude/commands/stats.md +26 -12
  26. package/.claude/commands/swarm.md +25 -25
  27. package/.claude/skills/chrome-mcp-reference/SKILL.md +5 -0
  28. package/.claude/skills/hailer-api-client/SKILL.md +55 -16
  29. package/.claude/skills/hailer-app-builder/SKILL.md +4 -270
  30. package/.claude/skills/hailer-apps-pictures/SKILL.md +3 -3
  31. package/.claude/skills/hailer-design-system/SKILL.md +96 -4
  32. package/.claude/skills/hailer-monolith-automations/SKILL.md +138 -116
  33. package/.claude/skills/hailer-permissions-system/SKILL.md +6 -9
  34. package/.claude/skills/hailer-project-protocol/SKILL.md +20 -110
  35. package/.claude/skills/integration-patterns/SKILL.md +6 -6
  36. package/.claude/skills/lsp-setup/SKILL.md +8 -9
  37. package/.claude/skills/sdk-activity-patterns/SKILL.md +238 -0
  38. package/.claude/skills/{SDK-document-templates → sdk-document-templates}/SKILL.md +13 -340
  39. package/.claude/skills/{SDK-function-fields → sdk-function-fields}/SKILL.md +8 -40
  40. package/.claude/skills/{SDK-insight-queries → sdk-insight-queries}/SKILL.md +114 -392
  41. package/.claude/skills/{SDK-ws-config-skill → sdk-ws-config-skill}/SKILL.md +79 -310
  42. package/.claude/skills/zapier-hailer-patterns/SKILL.md +84 -361
  43. package/.opencode/package-lock.json +117 -0
  44. package/CLAUDE.md +5 -358
  45. package/dist/app.d.ts.map +1 -1
  46. package/dist/app.js +10 -127
  47. package/dist/app.js.map +1 -1
  48. package/dist/bot/bot-manager.d.ts +3 -14
  49. package/dist/bot/bot-manager.d.ts.map +1 -1
  50. package/dist/bot/bot-manager.js +13 -4
  51. package/dist/bot/bot-manager.js.map +1 -1
  52. package/dist/bot/bot.d.ts +23 -102
  53. package/dist/bot/bot.d.ts.map +1 -1
  54. package/dist/bot/bot.js +356 -1212
  55. package/dist/bot/bot.js.map +1 -1
  56. package/dist/bot/services/bot-permissions.d.ts +50 -0
  57. package/dist/bot/services/bot-permissions.d.ts.map +1 -0
  58. package/dist/bot/services/bot-permissions.js +198 -0
  59. package/dist/bot/services/bot-permissions.js.map +1 -0
  60. package/dist/bot/services/index.d.ts +4 -2
  61. package/dist/bot/services/index.d.ts.map +1 -1
  62. package/dist/bot/services/index.js +10 -5
  63. package/dist/bot/services/index.js.map +1 -1
  64. package/dist/bot/services/message-classifier.d.ts +1 -1
  65. package/dist/bot/services/message-classifier.d.ts.map +1 -1
  66. package/dist/bot/services/message-classifier.js.map +1 -1
  67. package/dist/bot/services/signal-router.d.ts +32 -0
  68. package/dist/bot/services/signal-router.d.ts.map +1 -0
  69. package/dist/bot/services/signal-router.js +132 -0
  70. package/dist/bot/services/signal-router.js.map +1 -0
  71. package/dist/bot/services/system-prompt.d.ts +12 -0
  72. package/dist/bot/services/system-prompt.d.ts.map +1 -0
  73. package/dist/bot/services/system-prompt.js +93 -0
  74. package/dist/bot/services/system-prompt.js.map +1 -0
  75. package/dist/bot/services/types.d.ts +7 -34
  76. package/dist/bot/services/types.d.ts.map +1 -1
  77. package/dist/bot/services/types.js +0 -3
  78. package/dist/bot/services/types.js.map +1 -1
  79. package/dist/bot/services/workspace-refresh.d.ts +47 -0
  80. package/dist/bot/services/workspace-refresh.d.ts.map +1 -0
  81. package/dist/bot/services/workspace-refresh.js +154 -0
  82. package/dist/bot/services/workspace-refresh.js.map +1 -0
  83. package/dist/bot-config/constants.d.ts +0 -36
  84. package/dist/bot-config/constants.d.ts.map +1 -1
  85. package/dist/bot-config/constants.js +1 -76
  86. package/dist/bot-config/constants.js.map +1 -1
  87. package/dist/bot-config/context.d.ts +2 -42
  88. package/dist/bot-config/context.d.ts.map +1 -1
  89. package/dist/bot-config/context.js +13 -134
  90. package/dist/bot-config/context.js.map +1 -1
  91. package/dist/bot-config/index.d.ts +6 -15
  92. package/dist/bot-config/index.d.ts.map +1 -1
  93. package/dist/bot-config/index.js +5 -80
  94. package/dist/bot-config/index.js.map +1 -1
  95. package/dist/bot-config/loader.d.ts +16 -4
  96. package/dist/bot-config/loader.d.ts.map +1 -1
  97. package/dist/bot-config/loader.js +187 -96
  98. package/dist/bot-config/loader.js.map +1 -1
  99. package/dist/bot-config/persistence.d.ts +1 -52
  100. package/dist/bot-config/persistence.d.ts.map +1 -1
  101. package/dist/bot-config/persistence.js +3 -213
  102. package/dist/bot-config/persistence.js.map +1 -1
  103. package/dist/bot-config/state.d.ts +0 -41
  104. package/dist/bot-config/state.d.ts.map +1 -1
  105. package/dist/bot-config/state.js +0 -151
  106. package/dist/bot-config/state.js.map +1 -1
  107. package/dist/bot-config/tools.d.ts +1 -1
  108. package/dist/bot-config/tools.js +27 -27
  109. package/dist/bot-config/tools.js.map +1 -1
  110. package/dist/bot-config/types.d.ts +39 -32
  111. package/dist/bot-config/types.d.ts.map +1 -1
  112. package/dist/bot-config/types.js +0 -3
  113. package/dist/bot-config/types.js.map +1 -1
  114. package/dist/bot-config/webhooks.d.ts +0 -4
  115. package/dist/bot-config/webhooks.d.ts.map +1 -1
  116. package/dist/bot-config/webhooks.js +0 -13
  117. package/dist/bot-config/webhooks.js.map +1 -1
  118. package/dist/commands/seed-config.js +16 -31
  119. package/dist/commands/seed-config.js.map +1 -1
  120. package/dist/config.d.ts +0 -9
  121. package/dist/config.d.ts.map +1 -1
  122. package/dist/config.js +0 -15
  123. package/dist/config.js.map +1 -1
  124. package/dist/mcp/hailer-clients.js +2 -2
  125. package/dist/mcp/hailer-clients.js.map +1 -1
  126. package/dist/mcp/tool-registry.d.ts +10 -115
  127. package/dist/mcp/tool-registry.d.ts.map +1 -1
  128. package/dist/mcp/tool-registry.js +39 -363
  129. package/dist/mcp/tool-registry.js.map +1 -1
  130. package/dist/mcp/tools/activity.d.ts +3 -0
  131. package/dist/mcp/tools/activity.d.ts.map +1 -1
  132. package/dist/mcp/tools/activity.js +8 -1
  133. package/dist/mcp/tools/activity.js.map +1 -1
  134. package/dist/mcp/tools/app-core.d.ts +3 -0
  135. package/dist/mcp/tools/app-core.d.ts.map +1 -1
  136. package/dist/mcp/tools/app-core.js +9 -2
  137. package/dist/mcp/tools/app-core.js.map +1 -1
  138. package/dist/mcp/tools/app-marketplace.d.ts +3 -0
  139. package/dist/mcp/tools/app-marketplace.d.ts.map +1 -1
  140. package/dist/mcp/tools/app-marketplace.js +13 -1
  141. package/dist/mcp/tools/app-marketplace.js.map +1 -1
  142. package/dist/mcp/tools/app-member.d.ts +3 -0
  143. package/dist/mcp/tools/app-member.d.ts.map +1 -1
  144. package/dist/mcp/tools/app-member.js +6 -1
  145. package/dist/mcp/tools/app-member.js.map +1 -1
  146. package/dist/mcp/tools/app-scaffold.d.ts +3 -0
  147. package/dist/mcp/tools/app-scaffold.d.ts.map +1 -1
  148. package/dist/mcp/tools/app-scaffold.js +15 -11
  149. package/dist/mcp/tools/app-scaffold.js.map +1 -1
  150. package/dist/mcp/tools/company.d.ts +3 -0
  151. package/dist/mcp/tools/company.d.ts.map +1 -1
  152. package/dist/mcp/tools/company.js +5 -1
  153. package/dist/mcp/tools/company.js.map +1 -1
  154. package/dist/mcp/tools/discussion.d.ts +3 -0
  155. package/dist/mcp/tools/discussion.d.ts.map +1 -1
  156. package/dist/mcp/tools/discussion.js +13 -2
  157. package/dist/mcp/tools/discussion.js.map +1 -1
  158. package/dist/mcp/tools/file.d.ts +3 -0
  159. package/dist/mcp/tools/file.d.ts.map +1 -1
  160. package/dist/mcp/tools/file.js +6 -1
  161. package/dist/mcp/tools/file.js.map +1 -1
  162. package/dist/mcp/tools/index.d.ts +7 -0
  163. package/dist/mcp/tools/index.d.ts.map +1 -0
  164. package/dist/mcp/tools/index.js +34 -0
  165. package/dist/mcp/tools/index.js.map +1 -0
  166. package/dist/mcp/tools/insight.d.ts +3 -0
  167. package/dist/mcp/tools/insight.d.ts.map +1 -1
  168. package/dist/mcp/tools/insight.js +18 -8
  169. package/dist/mcp/tools/insight.js.map +1 -1
  170. package/dist/mcp/tools/user.d.ts +3 -0
  171. package/dist/mcp/tools/user.d.ts.map +1 -1
  172. package/dist/mcp/tools/user.js +6 -1
  173. package/dist/mcp/tools/user.js.map +1 -1
  174. package/dist/mcp/tools/workflow-permissions.d.ts +3 -0
  175. package/dist/mcp/tools/workflow-permissions.d.ts.map +1 -1
  176. package/dist/mcp/tools/workflow-permissions.js +8 -1
  177. package/dist/mcp/tools/workflow-permissions.js.map +1 -1
  178. package/dist/mcp/tools/workflow.d.ts +3 -0
  179. package/dist/mcp/tools/workflow.d.ts.map +1 -1
  180. package/dist/mcp/tools/workflow.js +29 -28
  181. package/dist/mcp/tools/workflow.js.map +1 -1
  182. package/dist/mcp/utils/index.d.ts +4 -11
  183. package/dist/mcp/utils/index.d.ts.map +1 -1
  184. package/dist/mcp/utils/index.js +5 -36
  185. package/dist/mcp/utils/index.js.map +1 -1
  186. package/dist/mcp/utils/role-utils.d.ts +0 -32
  187. package/dist/mcp/utils/role-utils.d.ts.map +1 -1
  188. package/dist/mcp/utils/role-utils.js +0 -73
  189. package/dist/mcp/utils/role-utils.js.map +1 -1
  190. package/dist/mcp/utils/tool-helpers.d.ts +0 -25
  191. package/dist/mcp/utils/tool-helpers.d.ts.map +1 -1
  192. package/dist/mcp/utils/tool-helpers.js +0 -34
  193. package/dist/mcp/utils/tool-helpers.js.map +1 -1
  194. package/dist/mcp/webhook-handler.d.ts +4 -34
  195. package/dist/mcp/webhook-handler.d.ts.map +1 -1
  196. package/dist/mcp/webhook-handler.js +57 -74
  197. package/dist/mcp/webhook-handler.js.map +1 -1
  198. package/dist/mcp-server.d.ts.map +1 -1
  199. package/dist/mcp-server.js +3 -78
  200. package/dist/mcp-server.js.map +1 -1
  201. package/package.json +1 -2
  202. package/.claude/agents/agent-ada-skill-builder.md +0 -94
  203. package/.claude/agents/agent-alejandro-function-fields.md +0 -342
  204. package/.claude/agents/agent-bjorn-config-audit.md +0 -103
  205. package/.claude/agents/agent-builder-agent-creator.md +0 -130
  206. package/.claude/agents/agent-code-simplifier.md +0 -53
  207. package/.claude/agents/agent-dmitri-activity-crud.md +0 -159
  208. package/.claude/agents/agent-giuseppe-app-builder.md +0 -208
  209. package/.claude/agents/agent-gunther-mcp-tools.md +0 -39
  210. package/.claude/agents/agent-helga-workflow-config.md +0 -204
  211. package/.claude/agents/agent-igor-activity-mover-automation.md +0 -125
  212. package/.claude/agents/agent-ingrid-doc-templates.md +0 -261
  213. package/.claude/agents/agent-ivan-monolith.md +0 -154
  214. package/.claude/agents/agent-kenji-data-reader.md +0 -86
  215. package/.claude/agents/agent-lars-code-inspector.md +0 -102
  216. package/.claude/agents/agent-marco-mockup-builder.md +0 -110
  217. package/.claude/agents/agent-marcus-api-documenter.md +0 -323
  218. package/.claude/agents/agent-marketplace-publisher.md +0 -280
  219. package/.claude/agents/agent-marketplace-reviewer.md +0 -309
  220. package/.claude/agents/agent-permissions-handler.md +0 -208
  221. package/.claude/agents/agent-simple-writer.md +0 -48
  222. package/.claude/agents/agent-svetlana-code-review.md +0 -171
  223. package/.claude/agents/agent-tanya-test-runner.md +0 -333
  224. package/.claude/agents/agent-ui-designer.md +0 -100
  225. package/.claude/agents/agent-viktor-sql-insights.md +0 -212
  226. package/.claude/agents/agent-web-search.md +0 -55
  227. package/.claude/agents/agent-yevgeni-discussions.md +0 -45
  228. package/.claude/agents/agent-zara-zapier.md +0 -159
  229. package/.claude/skills/SDK-activity-patterns/SKILL.md +0 -428
  230. package/.claude/skills/SDK-generate-skill/SKILL.md +0 -92
  231. package/.claude/skills/SDK-init-skill/SKILL.md +0 -127
  232. package/.claude/skills/agent-structure/SKILL.md +0 -98
  233. package/.claude/skills/delegation-routing/SKILL.md +0 -202
  234. package/.claude/skills/frontend-design/SKILL.md +0 -254
  235. package/.claude/skills/hailer-activity-mover/SKILL.md +0 -213
  236. package/.claude/skills/hailer-rest-api/SKILL.md +0 -61
  237. package/.claude/skills/hailer-rest-api/hailer-activities.md +0 -184
  238. package/.claude/skills/hailer-rest-api/hailer-admin.md +0 -473
  239. package/.claude/skills/hailer-rest-api/hailer-calendar.md +0 -256
  240. package/.claude/skills/hailer-rest-api/hailer-feed.md +0 -249
  241. package/.claude/skills/hailer-rest-api/hailer-insights.md +0 -195
  242. package/.claude/skills/hailer-rest-api/hailer-messaging.md +0 -276
  243. package/.claude/skills/hailer-rest-api/hailer-workflows.md +0 -283
  244. package/.claude/skills/insight-join-patterns/SKILL.md +0 -174
  245. package/.claude/skills/json-only-output/SKILL.md +0 -72
  246. package/.claude/skills/mcp-direct-tools/SKILL.md +0 -153
  247. package/.claude/skills/optional-parameters/SKILL.md +0 -72
  248. package/.claude/skills/tool-parameter-usage/SKILL.md +0 -126
  249. package/.claude/skills/tool-response-verification/SKILL.md +0 -92
  250. package/.opencode/agent/agent-ada-skill-builder.md +0 -35
  251. package/.opencode/agent/agent-alejandro-function-fields.md +0 -39
  252. package/.opencode/agent/agent-bjorn-config-audit.md +0 -36
  253. package/.opencode/agent/agent-builder-agent-creator.md +0 -39
  254. package/.opencode/agent/agent-code-simplifier.md +0 -31
  255. package/.opencode/agent/agent-dmitri-activity-crud.md +0 -40
  256. package/.opencode/agent/agent-giuseppe-app-builder.md +0 -37
  257. package/.opencode/agent/agent-gunther-mcp-tools.md +0 -39
  258. package/.opencode/agent/agent-helga-workflow-config.md +0 -204
  259. package/.opencode/agent/agent-igor-activity-mover-automation.md +0 -46
  260. package/.opencode/agent/agent-ingrid-doc-templates.md +0 -39
  261. package/.opencode/agent/agent-ivan-monolith.md +0 -46
  262. package/.opencode/agent/agent-kenji-data-reader.md +0 -53
  263. package/.opencode/agent/agent-lars-code-inspector.md +0 -28
  264. package/.opencode/agent/agent-marco-mockup-builder.md +0 -42
  265. package/.opencode/agent/agent-marcus-api-documenter.md +0 -53
  266. package/.opencode/agent/agent-marketplace-publisher.md +0 -44
  267. package/.opencode/agent/agent-marketplace-reviewer.md +0 -42
  268. package/.opencode/agent/agent-permissions-handler.md +0 -50
  269. package/.opencode/agent/agent-simple-writer.md +0 -45
  270. package/.opencode/agent/agent-svetlana-code-review.md +0 -39
  271. package/.opencode/agent/agent-tanya-test-runner.md +0 -57
  272. package/.opencode/agent/agent-ui-designer.md +0 -56
  273. package/.opencode/agent/agent-viktor-sql-insights.md +0 -34
  274. package/.opencode/agent/agent-web-search.md +0 -42
  275. package/.opencode/agent/agent-yevgeni-discussions.md +0 -37
  276. package/.opencode/agent/agent-zara-zapier.md +0 -53
  277. package/.opencode/commands/app-squad.md +0 -135
  278. package/.opencode/commands/audit-squad.md +0 -158
  279. package/.opencode/commands/autoplan.md +0 -563
  280. package/.opencode/commands/cleanup-squad.md +0 -98
  281. package/.opencode/commands/config-squad.md +0 -106
  282. package/.opencode/commands/crud-squad.md +0 -87
  283. package/.opencode/commands/data-squad.md +0 -97
  284. package/.opencode/commands/debug-squad.md +0 -303
  285. package/.opencode/commands/doc-squad.md +0 -65
  286. package/.opencode/commands/handoff.md +0 -137
  287. package/.opencode/commands/health.md +0 -49
  288. package/.opencode/commands/help-agents.md +0 -151
  289. package/.opencode/commands/help-commands.md +0 -32
  290. package/.opencode/commands/help-faq.md +0 -29
  291. package/.opencode/commands/help-plugins.md +0 -28
  292. package/.opencode/commands/help-skills.md +0 -7
  293. package/.opencode/commands/help-tools.md +0 -40
  294. package/.opencode/commands/help.md +0 -28
  295. package/.opencode/commands/hotfix-squad.md +0 -112
  296. package/.opencode/commands/integration-squad.md +0 -82
  297. package/.opencode/commands/janitor-squad.md +0 -167
  298. package/.opencode/commands/learn-auto.md +0 -120
  299. package/.opencode/commands/learn.md +0 -120
  300. package/.opencode/commands/mcp-list.md +0 -27
  301. package/.opencode/commands/onboard-squad.md +0 -140
  302. package/.opencode/commands/plan-workspace.md +0 -732
  303. package/.opencode/commands/prd.md +0 -131
  304. package/.opencode/commands/project-status.md +0 -82
  305. package/.opencode/commands/publish.md +0 -138
  306. package/.opencode/commands/recap.md +0 -69
  307. package/.opencode/commands/restore.md +0 -64
  308. package/.opencode/commands/review-squad.md +0 -152
  309. package/.opencode/commands/save.md +0 -24
  310. package/.opencode/commands/stats.md +0 -19
  311. package/.opencode/commands/swarm.md +0 -210
  312. package/.opencode/commands/tool-builder.md +0 -39
  313. package/.opencode/commands/ws-pull.md +0 -44
package/CLAUDE.md CHANGED
@@ -1,9 +1,8 @@
1
- # Hailer SDK
1
+ # Hailer MCP Server
2
2
 
3
3
  MCP tools for Hailer workspaces: workflows, activities, insights, and apps.
4
4
 
5
- <quick-start>
6
- ## Quick Start (New Project Setup)
5
+ ## Quick Start
7
6
 
8
7
  ```bash
9
8
  npm init @hailer/sdk # Scaffold project with workspace/ config
@@ -11,360 +10,8 @@ npm run pull # Pull latest workflow schemas from Hailer
11
10
  npm run generate # Generate TypeScript types
12
11
  ```
13
12
 
14
- Then ask Claude Code to build features. It delegates to specialized agents automatically.
15
- Run `/help` for an overview, or `/help:agents`, `/help:skills`, `/help:commands` for details.
16
- </quick-start>
13
+ Then ask Claude Code to build features. Load relevant skills for domain context.
17
14
 
18
- ---
15
+ ## Project-Level Instructions
19
16
 
20
- <identity>
21
- You are the orchestrator. You delegate tasks to specialized agents, run commands from their responses, and summarize results for users.
22
-
23
- Always delegate - agents have optimized tools and context for their domains.
24
- </identity>
25
-
26
- <orchestrator-rules>
27
- DO DIRECTLY: Answer from context, summarize agent results, run push/sync commands
28
- DELEGATE TO AGENTS: Everything else. No exceptions.
29
-
30
- **FEATURE REQUESTS:** Before implementing, ask "Want me to create a PRD first?" Only skip if user declines or already used `/prd`/`/autoplan`.
31
-
32
- **NEVER USE BUILT-IN AGENTS:** Do not spawn Plan, Explore, general-purpose, or Bash subagents. These are Claude Code built-ins that lack specialized skills and tools. Instead:
33
- - Give the executing agent a prompt that includes research + planning + execution
34
- - Agents have the Skill tool — they can load patterns themselves
35
- - E.g., instead of "Plan agent researches templates → Ingrid implements", just tell Ingrid: "Load SDK-document-templates skill, plan the template structure, then build it"
36
-
37
- **ANTI-PATTERNS (never do these):**
38
- - "Let me use Plan agent to research first..." → Include research in the agent's prompt
39
- - "I'll use Explore to find the code..." → Use Glob/Grep directly, or include in agent prompt
40
- - "I'll just quickly read this file..." → Delegate to the appropriate agent
41
- - "Let me check this one field..." → Delegate to Kenji
42
- - "I can create this simple activity..." → Delegate to Dmitri
43
- - "This is a small change..." → Delegate to the appropriate agent
44
- - "User gave detailed plan, so I'll skip PRD..." → Still ask about PRD
45
-
46
- **CRITICAL ROUTING RULE — Kenji vs Giuseppe:**
47
- - **Kenji** = Hailer workspace data ONLY (workspace/ files, MCP API queries, field IDs, schemas)
48
- - **Giuseppe** = App source code (apps/, src/, .tsx/.ts files, API call bugs, UI fixes, debugging)
49
- - NEVER send app source code tasks to Kenji. He reads workspace/ config, not app code.
50
- - For app bugs/fixes: Giuseppe (complex) or Simple Writer (simple string/ID fixes)
51
-
52
- **MULTI-AGENT WORK:** Prefer squads over manual agent chaining. If a task needs 2+ agents in sequence (e.g., Helga → Alejandro → Viktor), check if a squad already does it (`/help:commands`). For large-scale repetitive work across many items, use `/swarm` instead of looping agents yourself.
53
-
54
- Agents return JSON. You interpret it for the user.
55
- </orchestrator-rules>
56
-
57
- <delegation-blocks>
58
- ## When Hook Blocks You
59
-
60
- Hooks enforce delegation by blocking certain direct tool calls. When blocked:
61
-
62
- **1. Default: Delegate (recommended)**
63
- The block message shows the suggested agent. Use it:
64
- ```
65
- Task(subagent_type="agent-kenji-data-reader", prompt='{"task":"..."}')
66
- ```
67
-
68
- **2. Override: Ask user permission first**
69
- If context suggests user wants direct action, ask:
70
- ```
71
- AskUserQuestion:
72
- question: "Hook wants me to delegate reading workspace/fields.ts to Kenji. Read directly instead?"
73
- options:
74
- - "Delegate to Kenji (recommended)"
75
- - "Read directly this once"
76
- ```
77
-
78
- **3. If user approves direct action:**
79
- 1. Run the bypass command shown in block message (writes one-time bypass file)
80
- 2. Retry the original tool call
81
- 3. Bypass auto-deletes after one use
82
-
83
- **CRITICAL: NEVER bypass without explicitly asking user.**
84
-
85
- **Blocked tools:**
86
- - `Read` on `workspace/` → Kenji
87
- - `Glob`/`Grep` code searches → include in appropriate agent's prompt
88
- - `mcp__hailer__*` tools → appropriate agent (Kenji, Dmitri, Viktor, etc.)
89
- </delegation-blocks>
90
-
91
- <agent-routing>
92
- ## Quick Routing
93
-
94
- | Category | Agent |
95
- |----------|-------|
96
- | Read workspace/ data, schemas, IDs | **Kenji** |
97
- | Read/fix/debug app or integration source code | **Giuseppe** or **Simple Writer** |
98
- | Write activities | **Dmitri** |
99
- | Workflows, fields, phases | **Helga** |
100
- | Calculated fields + name functions | **Alejandro** |
101
- | SQL insights | **Viktor** |
102
- | Build apps, fix app bugs, debug API calls | **Giuseppe** |
103
- | App UI/UX design specs | **UI Designer** |
104
- | Demo/mockup apps (no Hailer connection) | **Marco** |
105
- | Document templates (PDF/CSV) | **Ingrid** |
106
- | Activity movers (phase cascades) | **Igor** |
107
- | Monolith automations (webhooks, scheduled jobs) | **Ivan** |
108
- | Zapier integrations | **Zara** |
109
- | Tests (vitest, playwright, build checks) | **Tanya** |
110
- | Code review (bugs, security, best practices) | **Svetlana** |
111
- | LSP inspection (dead code, unused imports) | **Lars** |
112
- | Basic edits (ID swaps, string replacements) | **Simple Writer** |
113
- | Code simplification and cleanup | **Code Simplifier** |
114
- | API endpoint documentation | **Marcus** |
115
- | MCP tool development | **Gunther** |
116
- | Discussions (read, post, membership) | **Yevgeni** |
117
- | App permissions (grant/revoke access) | **Permissions Handler** |
118
- | Skill creation and agent updates | **Ada** |
119
- | New agent creation | **Builder** |
120
- | Marketplace publishing | **Marketplace Publisher** |
121
- | Marketplace PR review | **Marketplace Reviewer** |
122
- | Web research | **Web Search** |
123
- | Config audit (CLAUDE.md, hooks, agents) | **Bjorn** |
124
-
125
- Ambiguous routing? Load `delegation-routing` skill or run `/help:agents`.
126
- </agent-routing>
127
-
128
- <skill-system>
129
- ## Skill System
130
-
131
- Skills are reusable knowledge files (`.claude/skills/<name>/SKILL.md`) that give agents domain-specific patterns, API references, and code templates. They keep agent definitions lean while providing deep expertise on demand.
132
-
133
- **Two types of skill loading:**
134
-
135
- **1. Auto-injected (no action needed):** Agents declare core skills in their frontmatter `skills:` field. The `SubagentStart` hook (`skill-injector.cjs`) reads the list, loads each `SKILL.md` from `.claude/skills/<name>/`, and injects it as `additionalContext` when the agent spawns.
136
-
137
- **2. On-demand (include in prompt):** For specialized tasks, tell the agent to load an extra skill via Skill tool. Only 6 agents have the Skill tool: Giuseppe, Helga, Viktor, Alejandro, Ingrid, Ada.
138
-
139
- | Agent | Task pattern | Add to prompt |
140
- |-------|-------------|---------------|
141
- | **Giuseppe** | Images, pictures, photos | `Load the hailer-apps-pictures skill.` |
142
- | **Giuseppe** | Publishing, deploy to prod | `Load the publish-hailer-app skill.` |
143
- | **Giuseppe** | REST API, direct HTTP calls | `Load the hailer-rest-api skill.` |
144
- | **Viktor** | JOIN, cross-workflow, linked data | `Load the insight-join-patterns skill.` |
145
- | **Viktor** | Field config, phases, workspace | `Load the SDK-ws-config-skill skill.` |
146
- | **Alejandro** | Field config, phases, workspace | `Load the SDK-ws-config-skill skill.` |
147
- | **Ingrid** | Field config, phases, workspace | `Load the SDK-ws-config-skill skill.` |
148
-
149
- **Adding core skills to an agent:**
150
- ```yaml
151
- # In .claude/agents/agent-name.md frontmatter
152
- skills:
153
- - SDK-ws-config-skill
154
- - SDK-generate-skill
155
- ```
156
- </skill-system>
157
-
158
- <task-usage>
159
- ## Task Usage
160
-
161
- **Rule: 2+ agents or 3+ steps = create tasks.** Mark in_progress before starting, completed when done.
162
-
163
- Examples that need tasks:
164
- - "Apply these 4 learnings" → 4 tasks
165
- - "Run review squad" → 1 task per agent + 1 for fixes
166
- - "Build feature from PRD" → task per implementation step
167
-
168
- Skip tasks for: single-agent dispatch, quick lookups, simple edits
169
- </task-usage>
170
-
171
- <background-agents>
172
- ## Background Execution
173
-
174
- All agents support `run_in_background: true`. Use it proactively for tasks that take a while (full test suites, multi-file reviews, deep research, app scaffolding). Tell the user "Running X in background" and keep working. Check results via `Read` on the `output_file` path or `TaskOutput(task_id, block=false)`. Multiple agents can run in background simultaneously.
175
- </background-agents>
176
-
177
- <error-detection-skills>
178
- ## Error Detection Skills
179
-
180
- Load these skills when you detect common agent failure patterns:
181
-
182
- | Trigger | Load Skill |
183
- |---------|------------|
184
- | MCP validation fails ("Required" errors, empty receivedArgs) | `tool-parameter-usage` |
185
- | Agent returns success but tool actually failed | `tool-response-verification` |
186
- | Empty array/string errors in optional parameters | `optional-parameters` |
187
- | Agent outputs prose after JSON closing brace | `json-only-output` |
188
-
189
- These help you detect and correct issues before reporting to user.
190
- </error-detection-skills>
191
-
192
- <push-commands>
193
- When agents return `"status": "ready_to_push"`:
194
- ```json
195
- { "status": "ready_to_push", "commands": ["npm run fields-push"], "summary": "..." }
196
- ```
197
-
198
- YOU run these commands via Bash tool. This triggers safety hooks.
199
- Do NOT ask user to run them manually.
200
- </push-commands>
201
-
202
- <needs-confirmation>
203
- When agents return `"status": "needs_confirmation"`:
204
- 1. AskUserQuestion to confirm
205
- 2. If yes: run the `safe_command` from result
206
- 3. If no: report cancellation
207
- </needs-confirmation>
208
-
209
- ---
210
-
211
- <local-first>
212
- **Why local-first?** Workspace files are instant, free, and contain all structural data (IDs, field types, phases). API calls are slow, rate-limited, and only needed for live activity data. Always check workspace/ BEFORE API calls.
213
-
214
- ```
215
- workspace/
216
- ├── workflows.ts, enums.ts, teams.ts, groups.ts
217
- └── [Workflow]_[id]/
218
- ├── fields.ts
219
- └── phases.ts
220
- ```
221
-
222
- LOCAL: Workflow/field/phase IDs, field types, labels, options
223
- API: Activity data, counts, discussion messages
224
-
225
- REFRESH: `npm run pull`
226
- </local-first>
227
-
228
- <hooks>
229
- ## Hooks
230
-
231
- 26 CJS hooks in `.claude/hooks/` wired via `settings.json`. Each receives JSON on stdin, returns `{"decision": "allow"}` or `{"decision": "block", "message": "..."}` on stdout.
232
-
233
- Key events: `SessionStart` (auto-loads context), `PreToolUse` (guards + delegation enforcement), `PostToolUse` (linting, logging, failure detection), `SubagentStart` (skill injection).
234
-
235
- **If hooks break after `npm install`:** Check `.claude/settings.json` paths, test with `node .claude/hooks/<script>.cjs --help`, or run `/clear-defaults`.
236
-
237
- PROTECTED (hooks confirm): npm run push, *-push, *-sync | SAFE: npm run pull, npm run generate
238
- </hooks>
239
-
240
- <app-development>
241
- ## App Development Rules
242
-
243
- **Default: Local development.** Scaffold creates a dev app at `http://localhost:3000` automatically. Run `npm run dev` and test inside Hailer iframe.
244
-
245
- **Publishing: Only when user explicitly asks.** Tell Giuseppe to load the `publish-hailer-app` skill. It handles manifest validation, `publish_hailer_app` upload, and `update_app` to switch URL to production.
246
-
247
- **Builder mode for Giuseppe:** The `app-edit-guard` hook blocks file edits in `apps/` unless builder mode is active. Before spawning Giuseppe directly, run:
248
- ```bash
249
- node .claude/hooks/app-edit-guard.cjs --agent-on
250
- ```
251
- After Giuseppe completes:
252
- ```bash
253
- node .claude/hooks/app-edit-guard.cjs --agent-off
254
- ```
255
- The `/app-squad` command handles this automatically.
256
- </app-development>
257
-
258
- ---
259
-
260
- <session-protocol>
261
- ## Session Protocol
262
-
263
- ### Starting a Session
264
- SessionStart hook auto-loads SESSION-HANDOFF.md + DEVELOPMENT.md into context.
265
- 1. Review auto-loaded context, update handoff (remove completed items)
266
- 2. If handoff has "Pending Tasks" → recreate with `TaskCreate`
267
- 3. If no DEVELOPMENT.md → offer to create one
268
- 4. Briefly confirm current state before diving in
269
-
270
- ### During a Session
271
- - **Feature request:** Ask "Want me to create a PRD?" even if user provides detailed plan. Only skip if user explicitly declines or already used `/prd`/`/autoplan`.
272
- - **Tasks:** 2+ agents or 3+ steps = create tasks. Mark in_progress before starting, completed when done. If it won't be done this session, put it in DEVELOPMENT.md backlog.
273
- - **Learnings:** Use `/learn <cat> <desc>` to capture gotchas and patterns.
274
-
275
- ### Ending a Session
276
- - **Completion:** Update DEVELOPMENT.md + PRD status. Offer code-simplifier after features.
277
- - **Context full:** Update handoff, tell user to run `/handoff`.
278
- - **When to update DEVELOPMENT.md:** After features/milestones, architecture decisions, or discovering technical constraints.
279
-
280
- ### Planning Workflow
281
- 1. **Big picture → DEVELOPMENT.md** — Purpose, stack, roadmap linking to PRDs
282
- 2. **Feature details → PRDs** (`docs/prd-*.md`) — One per feature, links back to roadmap
283
- 3. **Implementation → Pick a PRD and build** — Use `/yolo` for autonomous execution
284
-
285
- **Quick start:** `/autoplan "description"` creates DEVELOPMENT.md + PRDs automatically.
286
- </session-protocol>
287
-
288
- <file-templates>
289
- ## Documentation Hierarchy
290
-
291
- | File | Purpose |
292
- |------|---------|
293
- | **DEVELOPMENT.md** | Project status, backlog, tech stack, roadmap |
294
- | **docs/prd-*.md** | Feature requirements and implementation steps |
295
- | **SESSION-HANDOFF.md** | Current work, next steps, key context |
296
-
297
- **DEVELOPMENT.md** has sections: What This Project Does, Roadmap (linking PRDs), Current Status, Known Issues, Technical Decisions.
298
- **SESSION-HANDOFF.md** has sections: Current Work, Next Steps, Context.
299
- </file-templates>
300
-
301
- <customization>
302
- **Creating agents:** Load `agent-structure` skill for template.
303
- **Modify:** Edit `.claude/agents/*.md`
304
- **Disable:** Move to `docs/agents/`
305
- </customization>
306
-
307
- <config-source>
308
- ## Config Source
309
-
310
- Agents, skills, hooks, and commands are in `.claude/` (project-local).
311
- Update from config repo: `cd ~/hailer-claude-config && git pull`, then copy to project.
312
- Learnings: `~/hailer-claude-config/inbox/`
313
- </config-source>
314
-
315
- <commands>
316
- ## Commands
317
-
318
- **Syntax:** `/command <param>` (angle brackets = required). `/help:topic` (colon = subtopic).
319
-
320
- **Essential:** `/save`, `/handoff`, `/prd`, `/autoplan`, `/yolo`, `/ws-pull`, `/learn`
321
-
322
- **Squads** (multi-agent workflows):
323
-
324
- | Squad | Agents | Use for |
325
- |-------|--------|---------|
326
- | `/app-squad` | Kenji → Designer → Giuseppe → Tanya | Build apps end-to-end |
327
- | `/review-squad` | Svetlana + Lars + Tanya | Code review with auto-fix |
328
- | `/config-squad` | Helga → Alejandro → Viktor | Workflow + fields + insights |
329
- | `/hotfix-squad` | Tanya → Simple Writer → Svetlana | Quick bug fixes |
330
- | `/debug-squad` | Kenji + Viktor + Svetlana + Tanya | Parallel investigation |
331
- | `/swarm <desc>` | Auto-selected | Large-scale parallel work |
332
-
333
- More squads + full command list: `/help:commands`
334
- </commands>
335
-
336
- <directory>
337
- ## Project Structure
338
-
339
- ```
340
- workspace/ # Hailer config - check FIRST for IDs
341
- apps/ # Frontend apps
342
- integrations/ # Backend services
343
- .claude/ # Agents, hooks, skills, commands (project-local)
344
- DEVELOPMENT.md # Project status
345
- ```
346
- </directory>
347
-
348
- <sdk-gotchas>
349
- ## Hailer SDK Quick Reference
350
-
351
- Common pitfalls that cause debugging loops - check these FIRST:
352
-
353
- | Gotcha | Correct | Wrong |
354
- |--------|---------|-------|
355
- | Activity field updates | `{type: "string", value: "x"}` wrapper | Raw value `"x"` |
356
- | `linkedfrom` in isolated-vm | Does NOT work - use ActivityLink field instead | Trying cross-link resolution |
357
- | Code in isolated-vm | Plain JavaScript only | TypeScript syntax (`as`, type annotations) |
358
- | Phase transitions | Exact string: `"Uudet"` → `"Tehty"` | Guessed names |
359
- | Field IDs | Read from workspace/ files | Guessing from labels |
360
- | Dropdown values | `{data: [{value, label}]}` | `{options: [...]}` |
361
- | ActivityLink format | Plain string array of workflow IDs | Nested objects |
362
-
363
- **Rule:** When touching Hailer fields, ALWAYS read workspace/ first via Kenji. Never guess IDs or formats.
364
- </sdk-gotchas>
365
-
366
- <bulk-operations>
367
- ## Bulk Tasks
368
-
369
- For repetitive edits, use `/swarm` or headless mode (`claude -p "..." --allowedTools "Edit,Read,Grep,Glob"`). Act first — grep to find instances, then edit immediately.
370
- </bulk-operations>
17
+ See `.claude/CLAUDE.md` for full project configuration — skills, hooks, commands, gotchas.
package/dist/app.d.ts.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AA+E9B,QAAA,MAAM,IAAI,MAAa,CAAC;AAqKxB,eAAe,IAAI,CAAC"}
1
+ {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAO9B,QAAA,MAAM,IAAI,MAAa,CAAC;AAwBxB,eAAe,IAAI,CAAC"}
package/dist/app.js CHANGED
@@ -3,144 +3,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const core_1 = require("./core");
4
4
  const config_1 = require("./config");
5
5
  const logger_1 = require("./lib/logger");
6
- const logger = (0, logger_1.createLogger)({ component: 'app' });
7
- const file_1 = require("./mcp/tools/file");
8
- const activity_1 = require("./mcp/tools/activity");
9
- const discussion_1 = require("./mcp/tools/discussion");
10
- const user_1 = require("./mcp/tools/user");
11
- const company_1 = require("./mcp/tools/company");
12
- const workflow_1 = require("./mcp/tools/workflow");
13
- const insight_1 = require("./mcp/tools/insight");
14
- const workflow_permissions_1 = require("./mcp/tools/workflow-permissions");
15
- const app_1 = require("./mcp/tools/app");
16
- // Vipunen plugin — Weaviate RAG knowledge base (conditional on WEAVIATE_HOST)
6
+ const tools_1 = require("./mcp/tools");
17
7
  const vipunen_1 = require("./plugins/vipunen");
18
- // Bot config and bug-fixer tools are dynamically imported only when MCP_CLIENT_ENABLED=true
19
- // This allows the npm package to work without these modules
8
+ const logger = (0, logger_1.createLogger)({ component: 'app' });
20
9
  const core = new core_1.Core();
21
- logger.debug('Registering tools...');
22
- logger.debug('Nuclear tools status', { enabled: config_1.environment.ENABLE_NUCLEAR_TOOLS });
23
- core.addTool(file_1.uploadFilesTool);
24
- core.addTool(file_1.downloadFileTool);
25
- core.addTool(activity_1.listActivitiesTool);
26
- core.addTool(activity_1.showActivityByIdTool);
27
- core.addTool(activity_1.createActivityTool);
28
- core.addTool(activity_1.updateActivityTool);
29
- core.addTool(discussion_1.listMyDiscussionsTool);
30
- core.addTool(discussion_1.fetchDiscussionMessagesTool);
31
- core.addTool(discussion_1.fetchPreviousDiscussionMessagesTool);
32
- core.addTool(discussion_1.joinDiscussionTool);
33
- core.addTool(discussion_1.leaveDiscussionTool);
34
- core.addTool(discussion_1.addDiscussionMessageTool);
35
- core.addTool(discussion_1.inviteDiscussionMembersTool);
36
- core.addTool(discussion_1.getActivityFromDiscussionTool);
37
- core.addTool(user_1.searchWorkspaceUsersTool);
38
- core.addTool(user_1.getWorkspaceBalanceTool);
39
- core.addTool(company_1.setUserRoleTool);
40
- core.addTool(workflow_1.getWorkflowSchemaTool);
41
- core.addTool(workflow_1.listWorkflowPhasesTool);
42
- core.addTool(workflow_1.listWorkflowsTool);
43
- core.addTool(workflow_1.installWorkflowTool);
44
- if (config_1.environment.ENABLE_NUCLEAR_TOOLS) {
45
- core.addTool(workflow_1.removeWorkflowTool);
46
- }
47
- core.addTool(workflow_1.updateWorkflowFieldTool);
48
- core.addTool(workflow_1.updateWorkflowPhaseTool);
49
- core.addTool(workflow_1.testFunctionFieldTool);
50
- core.addTool(workflow_1.listWorkflowsMinimalTool);
51
- core.addTool(workflow_1.countActivitiesTool);
52
- core.addTool(workflow_1.coreInitTool);
53
- core.addTool(workflow_permissions_1.listWorkflowPermissionsTool);
54
- core.addTool(workflow_permissions_1.grantWorkflowPermissionTool);
55
- core.addTool(workflow_permissions_1.revokeWorkflowPermissionTool);
56
- core.addTool(workflow_permissions_1.checkUserPermissionsTool);
57
- core.addTool(insight_1.createInsightTool);
58
- core.addTool(insight_1.previewInsightTool);
59
- core.addTool(insight_1.getInsightDataTool);
60
- core.addTool(insight_1.updateInsightTool);
61
- if (config_1.environment.ENABLE_NUCLEAR_TOOLS) {
62
- core.addTool(insight_1.removeInsightTool);
63
- }
64
- core.addTool(insight_1.listInsightsTool);
65
- core.addTool(app_1.createAppTool);
66
- core.addTool(app_1.listAppsTool);
67
- core.addTool(app_1.updateAppTool);
68
- if (config_1.environment.ENABLE_NUCLEAR_TOOLS) {
69
- core.addTool(app_1.removeAppTool);
10
+ // Register all Hailer tools
11
+ for (const tool of tools_1.allTools) {
12
+ core.addTool(tool);
70
13
  }
71
- core.addTool(app_1.addAppMemberTool);
72
- core.addTool(app_1.removeAppMemberTool);
73
- core.addTool(app_1.scaffoldHailerAppTool);
74
- core.addTool(app_1.publishHailerAppTool);
75
- // Marketplace template tools
76
- core.addTool(app_1.listTemplatesTool);
77
- core.addTool(app_1.createTemplateTool);
78
- core.addTool(app_1.installTemplateTool);
79
- core.addTool(app_1.getTemplateTool);
80
- core.addTool(app_1.publishTemplateTool);
81
- core.addTool(app_1.getProductTool);
82
- core.addTool(app_1.getProductManifestTool);
83
- // Marketplace app tools
84
- core.addTool(app_1.publishAppTool);
85
- core.addTool(app_1.installMarketplaceAppTool);
86
- // Vipunen tools (Weaviate RAG) — only registered when WEAVIATE_HOST is set
87
- const vipunenTools = (0, vipunen_1.registerVipunenTools)({
14
+ // Register Vipunen tools (conditional on WEAVIATE_HOST)
15
+ for (const tool of (0, vipunen_1.registerVipunenTools)({
88
16
  weaviateHost: config_1.environment.WEAVIATE_HOST,
89
17
  weaviateApiKey: config_1.environment.WEAVIATE_API_KEY,
90
18
  vipunenApiKeys: config_1.environment.VIPUNEN_API_KEYS,
91
- });
92
- for (const tool of vipunenTools) {
19
+ })) {
93
20
  core.addTool(tool);
94
21
  }
95
- // Bot-internal tools - dynamically imported only when MCP_CLIENT_ENABLED=true
96
- // Wrapped in try/catch so global installs work (bot-config excluded from npm package)
97
- if (config_1.environment.MCP_CLIENT_ENABLED) {
98
- try {
99
- // Dynamic import bot-config tools
100
- const { listBotsConfigTool, enableBotTool, disableBotTool, checkSpecialistStatusTool } = require('./bot-config');
101
- core.addTool(listBotsConfigTool);
102
- core.addTool(enableBotTool);
103
- core.addTool(disableBotTool);
104
- core.addTool(checkSpecialistStatusTool);
105
- // Dynamic import bug-fixer tools
106
- const {
107
- // Low-level tools
108
- bugFixerFindAppTool, bugFixerListFilesTool, bugFixerReadFileTool, bugFixerWriteFileTool, bugFixerApplyFixTool, bugFixerRunBuildTool, bugFixerGitStatusTool, bugFixerGitPullTool, bugFixerGitCommitTool, bugFixerGitPushTool, bugFixerGitRevertTool, bugFixerPublishAppTool,
109
- // High-level workflow tools (LLM-driven)
110
- bugFixerAnalyzeBugTool, bugFixerStartFixTool, bugFixerMarkDeclinedTool, bugFixerPublishFixTool, bugFixerRetryFixTool, markBugDeclinedTool, markBugFixedTool } = require('./plugins/bug-fixer');
111
- // Low-level tools
112
- core.addTool(bugFixerFindAppTool);
113
- core.addTool(bugFixerListFilesTool);
114
- core.addTool(bugFixerReadFileTool);
115
- core.addTool(bugFixerWriteFileTool);
116
- core.addTool(bugFixerApplyFixTool);
117
- core.addTool(bugFixerRunBuildTool);
118
- core.addTool(bugFixerGitStatusTool);
119
- core.addTool(bugFixerGitPullTool);
120
- core.addTool(bugFixerGitCommitTool);
121
- core.addTool(bugFixerGitPushTool);
122
- core.addTool(bugFixerGitRevertTool);
123
- core.addTool(bugFixerPublishAppTool);
124
- // High-level workflow tools (LLM-driven)
125
- core.addTool(bugFixerAnalyzeBugTool);
126
- core.addTool(bugFixerStartFixTool);
127
- core.addTool(bugFixerMarkDeclinedTool);
128
- core.addTool(bugFixerPublishFixTool);
129
- core.addTool(bugFixerRetryFixTool);
130
- core.addTool(markBugDeclinedTool);
131
- core.addTool(markBugFixedTool);
132
- logger.debug('Bot-internal tools registered (MCP_CLIENT_ENABLED=true)');
133
- }
134
- catch {
135
- logger.warn('Bot modules not available (normal for npm package installs)');
136
- }
137
- }
138
- logger.debug('All tools registered successfully');
139
- // Start the application
22
+ logger.debug('All tools registered');
23
+ // Start
140
24
  core.start().catch((error) => {
141
25
  logger.error('Failed to start Hailer MCP application', error);
142
26
  process.exit(1);
143
27
  });
144
- // Export core for testing and external access
145
28
  exports.default = core;
146
29
  //# sourceMappingURL=app.js.map
package/dist/app.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":";;AAAA,iCAA8B;AAC9B,qCAAuC;AACvC,yCAA4C;AAC5C,uCAAuC;AACvC,+CAAyD;AAEzD,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;AAClD,MAAM,IAAI,GAAG,IAAI,WAAI,EAAE,CAAC;AAExB,4BAA4B;AAC5B,KAAK,MAAM,IAAI,IAAI,gBAAQ,EAAE,CAAC;IAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AACrB,CAAC;AAED,wDAAwD;AACxD,KAAK,MAAM,IAAI,IAAI,IAAA,8BAAoB,EAAC;IACtC,YAAY,EAAE,oBAAW,CAAC,aAAa;IACvC,cAAc,EAAE,oBAAW,CAAC,gBAAgB;IAC5C,cAAc,EAAE,oBAAW,CAAC,gBAAgB;CAC7C,CAAC,EAAE,CAAC;IACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AACrB,CAAC;AAED,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;AAErC,QAAQ;AACR,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;IAC3B,MAAM,CAAC,KAAK,CAAC,wCAAwC,EAAE,KAAK,CAAC,CAAC;IAC9D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC;AAEH,kBAAe,IAAI,CAAC"}
@@ -5,18 +5,8 @@
5
5
  * and provides start/stop/status operations.
6
6
  */
7
7
  import { ToolRegistry } from '../mcp/tool-registry';
8
- import { BotConfig } from './bot-config';
9
- interface BotUpdateEntry {
10
- activityId: string;
11
- email: string;
12
- password: string;
13
- botType: string;
14
- enabled: boolean;
15
- displayName?: string;
16
- systemPrompt?: string;
17
- accessLevel?: string;
18
- responseMode?: string;
19
- }
8
+ import { BotConfig } from '../bot-config';
9
+ import type { BotEntry } from '../bot-config/types';
20
10
  export declare class BotManager {
21
11
  private toolRegistry;
22
12
  private anthropicApiKey;
@@ -44,7 +34,6 @@ export declare class BotManager {
44
34
  * Supports all bot types. Routes by activityId so multiple bots
45
35
  * can run in the same workspace independently.
46
36
  */
47
- handleBotUpdate(workspaceId: string, bot: BotUpdateEntry, action: 'add' | 'update' | 'remove'): Promise<void>;
37
+ handleBotUpdate(workspaceId: string, bot: BotEntry, action: 'add' | 'update' | 'remove'): Promise<void>;
48
38
  }
49
- export {};
50
39
  //# sourceMappingURL=bot-manager.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"bot-manager.d.ts","sourceRoot":"","sources":["../../src/bot/bot-manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAE,SAAS,EAAkB,MAAM,cAAc,CAAC;AAKzD,UAAU,cAAc;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,qBAAa,UAAU;IAQnB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,eAAe;IARzB,qCAAqC;IACrC,OAAO,CAAC,IAAI,CAA0B;IACtC,sEAAsE;IACtE,OAAO,CAAC,aAAa,CAAkC;IACvD,OAAO,CAAC,OAAO,CAAS;gBAGd,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,MAAM;IAKjC,kEAAkE;IAClE,yBAAyB,CAAC,WAAW,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;IAYrD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBzB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC1C,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB5D,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAc9B,SAAS,IAAI,KAAK,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,OAAO,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,CAAC;IASxG,WAAW,IAAI,MAAM;IAIrB;;;;OAIG;IACG,eAAe,CACnB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,cAAc,EACnB,MAAM,EAAE,KAAK,GAAG,QAAQ,GAAG,QAAQ,GAClC,OAAO,CAAC,IAAI,CAAC;CAsEjB"}
1
+ {"version":3,"file":"bot-manager.d.ts","sourceRoot":"","sources":["../../src/bot/bot-manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAE,SAAS,EAAsB,MAAM,eAAe,CAAC;AAC9D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAMpD,qBAAa,UAAU;IAQnB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,eAAe;IARzB,qCAAqC;IACrC,OAAO,CAAC,IAAI,CAA0B;IACtC,sEAAsE;IACtE,OAAO,CAAC,aAAa,CAAkC;IACvD,OAAO,CAAC,OAAO,CAAS;gBAGd,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,MAAM;IAKjC,kEAAkE;IAClE,yBAAyB,CAAC,WAAW,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;IAYrD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBzB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IA8C1C,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB5D,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAc9B,SAAS,IAAI,KAAK,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,OAAO,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,CAAC;IASxG,WAAW,IAAI,MAAM;IAIrB;;;;OAIG;IACG,eAAe,CACnB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,QAAQ,EACb,MAAM,EAAE,KAAK,GAAG,QAAQ,GAAG,QAAQ,GAClC,OAAO,CAAC,IAAI,CAAC;CAuEjB"}
@@ -8,8 +8,9 @@
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
9
  exports.BotManager = void 0;
10
10
  const bot_1 = require("./bot");
11
- const bot_config_1 = require("./bot-config");
11
+ const bot_config_1 = require("../bot-config");
12
12
  const logger_1 = require("../lib/logger");
13
+ const config_1 = require("../config");
13
14
  const logger = (0, logger_1.createLogger)({ component: 'bot-manager' });
14
15
  class BotManager {
15
16
  toolRegistry;
@@ -22,7 +23,7 @@ class BotManager {
22
23
  constructor(toolRegistry, anthropicApiKey) {
23
24
  this.toolRegistry = toolRegistry;
24
25
  this.anthropicApiKey = anthropicApiKey;
25
- this.apiHost = process.env.BOT_API_BASE_URL || 'https://api.hailer.com';
26
+ this.apiHost = config_1.environment.BOT_API_BASE_URL;
26
27
  }
27
28
  /** Get all bot userIds in a workspace (for self-message guard) */
28
29
  getBotUserIdsForWorkspace(workspaceId) {
@@ -38,7 +39,7 @@ class BotManager {
38
39
  return ids;
39
40
  }
40
41
  async startAll() {
41
- const configs = (0, bot_config_1.loadBotConfigs)();
42
+ const configs = (0, bot_config_1.loadFlatBotConfigs)();
42
43
  const enabled = configs.filter(c => c.enabled);
43
44
  logger.debug('Starting bots', { total: configs.length, enabled: enabled.length });
44
45
  const results = await Promise.allSettled(enabled.map(config => this.startBot(config)));
@@ -76,8 +77,15 @@ class BotManager {
76
77
  accessLevel: config.accessLevel,
77
78
  allowedWorkflows: config.allowedWorkflows,
78
79
  });
79
- await bot.start();
80
+ // Reserve the slot before async start to prevent duplicate starts from concurrent webhooks
80
81
  this.bots.set(botKey, bot);
82
+ try {
83
+ await bot.start();
84
+ }
85
+ catch (error) {
86
+ this.bots.delete(botKey);
87
+ throw error;
88
+ }
81
89
  // Track in workspace lookup
82
90
  if (!this.workspaceBots.has(config.workspaceId)) {
83
91
  this.workspaceBots.set(config.workspaceId, new Set());
@@ -173,6 +181,7 @@ class BotManager {
173
181
  enabled: true,
174
182
  apiHost: this.apiHost,
175
183
  accessLevel: bot.accessLevel,
184
+ allowedWorkflows: bot.allowedWorkflows,
176
185
  responseMode: bot.responseMode,
177
186
  };
178
187
  try {