agent-relay 2.0.29 → 2.0.32

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 (894) hide show
  1. package/README.md +19 -0
  2. package/dist/index.cjs +85691 -0
  3. package/dist/src/bridge/index.d.ts.map +1 -0
  4. package/dist/src/bridge/index.js.map +1 -0
  5. package/dist/src/cli/commands/doctor.d.ts +2 -0
  6. package/dist/src/cli/commands/doctor.d.ts.map +1 -0
  7. package/dist/src/cli/commands/doctor.js +451 -0
  8. package/dist/src/cli/commands/doctor.js.map +1 -0
  9. package/dist/src/cli/index.d.ts.map +1 -0
  10. package/dist/src/cli/index.js +29 -1
  11. package/dist/src/cli/index.js.map +1 -0
  12. package/dist/src/config/relay-config.d.ts.map +1 -0
  13. package/dist/src/config/relay-config.js.map +1 -0
  14. package/dist/src/continuity/index.d.ts.map +1 -0
  15. package/dist/src/continuity/index.js.map +1 -0
  16. package/dist/src/daemon/index.d.ts.map +1 -0
  17. package/dist/src/daemon/index.js.map +1 -0
  18. package/dist/src/health-worker-manager.d.ts.map +1 -0
  19. package/dist/src/health-worker-manager.js.map +1 -0
  20. package/dist/src/health-worker.d.ts.map +1 -0
  21. package/dist/src/health-worker.js.map +1 -0
  22. package/dist/src/hooks/index.d.ts.map +1 -0
  23. package/dist/src/hooks/index.js.map +1 -0
  24. package/dist/src/index.d.ts.map +1 -0
  25. package/dist/src/index.js.map +1 -0
  26. package/dist/src/memory/index.d.ts.map +1 -0
  27. package/dist/src/memory/index.js.map +1 -0
  28. package/dist/src/policy/index.d.ts.map +1 -0
  29. package/dist/src/policy/index.js.map +1 -0
  30. package/dist/src/protocol/index.d.ts.map +1 -0
  31. package/dist/src/protocol/index.js.map +1 -0
  32. package/dist/src/resiliency/index.d.ts.map +1 -0
  33. package/dist/src/resiliency/index.js.map +1 -0
  34. package/dist/src/shared/cli-auth-config.d.ts.map +1 -0
  35. package/dist/src/shared/cli-auth-config.js.map +1 -0
  36. package/dist/src/state/index.d.ts.map +1 -0
  37. package/dist/src/state/index.js.map +1 -0
  38. package/dist/src/storage/index.d.ts.map +1 -0
  39. package/dist/src/storage/index.js.map +1 -0
  40. package/dist/src/trajectory/index.d.ts.map +1 -0
  41. package/dist/src/trajectory/index.js.map +1 -0
  42. package/dist/src/utils/index.d.ts.map +1 -0
  43. package/dist/src/utils/index.js.map +1 -0
  44. package/dist/src/wrapper/index.d.ts.map +1 -0
  45. package/dist/src/wrapper/index.js.map +1 -0
  46. package/package.json +83 -20
  47. package/packages/api-types/dist/index.d.ts.map +1 -0
  48. package/packages/api-types/dist/index.js.map +1 -0
  49. package/packages/api-types/dist/schemas/agent.d.ts.map +1 -0
  50. package/packages/api-types/dist/schemas/agent.js.map +1 -0
  51. package/packages/api-types/dist/schemas/api.d.ts.map +1 -0
  52. package/packages/api-types/dist/schemas/api.js.map +1 -0
  53. package/packages/api-types/dist/schemas/decision.d.ts.map +1 -0
  54. package/packages/api-types/dist/schemas/decision.js.map +1 -0
  55. package/packages/api-types/dist/schemas/fleet.d.ts.map +1 -0
  56. package/packages/api-types/dist/schemas/fleet.js.map +1 -0
  57. package/packages/api-types/dist/schemas/history.d.ts.map +1 -0
  58. package/packages/api-types/dist/schemas/history.js.map +1 -0
  59. package/packages/api-types/dist/schemas/index.d.ts.map +1 -0
  60. package/packages/api-types/dist/schemas/index.js.map +1 -0
  61. package/packages/api-types/dist/schemas/message.d.ts.map +1 -0
  62. package/packages/api-types/dist/schemas/message.js.map +1 -0
  63. package/packages/api-types/dist/schemas/session.d.ts.map +1 -0
  64. package/packages/api-types/dist/schemas/session.js.map +1 -0
  65. package/packages/api-types/dist/schemas/task.d.ts.map +1 -0
  66. package/packages/api-types/dist/schemas/task.js.map +1 -0
  67. package/packages/api-types/package.json +1 -1
  68. package/packages/api-types/src/index.ts +22 -0
  69. package/packages/api-types/src/schemas/agent.test.ts +164 -0
  70. package/packages/api-types/src/schemas/agent.ts +110 -0
  71. package/packages/api-types/src/schemas/api.test.ts +372 -0
  72. package/packages/api-types/src/schemas/api.ts +194 -0
  73. package/packages/api-types/src/schemas/decision.test.ts +324 -0
  74. package/packages/api-types/src/schemas/decision.ts +136 -0
  75. package/packages/api-types/src/schemas/fleet.test.ts +212 -0
  76. package/packages/api-types/src/schemas/fleet.ts +83 -0
  77. package/packages/api-types/src/schemas/history.test.ts +242 -0
  78. package/packages/api-types/src/schemas/history.ts +84 -0
  79. package/packages/api-types/src/schemas/index.ts +148 -0
  80. package/packages/api-types/src/schemas/message.test.ts +192 -0
  81. package/packages/api-types/src/schemas/message.ts +98 -0
  82. package/packages/api-types/src/schemas/session.test.ts +104 -0
  83. package/packages/api-types/src/schemas/session.ts +40 -0
  84. package/packages/api-types/src/schemas/task.test.ts +192 -0
  85. package/packages/api-types/src/schemas/task.ts +78 -0
  86. package/packages/api-types/tsconfig.json +19 -0
  87. package/packages/api-types/vitest.config.ts +9 -0
  88. package/packages/benchmark/README.md +200 -0
  89. package/packages/benchmark/datasets/coding-tasks.yaml +127 -0
  90. package/packages/benchmark/datasets/coordination-tasks.yaml +122 -0
  91. package/packages/benchmark/dist/benchmark.d.ts +47 -0
  92. package/packages/benchmark/dist/benchmark.d.ts.map +1 -0
  93. package/packages/benchmark/dist/benchmark.js +224 -0
  94. package/packages/benchmark/dist/benchmark.js.map +1 -0
  95. package/packages/benchmark/dist/cli.d.ts +8 -0
  96. package/packages/benchmark/dist/cli.d.ts.map +1 -0
  97. package/packages/benchmark/dist/cli.js +185 -0
  98. package/packages/benchmark/dist/cli.js.map +1 -0
  99. package/packages/benchmark/dist/harbor.d.ts +53 -0
  100. package/packages/benchmark/dist/harbor.d.ts.map +1 -0
  101. package/packages/benchmark/dist/harbor.js +127 -0
  102. package/packages/benchmark/dist/harbor.js.map +1 -0
  103. package/packages/benchmark/dist/index.d.ts +48 -0
  104. package/packages/benchmark/dist/index.d.ts.map +1 -0
  105. package/packages/benchmark/dist/index.js +50 -0
  106. package/packages/benchmark/dist/index.js.map +1 -0
  107. package/packages/benchmark/dist/runners/base.d.ts +63 -0
  108. package/packages/benchmark/dist/runners/base.d.ts.map +1 -0
  109. package/packages/benchmark/dist/runners/base.js +155 -0
  110. package/packages/benchmark/dist/runners/base.js.map +1 -0
  111. package/packages/benchmark/dist/runners/index.d.ts +10 -0
  112. package/packages/benchmark/dist/runners/index.d.ts.map +1 -0
  113. package/packages/benchmark/dist/runners/index.js +10 -0
  114. package/packages/benchmark/dist/runners/index.js.map +1 -0
  115. package/packages/benchmark/dist/runners/single.d.ts +19 -0
  116. package/packages/benchmark/dist/runners/single.d.ts.map +1 -0
  117. package/packages/benchmark/dist/runners/single.js +111 -0
  118. package/packages/benchmark/dist/runners/single.js.map +1 -0
  119. package/packages/benchmark/dist/runners/subagent.d.ts +32 -0
  120. package/packages/benchmark/dist/runners/subagent.d.ts.map +1 -0
  121. package/packages/benchmark/dist/runners/subagent.js +212 -0
  122. package/packages/benchmark/dist/runners/subagent.js.map +1 -0
  123. package/packages/benchmark/dist/runners/swarm.d.ts +36 -0
  124. package/packages/benchmark/dist/runners/swarm.d.ts.map +1 -0
  125. package/packages/benchmark/dist/runners/swarm.js +273 -0
  126. package/packages/benchmark/dist/runners/swarm.js.map +1 -0
  127. package/packages/benchmark/dist/types.d.ts +178 -0
  128. package/packages/benchmark/dist/types.d.ts.map +1 -0
  129. package/packages/benchmark/dist/types.js +16 -0
  130. package/packages/benchmark/dist/types.js.map +1 -0
  131. package/packages/benchmark/package.json +80 -0
  132. package/packages/benchmark/src/benchmark.ts +298 -0
  133. package/packages/benchmark/src/cli.ts +240 -0
  134. package/packages/benchmark/src/harbor.ts +170 -0
  135. package/packages/benchmark/src/index.ts +73 -0
  136. package/packages/benchmark/src/runners/base.ts +204 -0
  137. package/packages/benchmark/src/runners/index.ts +10 -0
  138. package/packages/benchmark/src/runners/single.ts +121 -0
  139. package/packages/benchmark/src/runners/subagent.ts +240 -0
  140. package/packages/benchmark/src/runners/swarm.ts +326 -0
  141. package/packages/benchmark/src/types.ts +205 -0
  142. package/packages/benchmark/tsconfig.json +20 -0
  143. package/packages/bridge/dist/index.d.ts.map +1 -0
  144. package/packages/bridge/dist/index.js.map +1 -0
  145. package/packages/bridge/dist/multi-project-client.d.ts.map +1 -0
  146. package/packages/bridge/dist/multi-project-client.js.map +1 -0
  147. package/packages/bridge/dist/shadow-cli.d.ts.map +1 -0
  148. package/packages/bridge/dist/shadow-cli.js.map +1 -0
  149. package/packages/bridge/dist/spawner.d.ts.map +1 -0
  150. package/packages/bridge/dist/spawner.js +10 -2
  151. package/packages/bridge/dist/spawner.js.map +1 -0
  152. package/packages/bridge/dist/types.d.ts.map +1 -0
  153. package/packages/bridge/dist/types.js.map +1 -0
  154. package/packages/bridge/dist/utils.d.ts.map +1 -0
  155. package/packages/bridge/dist/utils.js.map +1 -0
  156. package/packages/bridge/package.json +8 -8
  157. package/packages/bridge/src/index.ts +25 -0
  158. package/packages/bridge/src/multi-project-client.test.ts +340 -0
  159. package/packages/bridge/src/multi-project-client.ts +469 -0
  160. package/packages/bridge/src/shadow-cli.ts +95 -0
  161. package/packages/bridge/src/spawner-mcp.test.ts +505 -0
  162. package/packages/bridge/src/spawner.ts +1724 -0
  163. package/packages/bridge/src/types.ts +145 -0
  164. package/packages/bridge/src/utils.test.ts +98 -0
  165. package/packages/bridge/src/utils.ts +67 -0
  166. package/packages/bridge/tsconfig.json +29 -0
  167. package/packages/bridge/vitest.config.ts +9 -0
  168. package/packages/cli-tester/dist/index.d.ts.map +1 -0
  169. package/packages/cli-tester/dist/index.js.map +1 -0
  170. package/packages/cli-tester/dist/utils/credential-check.d.ts.map +1 -0
  171. package/packages/cli-tester/dist/utils/credential-check.js.map +1 -0
  172. package/packages/cli-tester/dist/utils/socket-client.d.ts.map +1 -0
  173. package/packages/cli-tester/dist/utils/socket-client.js.map +1 -0
  174. package/packages/cli-tester/docker/Dockerfile +61 -0
  175. package/packages/cli-tester/docker/docker-compose.yml +71 -0
  176. package/packages/cli-tester/package.json +1 -1
  177. package/packages/cli-tester/src/index.ts +40 -0
  178. package/packages/cli-tester/src/utils/credential-check.ts +284 -0
  179. package/packages/cli-tester/src/utils/socket-client.ts +211 -0
  180. package/packages/cli-tester/tests/credential-check.test.ts +56 -0
  181. package/packages/cli-tester/tsconfig.json +11 -0
  182. package/packages/config/dist/agent-config.d.ts.map +1 -0
  183. package/packages/config/dist/agent-config.js.map +1 -0
  184. package/packages/config/dist/bridge-config.d.ts.map +1 -0
  185. package/packages/config/dist/bridge-config.js.map +1 -0
  186. package/packages/config/dist/bridge-utils.d.ts.map +1 -0
  187. package/packages/config/dist/bridge-utils.js.map +1 -0
  188. package/packages/config/dist/cli-auth-config.d.ts.map +1 -0
  189. package/packages/config/dist/cli-auth-config.js.map +1 -0
  190. package/packages/config/dist/cloud-config.d.ts.map +1 -0
  191. package/packages/config/dist/cloud-config.js.map +1 -0
  192. package/packages/config/dist/index.d.ts.map +1 -0
  193. package/packages/config/dist/index.js.map +1 -0
  194. package/packages/config/dist/project-namespace.d.ts.map +1 -0
  195. package/packages/config/dist/project-namespace.js.map +1 -0
  196. package/packages/config/dist/relay-config.d.ts.map +1 -0
  197. package/packages/config/dist/relay-config.js.map +1 -0
  198. package/packages/config/dist/relay-file-writer.d.ts.map +1 -0
  199. package/packages/config/dist/relay-file-writer.js.map +1 -0
  200. package/packages/config/dist/schemas.d.ts.map +1 -0
  201. package/packages/config/dist/schemas.js.map +1 -0
  202. package/packages/config/dist/shadow-config.d.ts.map +1 -0
  203. package/packages/config/dist/shadow-config.js.map +1 -0
  204. package/packages/config/dist/teams-config.d.ts.map +1 -0
  205. package/packages/config/dist/teams-config.js.map +1 -0
  206. package/packages/config/dist/trajectory-config.d.ts.map +1 -0
  207. package/packages/config/dist/trajectory-config.js.map +1 -0
  208. package/packages/config/package.json +2 -2
  209. package/packages/config/src/agent-config.test.ts +245 -0
  210. package/packages/config/src/agent-config.ts +160 -0
  211. package/packages/config/src/bridge-config.test.ts +132 -0
  212. package/packages/config/src/bridge-config.ts +189 -0
  213. package/packages/config/src/bridge-utils.ts +59 -0
  214. package/packages/config/src/cli-auth-config.ts +548 -0
  215. package/packages/config/src/cloud-config.ts +208 -0
  216. package/packages/config/src/index.ts +12 -0
  217. package/packages/config/src/project-namespace.ts +344 -0
  218. package/packages/config/src/relay-config.test.ts +51 -0
  219. package/packages/config/src/relay-config.ts +36 -0
  220. package/packages/config/src/relay-file-writer.test.ts +351 -0
  221. package/packages/config/src/relay-file-writer.ts +508 -0
  222. package/packages/config/src/schemas.test.ts +59 -0
  223. package/packages/config/src/schemas.ts +201 -0
  224. package/packages/config/src/shadow-config.ts +205 -0
  225. package/packages/config/src/teams-config.ts +135 -0
  226. package/packages/config/src/trajectory-config.ts +222 -0
  227. package/packages/config/tsconfig.json +21 -0
  228. package/packages/config/vitest.config.ts +9 -0
  229. package/packages/continuity/dist/formatter.d.ts.map +1 -0
  230. package/packages/continuity/dist/formatter.js.map +1 -0
  231. package/packages/continuity/dist/handoff-store.d.ts.map +1 -0
  232. package/packages/continuity/dist/handoff-store.js.map +1 -0
  233. package/packages/continuity/dist/index.d.ts.map +1 -0
  234. package/packages/continuity/dist/index.js.map +1 -0
  235. package/packages/continuity/dist/ledger-store.d.ts.map +1 -0
  236. package/packages/continuity/dist/ledger-store.js.map +1 -0
  237. package/packages/continuity/dist/manager.d.ts.map +1 -0
  238. package/packages/continuity/dist/manager.js.map +1 -0
  239. package/packages/continuity/dist/parser.d.ts.map +1 -0
  240. package/packages/continuity/dist/parser.js.map +1 -0
  241. package/packages/continuity/dist/types.d.ts.map +1 -0
  242. package/packages/continuity/dist/types.js.map +1 -0
  243. package/packages/continuity/package.json +1 -1
  244. package/packages/continuity/src/formatter.ts +371 -0
  245. package/packages/continuity/src/handoff-store.ts +523 -0
  246. package/packages/continuity/src/index.ts +9 -0
  247. package/packages/continuity/src/ledger-store.ts +594 -0
  248. package/packages/continuity/src/manager.test.ts +291 -0
  249. package/packages/continuity/src/manager.ts +774 -0
  250. package/packages/continuity/src/parser.test.ts +292 -0
  251. package/packages/continuity/src/parser.ts +680 -0
  252. package/packages/continuity/src/types.ts +211 -0
  253. package/packages/continuity/tsconfig.json +21 -0
  254. package/packages/continuity/vitest.config.ts +9 -0
  255. package/packages/daemon/dist/agent-manager.d.ts.map +1 -0
  256. package/packages/daemon/dist/agent-manager.js.map +1 -0
  257. package/packages/daemon/dist/agent-registry.d.ts.map +1 -0
  258. package/packages/daemon/dist/agent-registry.js.map +1 -0
  259. package/packages/daemon/dist/agent-signing.d.ts.map +1 -0
  260. package/packages/daemon/dist/agent-signing.js.map +1 -0
  261. package/packages/daemon/dist/api.d.ts.map +1 -0
  262. package/packages/daemon/dist/api.js.map +1 -0
  263. package/packages/daemon/dist/auth.d.ts.map +1 -0
  264. package/packages/daemon/dist/auth.js.map +1 -0
  265. package/packages/daemon/dist/channel-membership-store.d.ts.map +1 -0
  266. package/packages/daemon/dist/channel-membership-store.js.map +1 -0
  267. package/packages/daemon/dist/cli-auth.d.ts.map +1 -0
  268. package/packages/daemon/dist/cli-auth.js.map +1 -0
  269. package/packages/daemon/dist/cloud-sync.d.ts.map +1 -0
  270. package/packages/daemon/dist/cloud-sync.js.map +1 -0
  271. package/packages/daemon/dist/connection.d.ts.map +1 -0
  272. package/packages/daemon/dist/connection.js.map +1 -0
  273. package/packages/daemon/dist/consensus-integration.d.ts.map +1 -0
  274. package/packages/daemon/dist/consensus-integration.js.map +1 -0
  275. package/packages/daemon/dist/consensus.d.ts.map +1 -0
  276. package/packages/daemon/dist/consensus.js.map +1 -0
  277. package/packages/daemon/dist/delivery-tracker.d.ts.map +1 -0
  278. package/packages/daemon/dist/delivery-tracker.js.map +1 -0
  279. package/packages/daemon/dist/enhanced-features.d.ts.map +1 -0
  280. package/packages/daemon/dist/enhanced-features.js.map +1 -0
  281. package/packages/daemon/dist/index.d.ts.map +1 -0
  282. package/packages/daemon/dist/index.js.map +1 -0
  283. package/packages/daemon/dist/migrations/index.d.ts.map +1 -0
  284. package/packages/daemon/dist/migrations/index.js.map +1 -0
  285. package/packages/daemon/dist/orchestrator.d.ts.map +1 -0
  286. package/packages/daemon/dist/orchestrator.js.map +1 -0
  287. package/packages/daemon/dist/rate-limiter.d.ts.map +1 -0
  288. package/packages/daemon/dist/rate-limiter.js.map +1 -0
  289. package/packages/daemon/dist/registry.d.ts.map +1 -0
  290. package/packages/daemon/dist/registry.js.map +1 -0
  291. package/packages/daemon/dist/relay-ledger.d.ts.map +1 -0
  292. package/packages/daemon/dist/relay-ledger.js.map +1 -0
  293. package/packages/daemon/dist/relay-watchdog.d.ts.map +1 -0
  294. package/packages/daemon/dist/relay-watchdog.js.map +1 -0
  295. package/packages/daemon/dist/repo-manager.d.ts.map +1 -0
  296. package/packages/daemon/dist/repo-manager.js.map +1 -0
  297. package/packages/daemon/dist/router.d.ts.map +1 -0
  298. package/packages/daemon/dist/router.js.map +1 -0
  299. package/packages/daemon/dist/server.d.ts +1 -0
  300. package/packages/daemon/dist/server.d.ts.map +1 -0
  301. package/packages/daemon/dist/server.js +46 -16
  302. package/packages/daemon/dist/server.js.map +1 -0
  303. package/packages/daemon/dist/spawn-manager.d.ts.map +1 -0
  304. package/packages/daemon/dist/spawn-manager.js.map +1 -0
  305. package/packages/daemon/dist/sync-queue.d.ts.map +1 -0
  306. package/packages/daemon/dist/sync-queue.js.map +1 -0
  307. package/packages/daemon/dist/types.d.ts.map +1 -0
  308. package/packages/daemon/dist/types.js.map +1 -0
  309. package/packages/daemon/dist/workspace-manager.d.ts.map +1 -0
  310. package/packages/daemon/dist/workspace-manager.js.map +1 -0
  311. package/packages/daemon/package.json +12 -12
  312. package/packages/daemon/src/agent-manager.ts +679 -0
  313. package/packages/daemon/src/agent-registry.ts +284 -0
  314. package/packages/daemon/src/agent-signing.ts +707 -0
  315. package/packages/daemon/src/api.ts +1012 -0
  316. package/packages/daemon/src/auth.ts +276 -0
  317. package/packages/daemon/src/channel-membership-store.ts +217 -0
  318. package/packages/daemon/src/cli-auth.ts +906 -0
  319. package/packages/daemon/src/cloud-sync.ts +902 -0
  320. package/packages/daemon/src/connection.ts +534 -0
  321. package/packages/daemon/src/consensus-integration.ts +510 -0
  322. package/packages/daemon/src/consensus.ts +848 -0
  323. package/packages/daemon/src/delivery-tracker.ts +145 -0
  324. package/packages/daemon/src/enhanced-features.ts +390 -0
  325. package/packages/daemon/src/index.ts +52 -0
  326. package/packages/daemon/src/migrations/0001_initial.sql +72 -0
  327. package/packages/daemon/src/migrations/index.test.ts +195 -0
  328. package/packages/daemon/src/migrations/index.ts +286 -0
  329. package/packages/daemon/src/orchestrator.test.ts +231 -0
  330. package/packages/daemon/src/orchestrator.ts +1376 -0
  331. package/packages/daemon/src/rate-limiter.ts +172 -0
  332. package/packages/daemon/src/registry.ts +8 -0
  333. package/packages/daemon/src/relay-ledger.test.ts +358 -0
  334. package/packages/daemon/src/relay-ledger.ts +713 -0
  335. package/packages/daemon/src/relay-watchdog.test.ts +881 -0
  336. package/packages/daemon/src/relay-watchdog.ts +785 -0
  337. package/packages/daemon/src/repo-manager.ts +468 -0
  338. package/packages/daemon/src/router.test.ts +149 -0
  339. package/packages/daemon/src/router.ts +1885 -0
  340. package/packages/daemon/src/server.ts +1871 -0
  341. package/packages/daemon/src/spawn-manager.ts +275 -0
  342. package/packages/daemon/src/sync-queue.ts +477 -0
  343. package/packages/daemon/src/types.ts +158 -0
  344. package/packages/daemon/src/workspace-manager.ts +371 -0
  345. package/packages/daemon/tsconfig.json +21 -0
  346. package/packages/hooks/dist/browser.d.ts.map +1 -0
  347. package/packages/hooks/dist/browser.js.map +1 -0
  348. package/packages/hooks/dist/emitter.d.ts.map +1 -0
  349. package/packages/hooks/dist/emitter.js.map +1 -0
  350. package/packages/hooks/dist/inbox-check/hook.d.ts.map +1 -0
  351. package/packages/hooks/dist/inbox-check/hook.js.map +1 -0
  352. package/packages/hooks/dist/inbox-check/index.d.ts.map +1 -0
  353. package/packages/hooks/dist/inbox-check/index.js.map +1 -0
  354. package/packages/hooks/dist/inbox-check/types.d.ts.map +1 -0
  355. package/packages/hooks/dist/inbox-check/types.js.map +1 -0
  356. package/packages/hooks/dist/inbox-check/utils.d.ts.map +1 -0
  357. package/packages/hooks/dist/inbox-check/utils.js.map +1 -0
  358. package/packages/hooks/dist/index.d.ts.map +1 -0
  359. package/packages/hooks/dist/index.js.map +1 -0
  360. package/packages/hooks/dist/registry.d.ts.map +1 -0
  361. package/packages/hooks/dist/registry.js.map +1 -0
  362. package/packages/hooks/dist/trajectory-hooks.d.ts.map +1 -0
  363. package/packages/hooks/dist/trajectory-hooks.js.map +1 -0
  364. package/packages/hooks/dist/types.d.ts.map +1 -0
  365. package/packages/hooks/dist/types.js.map +1 -0
  366. package/packages/hooks/package.json +4 -4
  367. package/packages/hooks/src/browser.ts +2 -0
  368. package/packages/hooks/src/emitter.ts +84 -0
  369. package/packages/hooks/src/inbox-check/hook.ts +114 -0
  370. package/packages/hooks/src/inbox-check/index.ts +8 -0
  371. package/packages/hooks/src/inbox-check/types.ts +39 -0
  372. package/packages/hooks/src/inbox-check/utils.test.ts +287 -0
  373. package/packages/hooks/src/inbox-check/utils.ts +125 -0
  374. package/packages/hooks/src/index.ts +11 -0
  375. package/packages/hooks/src/registry.ts +614 -0
  376. package/packages/hooks/src/shims.d.ts +3 -0
  377. package/packages/hooks/src/trajectory-hooks.ts +251 -0
  378. package/packages/hooks/src/types.ts +342 -0
  379. package/packages/hooks/tsconfig.json +21 -0
  380. package/packages/hooks/vitest.config.ts +9 -0
  381. package/packages/mcp/dist/bin.d.ts.map +1 -0
  382. package/packages/mcp/dist/bin.js.map +1 -0
  383. package/packages/mcp/dist/client.d.ts +9 -15
  384. package/packages/mcp/dist/client.d.ts.map +1 -0
  385. package/packages/mcp/dist/client.js +42 -74
  386. package/packages/mcp/dist/client.js.map +1 -0
  387. package/packages/mcp/dist/cloud.d.ts.map +1 -0
  388. package/packages/mcp/dist/cloud.js.map +1 -0
  389. package/packages/mcp/dist/errors.d.ts.map +1 -0
  390. package/packages/mcp/dist/errors.js.map +1 -0
  391. package/packages/mcp/dist/file-transport.d.ts.map +1 -0
  392. package/packages/mcp/dist/file-transport.js.map +1 -0
  393. package/packages/mcp/dist/hybrid-client.d.ts.map +1 -0
  394. package/packages/mcp/dist/hybrid-client.js.map +1 -0
  395. package/packages/mcp/dist/index.d.ts.map +1 -0
  396. package/packages/mcp/dist/index.js.map +1 -0
  397. package/packages/mcp/dist/install-cli.d.ts.map +1 -0
  398. package/packages/mcp/dist/install-cli.js.map +1 -0
  399. package/packages/mcp/dist/install.d.ts.map +1 -0
  400. package/packages/mcp/dist/install.js.map +1 -0
  401. package/packages/mcp/dist/prompts/index.d.ts.map +1 -0
  402. package/packages/mcp/dist/prompts/index.js.map +1 -0
  403. package/packages/mcp/dist/prompts/protocol.d.ts.map +1 -0
  404. package/packages/mcp/dist/prompts/protocol.js.map +1 -0
  405. package/packages/mcp/dist/resources/agents.d.ts.map +1 -0
  406. package/packages/mcp/dist/resources/agents.js.map +1 -0
  407. package/packages/mcp/dist/resources/inbox.d.ts.map +1 -0
  408. package/packages/mcp/dist/resources/inbox.js.map +1 -0
  409. package/packages/mcp/dist/resources/index.d.ts.map +1 -0
  410. package/packages/mcp/dist/resources/index.js.map +1 -0
  411. package/packages/mcp/dist/resources/project.d.ts.map +1 -0
  412. package/packages/mcp/dist/resources/project.js.map +1 -0
  413. package/packages/mcp/dist/server.d.ts.map +1 -0
  414. package/packages/mcp/dist/server.js.map +1 -0
  415. package/packages/mcp/dist/simple.d.ts +2 -5
  416. package/packages/mcp/dist/simple.d.ts.map +1 -0
  417. package/packages/mcp/dist/simple.js.map +1 -0
  418. package/packages/mcp/dist/tools/index.d.ts.map +1 -0
  419. package/packages/mcp/dist/tools/index.js.map +1 -0
  420. package/packages/mcp/dist/tools/relay-broadcast.d.ts.map +1 -0
  421. package/packages/mcp/dist/tools/relay-broadcast.js.map +1 -0
  422. package/packages/mcp/dist/tools/relay-channel.d.ts.map +1 -0
  423. package/packages/mcp/dist/tools/relay-channel.js.map +1 -0
  424. package/packages/mcp/dist/tools/relay-connected.d.ts.map +1 -0
  425. package/packages/mcp/dist/tools/relay-connected.js.map +1 -0
  426. package/packages/mcp/dist/tools/relay-consensus.d.ts.map +1 -0
  427. package/packages/mcp/dist/tools/relay-consensus.js.map +1 -0
  428. package/packages/mcp/dist/tools/relay-continuity.d.ts.map +1 -0
  429. package/packages/mcp/dist/tools/relay-continuity.js.map +1 -0
  430. package/packages/mcp/dist/tools/relay-health.d.ts.map +1 -0
  431. package/packages/mcp/dist/tools/relay-health.js.map +1 -0
  432. package/packages/mcp/dist/tools/relay-inbox.d.ts.map +1 -0
  433. package/packages/mcp/dist/tools/relay-inbox.js.map +1 -0
  434. package/packages/mcp/dist/tools/relay-logs.d.ts.map +1 -0
  435. package/packages/mcp/dist/tools/relay-logs.js.map +1 -0
  436. package/packages/mcp/dist/tools/relay-metrics.d.ts.map +1 -0
  437. package/packages/mcp/dist/tools/relay-metrics.js.map +1 -0
  438. package/packages/mcp/dist/tools/relay-release.d.ts.map +1 -0
  439. package/packages/mcp/dist/tools/relay-release.js.map +1 -0
  440. package/packages/mcp/dist/tools/relay-remove-agent.d.ts.map +1 -0
  441. package/packages/mcp/dist/tools/relay-remove-agent.js.map +1 -0
  442. package/packages/mcp/dist/tools/relay-send.d.ts.map +1 -0
  443. package/packages/mcp/dist/tools/relay-send.js +4 -2
  444. package/packages/mcp/dist/tools/relay-send.js.map +1 -0
  445. package/packages/mcp/dist/tools/relay-shadow.d.ts.map +1 -0
  446. package/packages/mcp/dist/tools/relay-shadow.js.map +1 -0
  447. package/packages/mcp/dist/tools/relay-spawn.d.ts.map +1 -0
  448. package/packages/mcp/dist/tools/relay-spawn.js.map +1 -0
  449. package/packages/mcp/dist/tools/relay-status.d.ts.map +1 -0
  450. package/packages/mcp/dist/tools/relay-status.js.map +1 -0
  451. package/packages/mcp/dist/tools/relay-subscribe.d.ts.map +1 -0
  452. package/packages/mcp/dist/tools/relay-subscribe.js.map +1 -0
  453. package/packages/mcp/dist/tools/relay-who.d.ts.map +1 -0
  454. package/packages/mcp/dist/tools/relay-who.js.map +1 -0
  455. package/packages/mcp/package.json +3 -3
  456. package/packages/mcp/src/bin.ts +149 -0
  457. package/packages/mcp/src/client.ts +400 -0
  458. package/packages/mcp/src/cloud.ts +523 -0
  459. package/packages/mcp/src/errors.ts +54 -0
  460. package/packages/mcp/src/file-transport.ts +268 -0
  461. package/packages/mcp/src/hybrid-client.ts +209 -0
  462. package/packages/mcp/src/index.ts +122 -0
  463. package/packages/mcp/src/install-cli.ts +210 -0
  464. package/packages/mcp/src/install.ts +745 -0
  465. package/packages/mcp/src/prompts/index.ts +1 -0
  466. package/packages/mcp/src/prompts/protocol.ts +164 -0
  467. package/packages/mcp/src/resources/agents.ts +21 -0
  468. package/packages/mcp/src/resources/inbox.ts +21 -0
  469. package/packages/mcp/src/resources/index.ts +3 -0
  470. package/packages/mcp/src/resources/project.ts +29 -0
  471. package/packages/mcp/src/server.ts +431 -0
  472. package/packages/mcp/src/simple.ts +214 -0
  473. package/packages/mcp/src/tools/index.ts +133 -0
  474. package/packages/mcp/src/tools/relay-broadcast.ts +32 -0
  475. package/packages/mcp/src/tools/relay-channel.ts +93 -0
  476. package/packages/mcp/src/tools/relay-connected.ts +52 -0
  477. package/packages/mcp/src/tools/relay-consensus.ts +92 -0
  478. package/packages/mcp/src/tools/relay-continuity.ts +127 -0
  479. package/packages/mcp/src/tools/relay-health.ts +148 -0
  480. package/packages/mcp/src/tools/relay-inbox.ts +70 -0
  481. package/packages/mcp/src/tools/relay-logs.ts +106 -0
  482. package/packages/mcp/src/tools/relay-metrics.ts +140 -0
  483. package/packages/mcp/src/tools/relay-release.ts +54 -0
  484. package/packages/mcp/src/tools/relay-remove-agent.ts +58 -0
  485. package/packages/mcp/src/tools/relay-send.ts +84 -0
  486. package/packages/mcp/src/tools/relay-shadow.ts +67 -0
  487. package/packages/mcp/src/tools/relay-spawn.ts +87 -0
  488. package/packages/mcp/src/tools/relay-status.ts +57 -0
  489. package/packages/mcp/src/tools/relay-subscribe.ts +61 -0
  490. package/packages/mcp/src/tools/relay-who.ts +59 -0
  491. package/packages/mcp/tests/client.test.ts +476 -0
  492. package/packages/mcp/tests/discover.test.ts +195 -0
  493. package/packages/mcp/tests/install.test.ts +123 -0
  494. package/packages/mcp/tests/prompts.test.ts +12 -0
  495. package/packages/mcp/tests/resources.test.ts +53 -0
  496. package/packages/mcp/tests/tools.test.ts +1242 -0
  497. package/packages/mcp/tsconfig.json +22 -0
  498. package/packages/mcp/vitest.config.ts +9 -0
  499. package/packages/memory/dist/adapters/index.d.ts.map +1 -0
  500. package/packages/memory/dist/adapters/index.js.map +1 -0
  501. package/packages/memory/dist/adapters/inmemory.d.ts.map +1 -0
  502. package/packages/memory/dist/adapters/inmemory.js.map +1 -0
  503. package/packages/memory/dist/adapters/supermemory.d.ts.map +1 -0
  504. package/packages/memory/dist/adapters/supermemory.js.map +1 -0
  505. package/packages/memory/dist/context-compaction.d.ts.map +1 -0
  506. package/packages/memory/dist/context-compaction.js.map +1 -0
  507. package/packages/memory/dist/factory.d.ts.map +1 -0
  508. package/packages/memory/dist/factory.js.map +1 -0
  509. package/packages/memory/dist/index.d.ts.map +1 -0
  510. package/packages/memory/dist/index.js.map +1 -0
  511. package/packages/memory/dist/memory-hooks.d.ts.map +1 -0
  512. package/packages/memory/dist/memory-hooks.js.map +1 -0
  513. package/packages/memory/dist/service.d.ts.map +1 -0
  514. package/packages/memory/dist/service.js.map +1 -0
  515. package/packages/memory/dist/types.d.ts.map +1 -0
  516. package/packages/memory/dist/types.js.map +1 -0
  517. package/packages/memory/package.json +2 -2
  518. package/packages/memory/src/adapters/index.ts +8 -0
  519. package/packages/memory/src/adapters/inmemory.ts +265 -0
  520. package/packages/memory/src/adapters/supermemory.ts +449 -0
  521. package/packages/memory/src/context-compaction.test.ts +660 -0
  522. package/packages/memory/src/context-compaction.ts +612 -0
  523. package/packages/memory/src/factory.ts +170 -0
  524. package/packages/memory/src/index.ts +33 -0
  525. package/packages/memory/src/memory-hooks.ts +410 -0
  526. package/packages/memory/src/service.ts +194 -0
  527. package/packages/memory/src/types.ts +211 -0
  528. package/packages/memory/tsconfig.json +21 -0
  529. package/packages/memory/vitest.config.ts +9 -0
  530. package/packages/policy/dist/agent-policy.d.ts.map +1 -0
  531. package/packages/policy/dist/agent-policy.js.map +1 -0
  532. package/packages/policy/dist/cloud-policy-fetcher.d.ts.map +1 -0
  533. package/packages/policy/dist/cloud-policy-fetcher.js.map +1 -0
  534. package/packages/policy/dist/index.d.ts.map +1 -0
  535. package/packages/policy/dist/index.js.map +1 -0
  536. package/packages/policy/package.json +2 -2
  537. package/packages/policy/src/agent-policy.ts +866 -0
  538. package/packages/policy/src/cloud-policy-fetcher.ts +78 -0
  539. package/packages/policy/src/index.ts +21 -0
  540. package/packages/policy/tsconfig.json +21 -0
  541. package/packages/policy/vitest.config.ts +9 -0
  542. package/packages/protocol/dist/channels.d.ts.map +1 -0
  543. package/packages/protocol/dist/channels.js.map +1 -0
  544. package/packages/protocol/dist/framing.d.ts.map +1 -0
  545. package/packages/protocol/dist/framing.js.map +1 -0
  546. package/packages/protocol/dist/id-generator.d.ts.map +1 -0
  547. package/packages/protocol/dist/id-generator.js.map +1 -0
  548. package/packages/protocol/dist/index.d.ts.map +1 -0
  549. package/packages/protocol/dist/index.js.map +1 -0
  550. package/packages/protocol/dist/relay-pty-schemas.d.ts +70 -2
  551. package/packages/protocol/dist/relay-pty-schemas.d.ts.map +1 -0
  552. package/packages/protocol/dist/relay-pty-schemas.js.map +1 -0
  553. package/packages/protocol/dist/types.d.ts +8 -0
  554. package/packages/protocol/dist/types.d.ts.map +1 -0
  555. package/packages/protocol/dist/types.js.map +1 -0
  556. package/packages/protocol/package.json +1 -1
  557. package/packages/protocol/src/channels.test.ts +330 -0
  558. package/packages/protocol/src/channels.ts +270 -0
  559. package/packages/protocol/src/framing.test.ts +164 -0
  560. package/packages/protocol/src/framing.ts +242 -0
  561. package/packages/protocol/src/id-generator.ts +69 -0
  562. package/packages/protocol/src/index.ts +4 -0
  563. package/packages/protocol/src/relay-pty-schemas.ts +400 -0
  564. package/packages/protocol/src/types.test.ts +271 -0
  565. package/packages/protocol/src/types.ts +846 -0
  566. package/packages/protocol/tsconfig.json +21 -0
  567. package/packages/protocol/vitest.config.ts +9 -0
  568. package/packages/resiliency/dist/cgroup-manager.d.ts.map +1 -0
  569. package/packages/resiliency/dist/cgroup-manager.js.map +1 -0
  570. package/packages/resiliency/dist/context-persistence.d.ts.map +1 -0
  571. package/packages/resiliency/dist/context-persistence.js.map +1 -0
  572. package/packages/resiliency/dist/crash-insights.d.ts.map +1 -0
  573. package/packages/resiliency/dist/crash-insights.js.map +1 -0
  574. package/packages/resiliency/dist/gossip-health.d.ts.map +1 -0
  575. package/packages/resiliency/dist/gossip-health.js.map +1 -0
  576. package/packages/resiliency/dist/health-monitor.d.ts.map +1 -0
  577. package/packages/resiliency/dist/health-monitor.js.map +1 -0
  578. package/packages/resiliency/dist/index.d.ts.map +1 -0
  579. package/packages/resiliency/dist/index.js.map +1 -0
  580. package/packages/resiliency/dist/leader-watchdog.d.ts.map +1 -0
  581. package/packages/resiliency/dist/leader-watchdog.js.map +1 -0
  582. package/packages/resiliency/dist/logger.d.ts.map +1 -0
  583. package/packages/resiliency/dist/logger.js.map +1 -0
  584. package/packages/resiliency/dist/memory-monitor.d.ts.map +1 -0
  585. package/packages/resiliency/dist/memory-monitor.js.map +1 -0
  586. package/packages/resiliency/dist/metrics.d.ts.map +1 -0
  587. package/packages/resiliency/dist/metrics.js.map +1 -0
  588. package/packages/resiliency/dist/provider-context.d.ts.map +1 -0
  589. package/packages/resiliency/dist/provider-context.js.map +1 -0
  590. package/packages/resiliency/dist/stateless-lead.d.ts.map +1 -0
  591. package/packages/resiliency/dist/stateless-lead.js.map +1 -0
  592. package/packages/resiliency/dist/supervisor.d.ts.map +1 -0
  593. package/packages/resiliency/dist/supervisor.js.map +1 -0
  594. package/packages/resiliency/package.json +1 -1
  595. package/packages/resiliency/src/cgroup-manager.ts +468 -0
  596. package/packages/resiliency/src/context-persistence.ts +538 -0
  597. package/packages/resiliency/src/crash-insights.test.ts +620 -0
  598. package/packages/resiliency/src/crash-insights.ts +660 -0
  599. package/packages/resiliency/src/gossip-health.ts +333 -0
  600. package/packages/resiliency/src/health-monitor.ts +371 -0
  601. package/packages/resiliency/src/index.ts +157 -0
  602. package/packages/resiliency/src/leader-watchdog.ts +260 -0
  603. package/packages/resiliency/src/logger.ts +320 -0
  604. package/packages/resiliency/src/memory-monitor.test.ts +637 -0
  605. package/packages/resiliency/src/memory-monitor.ts +740 -0
  606. package/packages/resiliency/src/metrics.ts +311 -0
  607. package/packages/resiliency/src/provider-context.ts +452 -0
  608. package/packages/resiliency/src/stateless-lead.ts +408 -0
  609. package/packages/resiliency/src/supervisor.ts +578 -0
  610. package/packages/resiliency/tsconfig.json +21 -0
  611. package/packages/resiliency/vitest.config.ts +9 -0
  612. package/packages/sdk/dist/client.d.ts.map +1 -0
  613. package/packages/sdk/dist/client.js.map +1 -0
  614. package/packages/sdk/dist/index.d.ts.map +1 -0
  615. package/packages/sdk/dist/index.js.map +1 -0
  616. package/packages/sdk/dist/logs.d.ts.map +1 -0
  617. package/packages/sdk/dist/logs.js.map +1 -0
  618. package/packages/sdk/dist/protocol/index.d.ts.map +1 -0
  619. package/packages/sdk/dist/protocol/index.js.map +1 -0
  620. package/packages/sdk/dist/standalone.d.ts.map +1 -0
  621. package/packages/sdk/dist/standalone.js.map +1 -0
  622. package/packages/sdk/examples/SWARM_CAPABILITIES.md +498 -0
  623. package/packages/sdk/examples/SWARM_PATTERNS.md +541 -0
  624. package/packages/sdk/package.json +2 -2
  625. package/packages/sdk/src/client.test.ts +568 -0
  626. package/packages/sdk/src/client.ts +1418 -0
  627. package/packages/sdk/src/index.ts +103 -0
  628. package/packages/sdk/src/logs.test.ts +98 -0
  629. package/packages/sdk/src/logs.ts +126 -0
  630. package/packages/sdk/src/protocol/framing.test.ts +164 -0
  631. package/packages/sdk/src/protocol/index.ts +8 -0
  632. package/packages/sdk/src/standalone.ts +176 -0
  633. package/packages/sdk/tsconfig.json +22 -0
  634. package/packages/sdk/vitest.config.ts +9 -0
  635. package/packages/spawner/.trajectories/index.json +5 -0
  636. package/packages/spawner/dist/index.d.ts.map +1 -0
  637. package/packages/spawner/dist/index.js.map +1 -0
  638. package/packages/spawner/dist/types.d.ts.map +1 -0
  639. package/packages/spawner/dist/types.js.map +1 -0
  640. package/packages/spawner/package.json +1 -1
  641. package/packages/spawner/src/index.ts +8 -0
  642. package/packages/spawner/src/types.test.ts +385 -0
  643. package/packages/spawner/src/types.ts +228 -0
  644. package/packages/spawner/tsconfig.json +19 -0
  645. package/packages/spawner/vitest.config.ts +9 -0
  646. package/packages/state/dist/agent-state.d.ts.map +1 -0
  647. package/packages/state/dist/agent-state.js.map +1 -0
  648. package/packages/state/dist/index.d.ts.map +1 -0
  649. package/packages/state/dist/index.js.map +1 -0
  650. package/packages/state/package.json +1 -1
  651. package/packages/state/src/agent-state.test.ts +335 -0
  652. package/packages/state/src/agent-state.ts +153 -0
  653. package/packages/state/src/index.ts +12 -0
  654. package/packages/state/tsconfig.json +21 -0
  655. package/packages/state/vitest.config.ts +9 -0
  656. package/packages/storage/dist/adapter.d.ts +28 -1
  657. package/packages/storage/dist/adapter.d.ts.map +1 -0
  658. package/packages/storage/dist/adapter.js +104 -10
  659. package/packages/storage/dist/adapter.js.map +1 -0
  660. package/packages/storage/dist/batched-sqlite-adapter.d.ts.map +1 -0
  661. package/packages/storage/dist/batched-sqlite-adapter.js.map +1 -0
  662. package/packages/storage/dist/dead-letter-queue.d.ts.map +1 -0
  663. package/packages/storage/dist/dead-letter-queue.js.map +1 -0
  664. package/packages/storage/dist/dlq-adapter.d.ts.map +1 -0
  665. package/packages/storage/dist/dlq-adapter.js.map +1 -0
  666. package/packages/storage/dist/index.d.ts +1 -0
  667. package/packages/storage/dist/index.d.ts.map +1 -0
  668. package/packages/storage/dist/index.js +1 -0
  669. package/packages/storage/dist/index.js.map +1 -0
  670. package/packages/storage/dist/jsonl-adapter.d.ts +77 -0
  671. package/packages/storage/dist/jsonl-adapter.d.ts.map +1 -0
  672. package/packages/storage/dist/jsonl-adapter.js +505 -0
  673. package/packages/storage/dist/jsonl-adapter.js.map +1 -0
  674. package/packages/storage/dist/sqlite-adapter.d.ts +6 -1
  675. package/packages/storage/dist/sqlite-adapter.d.ts.map +1 -0
  676. package/packages/storage/dist/sqlite-adapter.js +47 -0
  677. package/packages/storage/dist/sqlite-adapter.js.map +1 -0
  678. package/packages/storage/package.json +2 -2
  679. package/packages/storage/src/adapter.ts +438 -0
  680. package/packages/storage/src/batched-sqlite-adapter.test.ts +240 -0
  681. package/packages/storage/src/batched-sqlite-adapter.ts +239 -0
  682. package/packages/storage/src/dead-letter-queue.ts +643 -0
  683. package/packages/storage/src/dlq-adapter.test.ts +492 -0
  684. package/packages/storage/src/dlq-adapter.ts +954 -0
  685. package/packages/storage/src/index.ts +6 -0
  686. package/packages/storage/src/jsonl-adapter.test.ts +200 -0
  687. package/packages/storage/src/jsonl-adapter.ts +618 -0
  688. package/packages/storage/src/memory-adapter.test.ts +36 -0
  689. package/packages/storage/src/sqlite-adapter.test.ts +562 -0
  690. package/packages/storage/src/sqlite-adapter.ts +1058 -0
  691. package/packages/storage/tsconfig.json +21 -0
  692. package/packages/storage/vitest.config.ts +9 -0
  693. package/packages/telemetry/dist/client.d.ts.map +1 -0
  694. package/packages/telemetry/dist/client.js.map +1 -0
  695. package/packages/telemetry/dist/config.d.ts.map +1 -0
  696. package/packages/telemetry/dist/config.js.map +1 -0
  697. package/packages/telemetry/dist/events.d.ts.map +1 -0
  698. package/packages/telemetry/dist/events.js.map +1 -0
  699. package/packages/telemetry/dist/index.d.ts.map +1 -0
  700. package/packages/telemetry/dist/index.js.map +1 -0
  701. package/packages/telemetry/dist/machine-id.d.ts.map +1 -0
  702. package/packages/telemetry/dist/machine-id.js.map +1 -0
  703. package/packages/telemetry/dist/posthog-config.d.ts.map +1 -0
  704. package/packages/telemetry/dist/posthog-config.js.map +1 -0
  705. package/packages/telemetry/package.json +1 -1
  706. package/packages/telemetry/src/client.ts +158 -0
  707. package/packages/telemetry/src/config.ts +110 -0
  708. package/packages/telemetry/src/events.ts +137 -0
  709. package/packages/telemetry/src/index.ts +46 -0
  710. package/packages/telemetry/src/machine-id.ts +63 -0
  711. package/packages/telemetry/src/posthog-config.ts +39 -0
  712. package/packages/telemetry/tsconfig.json +21 -0
  713. package/packages/trajectory/dist/index.d.ts.map +1 -0
  714. package/packages/trajectory/dist/index.js.map +1 -0
  715. package/packages/trajectory/dist/integration.d.ts.map +1 -0
  716. package/packages/trajectory/dist/integration.js.map +1 -0
  717. package/packages/trajectory/package.json +2 -2
  718. package/packages/trajectory/src/index.ts +1 -0
  719. package/packages/trajectory/src/integration.ts +1268 -0
  720. package/packages/trajectory/tsconfig.json +21 -0
  721. package/packages/trajectory/vitest.config.ts +9 -0
  722. package/packages/user-directory/dist/index.d.ts.map +1 -0
  723. package/packages/user-directory/dist/index.js.map +1 -0
  724. package/packages/user-directory/dist/user-directory.d.ts.map +1 -0
  725. package/packages/user-directory/dist/user-directory.js.map +1 -0
  726. package/packages/user-directory/package.json +2 -2
  727. package/packages/user-directory/src/index.ts +12 -0
  728. package/packages/user-directory/src/user-directory.ts +393 -0
  729. package/packages/user-directory/tsconfig.json +21 -0
  730. package/packages/user-directory/vitest.config.ts +9 -0
  731. package/packages/utils/dist/cjs/client-helpers.js +127 -0
  732. package/packages/utils/dist/cjs/command-resolver.js +89 -0
  733. package/packages/utils/dist/cjs/error-tracking.js +106 -0
  734. package/packages/utils/dist/cjs/git-remote.js +120 -0
  735. package/packages/utils/dist/cjs/index.js +40 -0
  736. package/packages/utils/dist/cjs/logger.js +105 -0
  737. package/packages/utils/dist/cjs/model-mapping.js +54 -0
  738. package/packages/utils/dist/cjs/name-generator.js +179 -0
  739. package/packages/utils/dist/cjs/package.json +3 -0
  740. package/packages/utils/dist/cjs/precompiled-patterns.js +271 -0
  741. package/packages/utils/dist/cjs/relay-pty-path.js +143 -0
  742. package/packages/utils/dist/cjs/update-checker.js +185 -0
  743. package/packages/utils/dist/client-helpers.d.ts +73 -0
  744. package/packages/utils/dist/client-helpers.d.ts.map +1 -0
  745. package/packages/utils/dist/client-helpers.js +130 -0
  746. package/packages/utils/dist/client-helpers.js.map +1 -0
  747. package/packages/utils/dist/command-resolver.d.ts.map +1 -0
  748. package/packages/utils/dist/command-resolver.js.map +1 -0
  749. package/packages/utils/dist/error-tracking.d.ts.map +1 -0
  750. package/packages/utils/dist/error-tracking.js.map +1 -0
  751. package/packages/utils/dist/git-remote.d.ts.map +1 -0
  752. package/packages/utils/dist/git-remote.js.map +1 -0
  753. package/packages/utils/dist/index.d.ts +1 -0
  754. package/packages/utils/dist/index.d.ts.map +1 -0
  755. package/packages/utils/dist/index.js +1 -0
  756. package/packages/utils/dist/index.js.map +1 -0
  757. package/packages/utils/dist/logger.d.ts.map +1 -0
  758. package/packages/utils/dist/logger.js.map +1 -0
  759. package/packages/utils/dist/model-mapping.d.ts.map +1 -0
  760. package/packages/utils/dist/model-mapping.js.map +1 -0
  761. package/packages/utils/dist/name-generator.d.ts.map +1 -0
  762. package/packages/utils/dist/name-generator.js.map +1 -0
  763. package/packages/utils/dist/precompiled-patterns.d.ts.map +1 -0
  764. package/packages/utils/dist/precompiled-patterns.js.map +1 -0
  765. package/packages/utils/dist/relay-pty-path.d.ts +11 -5
  766. package/packages/utils/dist/relay-pty-path.d.ts.map +1 -0
  767. package/packages/utils/dist/relay-pty-path.js +60 -5
  768. package/packages/utils/dist/relay-pty-path.js.map +1 -0
  769. package/packages/utils/dist/update-checker.d.ts.map +1 -0
  770. package/packages/utils/dist/update-checker.js.map +1 -0
  771. package/packages/utils/package.json +37 -14
  772. package/packages/utils/scripts/build-cjs.mjs +24 -0
  773. package/packages/utils/src/client-helpers.ts +221 -0
  774. package/packages/utils/src/command-resolver.ts +82 -0
  775. package/packages/utils/src/error-tracking.ts +189 -0
  776. package/packages/utils/src/git-remote.ts +143 -0
  777. package/packages/utils/src/index.ts +10 -0
  778. package/packages/utils/src/logger.ts +107 -0
  779. package/packages/utils/src/model-mapping.test.ts +122 -0
  780. package/packages/utils/src/model-mapping.ts +58 -0
  781. package/packages/utils/src/name-generator.test.ts +259 -0
  782. package/packages/utils/src/name-generator.ts +56 -0
  783. package/packages/utils/src/precompiled-patterns.test.ts +452 -0
  784. package/packages/utils/src/precompiled-patterns.ts +395 -0
  785. package/packages/utils/src/relay-pty-path.ts +196 -0
  786. package/packages/utils/src/update-checker.test.ts +260 -0
  787. package/packages/utils/src/update-checker.ts +211 -0
  788. package/packages/utils/tsconfig.json +21 -0
  789. package/packages/utils/vitest.config.ts +9 -0
  790. package/packages/wrapper/dist/__fixtures__/claude-outputs.d.ts.map +1 -0
  791. package/packages/wrapper/dist/__fixtures__/claude-outputs.js.map +1 -0
  792. package/packages/wrapper/dist/__fixtures__/codex-outputs.d.ts.map +1 -0
  793. package/packages/wrapper/dist/__fixtures__/codex-outputs.js.map +1 -0
  794. package/packages/wrapper/dist/__fixtures__/gemini-outputs.d.ts.map +1 -0
  795. package/packages/wrapper/dist/__fixtures__/gemini-outputs.js.map +1 -0
  796. package/packages/wrapper/dist/__fixtures__/index.d.ts.map +1 -0
  797. package/packages/wrapper/dist/__fixtures__/index.js.map +1 -0
  798. package/packages/wrapper/dist/auth-detection.d.ts.map +1 -0
  799. package/packages/wrapper/dist/auth-detection.js.map +1 -0
  800. package/packages/wrapper/dist/base-wrapper.d.ts.map +1 -0
  801. package/packages/wrapper/dist/base-wrapper.js.map +1 -0
  802. package/packages/wrapper/dist/client.d.ts.map +1 -0
  803. package/packages/wrapper/dist/client.js.map +1 -0
  804. package/packages/wrapper/dist/id-generator.d.ts.map +1 -0
  805. package/packages/wrapper/dist/id-generator.js.map +1 -0
  806. package/packages/wrapper/dist/idle-detector.d.ts.map +1 -0
  807. package/packages/wrapper/dist/idle-detector.js.map +1 -0
  808. package/packages/wrapper/dist/inbox.d.ts.map +1 -0
  809. package/packages/wrapper/dist/inbox.js.map +1 -0
  810. package/packages/wrapper/dist/index.d.ts.map +1 -0
  811. package/packages/wrapper/dist/index.js.map +1 -0
  812. package/packages/wrapper/dist/parser.d.ts.map +1 -0
  813. package/packages/wrapper/dist/parser.js.map +1 -0
  814. package/packages/wrapper/dist/prompt-composer.d.ts.map +1 -0
  815. package/packages/wrapper/dist/prompt-composer.js.map +1 -0
  816. package/packages/wrapper/dist/relay-pty-orchestrator.d.ts +10 -0
  817. package/packages/wrapper/dist/relay-pty-orchestrator.d.ts.map +1 -0
  818. package/packages/wrapper/dist/relay-pty-orchestrator.js +69 -0
  819. package/packages/wrapper/dist/relay-pty-orchestrator.js.map +1 -0
  820. package/packages/wrapper/dist/shared.d.ts.map +1 -0
  821. package/packages/wrapper/dist/shared.js.map +1 -0
  822. package/packages/wrapper/dist/stuck-detector.d.ts.map +1 -0
  823. package/packages/wrapper/dist/stuck-detector.js.map +1 -0
  824. package/packages/wrapper/dist/tmux-resolver.d.ts.map +1 -0
  825. package/packages/wrapper/dist/tmux-resolver.js.map +1 -0
  826. package/packages/wrapper/dist/tmux-wrapper.d.ts.map +1 -0
  827. package/packages/wrapper/dist/tmux-wrapper.js.map +1 -0
  828. package/packages/wrapper/dist/trajectory-integration.d.ts.map +1 -0
  829. package/packages/wrapper/dist/trajectory-integration.js.map +1 -0
  830. package/packages/wrapper/dist/wrapper-types.d.ts.map +1 -0
  831. package/packages/wrapper/dist/wrapper-types.js.map +1 -0
  832. package/packages/wrapper/package.json +6 -9
  833. package/packages/wrapper/src/__fixtures__/claude-outputs.ts +471 -0
  834. package/packages/wrapper/src/__fixtures__/codex-outputs.ts +99 -0
  835. package/packages/wrapper/src/__fixtures__/gemini-outputs.ts +151 -0
  836. package/packages/wrapper/src/__fixtures__/index.ts +47 -0
  837. package/packages/wrapper/src/auth-detection.ts +244 -0
  838. package/packages/wrapper/src/base-wrapper.test.ts +589 -0
  839. package/packages/wrapper/src/base-wrapper.ts +810 -0
  840. package/packages/wrapper/src/client.test.ts +262 -0
  841. package/packages/wrapper/src/client.ts +984 -0
  842. package/packages/wrapper/src/id-generator.test.ts +71 -0
  843. package/packages/wrapper/src/id-generator.ts +69 -0
  844. package/packages/wrapper/src/idle-detector.test.ts +418 -0
  845. package/packages/wrapper/src/idle-detector.ts +384 -0
  846. package/packages/wrapper/src/inbox.test.ts +233 -0
  847. package/packages/wrapper/src/inbox.ts +89 -0
  848. package/packages/wrapper/src/index.ts +170 -0
  849. package/packages/wrapper/src/parser.regression.test.ts +251 -0
  850. package/packages/wrapper/src/parser.test.ts +1359 -0
  851. package/packages/wrapper/src/parser.ts +1477 -0
  852. package/packages/wrapper/src/prompt-composer.test.ts +219 -0
  853. package/packages/wrapper/src/prompt-composer.ts +231 -0
  854. package/packages/wrapper/src/relay-pty-orchestrator.test.ts +1204 -0
  855. package/packages/wrapper/src/relay-pty-orchestrator.ts +2626 -0
  856. package/packages/wrapper/src/shared.test.ts +322 -0
  857. package/packages/wrapper/src/shared.ts +495 -0
  858. package/packages/wrapper/src/stuck-detector.test.ts +303 -0
  859. package/packages/wrapper/src/stuck-detector.ts +511 -0
  860. package/packages/wrapper/src/tmux-resolver.test.ts +104 -0
  861. package/packages/wrapper/src/tmux-resolver.ts +207 -0
  862. package/packages/wrapper/src/tmux-wrapper.test.ts +316 -0
  863. package/packages/wrapper/src/tmux-wrapper.ts +2095 -0
  864. package/packages/wrapper/src/trajectory-detection.test.ts +151 -0
  865. package/packages/wrapper/src/trajectory-integration.ts +1261 -0
  866. package/packages/wrapper/src/wrapper-types.ts +45 -0
  867. package/packages/wrapper/tsconfig.json +19 -0
  868. package/packages/wrapper/vitest.config.ts +9 -0
  869. package/scripts/build-cjs.mjs +23 -0
  870. package/scripts/postinstall.js +132 -0
  871. package/.cursor/mcp.json +0 -11
  872. package/.gitattributes +0 -3
  873. package/.gitleaks.toml +0 -26
  874. package/.mcp.json +0 -11
  875. package/.nvmrc +0 -1
  876. package/ARCHITECTURE.md +0 -1245
  877. package/CHANGELOG.md +0 -231
  878. package/TESTING.md +0 -278
  879. package/TRAIL_GIT_AUTH_FIX.md +0 -113
  880. package/scripts/demos/README.md +0 -79
  881. package/scripts/demos/server-capacity.sh +0 -69
  882. package/scripts/demos/sprint-planning.sh +0 -73
  883. package/scripts/hooks/install.sh +0 -16
  884. package/scripts/hooks/pre-commit +0 -60
  885. package/scripts/post-publish-verify/README.md +0 -80
  886. package/scripts/post-publish-verify/run-verify.sh +0 -127
  887. package/scripts/post-publish-verify/verify-install.sh +0 -249
  888. package/scripts/stress-test-orchestrator-integration.mts +0 -1366
  889. package/scripts/stress-test-orchestrator.mjs +0 -584
  890. package/scripts/stress-test-relay-pty.sh +0 -452
  891. package/scripts/test-interactive-terminal.sh +0 -248
  892. package/specs/PRIMITIVES_ROADMAP.md +0 -2154
  893. package/tests/benchmarks/protocol.bench.ts +0 -310
  894. package/turbo.json +0 -37
