@a5c-ai/agent-platform 5.0.1-staging.b436b3b3e611

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 (554) hide show
  1. package/README.md +53 -0
  2. package/dist/anycli/cache.d.ts +45 -0
  3. package/dist/anycli/cache.d.ts.map +1 -0
  4. package/dist/anycli/cache.js +118 -0
  5. package/dist/anycli/index.d.ts +10 -0
  6. package/dist/anycli/index.d.ts.map +1 -0
  7. package/dist/anycli/index.js +25 -0
  8. package/dist/anycli/types.d.ts +32 -0
  9. package/dist/anycli/types.d.ts.map +1 -0
  10. package/dist/anycli/types.js +9 -0
  11. package/dist/api/breakpoints.d.ts +93 -0
  12. package/dist/api/breakpoints.d.ts.map +1 -0
  13. package/dist/api/breakpoints.js +334 -0
  14. package/dist/api/effects.d.ts +14 -0
  15. package/dist/api/effects.d.ts.map +1 -0
  16. package/dist/api/effects.js +306 -0
  17. package/dist/api/effectsTypes.d.ts +79 -0
  18. package/dist/api/effectsTypes.d.ts.map +1 -0
  19. package/dist/api/effectsTypes.js +6 -0
  20. package/dist/api/eventStream.d.ts +34 -0
  21. package/dist/api/eventStream.d.ts.map +1 -0
  22. package/dist/api/eventStream.js +126 -0
  23. package/dist/api/index.d.ts +10 -0
  24. package/dist/api/index.d.ts.map +1 -0
  25. package/dist/api/index.js +27 -0
  26. package/dist/api/runs.d.ts +85 -0
  27. package/dist/api/runs.d.ts.map +1 -0
  28. package/dist/api/runs.js +247 -0
  29. package/dist/api/utils.d.ts +28 -0
  30. package/dist/api/utils.d.ts.map +1 -0
  31. package/dist/api/utils.js +74 -0
  32. package/dist/breakpoints/approvalChains.d.ts +68 -0
  33. package/dist/breakpoints/approvalChains.d.ts.map +1 -0
  34. package/dist/breakpoints/approvalChains.js +111 -0
  35. package/dist/breakpoints/delegation.d.ts +42 -0
  36. package/dist/breakpoints/delegation.d.ts.map +1 -0
  37. package/dist/breakpoints/delegation.js +199 -0
  38. package/dist/breakpoints/delegationTypes.d.ts +46 -0
  39. package/dist/breakpoints/delegationTypes.d.ts.map +1 -0
  40. package/dist/breakpoints/delegationTypes.js +10 -0
  41. package/dist/breakpoints/postures.d.ts +28 -0
  42. package/dist/breakpoints/postures.d.ts.map +1 -0
  43. package/dist/breakpoints/postures.js +100 -0
  44. package/dist/cli/amuxEventsFormatter.d.ts +26 -0
  45. package/dist/cli/amuxEventsFormatter.d.ts.map +1 -0
  46. package/dist/cli/amuxEventsFormatter.js +86 -0
  47. package/dist/cli/args/argFlags.d.ts +6 -0
  48. package/dist/cli/args/argFlags.d.ts.map +1 -0
  49. package/dist/cli/args/argFlags.js +72 -0
  50. package/dist/cli/args/argPositionals.d.ts +3 -0
  51. package/dist/cli/args/argPositionals.d.ts.map +1 -0
  52. package/dist/cli/args/argPositionals.js +18 -0
  53. package/dist/cli/args/index.d.ts +4 -0
  54. package/dist/cli/args/index.d.ts.map +1 -0
  55. package/dist/cli/args/index.js +75 -0
  56. package/dist/cli/args/types.d.ts +13 -0
  57. package/dist/cli/args/types.d.ts.map +1 -0
  58. package/dist/cli/args/types.js +2 -0
  59. package/dist/cli/commands/daemon.d.ts +31 -0
  60. package/dist/cli/commands/daemon.d.ts.map +1 -0
  61. package/dist/cli/commands/daemon.js +156 -0
  62. package/dist/cli/commands/harness/createRun.d.ts +3 -0
  63. package/dist/cli/commands/harness/createRun.d.ts.map +1 -0
  64. package/dist/cli/commands/harness/createRun.js +8 -0
  65. package/dist/cli/commands/harness/resumeRun.d.ts +20 -0
  66. package/dist/cli/commands/harness/resumeRun.d.ts.map +1 -0
  67. package/dist/cli/commands/harness/resumeRun.js +341 -0
  68. package/dist/cli/commands/jsonlInteractive.d.ts +35 -0
  69. package/dist/cli/commands/jsonlInteractive.d.ts.map +1 -0
  70. package/dist/cli/commands/jsonlInteractive.js +302 -0
  71. package/dist/cli/commands/mcpServe.d.ts +18 -0
  72. package/dist/cli/commands/mcpServe.d.ts.map +1 -0
  73. package/dist/cli/commands/mcpServe.js +59 -0
  74. package/dist/cli/commands/session/history.d.ts +14 -0
  75. package/dist/cli/commands/session/history.d.ts.map +1 -0
  76. package/dist/cli/commands/session/history.js +100 -0
  77. package/dist/cli/commands/tui.d.ts +23 -0
  78. package/dist/cli/commands/tui.d.ts.map +1 -0
  79. package/dist/cli/commands/tui.js +183 -0
  80. package/dist/cli/dispatch.d.ts +4 -0
  81. package/dist/cli/dispatch.d.ts.map +1 -0
  82. package/dist/cli/dispatch.js +332 -0
  83. package/dist/cli/main.d.ts +7 -0
  84. package/dist/cli/main.d.ts.map +1 -0
  85. package/dist/cli/main.js +41 -0
  86. package/dist/cli/program.d.ts +7 -0
  87. package/dist/cli/program.d.ts.map +1 -0
  88. package/dist/cli/program.js +8 -0
  89. package/dist/cli/ui.d.ts +9 -0
  90. package/dist/cli/ui.d.ts.map +1 -0
  91. package/dist/cli/ui.js +125 -0
  92. package/dist/compression/compaction.d.ts +82 -0
  93. package/dist/compression/compaction.d.ts.map +1 -0
  94. package/dist/compression/compaction.js +310 -0
  95. package/dist/cost/claudeCodeParser.d.ts +81 -0
  96. package/dist/cost/claudeCodeParser.d.ts.map +1 -0
  97. package/dist/cost/claudeCodeParser.js +232 -0
  98. package/dist/cost/collector.d.ts +42 -0
  99. package/dist/cost/collector.d.ts.map +1 -0
  100. package/dist/cost/collector.js +105 -0
  101. package/dist/cost/effectCost.d.ts +23 -0
  102. package/dist/cost/effectCost.d.ts.map +1 -0
  103. package/dist/cost/effectCost.js +26 -0
  104. package/dist/cost/index.d.ts +7 -0
  105. package/dist/cost/index.d.ts.map +1 -0
  106. package/dist/cost/index.js +28 -0
  107. package/dist/cost/journal.d.ts +40 -0
  108. package/dist/cost/journal.d.ts.map +1 -0
  109. package/dist/cost/journal.js +137 -0
  110. package/dist/cost/types.d.ts +164 -0
  111. package/dist/cost/types.d.ts.map +1 -0
  112. package/dist/cost/types.js +228 -0
  113. package/dist/daemon/automationExecutor.d.ts +16 -0
  114. package/dist/daemon/automationExecutor.d.ts.map +1 -0
  115. package/dist/daemon/automationExecutor.js +222 -0
  116. package/dist/daemon/config.d.ts +8 -0
  117. package/dist/daemon/config.d.ts.map +1 -0
  118. package/dist/daemon/config.js +209 -0
  119. package/dist/daemon/daemonLog.d.ts +13 -0
  120. package/dist/daemon/daemonLog.d.ts.map +1 -0
  121. package/dist/daemon/daemonLog.js +64 -0
  122. package/dist/daemon/fileWatcher.d.ts +9 -0
  123. package/dist/daemon/fileWatcher.d.ts.map +1 -0
  124. package/dist/daemon/fileWatcher.js +141 -0
  125. package/dist/daemon/index.d.ts +7 -0
  126. package/dist/daemon/index.d.ts.map +1 -0
  127. package/dist/daemon/index.js +21 -0
  128. package/dist/daemon/lifecycle.d.ts +12 -0
  129. package/dist/daemon/lifecycle.d.ts.map +1 -0
  130. package/dist/daemon/lifecycle.js +257 -0
  131. package/dist/daemon/loop.d.ts +21 -0
  132. package/dist/daemon/loop.d.ts.map +1 -0
  133. package/dist/daemon/loop.js +196 -0
  134. package/dist/daemon/timerScheduler.d.ts +13 -0
  135. package/dist/daemon/timerScheduler.d.ts.map +1 -0
  136. package/dist/daemon/timerScheduler.js +122 -0
  137. package/dist/daemon/types.d.ts +93 -0
  138. package/dist/daemon/types.d.ts.map +1 -0
  139. package/dist/daemon/types.js +25 -0
  140. package/dist/daemon/webhookListener.d.ts +6 -0
  141. package/dist/daemon/webhookListener.d.ts.map +1 -0
  142. package/dist/daemon/webhookListener.js +110 -0
  143. package/dist/governance/authority.d.ts +68 -0
  144. package/dist/governance/authority.d.ts.map +1 -0
  145. package/dist/governance/authority.js +136 -0
  146. package/dist/governance/bridge.d.ts +17 -0
  147. package/dist/governance/bridge.d.ts.map +1 -0
  148. package/dist/governance/bridge.js +46 -0
  149. package/dist/governance/builtins.d.ts +25 -0
  150. package/dist/governance/builtins.d.ts.map +1 -0
  151. package/dist/governance/builtins.js +67 -0
  152. package/dist/governance/categories.d.ts +58 -0
  153. package/dist/governance/categories.d.ts.map +1 -0
  154. package/dist/governance/categories.js +120 -0
  155. package/dist/governance/decisionTrail.d.ts +60 -0
  156. package/dist/governance/decisionTrail.d.ts.map +1 -0
  157. package/dist/governance/decisionTrail.js +68 -0
  158. package/dist/governance/engine.d.ts +20 -0
  159. package/dist/governance/engine.d.ts.map +1 -0
  160. package/dist/governance/engine.js +124 -0
  161. package/dist/governance/index.d.ts +20 -0
  162. package/dist/governance/index.d.ts.map +1 -0
  163. package/dist/governance/index.js +75 -0
  164. package/dist/governance/logging.d.ts +18 -0
  165. package/dist/governance/logging.d.ts.map +1 -0
  166. package/dist/governance/logging.js +83 -0
  167. package/dist/governance/mandate.d.ts +83 -0
  168. package/dist/governance/mandate.d.ts.map +1 -0
  169. package/dist/governance/mandate.js +180 -0
  170. package/dist/governance/permissionEvents.d.ts +51 -0
  171. package/dist/governance/permissionEvents.d.ts.map +1 -0
  172. package/dist/governance/permissionEvents.js +52 -0
  173. package/dist/governance/permissionPropagation.d.ts +18 -0
  174. package/dist/governance/permissionPropagation.d.ts.map +1 -0
  175. package/dist/governance/permissionPropagation.js +58 -0
  176. package/dist/governance/postureBridge.d.ts +17 -0
  177. package/dist/governance/postureBridge.d.ts.map +1 -0
  178. package/dist/governance/postureBridge.js +117 -0
  179. package/dist/governance/sandboxBridge.d.ts +49 -0
  180. package/dist/governance/sandboxBridge.d.ts.map +1 -0
  181. package/dist/governance/sandboxBridge.js +77 -0
  182. package/dist/governance/sandboxPolicy.d.ts +51 -0
  183. package/dist/governance/sandboxPolicy.d.ts.map +1 -0
  184. package/dist/governance/sandboxPolicy.js +177 -0
  185. package/dist/governance/types.d.ts +3 -0
  186. package/dist/governance/types.d.ts.map +1 -0
  187. package/dist/governance/types.js +5 -0
  188. package/dist/harness/amux/amuxBridge.d.ts +71 -0
  189. package/dist/harness/amux/amuxBridge.d.ts.map +1 -0
  190. package/dist/harness/amux/amuxBridge.js +117 -0
  191. package/dist/harness/amux/amuxClientFactory.d.ts +29 -0
  192. package/dist/harness/amux/amuxClientFactory.d.ts.map +1 -0
  193. package/dist/harness/amux/amuxClientFactory.js +90 -0
  194. package/dist/harness/amux/amuxEventEmitter.d.ts +51 -0
  195. package/dist/harness/amux/amuxEventEmitter.d.ts.map +1 -0
  196. package/dist/harness/amux/amuxEventEmitter.js +143 -0
  197. package/dist/harness/amux/amuxEventMapper.d.ts +58 -0
  198. package/dist/harness/amux/amuxEventMapper.d.ts.map +1 -0
  199. package/dist/harness/amux/amuxEventMapper.js +92 -0
  200. package/dist/harness/amux/amuxHarnessMap.d.ts +25 -0
  201. package/dist/harness/amux/amuxHarnessMap.d.ts.map +1 -0
  202. package/dist/harness/amux/amuxHarnessMap.js +55 -0
  203. package/dist/harness/amux/amuxStdinReader.d.ts +45 -0
  204. package/dist/harness/amux/amuxStdinReader.d.ts.map +1 -0
  205. package/dist/harness/amux/amuxStdinReader.js +106 -0
  206. package/dist/harness/amux/amuxTypes.d.ts +122 -0
  207. package/dist/harness/amux/amuxTypes.d.ts.map +1 -0
  208. package/dist/harness/amux/amuxTypes.js +11 -0
  209. package/dist/harness/amux/index.d.ts +17 -0
  210. package/dist/harness/amux/index.d.ts.map +1 -0
  211. package/dist/harness/amux/index.js +34 -0
  212. package/dist/harness/backgroundTracker.d.ts +64 -0
  213. package/dist/harness/backgroundTracker.d.ts.map +1 -0
  214. package/dist/harness/backgroundTracker.js +107 -0
  215. package/dist/harness/builtInHarness.d.ts +3 -0
  216. package/dist/harness/builtInHarness.d.ts.map +1 -0
  217. package/dist/harness/builtInHarness.js +18 -0
  218. package/dist/harness/capabilityRouter.d.ts +76 -0
  219. package/dist/harness/capabilityRouter.d.ts.map +1 -0
  220. package/dist/harness/capabilityRouter.js +176 -0
  221. package/dist/harness/fallbackChains.d.ts +42 -0
  222. package/dist/harness/fallbackChains.d.ts.map +1 -0
  223. package/dist/harness/fallbackChains.js +69 -0
  224. package/dist/harness/hostContract.d.ts +63 -0
  225. package/dist/harness/hostContract.d.ts.map +1 -0
  226. package/dist/harness/hostContract.js +136 -0
  227. package/dist/harness/index.d.ts +10 -0
  228. package/dist/harness/index.d.ts.map +1 -0
  229. package/dist/harness/index.js +66 -0
  230. package/dist/harness/internal/createRun/askUserQuestion.d.ts +11 -0
  231. package/dist/harness/internal/createRun/askUserQuestion.d.ts.map +1 -0
  232. package/dist/harness/internal/createRun/askUserQuestion.js +162 -0
  233. package/dist/harness/internal/createRun/index.d.ts +25 -0
  234. package/dist/harness/internal/createRun/index.d.ts.map +1 -0
  235. package/dist/harness/internal/createRun/index.js +137 -0
  236. package/dist/harness/internal/createRun/orchestration/constants.d.ts +7 -0
  237. package/dist/harness/internal/createRun/orchestration/constants.d.ts.map +1 -0
  238. package/dist/harness/internal/createRun/orchestration/constants.js +13 -0
  239. package/dist/harness/internal/createRun/orchestration/effects.d.ts +43 -0
  240. package/dist/harness/internal/createRun/orchestration/effects.d.ts.map +1 -0
  241. package/dist/harness/internal/createRun/orchestration/effects.js +490 -0
  242. package/dist/harness/internal/createRun/orchestration/effectsHelpers.d.ts +20 -0
  243. package/dist/harness/internal/createRun/orchestration/effectsHelpers.d.ts.map +1 -0
  244. package/dist/harness/internal/createRun/orchestration/effectsHelpers.js +79 -0
  245. package/dist/harness/internal/createRun/orchestration/externalPhase.d.ts +3 -0
  246. package/dist/harness/internal/createRun/orchestration/externalPhase.d.ts.map +1 -0
  247. package/dist/harness/internal/createRun/orchestration/externalPhase.js +319 -0
  248. package/dist/harness/internal/createRun/orchestration/externalPhaseHelpers.d.ts +16 -0
  249. package/dist/harness/internal/createRun/orchestration/externalPhaseHelpers.d.ts.map +1 -0
  250. package/dist/harness/internal/createRun/orchestration/externalPhaseHelpers.js +104 -0
  251. package/dist/harness/internal/createRun/orchestration/index.d.ts +14 -0
  252. package/dist/harness/internal/createRun/orchestration/index.d.ts.map +1 -0
  253. package/dist/harness/internal/createRun/orchestration/index.js +36 -0
  254. package/dist/harness/internal/createRun/orchestration/internalPhase.d.ts +3 -0
  255. package/dist/harness/internal/createRun/orchestration/internalPhase.d.ts.map +1 -0
  256. package/dist/harness/internal/createRun/orchestration/internalPhase.js +464 -0
  257. package/dist/harness/internal/createRun/orchestration/internalTools.d.ts +26 -0
  258. package/dist/harness/internal/createRun/orchestration/internalTools.d.ts.map +1 -0
  259. package/dist/harness/internal/createRun/orchestration/internalTools.js +262 -0
  260. package/dist/harness/internal/createRun/orchestration/internalToolsHelpers.d.ts +17 -0
  261. package/dist/harness/internal/createRun/orchestration/internalToolsHelpers.d.ts.map +1 -0
  262. package/dist/harness/internal/createRun/orchestration/internalToolsHelpers.js +23 -0
  263. package/dist/harness/internal/createRun/orchestration/taskResult.d.ts +10 -0
  264. package/dist/harness/internal/createRun/orchestration/taskResult.d.ts.map +1 -0
  265. package/dist/harness/internal/createRun/orchestration/taskResult.js +67 -0
  266. package/dist/harness/internal/createRun/orchestration/types.d.ts +46 -0
  267. package/dist/harness/internal/createRun/orchestration/types.d.ts.map +1 -0
  268. package/dist/harness/internal/createRun/orchestration/types.js +2 -0
  269. package/dist/harness/internal/createRun/orchestration/verbose.d.ts +7 -0
  270. package/dist/harness/internal/createRun/orchestration/verbose.d.ts.map +1 -0
  271. package/dist/harness/internal/createRun/orchestration/verbose.js +240 -0
  272. package/dist/harness/internal/createRun/output.d.ts +38 -0
  273. package/dist/harness/internal/createRun/output.d.ts.map +1 -0
  274. package/dist/harness/internal/createRun/output.js +415 -0
  275. package/dist/harness/internal/createRun/pi.d.ts +34 -0
  276. package/dist/harness/internal/createRun/pi.d.ts.map +1 -0
  277. package/dist/harness/internal/createRun/pi.js +216 -0
  278. package/dist/harness/internal/createRun/planProcess/agentOutput.d.ts +5 -0
  279. package/dist/harness/internal/createRun/planProcess/agentOutput.d.ts.map +1 -0
  280. package/dist/harness/internal/createRun/planProcess/agentOutput.js +113 -0
  281. package/dist/harness/internal/createRun/planProcess/delegation.d.ts +23 -0
  282. package/dist/harness/internal/createRun/planProcess/delegation.d.ts.map +1 -0
  283. package/dist/harness/internal/createRun/planProcess/delegation.js +176 -0
  284. package/dist/harness/internal/createRun/planProcess/external.d.ts +14 -0
  285. package/dist/harness/internal/createRun/planProcess/external.d.ts.map +1 -0
  286. package/dist/harness/internal/createRun/planProcess/external.js +139 -0
  287. package/dist/harness/internal/createRun/planProcess/index.d.ts +12 -0
  288. package/dist/harness/internal/createRun/planProcess/index.d.ts.map +1 -0
  289. package/dist/harness/internal/createRun/planProcess/index.js +24 -0
  290. package/dist/harness/internal/createRun/planProcess/paths.d.ts +7 -0
  291. package/dist/harness/internal/createRun/planProcess/paths.d.ts.map +1 -0
  292. package/dist/harness/internal/createRun/planProcess/paths.js +98 -0
  293. package/dist/harness/internal/createRun/planProcess/phase.d.ts +6 -0
  294. package/dist/harness/internal/createRun/planProcess/phase.d.ts.map +1 -0
  295. package/dist/harness/internal/createRun/planProcess/phase.js +361 -0
  296. package/dist/harness/internal/createRun/planProcess/phaseHelpers.d.ts +37 -0
  297. package/dist/harness/internal/createRun/planProcess/phaseHelpers.d.ts.map +1 -0
  298. package/dist/harness/internal/createRun/planProcess/phaseHelpers.js +159 -0
  299. package/dist/harness/internal/createRun/planProcess/phaseTypes.d.ts +25 -0
  300. package/dist/harness/internal/createRun/planProcess/phaseTypes.d.ts.map +1 -0
  301. package/dist/harness/internal/createRun/planProcess/phaseTypes.js +6 -0
  302. package/dist/harness/internal/createRun/planProcess/prompts.d.ts +20 -0
  303. package/dist/harness/internal/createRun/planProcess/prompts.d.ts.map +1 -0
  304. package/dist/harness/internal/createRun/planProcess/prompts.js +208 -0
  305. package/dist/harness/internal/createRun/planProcess/recovery.d.ts +18 -0
  306. package/dist/harness/internal/createRun/planProcess/recovery.d.ts.map +1 -0
  307. package/dist/harness/internal/createRun/planProcess/recovery.js +188 -0
  308. package/dist/harness/internal/createRun/planProcess/recovery.test.d.ts +2 -0
  309. package/dist/harness/internal/createRun/planProcess/recovery.test.d.ts.map +1 -0
  310. package/dist/harness/internal/createRun/planProcess/recovery.test.js +68 -0
  311. package/dist/harness/internal/createRun/planProcess/runState.d.ts +40 -0
  312. package/dist/harness/internal/createRun/planProcess/runState.d.ts.map +1 -0
  313. package/dist/harness/internal/createRun/planProcess/runState.js +179 -0
  314. package/dist/harness/internal/createRun/planProcess/understandIntent.d.ts +22 -0
  315. package/dist/harness/internal/createRun/planProcess/understandIntent.d.ts.map +1 -0
  316. package/dist/harness/internal/createRun/planProcess/understandIntent.js +65 -0
  317. package/dist/harness/internal/createRun/planProcess/validation.d.ts +2 -0
  318. package/dist/harness/internal/createRun/planProcess/validation.d.ts.map +1 -0
  319. package/dist/harness/internal/createRun/planProcess/validation.js +212 -0
  320. package/dist/harness/internal/createRun/planProcess/validationSource.d.ts +11 -0
  321. package/dist/harness/internal/createRun/planProcess/validationSource.d.ts.map +1 -0
  322. package/dist/harness/internal/createRun/planProcess/validationSource.js +328 -0
  323. package/dist/harness/internal/createRun/planProcess/validationText.d.ts +3 -0
  324. package/dist/harness/internal/createRun/planProcess/validationText.d.ts.map +1 -0
  325. package/dist/harness/internal/createRun/planProcess/validationText.js +145 -0
  326. package/dist/harness/internal/createRun/prompts.d.ts +49 -0
  327. package/dist/harness/internal/createRun/prompts.d.ts.map +1 -0
  328. package/dist/harness/internal/createRun/prompts.js +307 -0
  329. package/dist/harness/internal/createRun/resumeState.d.ts +28 -0
  330. package/dist/harness/internal/createRun/resumeState.d.ts.map +1 -0
  331. package/dist/harness/internal/createRun/resumeState.js +133 -0
  332. package/dist/harness/internal/createRun/utils.d.ts +182 -0
  333. package/dist/harness/internal/createRun/utils.d.ts.map +1 -0
  334. package/dist/harness/internal/createRun/utils.js +133 -0
  335. package/dist/harness/internal.d.ts +13 -0
  336. package/dist/harness/internal.d.ts.map +1 -0
  337. package/dist/harness/internal.js +149 -0
  338. package/dist/harness/invoker/launch.d.ts +20 -0
  339. package/dist/harness/invoker/launch.d.ts.map +1 -0
  340. package/dist/harness/invoker/launch.js +23 -0
  341. package/dist/harness/invoker/processControl.d.ts +11 -0
  342. package/dist/harness/invoker/processControl.d.ts.map +1 -0
  343. package/dist/harness/invoker/processControl.js +50 -0
  344. package/dist/harness/invoker.d.ts +43 -0
  345. package/dist/harness/invoker.d.ts.map +1 -0
  346. package/dist/harness/invoker.js +210 -0
  347. package/dist/harness/modeSelector.d.ts +50 -0
  348. package/dist/harness/modeSelector.d.ts.map +1 -0
  349. package/dist/harness/modeSelector.js +124 -0
  350. package/dist/harness/modelSelection.d.ts +37 -0
  351. package/dist/harness/modelSelection.d.ts.map +1 -0
  352. package/dist/harness/modelSelection.js +81 -0
  353. package/dist/harness/operatorCommands.d.ts +38 -0
  354. package/dist/harness/operatorCommands.d.ts.map +1 -0
  355. package/dist/harness/operatorCommands.js +118 -0
  356. package/dist/harness/piSecureSandbox.d.ts +8 -0
  357. package/dist/harness/piSecureSandbox.d.ts.map +1 -0
  358. package/dist/harness/piSecureSandbox.js +366 -0
  359. package/dist/harness/piSecureSandboxTypes.d.ts +51 -0
  360. package/dist/harness/piSecureSandboxTypes.d.ts.map +1 -0
  361. package/dist/harness/piSecureSandboxTypes.js +6 -0
  362. package/dist/harness/piWrapper/compaction.d.ts +13 -0
  363. package/dist/harness/piWrapper/compaction.d.ts.map +1 -0
  364. package/dist/harness/piWrapper/compaction.js +38 -0
  365. package/dist/harness/piWrapper/instructionPrompts.d.ts +2 -0
  366. package/dist/harness/piWrapper/instructionPrompts.d.ts.map +1 -0
  367. package/dist/harness/piWrapper/instructionPrompts.js +97 -0
  368. package/dist/harness/piWrapper/moduleSupport.d.ts +77 -0
  369. package/dist/harness/piWrapper/moduleSupport.d.ts.map +1 -0
  370. package/dist/harness/piWrapper/moduleSupport.js +204 -0
  371. package/dist/harness/piWrapper.d.ts +80 -0
  372. package/dist/harness/piWrapper.d.ts.map +1 -0
  373. package/dist/harness/piWrapper.js +389 -0
  374. package/dist/harness/piWrapper.test.d.ts +2 -0
  375. package/dist/harness/piWrapper.test.d.ts.map +1 -0
  376. package/dist/harness/piWrapper.test.js +193 -0
  377. package/dist/harness/planMode.d.ts +68 -0
  378. package/dist/harness/planMode.d.ts.map +1 -0
  379. package/dist/harness/planMode.js +145 -0
  380. package/dist/harness/selectionPolicies.d.ts +29 -0
  381. package/dist/harness/selectionPolicies.d.ts.map +1 -0
  382. package/dist/harness/selectionPolicies.js +165 -0
  383. package/dist/harness/types.d.ts +266 -0
  384. package/dist/harness/types.d.ts.map +1 -0
  385. package/dist/harness/types.js +34 -0
  386. package/dist/index.d.ts +14 -0
  387. package/dist/index.d.ts.map +1 -0
  388. package/dist/index.js +52 -0
  389. package/dist/interaction/askUserQuestion/core.d.ts +8 -0
  390. package/dist/interaction/askUserQuestion/core.d.ts.map +1 -0
  391. package/dist/interaction/askUserQuestion/core.js +112 -0
  392. package/dist/interaction/askUserQuestion/terminal.d.ts +15 -0
  393. package/dist/interaction/askUserQuestion/terminal.d.ts.map +1 -0
  394. package/dist/interaction/askUserQuestion/terminal.js +128 -0
  395. package/dist/interaction/askUserQuestion.d.ts +10 -0
  396. package/dist/interaction/askUserQuestion.d.ts.map +1 -0
  397. package/dist/interaction/askUserQuestion.js +295 -0
  398. package/dist/interaction/askUserQuestionTypes.d.ts +31 -0
  399. package/dist/interaction/askUserQuestionTypes.d.ts.map +1 -0
  400. package/dist/interaction/askUserQuestionTypes.js +6 -0
  401. package/dist/interaction/index.d.ts +4 -0
  402. package/dist/interaction/index.d.ts.map +1 -0
  403. package/dist/interaction/index.js +20 -0
  404. package/dist/interaction/interactionRouter.d.ts +25 -0
  405. package/dist/interaction/interactionRouter.d.ts.map +1 -0
  406. package/dist/interaction/interactionRouter.js +55 -0
  407. package/dist/mcp/channels/allowlist.d.ts +19 -0
  408. package/dist/mcp/channels/allowlist.d.ts.map +1 -0
  409. package/dist/mcp/channels/allowlist.js +140 -0
  410. package/dist/mcp/channels/channelManager.d.ts +64 -0
  411. package/dist/mcp/channels/channelManager.d.ts.map +1 -0
  412. package/dist/mcp/channels/channelManager.js +137 -0
  413. package/dist/mcp/channels/inboundQueue.d.ts +47 -0
  414. package/dist/mcp/channels/inboundQueue.d.ts.map +1 -0
  415. package/dist/mcp/channels/inboundQueue.js +96 -0
  416. package/dist/mcp/channels/index.d.ts +17 -0
  417. package/dist/mcp/channels/index.d.ts.map +1 -0
  418. package/dist/mcp/channels/index.js +39 -0
  419. package/dist/mcp/channels/outbound.d.ts +33 -0
  420. package/dist/mcp/channels/outbound.d.ts.map +1 -0
  421. package/dist/mcp/channels/outbound.js +94 -0
  422. package/dist/mcp/channels/permissionRelay.d.ts +62 -0
  423. package/dist/mcp/channels/permissionRelay.d.ts.map +1 -0
  424. package/dist/mcp/channels/permissionRelay.js +159 -0
  425. package/dist/mcp/channels/types.d.ts +135 -0
  426. package/dist/mcp/channels/types.d.ts.map +1 -0
  427. package/dist/mcp/channels/types.js +16 -0
  428. package/dist/mcp/client/config.d.ts +28 -0
  429. package/dist/mcp/client/config.d.ts.map +1 -0
  430. package/dist/mcp/client/config.js +142 -0
  431. package/dist/mcp/client/executor.d.ts +30 -0
  432. package/dist/mcp/client/executor.d.ts.map +1 -0
  433. package/dist/mcp/client/executor.js +60 -0
  434. package/dist/mcp/client/index.d.ts +12 -0
  435. package/dist/mcp/client/index.d.ts.map +1 -0
  436. package/dist/mcp/client/index.js +27 -0
  437. package/dist/mcp/client/manager.d.ts +74 -0
  438. package/dist/mcp/client/manager.d.ts.map +1 -0
  439. package/dist/mcp/client/manager.js +214 -0
  440. package/dist/mcp/client/toolRegistry.d.ts +50 -0
  441. package/dist/mcp/client/toolRegistry.d.ts.map +1 -0
  442. package/dist/mcp/client/toolRegistry.js +118 -0
  443. package/dist/mcp/client/types.d.ts +96 -0
  444. package/dist/mcp/client/types.d.ts.map +1 -0
  445. package/dist/mcp/client/types.js +15 -0
  446. package/dist/mcp/transport/index.d.ts +9 -0
  447. package/dist/mcp/transport/index.d.ts.map +1 -0
  448. package/dist/mcp/transport/index.js +13 -0
  449. package/dist/mcp/transport/session.d.ts +18 -0
  450. package/dist/mcp/transport/session.d.ts.map +1 -0
  451. package/dist/mcp/transport/session.js +78 -0
  452. package/dist/mcp/transport/types.d.ts +19 -0
  453. package/dist/mcp/transport/types.d.ts.map +1 -0
  454. package/dist/mcp/transport/types.js +7 -0
  455. package/dist/mcp/transport/websocket.d.ts +41 -0
  456. package/dist/mcp/transport/websocket.d.ts.map +1 -0
  457. package/dist/mcp/transport/websocket.js +271 -0
  458. package/dist/observability/health.d.ts +19 -0
  459. package/dist/observability/health.d.ts.map +1 -0
  460. package/dist/observability/health.js +129 -0
  461. package/dist/observability/index.d.ts +7 -0
  462. package/dist/observability/index.d.ts.map +1 -0
  463. package/dist/observability/index.js +22 -0
  464. package/dist/observability/runStatus.d.ts +44 -0
  465. package/dist/observability/runStatus.d.ts.map +1 -0
  466. package/dist/observability/runStatus.js +169 -0
  467. package/dist/observability/timeline.d.ts +11 -0
  468. package/dist/observability/timeline.d.ts.map +1 -0
  469. package/dist/observability/timeline.js +176 -0
  470. package/dist/observability/types.d.ts +62 -0
  471. package/dist/observability/types.d.ts.map +1 -0
  472. package/dist/observability/types.js +8 -0
  473. package/dist/observability/webhooks.d.ts +68 -0
  474. package/dist/observability/webhooks.d.ts.map +1 -0
  475. package/dist/observability/webhooks.js +132 -0
  476. package/dist/prompts/commandTemplates.d.ts +3 -0
  477. package/dist/prompts/commandTemplates.d.ts.map +1 -0
  478. package/dist/prompts/commandTemplates.js +238 -0
  479. package/dist/runtime/index.d.ts +3 -0
  480. package/dist/runtime/index.d.ts.map +1 -0
  481. package/dist/runtime/index.js +28 -0
  482. package/dist/seams/contract.d.ts +55 -0
  483. package/dist/seams/contract.d.ts.map +1 -0
  484. package/dist/seams/contract.js +120 -0
  485. package/dist/seams/contract.test.d.ts +2 -0
  486. package/dist/seams/contract.test.d.ts.map +1 -0
  487. package/dist/seams/contract.test.js +96 -0
  488. package/dist/seams/index.d.ts +3 -0
  489. package/dist/seams/index.d.ts.map +1 -0
  490. package/dist/seams/index.js +8 -0
  491. package/dist/session/context.d.ts +22 -0
  492. package/dist/session/context.d.ts.map +1 -0
  493. package/dist/session/context.js +113 -0
  494. package/dist/session/continuityState.d.ts +39 -0
  495. package/dist/session/continuityState.d.ts.map +1 -0
  496. package/dist/session/continuityState.js +164 -0
  497. package/dist/session/cost.d.ts +63 -0
  498. package/dist/session/cost.d.ts.map +1 -0
  499. package/dist/session/cost.js +194 -0
  500. package/dist/session/discovery.d.ts +22 -0
  501. package/dist/session/discovery.d.ts.map +1 -0
  502. package/dist/session/discovery.js +35 -0
  503. package/dist/session/history.d.ts +30 -0
  504. package/dist/session/history.d.ts.map +1 -0
  505. package/dist/session/history.js +143 -0
  506. package/dist/session/index.d.ts +7 -0
  507. package/dist/session/index.d.ts.map +1 -0
  508. package/dist/session/index.js +70 -0
  509. package/dist/session/memoryExtraction.d.ts +65 -0
  510. package/dist/session/memoryExtraction.d.ts.map +1 -0
  511. package/dist/session/memoryExtraction.js +201 -0
  512. package/dist/session/parse.d.ts +45 -0
  513. package/dist/session/parse.d.ts.map +1 -0
  514. package/dist/session/parse.js +170 -0
  515. package/dist/session/persistence.d.ts +46 -0
  516. package/dist/session/persistence.d.ts.map +1 -0
  517. package/dist/session/persistence.js +180 -0
  518. package/dist/session/types.d.ts +267 -0
  519. package/dist/session/types.d.ts.map +1 -0
  520. package/dist/session/types.js +45 -0
  521. package/dist/session/write.d.ts +61 -0
  522. package/dist/session/write.d.ts.map +1 -0
  523. package/dist/session/write.js +213 -0
  524. package/dist/storage/atomic.d.ts +2 -0
  525. package/dist/storage/atomic.d.ts.map +1 -0
  526. package/dist/storage/atomic.js +54 -0
  527. package/dist/storage/clock.d.ts +2 -0
  528. package/dist/storage/clock.d.ts.map +1 -0
  529. package/dist/storage/clock.js +6 -0
  530. package/dist/storage/index.d.ts +7 -0
  531. package/dist/storage/index.d.ts.map +1 -0
  532. package/dist/storage/index.js +9 -0
  533. package/dist/storage/journalWatcher.d.ts +24 -0
  534. package/dist/storage/journalWatcher.d.ts.map +1 -0
  535. package/dist/storage/journalWatcher.js +172 -0
  536. package/dist/storage/paths.d.ts +5 -0
  537. package/dist/storage/paths.d.ts.map +1 -0
  538. package/dist/storage/paths.js +26 -0
  539. package/dist/storage/snapshotState.d.ts +10 -0
  540. package/dist/storage/snapshotState.d.ts.map +1 -0
  541. package/dist/storage/snapshotState.js +15 -0
  542. package/dist/storage/storeTaskArtifacts.d.ts +6 -0
  543. package/dist/storage/storeTaskArtifacts.d.ts.map +1 -0
  544. package/dist/storage/storeTaskArtifacts.js +55 -0
  545. package/dist/storage/types.d.ts +21 -0
  546. package/dist/storage/types.d.ts.map +1 -0
  547. package/dist/storage/types.js +2 -0
  548. package/dist/tasks/crud.d.ts +33 -0
  549. package/dist/tasks/crud.d.ts.map +1 -0
  550. package/dist/tasks/crud.js +150 -0
  551. package/dist/tasks/index.d.ts +2 -0
  552. package/dist/tasks/index.d.ts.map +1 -0
  553. package/dist/tasks/index.js +9 -0
  554. package/package.json +141 -0
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ /**
3
+ * Permission event creation, aggregation, and filtering for the governance layer.
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.createPermissionEvent = createPermissionEvent;
7
+ exports.aggregateChainEvents = aggregateChainEvents;
8
+ exports.filterEvents = filterEvents;
9
+ // ---------------------------------------------------------------------------
10
+ // Factory
11
+ // ---------------------------------------------------------------------------
12
+ function createPermissionEvent(options) {
13
+ return {
14
+ kind: options.kind,
15
+ operation: options.operation,
16
+ decision: options.decision,
17
+ timestamp: options.timestamp ?? new Date().toISOString(),
18
+ source: options.source,
19
+ ...(options.mandateId !== undefined ? { mandateId: options.mandateId } : {}),
20
+ ...(options.chainId !== undefined ? { chainId: options.chainId } : {}),
21
+ };
22
+ }
23
+ // ---------------------------------------------------------------------------
24
+ // Aggregation
25
+ // ---------------------------------------------------------------------------
26
+ /**
27
+ * Flatten multiple event arrays (from parent/child runs), filter by chainId,
28
+ * and sort chronologically.
29
+ */
30
+ function aggregateChainEvents(chainId, eventArrays) {
31
+ const all = [];
32
+ for (const arr of eventArrays) {
33
+ for (const ev of arr) {
34
+ if (ev.chainId === chainId) {
35
+ all.push(ev);
36
+ }
37
+ }
38
+ }
39
+ all.sort((a, b) => (a.timestamp < b.timestamp ? -1 : a.timestamp > b.timestamp ? 1 : 0));
40
+ return all;
41
+ }
42
+ function filterEvents(events, criteria) {
43
+ return events.filter((ev) => {
44
+ if (criteria.source !== undefined && ev.source !== criteria.source)
45
+ return false;
46
+ if (criteria.action !== undefined && ev.decision.action !== criteria.action)
47
+ return false;
48
+ if (criteria.kind !== undefined && ev.kind !== criteria.kind)
49
+ return false;
50
+ return true;
51
+ });
52
+ }
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Permission event propagation: formatting for different output targets
3
+ * and configuration for which event kinds propagate to which targets.
4
+ */
5
+ import type { PermissionEvent } from './permissionEvents';
6
+ export interface PropagationTarget {
7
+ name: string;
8
+ kinds: string[];
9
+ }
10
+ export interface PropagationConfig {
11
+ targets: PropagationTarget[];
12
+ }
13
+ export declare function formatPermissionForTui(event: PermissionEvent): string;
14
+ export declare function formatPermissionForJsonStream(event: PermissionEvent): PermissionEvent;
15
+ export declare function formatPermissionForCli(event: PermissionEvent): string;
16
+ export declare function createPropagationConfig(targets: PropagationTarget[]): PropagationConfig;
17
+ export declare function shouldPropagate(event: PermissionEvent, targetName: string, config: PropagationConfig): boolean;
18
+ //# sourceMappingURL=permissionPropagation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permissionPropagation.d.ts","sourceRoot":"","sources":["../../src/governance/permissionPropagation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAM1D,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,iBAAiB,EAAE,CAAC;CAC9B;AA4BD,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,eAAe,GAAG,MAAM,CAIrE;AAED,wBAAgB,6BAA6B,CAAC,KAAK,EAAE,eAAe,GAAG,eAAe,CAGrF;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,eAAe,GAAG,MAAM,CAGrE;AAMD,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,iBAAiB,EAAE,GAAG,iBAAiB,CAEvF;AAED,wBAAgB,eAAe,CAC7B,KAAK,EAAE,eAAe,EACtB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,iBAAiB,GACxB,OAAO,CAIT"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ /**
3
+ * Permission event propagation: formatting for different output targets
4
+ * and configuration for which event kinds propagate to which targets.
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.formatPermissionForTui = formatPermissionForTui;
8
+ exports.formatPermissionForJsonStream = formatPermissionForJsonStream;
9
+ exports.formatPermissionForCli = formatPermissionForCli;
10
+ exports.createPropagationConfig = createPropagationConfig;
11
+ exports.shouldPropagate = shouldPropagate;
12
+ // ---------------------------------------------------------------------------
13
+ // ANSI helpers
14
+ // ---------------------------------------------------------------------------
15
+ const RESET = '\x1b[0m';
16
+ const RED = '\x1b[31m';
17
+ const GREEN = '\x1b[32m';
18
+ const YELLOW = '\x1b[33m';
19
+ function colorForAction(action) {
20
+ switch (action) {
21
+ case 'block':
22
+ return RED;
23
+ case 'allow':
24
+ return GREEN;
25
+ case 'prompt':
26
+ return YELLOW;
27
+ default:
28
+ return '';
29
+ }
30
+ }
31
+ // ---------------------------------------------------------------------------
32
+ // Formatters
33
+ // ---------------------------------------------------------------------------
34
+ function formatPermissionForTui(event) {
35
+ const color = colorForAction(event.decision.action);
36
+ const target = event.operation.target ?? '';
37
+ return `${color}[${event.decision.action}]${RESET} ${event.kind} ${target}`;
38
+ }
39
+ function formatPermissionForJsonStream(event) {
40
+ // Return a clean copy with all fields — already JSON-serializable
41
+ return { ...event };
42
+ }
43
+ function formatPermissionForCli(event) {
44
+ const target = event.operation.target ?? '';
45
+ return `${event.decision.action} ${event.kind} ${target}`;
46
+ }
47
+ // ---------------------------------------------------------------------------
48
+ // Config
49
+ // ---------------------------------------------------------------------------
50
+ function createPropagationConfig(targets) {
51
+ return { targets };
52
+ }
53
+ function shouldPropagate(event, targetName, config) {
54
+ const target = config.targets.find((t) => t.name === targetName);
55
+ if (!target)
56
+ return false;
57
+ return target.kinds.includes(event.kind);
58
+ }
@@ -0,0 +1,17 @@
1
+ /**
2
+ * GAP-SEC: Posture-to-Policy Bridge.
3
+ *
4
+ * Converts breakpoint approval postures into governance PolicyRule[] so they
5
+ * can be evaluated by the unified policy engine.
6
+ */
7
+ import type { ActionCategory, ApprovalPosture } from "@a5c-ai/babysitter-sdk";
8
+ import type { PolicyRule } from './types';
9
+ /**
10
+ * Convert a single posture for a given action category into PolicyRule[].
11
+ */
12
+ export declare function postureToPolicyRules(category: ActionCategory, posture: ApprovalPosture): PolicyRule[];
13
+ /**
14
+ * Convert all DEFAULT_POSTURES (optionally overridden) into a sorted PolicyRule[].
15
+ */
16
+ export declare function allPosturesToPolicies(overrides?: Partial<Record<ActionCategory, Partial<ApprovalPosture>>>): PolicyRule[];
17
+ //# sourceMappingURL=postureBridge.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postureBridge.d.ts","sourceRoot":"","sources":["../../src/governance/postureBridge.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAqB1C;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,QAAQ,EAAE,cAAc,EACxB,OAAO,EAAE,eAAe,GACvB,UAAU,EAAE,CAwEd;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,GACpE,UAAU,EAAE,CAed"}
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+ /**
3
+ * GAP-SEC: Posture-to-Policy Bridge.
4
+ *
5
+ * Converts breakpoint approval postures into governance PolicyRule[] so they
6
+ * can be evaluated by the unified policy engine.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.postureToPolicyRules = postureToPolicyRules;
10
+ exports.allPosturesToPolicies = allPosturesToPolicies;
11
+ const postures_1 = require("../breakpoints/postures");
12
+ // ---------------------------------------------------------------------------
13
+ // Priority map by posture name
14
+ // ---------------------------------------------------------------------------
15
+ const POSTURE_PRIORITY = {
16
+ locked: 200,
17
+ guarded: 150,
18
+ cautious: 100,
19
+ permissive: 50,
20
+ };
21
+ function priorityForPosture(posture) {
22
+ return POSTURE_PRIORITY[posture.name] ?? 75;
23
+ }
24
+ // ---------------------------------------------------------------------------
25
+ // Core functions
26
+ // ---------------------------------------------------------------------------
27
+ /**
28
+ * Convert a single posture for a given action category into PolicyRule[].
29
+ */
30
+ function postureToPolicyRules(category, posture) {
31
+ const rules = [];
32
+ const basePriority = priorityForPosture(posture);
33
+ if (!posture.allowAutoApprove) {
34
+ // Locked: deny auto-approval entirely
35
+ rules.push({
36
+ id: `posture:${category}:deny-auto-approve`,
37
+ kind: 'permission',
38
+ condition: { field: 'labels', op: 'contains', value: category },
39
+ action: 'deny',
40
+ priority: basePriority,
41
+ metadata: {
42
+ source: 'posture-bridge',
43
+ category,
44
+ postureName: posture.name,
45
+ requiredApproverLevel: posture.requiredApproverLevel ?? 'any',
46
+ minConsecutiveApprovals: String(posture.minConsecutiveApprovalsForAutoN),
47
+ },
48
+ });
49
+ }
50
+ else if (posture.requireExplicitRule) {
51
+ // Guarded: warn (require explicit rule)
52
+ rules.push({
53
+ id: `posture:${category}:require-explicit-rule`,
54
+ kind: 'permission',
55
+ condition: { field: 'labels', op: 'contains', value: category },
56
+ action: 'warn',
57
+ priority: basePriority,
58
+ metadata: {
59
+ source: 'posture-bridge',
60
+ category,
61
+ postureName: posture.name,
62
+ requireExplicitRule: 'true',
63
+ minConsecutiveApprovals: String(posture.minConsecutiveApprovalsForAutoN),
64
+ },
65
+ });
66
+ }
67
+ else {
68
+ // Cautious or permissive: allow
69
+ rules.push({
70
+ id: `posture:${category}:allow-auto-approve`,
71
+ kind: 'permission',
72
+ condition: { field: 'labels', op: 'contains', value: category },
73
+ action: 'allow',
74
+ priority: basePriority,
75
+ metadata: {
76
+ source: 'posture-bridge',
77
+ category,
78
+ postureName: posture.name,
79
+ minConsecutiveApprovals: String(posture.minConsecutiveApprovalsForAutoN),
80
+ },
81
+ });
82
+ }
83
+ // If the posture has minConsecutiveApprovalsForAutoN > 0 and allows auto-approve,
84
+ // add an advisory warn rule for the threshold
85
+ if (posture.allowAutoApprove && posture.minConsecutiveApprovalsForAutoN > 0) {
86
+ rules.push({
87
+ id: `posture:${category}:consecutive-threshold`,
88
+ kind: 'resource-limit',
89
+ condition: { field: 'labels', op: 'contains', value: category },
90
+ action: 'warn',
91
+ priority: basePriority - 1,
92
+ metadata: {
93
+ source: 'posture-bridge',
94
+ category,
95
+ postureName: posture.name,
96
+ minConsecutiveApprovals: String(posture.minConsecutiveApprovalsForAutoN),
97
+ },
98
+ });
99
+ }
100
+ return rules;
101
+ }
102
+ /**
103
+ * Convert all DEFAULT_POSTURES (optionally overridden) into a sorted PolicyRule[].
104
+ */
105
+ function allPosturesToPolicies(overrides) {
106
+ const categories = ['read', 'write', 'execute', 'destroy', 'network', 'auth'];
107
+ const allRules = [];
108
+ for (const category of categories) {
109
+ const base = postures_1.DEFAULT_POSTURES[category];
110
+ const categoryOverrides = overrides?.[category];
111
+ const posture = categoryOverrides ? { ...base, ...categoryOverrides } : base;
112
+ allRules.push(...postureToPolicyRules(category, posture));
113
+ }
114
+ // Sort by priority descending
115
+ allRules.sort((a, b) => b.priority - a.priority);
116
+ return allRules;
117
+ }
@@ -0,0 +1,49 @@
1
+ /**
2
+ * Sandbox-to-governance bridge (GAP-SEC-002).
3
+ * Converts sandbox decisions into interaction requests and governance events,
4
+ * and derives child sandbox policies from mandate scopes.
5
+ */
6
+ import type { SandboxDecision, SandboxOperation, SandboxPolicy } from './sandboxPolicy';
7
+ export interface SandboxEvent {
8
+ kind: string;
9
+ operation: SandboxOperation;
10
+ decision: SandboxDecision;
11
+ timestamp: string;
12
+ source: string;
13
+ mandateId?: string;
14
+ }
15
+ export interface SandboxInteraction {
16
+ kind: 'approval';
17
+ operationKind?: string;
18
+ operationTarget?: string;
19
+ reason?: string;
20
+ }
21
+ interface BuildSandboxEventOptions {
22
+ mandateId?: string;
23
+ source?: string;
24
+ }
25
+ interface MandateScopeLike {
26
+ allowedEffectKinds: string[];
27
+ maxIterations: number;
28
+ maxConcurrentTasks: number;
29
+ timeoutMs: number;
30
+ }
31
+ /**
32
+ * Convert a sandbox decision to an interaction request.
33
+ * Returns null for allow/block (no human input needed), returns an approval
34
+ * interaction for prompt decisions.
35
+ */
36
+ export declare function sandboxDecisionToInteraction(decision: SandboxDecision, operation?: SandboxOperation): SandboxInteraction | null;
37
+ /**
38
+ * Build a SandboxEvent with auto-timestamp and default source.
39
+ */
40
+ export declare function buildSandboxEvent(operation: SandboxOperation, decision: SandboxDecision, options?: BuildSandboxEventOptions): SandboxEvent;
41
+ /**
42
+ * Derive a child sandbox policy from a parent policy respecting mandate scope.
43
+ * - All parent block rules are always inherited.
44
+ * - Allow/prompt rules are only inherited if their kind is within the mandate's
45
+ * allowedEffectKinds (or if allowedEffectKinds contains '*').
46
+ */
47
+ export declare function inheritSandboxPolicy(parentPolicy: SandboxPolicy, mandateScope: MandateScopeLike): SandboxPolicy;
48
+ export {};
49
+ //# sourceMappingURL=sandboxBridge.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sandboxBridge.d.ts","sourceRoot":"","sources":["../../src/governance/sandboxBridge.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EACV,eAAe,EACf,gBAAgB,EAChB,aAAa,EAEd,MAAM,iBAAiB,CAAC;AAMzB,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,gBAAgB,CAAC;IAC5B,QAAQ,EAAE,eAAe,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,UAAU,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,wBAAwB;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,gBAAgB;IACxB,kBAAkB,EAAE,MAAM,EAAE,CAAC;IAC7B,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;CACnB;AAMD;;;;GAIG;AACH,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,eAAe,EACzB,SAAS,CAAC,EAAE,gBAAgB,GAC3B,kBAAkB,GAAG,IAAI,CAmB3B;AAMD;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,gBAAgB,EAC3B,QAAQ,EAAE,eAAe,EACzB,OAAO,CAAC,EAAE,wBAAwB,GACjC,YAAY,CASd;AAMD;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAClC,YAAY,EAAE,aAAa,EAC3B,YAAY,EAAE,gBAAgB,GAC7B,aAAa,CAmBf"}
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ /**
3
+ * Sandbox-to-governance bridge (GAP-SEC-002).
4
+ * Converts sandbox decisions into interaction requests and governance events,
5
+ * and derives child sandbox policies from mandate scopes.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.sandboxDecisionToInteraction = sandboxDecisionToInteraction;
9
+ exports.buildSandboxEvent = buildSandboxEvent;
10
+ exports.inheritSandboxPolicy = inheritSandboxPolicy;
11
+ // ---------------------------------------------------------------------------
12
+ // Decision → Interaction
13
+ // ---------------------------------------------------------------------------
14
+ /**
15
+ * Convert a sandbox decision to an interaction request.
16
+ * Returns null for allow/block (no human input needed), returns an approval
17
+ * interaction for prompt decisions.
18
+ */
19
+ function sandboxDecisionToInteraction(decision, operation) {
20
+ if (decision.action !== 'prompt') {
21
+ return null;
22
+ }
23
+ const interaction = {
24
+ kind: 'approval',
25
+ };
26
+ if (operation) {
27
+ interaction.operationKind = operation.kind;
28
+ interaction.operationTarget = operation.target;
29
+ }
30
+ if (decision.reason) {
31
+ interaction.reason = decision.reason;
32
+ }
33
+ return interaction;
34
+ }
35
+ // ---------------------------------------------------------------------------
36
+ // Event factory
37
+ // ---------------------------------------------------------------------------
38
+ /**
39
+ * Build a SandboxEvent with auto-timestamp and default source.
40
+ */
41
+ function buildSandboxEvent(operation, decision, options) {
42
+ return {
43
+ kind: `sandbox.${operation.kind}`,
44
+ operation,
45
+ decision,
46
+ timestamp: new Date().toISOString(),
47
+ source: options?.source ?? 'sandbox',
48
+ ...(options?.mandateId ? { mandateId: options.mandateId } : {}),
49
+ };
50
+ }
51
+ // ---------------------------------------------------------------------------
52
+ // Policy inheritance from mandate scope
53
+ // ---------------------------------------------------------------------------
54
+ /**
55
+ * Derive a child sandbox policy from a parent policy respecting mandate scope.
56
+ * - All parent block rules are always inherited.
57
+ * - Allow/prompt rules are only inherited if their kind is within the mandate's
58
+ * allowedEffectKinds (or if allowedEffectKinds contains '*').
59
+ */
60
+ function inheritSandboxPolicy(parentPolicy, mandateScope) {
61
+ const allowAll = mandateScope.allowedEffectKinds.includes('*');
62
+ const childRules = [];
63
+ for (const rule of parentPolicy.rules) {
64
+ if (rule.action === 'block') {
65
+ // Always inherit blocks
66
+ childRules.push({ ...rule });
67
+ }
68
+ else if (allowAll || mandateScope.allowedEffectKinds.includes(rule.kind)) {
69
+ // Only inherit allow/prompt if mandate permits this kind
70
+ childRules.push({ ...rule });
71
+ }
72
+ }
73
+ return {
74
+ rules: childRules,
75
+ defaultAction: parentPolicy.defaultAction,
76
+ };
77
+ }
@@ -0,0 +1,51 @@
1
+ /**
2
+ * Sandbox policy evaluation for tool/operation sandboxing (GAP-SEC-002).
3
+ * Provides glob-based rule matching, policy composition with deny-overrides,
4
+ * and policy attenuation for child scopes.
5
+ */
6
+ export type SandboxOperationKind = 'fs.read' | 'fs.write' | 'fs.delete' | 'net.outbound' | 'net.inbound' | 'exec.shell' | 'exec.process';
7
+ export interface SandboxRule {
8
+ kind: SandboxOperationKind;
9
+ pattern: string;
10
+ action: 'allow' | 'block' | 'prompt';
11
+ priority: number;
12
+ }
13
+ export interface SandboxPolicy {
14
+ rules: SandboxRule[];
15
+ defaultAction: 'allow' | 'block' | 'prompt';
16
+ }
17
+ export interface SandboxDecision {
18
+ action: 'allow' | 'block' | 'prompt';
19
+ matchedRule?: SandboxRule;
20
+ reason: string;
21
+ }
22
+ export interface SandboxOperation {
23
+ kind: SandboxOperationKind;
24
+ target: string;
25
+ metadata?: Record<string, unknown>;
26
+ }
27
+ /**
28
+ * Simple glob matching supporting:
29
+ * - `*` matches any characters within a single path segment (no `/`)
30
+ * - `**` matches any characters including `/` (recursive)
31
+ * - Exact match
32
+ */
33
+ export declare function matchesPattern(pattern: string, target: string): boolean;
34
+ /**
35
+ * Evaluate a sandbox operation against a policy.
36
+ * Matches rules by operation kind, selects highest-priority match,
37
+ * falls back to defaultAction.
38
+ */
39
+ export declare function evaluateSandboxAccess(policy: SandboxPolicy, operation: SandboxOperation): SandboxDecision;
40
+ /**
41
+ * Compose multiple sandbox policies with deny-overrides semantics.
42
+ * Block rules from any policy take precedence. Empty input yields default-deny.
43
+ */
44
+ export declare function composeSandboxPolicies(policies: SandboxPolicy[]): SandboxPolicy;
45
+ /**
46
+ * Attenuate a parent policy with child constraints.
47
+ * The child can only narrow permissions: block additions are kept,
48
+ * allow rules that conflict with parent blocks are dropped.
49
+ */
50
+ export declare function attenuateSandboxPolicy(parent: SandboxPolicy, childConstraints: SandboxPolicy): SandboxPolicy;
51
+ //# sourceMappingURL=sandboxPolicy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sandboxPolicy.d.ts","sourceRoot":"","sources":["../../src/governance/sandboxPolicy.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAMH,MAAM,MAAM,oBAAoB,GAC5B,SAAS,GACT,UAAU,GACV,WAAW,GACX,cAAc,GACd,aAAa,GACb,YAAY,GACZ,cAAc,CAAC;AAEnB,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,oBAAoB,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;IACrC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,aAAa,EAAE,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;CAC7C;AAED,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;IACrC,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,oBAAoB,CAAC;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAMD;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CA8BvE;AAMD;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,aAAa,EACrB,SAAS,EAAE,gBAAgB,GAC1B,eAAe,CAyBjB;AAMD;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,aAAa,EAAE,GAAG,aAAa,CAiD/E;AAMD;;;;GAIG;AACH,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,aAAa,EACrB,gBAAgB,EAAE,aAAa,GAC9B,aAAa,CAoCf"}
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ /**
3
+ * Sandbox policy evaluation for tool/operation sandboxing (GAP-SEC-002).
4
+ * Provides glob-based rule matching, policy composition with deny-overrides,
5
+ * and policy attenuation for child scopes.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.matchesPattern = matchesPattern;
9
+ exports.evaluateSandboxAccess = evaluateSandboxAccess;
10
+ exports.composeSandboxPolicies = composeSandboxPolicies;
11
+ exports.attenuateSandboxPolicy = attenuateSandboxPolicy;
12
+ // ---------------------------------------------------------------------------
13
+ // Pattern matching
14
+ // ---------------------------------------------------------------------------
15
+ /**
16
+ * Simple glob matching supporting:
17
+ * - `*` matches any characters within a single path segment (no `/`)
18
+ * - `**` matches any characters including `/` (recursive)
19
+ * - Exact match
20
+ */
21
+ function matchesPattern(pattern, target) {
22
+ // Convert glob pattern to regex
23
+ let regex = '';
24
+ let i = 0;
25
+ while (i < pattern.length) {
26
+ if (pattern[i] === '*' && pattern[i + 1] === '*') {
27
+ // ** matches everything including path separators
28
+ regex += '.*';
29
+ i += 2;
30
+ // Skip trailing slash after **
31
+ if (pattern[i] === '/') {
32
+ i++;
33
+ }
34
+ }
35
+ else if (pattern[i] === '*') {
36
+ // * matches anything except path separator
37
+ regex += '[^/]*';
38
+ i++;
39
+ }
40
+ else if (pattern[i] === '?') {
41
+ regex += '[^/]';
42
+ i++;
43
+ }
44
+ else if ('.+^${}()|[]\\'.includes(pattern[i])) {
45
+ regex += '\\' + pattern[i];
46
+ i++;
47
+ }
48
+ else {
49
+ regex += pattern[i];
50
+ i++;
51
+ }
52
+ }
53
+ return new RegExp('^' + regex + '$').test(target);
54
+ }
55
+ // ---------------------------------------------------------------------------
56
+ // Evaluation
57
+ // ---------------------------------------------------------------------------
58
+ /**
59
+ * Evaluate a sandbox operation against a policy.
60
+ * Matches rules by operation kind, selects highest-priority match,
61
+ * falls back to defaultAction.
62
+ */
63
+ function evaluateSandboxAccess(policy, operation) {
64
+ const matching = [];
65
+ for (const rule of policy.rules) {
66
+ if (rule.kind === operation.kind && matchesPattern(rule.pattern, operation.target)) {
67
+ matching.push(rule);
68
+ }
69
+ }
70
+ if (matching.length === 0) {
71
+ return {
72
+ action: policy.defaultAction,
73
+ reason: `No matching rule; default action: ${policy.defaultAction}`,
74
+ };
75
+ }
76
+ // Highest priority wins
77
+ matching.sort((a, b) => b.priority - a.priority);
78
+ const winner = matching[0];
79
+ return {
80
+ action: winner.action,
81
+ matchedRule: winner,
82
+ reason: `Matched rule: ${winner.kind} ${winner.pattern} → ${winner.action} (priority ${winner.priority})`,
83
+ };
84
+ }
85
+ // ---------------------------------------------------------------------------
86
+ // Composition
87
+ // ---------------------------------------------------------------------------
88
+ /**
89
+ * Compose multiple sandbox policies with deny-overrides semantics.
90
+ * Block rules from any policy take precedence. Empty input yields default-deny.
91
+ */
92
+ function composeSandboxPolicies(policies) {
93
+ if (policies.length === 0) {
94
+ return { rules: [], defaultAction: 'block' };
95
+ }
96
+ const allRules = [];
97
+ for (const policy of policies) {
98
+ allRules.push(...policy.rules);
99
+ }
100
+ // Deny-overrides: for rules with the same kind+pattern, if any is 'block', elevate block priority
101
+ const ruleKey = (r) => `${r.kind}::${r.pattern}`;
102
+ const grouped = new Map();
103
+ for (const rule of allRules) {
104
+ const key = ruleKey(rule);
105
+ const group = grouped.get(key) ?? [];
106
+ group.push(rule);
107
+ grouped.set(key, group);
108
+ }
109
+ const mergedRules = [];
110
+ for (const [_key, group] of grouped) {
111
+ const hasBlock = group.some(r => r.action === 'block');
112
+ if (hasBlock) {
113
+ // Find highest-priority block rule, or promote one
114
+ const blockRules = group.filter(r => r.action === 'block');
115
+ const maxPriority = Math.max(...group.map(r => r.priority));
116
+ const bestBlock = blockRules.sort((a, b) => b.priority - a.priority)[0];
117
+ mergedRules.push({ ...bestBlock, priority: Math.max(bestBlock.priority, maxPriority) });
118
+ }
119
+ else {
120
+ // No block — keep highest priority rule
121
+ const best = group.sort((a, b) => b.priority - a.priority)[0];
122
+ mergedRules.push(best);
123
+ }
124
+ }
125
+ // Default action: most restrictive wins
126
+ let defaultAction = 'allow';
127
+ for (const policy of policies) {
128
+ if (policy.defaultAction === 'block') {
129
+ defaultAction = 'block';
130
+ break;
131
+ }
132
+ if (policy.defaultAction === 'prompt') {
133
+ defaultAction = 'prompt';
134
+ }
135
+ }
136
+ return { rules: mergedRules, defaultAction };
137
+ }
138
+ // ---------------------------------------------------------------------------
139
+ // Attenuation
140
+ // ---------------------------------------------------------------------------
141
+ /**
142
+ * Attenuate a parent policy with child constraints.
143
+ * The child can only narrow permissions: block additions are kept,
144
+ * allow rules that conflict with parent blocks are dropped.
145
+ */
146
+ function attenuateSandboxPolicy(parent, childConstraints) {
147
+ const ruleKey = (r) => `${r.kind}::${r.pattern}`;
148
+ // Index parent blocks
149
+ const parentBlocks = new Set();
150
+ for (const rule of parent.rules) {
151
+ if (rule.action === 'block') {
152
+ parentBlocks.add(ruleKey(rule));
153
+ }
154
+ }
155
+ // Start with all parent rules
156
+ const resultRules = [...parent.rules];
157
+ for (const childRule of childConstraints.rules) {
158
+ const key = ruleKey(childRule);
159
+ if (childRule.action === 'allow' && parentBlocks.has(key)) {
160
+ // Child cannot expand parent blocks to allows — skip
161
+ continue;
162
+ }
163
+ if (childRule.action === 'block') {
164
+ // Child can always add or strengthen blocks
165
+ // Check if parent already has this block
166
+ const existing = resultRules.find(r => ruleKey(r) === key && r.action === 'block');
167
+ if (!existing) {
168
+ resultRules.push(childRule);
169
+ }
170
+ else if (childRule.priority > existing.priority) {
171
+ existing.priority = childRule.priority;
172
+ }
173
+ }
174
+ }
175
+ // Apply deny-overrides on the combined set
176
+ return composeSandboxPolicies([{ rules: resultRules, defaultAction: parent.defaultAction }]);
177
+ }
@@ -0,0 +1,3 @@
1
+ export type { PolicyRuleKind, PolicyConditionOp, PolicyAction, PolicyCondition, PolicyRule, StatefulPolicyRule, PolicyEvaluationContext, PolicyDecision, PolicyDecisionLog, PolicyEngine, } from "@a5c-ai/babysitter-sdk";
2
+ export { isStatefulRule } from "@a5c-ai/babysitter-sdk";
3
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/governance/types.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,cAAc,EACd,iBAAiB,EACjB,YAAY,EACZ,eAAe,EACf,UAAU,EACV,kBAAkB,EAClB,uBAAuB,EACvB,cAAc,EACd,iBAAiB,EACjB,YAAY,GACb,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isStatefulRule = void 0;
4
+ var babysitter_sdk_1 = require("@a5c-ai/babysitter-sdk");
5
+ Object.defineProperty(exports, "isStatefulRule", { enumerable: true, get: function () { return babysitter_sdk_1.isStatefulRule; } });