@@ -0,0 +1,866 @@
1
+ /**
2
+ * Agent Policy Service
3
+ *
4
+ * Manages agent permissions and rules with multi-level fallback:
5
+ * 1. Repo-level policy (.claude/agents/*.md)
6
+ * 2. Workspace-level policy (from cloud API)
7
+ * 3. Built-in safe defaults
8
+ *
9
+ * Provides spawn authorization, tool permission checks, and audit logging.
10
+ */
11
+
12
+ import fs from 'node:fs';
13
+ import path from 'node:path';
14
+ import { findAgentConfig, type AgentConfig } from '@agent-relay/config/agent-config';
15
+
16
+ import os from 'node:os';
17
+
18
+ /**
19
+ * PRPM-style policy file format (YAML or JSON)
20
+ *
21
+ * Policy files are loaded from (in order of precedence):
22
+ * 1. User-level: ~/.config/agent-relay/policies/*.yaml (NOT in source control)
23
+ * 2. Cloud: Workspace config from dashboard (stored in database)
24
+ *
25
+ * PRPM packages install to the user-level location to avoid polluting repos.
26
+ * Install via: prpm install @org/strict-agent-rules --global
27
+ *
28
+ * Example policy file (~/.config/agent-relay/policies/strict-rules.yaml):
29
+ * ```yaml
30
+ * name: strict-spawn-rules
31
+ * version: 1.0.0
32
+ * description: Restrict agent spawning to leads only
33
+ *
34
+ * agents:
35
+ * - name: Lead
36
+ * canSpawn: ["*"]
37
+ * canMessage: ["*"]
38
+ * - name: Worker*
39
+ * canSpawn: []
40
+ * canMessage: ["Lead", "Coordinator"]
41
+ *
42
+ * settings:
43
+ * requireExplicitAgents: false
44
+ * auditEnabled: true
45
+ * ```
46
+ */
47
+
48
+ /**
49
+ * Agent policy definition
50
+ */
51
+ export interface AgentPolicy {
52
+ /** Agent name pattern (supports wildcards: "Lead", "Worker*", "*") */
53
+ name: string;
54
+ /** Allowed tools (empty = all allowed, ["none"] = no tools) */
55
+ allowedTools?: string[];
56
+ /** Agents this agent can spawn (empty = can spawn any) */
57
+ canSpawn?: string[];
58
+ /** Agents this agent can message (empty = can message any) */
59
+ canMessage?: string[];
60
+ /** Maximum concurrent spawns allowed */
61
+ maxSpawns?: number;
62
+ /** Rate limit: messages per minute */
63
+ rateLimit?: number;
64
+ /** Whether this agent can be spawned by others */
65
+ canBeSpawned?: boolean;
66
+ /** Custom metadata */
67
+ metadata?: Record<string, unknown>;
68
+ }
69
+
70
+ /**
71
+ * Workspace-level policy configuration
72
+ */
73
+ export interface WorkspacePolicy {
74
+ /** Default policy for agents without explicit config */
75
+ defaultPolicy: AgentPolicy;
76
+ /** Named agent policies */
77
+ agents: AgentPolicy[];
78
+ /** Global settings */
79
+ settings: {
80
+ /** Require explicit agent definitions (reject unknown agents) */
81
+ requireExplicitAgents: boolean;
82
+ /** Enable audit logging */
83
+ auditEnabled: boolean;
84
+ /** Maximum total agents */
85
+ maxTotalAgents: number;
86
+ };
87
+ }
88
+
89
+ /**
90
+ * Policy decision with reasoning
91
+ */
92
+ export interface PolicyDecision {
93
+ allowed: boolean;
94
+ reason: string;
95
+ policySource: 'repo' | 'local' | 'workspace' | 'default';
96
+ matchedPolicy?: AgentPolicy;
97
+ }
98
+
99
+ /**
100
+ * Audit log entry
101
+ */
102
+ export interface AuditEntry {
103
+ timestamp: number;
104
+ action: 'spawn' | 'message' | 'tool' | 'release';
105
+ actor: string;
106
+ target?: string;
107
+ decision: PolicyDecision;
108
+ context?: Record<string, unknown>;
109
+ }
110
+
111
+ /** Built-in safe defaults when no policy exists */
112
+ const DEFAULT_POLICY: AgentPolicy = {
113
+ name: '*',
114
+ allowedTools: undefined, // All tools allowed by default
115
+ canSpawn: undefined, // Can spawn any agent
116
+ canMessage: undefined, // Can message any agent
117
+ maxSpawns: 10,
118
+ rateLimit: 60, // 60 messages per minute
119
+ canBeSpawned: true,
120
+ };
121
+
122
+ /** Restrictive defaults for unknown agents in strict mode */
123
+ const STRICT_DEFAULT_POLICY: AgentPolicy = {
124
+ name: '*',
125
+ allowedTools: ['Read', 'Grep', 'Glob'], // Read-only by default
126
+ canSpawn: [], // Cannot spawn
127
+ canMessage: ['Lead', 'Coordinator'], // Can only message leads
128
+ maxSpawns: 0,
129
+ rateLimit: 10,
130
+ canBeSpawned: false,
131
+ };
132
+
133
+ /**
134
+ * Cloud policy fetcher interface
135
+ * Implement this to fetch workspace policies from cloud API
136
+ */
137
+ export interface CloudPolicyFetcher {
138
+ getWorkspacePolicy(workspaceId: string): Promise<WorkspacePolicy | null>;
139
+ }
140
+
141
+ export class AgentPolicyService {
142
+ private projectRoot: string;
143
+ private workspaceId?: string;
144
+ private cloudFetcher?: CloudPolicyFetcher;
145
+ private cachedWorkspacePolicy?: WorkspacePolicy;
146
+ private cachedLocalPolicy?: WorkspacePolicy;
147
+ private policyCacheExpiry = 0;
148
+ private localPolicyCacheExpiry = 0;
149
+ private auditLog: AuditEntry[] = [];
150
+ private strictMode: boolean;
151
+
152
+ /** Cache TTL in milliseconds (5 minutes) */
153
+ private static readonly CACHE_TTL_MS = 5 * 60 * 1000;
154
+ /** Local policy cache TTL (1 minute - files can change) */
155
+ private static readonly LOCAL_CACHE_TTL_MS = 60 * 1000;
156
+ /** Maximum audit log entries to keep in memory */
157
+ private static readonly MAX_AUDIT_ENTRIES = 1000;
158
+
159
+ constructor(options: {
160
+ projectRoot: string;
161
+ workspaceId?: string;
162
+ cloudFetcher?: CloudPolicyFetcher;
163
+ strictMode?: boolean;
164
+ }) {
165
+ this.projectRoot = options.projectRoot;
166
+ this.workspaceId = options.workspaceId;
167
+ this.cloudFetcher = options.cloudFetcher;
168
+ this.strictMode = options.strictMode ?? false;
169
+ }
170
+
171
+ /**
172
+ * Get the user-level policies directory
173
+ * Uses ~/.config/agent-relay/policies/ (not in source control)
174
+ */
175
+ private getUserPoliciesDir(): string {
176
+ const configDir = process.env.AGENT_RELAY_CONFIG_DIR ??
177
+ path.join(os.homedir(), '.config', 'agent-relay');
178
+ return path.join(configDir, 'policies');
179
+ }
180
+
181
+ /**
182
+ * Load policies from user-level directory (PRPM-installable)
183
+ * Files are YAML/JSON with agent policy definitions
184
+ * Location: ~/.config/agent-relay/policies/*.yaml
185
+ */
186
+ private loadLocalPolicies(): WorkspacePolicy | null {
187
+ // Check cache
188
+ if (this.cachedLocalPolicy && Date.now() < this.localPolicyCacheExpiry) {
189
+ return this.cachedLocalPolicy;
190
+ }
191
+
192
+ const policiesDir = this.getUserPoliciesDir();
193
+ if (!fs.existsSync(policiesDir)) {
194
+ return null;
195
+ }
196
+
197
+ try {
198
+ const files = fs.readdirSync(policiesDir).filter(f =>
199
+ f.endsWith('.yaml') || f.endsWith('.yml') || f.endsWith('.json')
200
+ );
201
+
202
+ if (files.length === 0) {
203
+ return null;
204
+ }
205
+
206
+ // Merge all policy files
207
+ const mergedAgents: AgentPolicy[] = [];
208
+ let mergedSettings: WorkspacePolicy['settings'] = {
209
+ requireExplicitAgents: false,
210
+ auditEnabled: true,
211
+ maxTotalAgents: 50,
212
+ };
213
+ let mergedDefault: AgentPolicy = { ...DEFAULT_POLICY };
214
+
215
+ for (const file of files) {
216
+ const filePath = path.join(policiesDir, file);
217
+ const content = fs.readFileSync(filePath, 'utf-8');
218
+
219
+ let parsed: Record<string, unknown>;
220
+ if (file.endsWith('.json')) {
221
+ parsed = JSON.parse(content);
222
+ } else {
223
+ // Simple YAML parsing for policy files
224
+ parsed = this.parseSimpleYaml(content);
225
+ }
226
+
227
+ // Merge agents
228
+ if (Array.isArray(parsed.agents)) {
229
+ for (const agent of parsed.agents) {
230
+ if (agent && typeof agent === 'object' && 'name' in agent) {
231
+ mergedAgents.push(agent as AgentPolicy);
232
+ }
233
+ }
234
+ }
235
+
236
+ // Merge settings (later files override)
237
+ if (parsed.settings && typeof parsed.settings === 'object') {
238
+ mergedSettings = { ...mergedSettings, ...parsed.settings as Record<string, unknown> };
239
+ }
240
+
241
+ // Merge default policy
242
+ if (parsed.defaultPolicy && typeof parsed.defaultPolicy === 'object') {
243
+ mergedDefault = { ...mergedDefault, ...parsed.defaultPolicy as AgentPolicy };
244
+ }
245
+ }
246
+
247
+ const policy: WorkspacePolicy = {
248
+ defaultPolicy: mergedDefault,
249
+ agents: mergedAgents,
250
+ settings: mergedSettings,
251
+ };
252
+
253
+ this.cachedLocalPolicy = policy;
254
+ this.localPolicyCacheExpiry = Date.now() + AgentPolicyService.LOCAL_CACHE_TTL_MS;
255
+
256
+ return policy;
257
+ } catch (err) {
258
+ console.error('[policy] Failed to load local policies:', err);
259
+ return null;
260
+ }
261
+ }
262
+
263
+ /**
264
+ * Simple YAML parser for policy files
265
+ * Handles basic key: value and arrays
266
+ */
267
+ private parseSimpleYaml(content: string): Record<string, unknown> {
268
+ const result: Record<string, unknown> = {};
269
+ const lines = content.split('\n');
270
+ let _currentKey = '';
271
+ let currentArray: unknown[] | null = null;
272
+ let currentObject: Record<string, unknown> | null = null;
273
+ let indent = 0;
274
+
275
+ for (const line of lines) {
276
+ const trimmed = line.trim();
277
+
278
+ // Skip comments and empty lines
279
+ if (!trimmed || trimmed.startsWith('#')) continue;
280
+
281
+ // Calculate indentation
282
+ const lineIndent = line.length - line.trimStart().length;
283
+
284
+ // Array item
285
+ if (trimmed.startsWith('- ')) {
286
+ const value = trimmed.slice(2).trim();
287
+
288
+ // Object in array (e.g., "- name: Worker")
289
+ if (value.includes(':')) {
290
+ const [key, val] = value.split(':').map(s => s.trim());
291
+ currentObject = { [key]: this.parseValue(val) };
292
+ if (currentArray) {
293
+ currentArray.push(currentObject);
294
+ }
295
+ } else {
296
+ // Simple array value
297
+ if (currentArray) {
298
+ currentArray.push(this.parseValue(value));
299
+ }
300
+ }
301
+ continue;
302
+ }
303
+
304
+ // Key: value pair
305
+ const colonIdx = trimmed.indexOf(':');
306
+ if (colonIdx > 0) {
307
+ const key = trimmed.slice(0, colonIdx).trim();
308
+ const value = trimmed.slice(colonIdx + 1).trim();
309
+
310
+ // If we're inside an object in an array
311
+ if (currentObject && lineIndent > indent) {
312
+ currentObject[key] = this.parseValue(value);
313
+ continue;
314
+ }
315
+
316
+ // Top-level or section key
317
+ if (value === '' || value === '|' || value === '>') {
318
+ // Start of array or nested object
319
+ _currentKey = key;
320
+ currentArray = [];
321
+ currentObject = null;
322
+ indent = lineIndent;
323
+ result[key] = currentArray;
324
+ } else {
325
+ // Simple key: value
326
+ if (lineIndent === 0) {
327
+ result[key] = this.parseValue(value);
328
+ _currentKey = '';
329
+ currentArray = null;
330
+ currentObject = null;
331
+ } else if (currentObject) {
332
+ currentObject[key] = this.parseValue(value);
333
+ }
334
+ }
335
+ }
336
+ }
337
+
338
+ return result;
339
+ }
340
+
341
+ /**
342
+ * Parse a YAML value string
343
+ */
344
+ private parseValue(value: string): unknown {
345
+ if (!value || value === '~' || value === 'null') return null;
346
+ if (value === 'true') return true;
347
+ if (value === 'false') return false;
348
+
349
+ // Array notation [a, b, c]
350
+ if (value.startsWith('[') && value.endsWith(']')) {
351
+ const inner = value.slice(1, -1);
352
+ if (!inner.trim()) return [];
353
+ return inner.split(',').map(s => {
354
+ const trimmed = s.trim().replace(/^["']|["']$/g, '');
355
+ return trimmed;
356
+ });
357
+ }
358
+
359
+ // Number
360
+ if (/^-?\d+(\.\d+)?$/.test(value)) {
361
+ return parseFloat(value);
362
+ }
363
+
364
+ // String (remove quotes if present)
365
+ return value.replace(/^["']|["']$/g, '');
366
+ }
367
+
368
+ /**
369
+ * Check if an agent can spawn another agent
370
+ */
371
+ async canSpawn(
372
+ spawnerName: string,
373
+ targetName: string,
374
+ targetCli: string
375
+ ): Promise<PolicyDecision> {
376
+ const spawnerPolicy = await this.getAgentPolicy(spawnerName);
377
+ const targetPolicy = await this.getAgentPolicy(targetName);
378
+
379
+ // Check if target can be spawned
380
+ if (targetPolicy.matchedPolicy?.canBeSpawned === false) {
381
+ const decision: PolicyDecision = {
382
+ allowed: false,
383
+ reason: `Agent "${targetName}" is not allowed to be spawned`,
384
+ policySource: targetPolicy.policySource,
385
+ matchedPolicy: targetPolicy.matchedPolicy,
386
+ };
387
+ this.audit('spawn', spawnerName, targetName, decision, { cli: targetCli });
388
+ return decision;
389
+ }
390
+
391
+ // Check if spawner can spawn
392
+ const canSpawnList = spawnerPolicy.matchedPolicy?.canSpawn;
393
+ if (canSpawnList !== undefined && canSpawnList.length > 0) {
394
+ const canSpawn = this.matchesPattern(targetName, canSpawnList);
395
+ if (!canSpawn) {
396
+ const decision: PolicyDecision = {
397
+ allowed: false,
398
+ reason: `Agent "${spawnerName}" is not allowed to spawn "${targetName}"`,
399
+ policySource: spawnerPolicy.policySource,
400
+ matchedPolicy: spawnerPolicy.matchedPolicy,
401
+ };
402
+ this.audit('spawn', spawnerName, targetName, decision, { cli: targetCli });
403
+ return decision;
404
+ }
405
+ }
406
+
407
+ // Check max spawns (would need spawn count tracking - placeholder)
408
+ const decision: PolicyDecision = {
409
+ allowed: true,
410
+ reason: 'Spawn permitted by policy',
411
+ policySource: spawnerPolicy.policySource,
412
+ matchedPolicy: spawnerPolicy.matchedPolicy,
413
+ };
414
+ this.audit('spawn', spawnerName, targetName, decision, { cli: targetCli });
415
+ return decision;
416
+ }
417
+
418
+ /**
419
+ * Check if an agent can send a message to another agent
420
+ */
421
+ async canMessage(
422
+ senderName: string,
423
+ recipientName: string
424
+ ): Promise<PolicyDecision> {
425
+ const senderPolicy = await this.getAgentPolicy(senderName);
426
+
427
+ const canMessageList = senderPolicy.matchedPolicy?.canMessage;
428
+ if (canMessageList !== undefined && canMessageList.length > 0) {
429
+ const canMessage = this.matchesPattern(recipientName, canMessageList);
430
+ if (!canMessage) {
431
+ const decision: PolicyDecision = {
432
+ allowed: false,
433
+ reason: `Agent "${senderName}" is not allowed to message "${recipientName}"`,
434
+ policySource: senderPolicy.policySource,
435
+ matchedPolicy: senderPolicy.matchedPolicy,
436
+ };
437
+ this.audit('message', senderName, recipientName, decision);
438
+ return decision;
439
+ }
440
+ }
441
+
442
+ const decision: PolicyDecision = {
443
+ allowed: true,
444
+ reason: 'Message permitted by policy',
445
+ policySource: senderPolicy.policySource,
446
+ matchedPolicy: senderPolicy.matchedPolicy,
447
+ };
448
+ this.audit('message', senderName, recipientName, decision);
449
+ return decision;
450
+ }
451
+
452
+ /**
453
+ * Check if an agent can use a specific tool
454
+ */
455
+ async canUseTool(agentName: string, toolName: string): Promise<PolicyDecision> {
456
+ const policy = await this.getAgentPolicy(agentName);
457
+
458
+ const allowedTools = policy.matchedPolicy?.allowedTools;
459
+ if (allowedTools !== undefined) {
460
+ // ["none"] means no tools allowed
461
+ if (allowedTools.length === 1 && allowedTools[0] === 'none') {
462
+ const decision: PolicyDecision = {
463
+ allowed: false,
464
+ reason: `Agent "${agentName}" is not allowed to use any tools`,
465
+ policySource: policy.policySource,
466
+ matchedPolicy: policy.matchedPolicy,
467
+ };
468
+ this.audit('tool', agentName, toolName, decision);
469
+ return decision;
470
+ }
471
+
472
+ // Check if tool is in allowed list
473
+ const allowed = this.matchesPattern(toolName, allowedTools);
474
+ if (!allowed) {
475
+ const decision: PolicyDecision = {
476
+ allowed: false,
477
+ reason: `Agent "${agentName}" is not allowed to use tool "${toolName}"`,
478
+ policySource: policy.policySource,
479
+ matchedPolicy: policy.matchedPolicy,
480
+ };
481
+ this.audit('tool', agentName, toolName, decision);
482
+ return decision;
483
+ }
484
+ }
485
+
486
+ const decision: PolicyDecision = {
487
+ allowed: true,
488
+ reason: 'Tool usage permitted by policy',
489
+ policySource: policy.policySource,
490
+ matchedPolicy: policy.matchedPolicy,
491
+ };
492
+ this.audit('tool', agentName, toolName, decision);
493
+ return decision;
494
+ }
495
+
496
+ /**
497
+ * Get the effective policy for an agent
498
+ * Fallback chain: repo config → user PRPM policies → cloud workspace → defaults
499
+ */
500
+ async getAgentPolicy(agentName: string): Promise<{
501
+ matchedPolicy: AgentPolicy;
502
+ policySource: 'repo' | 'local' | 'workspace' | 'default';
503
+ }> {
504
+ // 1. Try repo-level config (.claude/agents/*.md)
505
+ const repoConfig = findAgentConfig(agentName, this.projectRoot);
506
+ if (repoConfig) {
507
+ return {
508
+ matchedPolicy: this.configToPolicy(repoConfig),
509
+ policySource: 'repo',
510
+ };
511
+ }
512
+
513
+ // 2. Try user-level PRPM policies (~/.config/agent-relay/policies/*.yaml)
514
+ const localPolicy = this.loadLocalPolicies();
515
+ if (localPolicy) {
516
+ // Check for strict mode in local policy
517
+ if (localPolicy.settings?.requireExplicitAgents) {
518
+ const matchedPolicy = this.findMatchingPolicy(agentName, localPolicy.agents);
519
+ if (matchedPolicy) {
520
+ return { matchedPolicy, policySource: 'local' };
521
+ }
522
+ // Unknown agent in strict mode
523
+ return {
524
+ matchedPolicy: { ...STRICT_DEFAULT_POLICY, name: agentName },
525
+ policySource: 'local',
526
+ };
527
+ }
528
+
529
+ // Find matching policy
530
+ const matchedPolicy = this.findMatchingPolicy(agentName, localPolicy.agents);
531
+ if (matchedPolicy) {
532
+ return { matchedPolicy, policySource: 'local' };
533
+ }
534
+
535
+ // Use local default
536
+ if (localPolicy.defaultPolicy) {
537
+ return {
538
+ matchedPolicy: { ...localPolicy.defaultPolicy, name: agentName },
539
+ policySource: 'local',
540
+ };
541
+ }
542
+ }
543
+
544
+ // 3. Try workspace-level policy from cloud
545
+ const workspacePolicy = await this.getWorkspacePolicy();
546
+ if (workspacePolicy) {
547
+ // Check for strict mode
548
+ if (workspacePolicy.settings?.requireExplicitAgents) {
549
+ // In strict mode, unknown agents get restrictive defaults
550
+ const matchedPolicy = this.findMatchingPolicy(agentName, workspacePolicy.agents);
551
+ if (matchedPolicy) {
552
+ return { matchedPolicy, policySource: 'workspace' };
553
+ }
554
+ // Unknown agent in strict mode
555
+ return {
556
+ matchedPolicy: { ...STRICT_DEFAULT_POLICY, name: agentName },
557
+ policySource: 'workspace',
558
+ };
559
+ }
560
+
561
+ // Find matching policy
562
+ const matchedPolicy = this.findMatchingPolicy(agentName, workspacePolicy.agents);
563
+ if (matchedPolicy) {
564
+ return { matchedPolicy, policySource: 'workspace' };
565
+ }
566
+
567
+ // Use workspace default
568
+ if (workspacePolicy.defaultPolicy) {
569
+ return {
570
+ matchedPolicy: { ...workspacePolicy.defaultPolicy, name: agentName },
571
+ policySource: 'workspace',
572
+ };
573
+ }
574
+ }
575
+
576
+ // 4. Fall back to built-in defaults
577
+ const defaultPolicy = this.strictMode ? STRICT_DEFAULT_POLICY : DEFAULT_POLICY;
578
+ return {
579
+ matchedPolicy: { ...defaultPolicy, name: agentName },
580
+ policySource: 'default',
581
+ };
582
+ }
583
+
584
+ /**
585
+ * Get workspace policy from cloud (with caching)
586
+ */
587
+ private async getWorkspacePolicy(): Promise<WorkspacePolicy | null> {
588
+ if (!this.workspaceId || !this.cloudFetcher) {
589
+ return null;
590
+ }
591
+
592
+ // Check cache
593
+ if (this.cachedWorkspacePolicy && Date.now() < this.policyCacheExpiry) {
594
+ return this.cachedWorkspacePolicy;
595
+ }
596
+
597
+ try {
598
+ const policy = await this.cloudFetcher.getWorkspacePolicy(this.workspaceId);
599
+ if (policy) {
600
+ this.cachedWorkspacePolicy = policy;
601
+ this.policyCacheExpiry = Date.now() + AgentPolicyService.CACHE_TTL_MS;
602
+ }
603
+ return policy;
604
+ } catch (err) {
605
+ console.error('[policy] Failed to fetch workspace policy:', err);
606
+ // Return cached policy if available, even if expired
607
+ return this.cachedWorkspacePolicy ?? null;
608
+ }
609
+ }
610
+
611
+ /**
612
+ * Find matching policy from a list (supports wildcards)
613
+ */
614
+ private findMatchingPolicy(agentName: string, policies: AgentPolicy[]): AgentPolicy | null {
615
+ // First try exact match
616
+ const exactMatch = policies.find(p => p.name.toLowerCase() === agentName.toLowerCase());
617
+ if (exactMatch) return exactMatch;
618
+
619
+ // Then try pattern match
620
+ for (const policy of policies) {
621
+ if (this.matchesPattern(agentName, [policy.name])) {
622
+ return policy;
623
+ }
624
+ }
625
+
626
+ return null;
627
+ }
628
+
629
+ /**
630
+ * Check if a name matches any pattern in the list
631
+ * Supports: exact match, prefix* match, *suffix match, * (all)
632
+ */
633
+ private matchesPattern(name: string, patterns: string[]): boolean {
634
+ const lowerName = name.toLowerCase();
635
+ for (const pattern of patterns) {
636
+ const lowerPattern = pattern.toLowerCase();
637
+
638
+ // Wildcard all
639
+ if (lowerPattern === '*') return true;
640
+
641
+ // Exact match
642
+ if (lowerPattern === lowerName) return true;
643
+
644
+ // Prefix match (e.g., "Worker*" matches "WorkerA")
645
+ if (lowerPattern.endsWith('*')) {
646
+ const prefix = lowerPattern.slice(0, -1);
647
+ if (lowerName.startsWith(prefix)) return true;
648
+ }
649
+
650
+ // Suffix match (e.g., "*Lead" matches "TeamLead")
651
+ if (lowerPattern.startsWith('*')) {
652
+ const suffix = lowerPattern.slice(1);
653
+ if (lowerName.endsWith(suffix)) return true;
654
+ }
655
+ }
656
+ return false;
657
+ }
658
+
659
+ /**
660
+ * Convert AgentConfig to AgentPolicy
661
+ */
662
+ private configToPolicy(config: AgentConfig): AgentPolicy {
663
+ return {
664
+ name: config.name,
665
+ allowedTools: config.allowedTools,
666
+ // Other fields come from defaults since repo config doesn't specify them
667
+ canSpawn: undefined,
668
+ canMessage: undefined,
669
+ maxSpawns: 10,
670
+ rateLimit: 60,
671
+ canBeSpawned: true,
672
+ };
673
+ }
674
+
675
+ /**
676
+ * Record an audit entry
677
+ */
678
+ private audit(
679
+ action: AuditEntry['action'],
680
+ actor: string,
681
+ target: string | undefined,
682
+ decision: PolicyDecision,
683
+ context?: Record<string, unknown>
684
+ ): void {
685
+ const entry: AuditEntry = {
686
+ timestamp: Date.now(),
687
+ action,
688
+ actor,
689
+ target,
690
+ decision,
691
+ context,
692
+ };
693
+
694
+ this.auditLog.push(entry);
695
+
696
+ // Trim log if too large
697
+ if (this.auditLog.length > AgentPolicyService.MAX_AUDIT_ENTRIES) {
698
+ this.auditLog = this.auditLog.slice(-AgentPolicyService.MAX_AUDIT_ENTRIES / 2);
699
+ }
700
+
701
+ // Log denied actions
702
+ if (!decision.allowed) {
703
+ console.warn(`[policy] DENIED: ${action} by ${actor}${target ? ` -> ${target}` : ''}: ${decision.reason}`);
704
+ }
705
+ }
706
+
707
+ /**
708
+ * Get audit log entries
709
+ */
710
+ getAuditLog(options?: {
711
+ limit?: number;
712
+ action?: AuditEntry['action'];
713
+ actor?: string;
714
+ deniedOnly?: boolean;
715
+ }): AuditEntry[] {
716
+ let entries = [...this.auditLog];
717
+
718
+ if (options?.action) {
719
+ entries = entries.filter(e => e.action === options.action);
720
+ }
721
+ if (options?.actor) {
722
+ entries = entries.filter(e => e.actor === options.actor);
723
+ }
724
+ if (options?.deniedOnly) {
725
+ entries = entries.filter(e => !e.decision.allowed);
726
+ }
727
+ if (options?.limit) {
728
+ entries = entries.slice(-options.limit);
729
+ }
730
+
731
+ return entries;
732
+ }
733
+
734
+ /**
735
+ * Clear audit log
736
+ */
737
+ clearAuditLog(): void {
738
+ this.auditLog = [];
739
+ }
740
+
741
+ /**
742
+ * Invalidate cached workspace policy
743
+ */
744
+ invalidateCache(): void {
745
+ this.cachedWorkspacePolicy = undefined;
746
+ this.policyCacheExpiry = 0;
747
+ }
748
+
749
+ /**
750
+ * Get a human-readable policy summary for an agent
751
+ * This can be injected into agent prompts to inform them of their permissions
752
+ */
753
+ async getPolicySummary(agentName: string): Promise<string> {
754
+ const { matchedPolicy, policySource } = await this.getAgentPolicy(agentName);
755
+
756
+ const lines: string[] = [
757
+ `# Agent Policy for ${agentName}`,
758
+ `Source: ${policySource}`,
759
+ '',
760
+ ];
761
+
762
+ // Tools
763
+ if (matchedPolicy.allowedTools) {
764
+ if (matchedPolicy.allowedTools.length === 1 && matchedPolicy.allowedTools[0] === 'none') {
765
+ lines.push('**Tools**: No tools allowed');
766
+ } else {
767
+ lines.push(`**Allowed Tools**: ${matchedPolicy.allowedTools.join(', ')}`);
768
+ }
769
+ } else {
770
+ lines.push('**Tools**: All tools allowed');
771
+ }
772
+
773
+ // Spawning
774
+ if (matchedPolicy.canSpawn) {
775
+ if (matchedPolicy.canSpawn.length === 0) {
776
+ lines.push('**Spawning**: Cannot spawn other agents');
777
+ } else {
778
+ lines.push(`**Can Spawn**: ${matchedPolicy.canSpawn.join(', ')}`);
779
+ }
780
+ } else {
781
+ lines.push('**Spawning**: Can spawn any agent');
782
+ }
783
+
784
+ // Messaging
785
+ if (matchedPolicy.canMessage) {
786
+ if (matchedPolicy.canMessage.length === 0) {
787
+ lines.push('**Messaging**: Cannot message other agents');
788
+ } else {
789
+ lines.push(`**Can Message**: ${matchedPolicy.canMessage.join(', ')}`);
790
+ }
791
+ } else {
792
+ lines.push('**Messaging**: Can message any agent');
793
+ }
794
+
795
+ // Limits
796
+ if (matchedPolicy.maxSpawns !== undefined) {
797
+ lines.push(`**Max Spawns**: ${matchedPolicy.maxSpawns}`);
798
+ }
799
+ if (matchedPolicy.rateLimit !== undefined) {
800
+ lines.push(`**Rate Limit**: ${matchedPolicy.rateLimit} messages/min`);
801
+ }
802
+
803
+ return lines.join('\n');
804
+ }
805
+
806
+ /**
807
+ * Get a concise policy instruction for injection into agent prompts
808
+ */
809
+ async getPolicyInstruction(agentName: string): Promise<string | null> {
810
+ const { matchedPolicy, policySource: _policySource } = await this.getAgentPolicy(agentName);
811
+
812
+ // Only generate instructions if there are restrictions
813
+ const hasRestrictions =
814
+ matchedPolicy.allowedTools !== undefined ||
815
+ matchedPolicy.canSpawn !== undefined ||
816
+ matchedPolicy.canMessage !== undefined;
817
+
818
+ if (!hasRestrictions) {
819
+ return null; // No restrictions, no need to inform agent
820
+ }
821
+
822
+ const restrictions: string[] = [];
823
+
824
+ if (matchedPolicy.allowedTools) {
825
+ if (matchedPolicy.allowedTools.length === 1 && matchedPolicy.allowedTools[0] === 'none') {
826
+ restrictions.push('You are not allowed to use any tools.');
827
+ } else {
828
+ restrictions.push(`You may only use these tools: ${matchedPolicy.allowedTools.join(', ')}.`);
829
+ }
830
+ }
831
+
832
+ if (matchedPolicy.canSpawn) {
833
+ if (matchedPolicy.canSpawn.length === 0) {
834
+ restrictions.push('You are not allowed to spawn other agents.');
835
+ } else {
836
+ restrictions.push(`You may only spawn these agents: ${matchedPolicy.canSpawn.join(', ')}.`);
837
+ }
838
+ }
839
+
840
+ if (matchedPolicy.canMessage) {
841
+ if (matchedPolicy.canMessage.length === 0) {
842
+ restrictions.push('You are not allowed to message other agents.');
843
+ } else {
844
+ restrictions.push(`You may only message these agents: ${matchedPolicy.canMessage.join(', ')}.`);
845
+ }
846
+ }
847
+
848
+ if (restrictions.length === 0) {
849
+ return null;
850
+ }
851
+
852
+ return `[Policy Restrictions]\n${restrictions.join('\n')}`;
853
+ }
854
+ }
855
+
856
+ /**
857
+ * Create a policy service for a project
858
+ */
859
+ export function createPolicyService(options: {
860
+ projectRoot: string;
861
+ workspaceId?: string;
862
+ cloudFetcher?: CloudPolicyFetcher;
863
+ strictMode?: boolean;
864
+ }): AgentPolicyService {
865
+ return new AgentPolicyService(options);
866
+ }