daycare-cli 2026.2.26 → 2026.2.28

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 (402) hide show
  1. package/dist/config/configResolve.d.ts.map +1 -1
  2. package/dist/config/configResolve.js +15 -1
  3. package/dist/config/configResolve.js.map +1 -1
  4. package/dist/config/configResolve.spec.js +47 -0
  5. package/dist/config/configResolve.spec.js.map +1 -1
  6. package/dist/config/configSettingsParse.d.ts.map +1 -1
  7. package/dist/config/configSettingsParse.js +10 -0
  8. package/dist/config/configSettingsParse.js.map +1 -1
  9. package/dist/config/configSettingsParse.spec.js +32 -0
  10. package/dist/config/configSettingsParse.spec.js.map +1 -1
  11. package/dist/config/configTypes.d.ts +2 -1
  12. package/dist/config/configTypes.d.ts.map +1 -1
  13. package/dist/engine/agents/agent.d.ts +2 -0
  14. package/dist/engine/agents/agent.d.ts.map +1 -1
  15. package/dist/engine/agents/agent.js +18 -3
  16. package/dist/engine/agents/agent.js.map +1 -1
  17. package/dist/engine/agents/agentSystem.d.ts +5 -0
  18. package/dist/engine/agents/agentSystem.d.ts.map +1 -1
  19. package/dist/engine/agents/agentSystem.js +16 -1
  20. package/dist/engine/agents/agentSystem.js.map +1 -1
  21. package/dist/engine/agents/agentSystem.spec.js +59 -0
  22. package/dist/engine/agents/agentSystem.spec.js.map +1 -1
  23. package/dist/engine/agents/ops/agentLoopRun.d.ts +0 -2
  24. package/dist/engine/agents/ops/agentLoopRun.d.ts.map +1 -1
  25. package/dist/engine/agents/ops/agentLoopRun.js +4 -7
  26. package/dist/engine/agents/ops/agentLoopRun.js.map +1 -1
  27. package/dist/engine/agents/ops/agentLoopRun.spec.js +21 -24
  28. package/dist/engine/agents/ops/agentLoopRun.spec.js.map +1 -1
  29. package/dist/engine/agents/ops/agentSystemPromptContext.d.ts +1 -1
  30. package/dist/engine/agents/ops/agentSystemPromptContext.d.ts.map +1 -1
  31. package/dist/engine/agents/ops/agentSystemPromptSectionEnvironment.d.ts.map +1 -1
  32. package/dist/engine/agents/ops/agentSystemPromptSectionEnvironment.js +12 -1
  33. package/dist/engine/agents/ops/agentSystemPromptSectionEnvironment.js.map +1 -1
  34. package/dist/engine/agents/ops/agentSystemPromptSectionMemory.d.ts.map +1 -1
  35. package/dist/engine/agents/ops/agentSystemPromptSectionMemory.js +0 -4
  36. package/dist/engine/agents/ops/agentSystemPromptSectionMemory.js.map +1 -1
  37. package/dist/engine/agents/ops/agentSystemPromptSectionPermissions.d.ts +2 -2
  38. package/dist/engine/agents/ops/agentSystemPromptSectionPermissions.d.ts.map +1 -1
  39. package/dist/engine/agents/ops/agentSystemPromptSectionPermissions.js +12 -30
  40. package/dist/engine/agents/ops/agentSystemPromptSectionPermissions.js.map +1 -1
  41. package/dist/engine/apps/appExecute.spec.js +2 -10
  42. package/dist/engine/apps/appExecute.spec.js.map +1 -1
  43. package/dist/engine/apps/appInstallToolBuild.js +1 -1
  44. package/dist/engine/apps/appInstallToolBuild.js.map +1 -1
  45. package/dist/engine/apps/appInstallToolBuild.spec.js +1 -5
  46. package/dist/engine/apps/appInstallToolBuild.spec.js.map +1 -1
  47. package/dist/engine/apps/appRuleToolBuild.spec.js +1 -5
  48. package/dist/engine/apps/appRuleToolBuild.spec.js.map +1 -1
  49. package/dist/engine/apps/appToolExecutorBuild.spec.js +1 -5
  50. package/dist/engine/apps/appToolExecutorBuild.spec.js.map +1 -1
  51. package/dist/engine/engine.d.ts.map +1 -1
  52. package/dist/engine/engine.js +10 -0
  53. package/dist/engine/engine.js.map +1 -1
  54. package/dist/engine/friends/nametagGenerate.d.ts +6 -0
  55. package/dist/engine/friends/nametagGenerate.d.ts.map +1 -0
  56. package/dist/engine/friends/nametagGenerate.js +9 -0
  57. package/dist/engine/friends/nametagGenerate.js.map +1 -0
  58. package/dist/engine/friends/nametagGenerate.spec.d.ts +2 -0
  59. package/dist/engine/friends/nametagGenerate.spec.d.ts.map +1 -0
  60. package/dist/engine/friends/nametagGenerate.spec.js +18 -0
  61. package/dist/engine/friends/nametagGenerate.spec.js.map +1 -0
  62. package/dist/engine/modules/executablePrompts/executablePromptExpand.spec.js +1 -5
  63. package/dist/engine/modules/executablePrompts/executablePromptExpand.spec.js.map +1 -1
  64. package/dist/engine/modules/monty/montyPythonTypeFromSchemaRuntime.spec.js +1 -5
  65. package/dist/engine/modules/monty/montyPythonTypeFromSchemaRuntime.spec.js.map +1 -1
  66. package/dist/engine/modules/rlm/rlmExecute.spec.js +1 -5
  67. package/dist/engine/modules/rlm/rlmExecute.spec.js.map +1 -1
  68. package/dist/engine/modules/rlm/rlmPromptSkills.spec.js +9 -9
  69. package/dist/engine/modules/rlm/rlmPromptSkills.spec.js.map +1 -1
  70. package/dist/engine/modules/rlm/rlmRestore.spec.js +1 -5
  71. package/dist/engine/modules/rlm/rlmRestore.spec.js.map +1 -1
  72. package/dist/engine/modules/rlm/rlmTool.spec.js +1 -5
  73. package/dist/engine/modules/rlm/rlmTool.spec.js.map +1 -1
  74. package/dist/engine/modules/say/sayFileResolve.d.ts +4 -5
  75. package/dist/engine/modules/say/sayFileResolve.d.ts.map +1 -1
  76. package/dist/engine/modules/say/sayFileResolve.js +24 -14
  77. package/dist/engine/modules/say/sayFileResolve.js.map +1 -1
  78. package/dist/engine/modules/say/sayFileResolve.spec.js +28 -29
  79. package/dist/engine/modules/say/sayFileResolve.spec.js.map +1 -1
  80. package/dist/engine/modules/toolResolver.spec.js +1 -5
  81. package/dist/engine/modules/toolResolver.spec.js.map +1 -1
  82. package/dist/engine/modules/tools/agentCompactTool.spec.js +1 -5
  83. package/dist/engine/modules/tools/agentCompactTool.spec.js.map +1 -1
  84. package/dist/engine/modules/tools/agentResetTool.spec.js +1 -5
  85. package/dist/engine/modules/tools/agentResetTool.spec.js.map +1 -1
  86. package/dist/engine/modules/tools/background.spec.js +3 -11
  87. package/dist/engine/modules/tools/background.spec.js.map +1 -1
  88. package/dist/engine/modules/tools/channelCreateTool.spec.js +1 -5
  89. package/dist/engine/modules/tools/channelCreateTool.spec.js.map +1 -1
  90. package/dist/engine/modules/tools/channelHistoryTool.spec.js +1 -5
  91. package/dist/engine/modules/tools/channelHistoryTool.spec.js.map +1 -1
  92. package/dist/engine/modules/tools/channelMemberTool.spec.js +1 -5
  93. package/dist/engine/modules/tools/channelMemberTool.spec.js.map +1 -1
  94. package/dist/engine/modules/tools/channelSendTool.spec.js +1 -5
  95. package/dist/engine/modules/tools/channelSendTool.spec.js.map +1 -1
  96. package/dist/engine/modules/tools/friendAddToolBuild.d.ts +7 -0
  97. package/dist/engine/modules/tools/friendAddToolBuild.d.ts.map +1 -0
  98. package/dist/engine/modules/tools/friendAddToolBuild.js +160 -0
  99. package/dist/engine/modules/tools/friendAddToolBuild.js.map +1 -0
  100. package/dist/engine/modules/tools/friendAddToolBuild.spec.d.ts +2 -0
  101. package/dist/engine/modules/tools/friendAddToolBuild.spec.d.ts.map +1 -0
  102. package/dist/engine/modules/tools/friendAddToolBuild.spec.js +151 -0
  103. package/dist/engine/modules/tools/friendAddToolBuild.spec.js.map +1 -0
  104. package/dist/engine/modules/tools/friendRemoveToolBuild.d.ts +7 -0
  105. package/dist/engine/modules/tools/friendRemoveToolBuild.d.ts.map +1 -0
  106. package/dist/engine/modules/tools/friendRemoveToolBuild.js +171 -0
  107. package/dist/engine/modules/tools/friendRemoveToolBuild.js.map +1 -0
  108. package/dist/engine/modules/tools/friendRemoveToolBuild.spec.d.ts +2 -0
  109. package/dist/engine/modules/tools/friendRemoveToolBuild.spec.d.ts.map +1 -0
  110. package/dist/engine/modules/tools/friendRemoveToolBuild.spec.js +172 -0
  111. package/dist/engine/modules/tools/friendRemoveToolBuild.spec.js.map +1 -0
  112. package/dist/engine/modules/tools/friendSendToolBuild.d.ts +7 -0
  113. package/dist/engine/modules/tools/friendSendToolBuild.d.ts.map +1 -0
  114. package/dist/engine/modules/tools/friendSendToolBuild.js +101 -0
  115. package/dist/engine/modules/tools/friendSendToolBuild.js.map +1 -0
  116. package/dist/engine/modules/tools/friendSendToolBuild.spec.d.ts +2 -0
  117. package/dist/engine/modules/tools/friendSendToolBuild.spec.d.ts.map +1 -0
  118. package/dist/engine/modules/tools/friendSendToolBuild.spec.js +120 -0
  119. package/dist/engine/modules/tools/friendSendToolBuild.spec.js.map +1 -0
  120. package/dist/engine/modules/tools/friendShareSubuserToolBuild.d.ts +7 -0
  121. package/dist/engine/modules/tools/friendShareSubuserToolBuild.d.ts.map +1 -0
  122. package/dist/engine/modules/tools/friendShareSubuserToolBuild.js +127 -0
  123. package/dist/engine/modules/tools/friendShareSubuserToolBuild.js.map +1 -0
  124. package/dist/engine/modules/tools/friendShareSubuserToolBuild.spec.d.ts +2 -0
  125. package/dist/engine/modules/tools/friendShareSubuserToolBuild.spec.d.ts.map +1 -0
  126. package/dist/engine/modules/tools/friendShareSubuserToolBuild.spec.js +119 -0
  127. package/dist/engine/modules/tools/friendShareSubuserToolBuild.spec.js.map +1 -0
  128. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.d.ts +7 -0
  129. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.d.ts.map +1 -0
  130. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.js +115 -0
  131. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.js.map +1 -0
  132. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.spec.d.ts +2 -0
  133. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.spec.d.ts.map +1 -0
  134. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.spec.js +100 -0
  135. package/dist/engine/modules/tools/friendUnshareSubuserToolBuild.spec.js.map +1 -0
  136. package/dist/engine/modules/tools/image-generation.d.ts.map +1 -1
  137. package/dist/engine/modules/tools/image-generation.js +26 -10
  138. package/dist/engine/modules/tools/image-generation.js.map +1 -1
  139. package/dist/engine/modules/tools/image-generation.spec.js +13 -10
  140. package/dist/engine/modules/tools/image-generation.spec.js.map +1 -1
  141. package/dist/engine/modules/tools/mermaid-png.d.ts.map +1 -1
  142. package/dist/engine/modules/tools/mermaid-png.js +16 -11
  143. package/dist/engine/modules/tools/mermaid-png.js.map +1 -1
  144. package/dist/engine/modules/tools/mermaid-png.spec.js +20 -24
  145. package/dist/engine/modules/tools/mermaid-png.spec.js.map +1 -1
  146. package/dist/engine/modules/tools/pdf-process.d.ts.map +1 -1
  147. package/dist/engine/modules/tools/pdf-process.js +10 -38
  148. package/dist/engine/modules/tools/pdf-process.js.map +1 -1
  149. package/dist/engine/modules/tools/pdf-process.spec.js +15 -5
  150. package/dist/engine/modules/tools/pdf-process.spec.js.map +1 -1
  151. package/dist/engine/modules/tools/permanentAgentToolBuild.spec.js +5 -13
  152. package/dist/engine/modules/tools/permanentAgentToolBuild.spec.js.map +1 -1
  153. package/dist/engine/modules/tools/send-file.d.ts.map +1 -1
  154. package/dist/engine/modules/tools/send-file.js +20 -11
  155. package/dist/engine/modules/tools/send-file.js.map +1 -1
  156. package/dist/engine/modules/tools/sendUserMessageTool.spec.js +1 -5
  157. package/dist/engine/modules/tools/sendUserMessageTool.spec.js.map +1 -1
  158. package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js +1 -2
  159. package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js.map +1 -1
  160. package/dist/engine/modules/tools/signal.spec.js +1 -5
  161. package/dist/engine/modules/tools/signal.spec.js.map +1 -1
  162. package/dist/engine/modules/tools/signalEventsCsvToolBuild.spec.js +1 -5
  163. package/dist/engine/modules/tools/signalEventsCsvToolBuild.spec.js.map +1 -1
  164. package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.js +1 -5
  165. package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.js.map +1 -1
  166. package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.js +1 -5
  167. package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.js.map +1 -1
  168. package/dist/engine/modules/tools/skillToolBuild.js +3 -3
  169. package/dist/engine/modules/tools/skillToolBuild.js.map +1 -1
  170. package/dist/engine/modules/tools/skillToolBuild.spec.js +12 -9
  171. package/dist/engine/modules/tools/skillToolBuild.spec.js.map +1 -1
  172. package/dist/engine/modules/tools/subuserConfigureToolBuild.spec.js +1 -2
  173. package/dist/engine/modules/tools/subuserConfigureToolBuild.spec.js.map +1 -1
  174. package/dist/engine/modules/tools/subuserCreateToolBuild.spec.js +1 -2
  175. package/dist/engine/modules/tools/subuserCreateToolBuild.spec.js.map +1 -1
  176. package/dist/engine/modules/tools/subuserListToolBuild.spec.js +1 -2
  177. package/dist/engine/modules/tools/subuserListToolBuild.spec.js.map +1 -1
  178. package/dist/engine/modules/tools/topologyToolBuild.d.ts.map +1 -1
  179. package/dist/engine/modules/tools/topologyToolBuild.js +111 -2
  180. package/dist/engine/modules/tools/topologyToolBuild.js.map +1 -1
  181. package/dist/engine/modules/tools/topologyToolBuild.spec.js +99 -2
  182. package/dist/engine/modules/tools/topologyToolBuild.spec.js.map +1 -1
  183. package/dist/engine/modules/tools/types.d.ts +3 -4
  184. package/dist/engine/modules/tools/types.d.ts.map +1 -1
  185. package/dist/plugins/dashboard/site/404.html +1 -1
  186. package/dist/plugins/dashboard/site/agent.html +1 -1
  187. package/dist/plugins/dashboard/site/agent.txt +1 -1
  188. package/dist/plugins/dashboard/site/agents.html +1 -1
  189. package/dist/plugins/dashboard/site/agents.txt +1 -1
  190. package/dist/plugins/dashboard/site/automations.html +1 -1
  191. package/dist/plugins/dashboard/site/automations.txt +1 -1
  192. package/dist/plugins/dashboard/site/connectors.html +1 -1
  193. package/dist/plugins/dashboard/site/connectors.txt +1 -1
  194. package/dist/plugins/dashboard/site/index.html +1 -1
  195. package/dist/plugins/dashboard/site/index.txt +1 -1
  196. package/dist/plugins/dashboard/site/memory.html +1 -1
  197. package/dist/plugins/dashboard/site/memory.txt +1 -1
  198. package/dist/plugins/dashboard/site/processes.html +1 -1
  199. package/dist/plugins/dashboard/site/processes.txt +1 -1
  200. package/dist/plugins/dashboard/site/providers.html +1 -1
  201. package/dist/plugins/dashboard/site/providers.txt +1 -1
  202. package/dist/plugins/dashboard/site/signals.html +1 -1
  203. package/dist/plugins/dashboard/site/signals.txt +1 -1
  204. package/dist/plugins/dashboard/site/telemetry.html +1 -1
  205. package/dist/plugins/dashboard/site/telemetry.txt +1 -1
  206. package/dist/plugins/dashboard/site/tools.html +1 -1
  207. package/dist/plugins/dashboard/site/tools.txt +1 -1
  208. package/dist/plugins/database/__tests__/plugin.spec.js +4 -2
  209. package/dist/plugins/database/__tests__/plugin.spec.js.map +1 -1
  210. package/dist/plugins/monty-python/tool.spec.js +1 -2
  211. package/dist/plugins/monty-python/tool.spec.js.map +1 -1
  212. package/dist/plugins/shell/processTools.js +1 -1
  213. package/dist/plugins/shell/processTools.js.map +1 -1
  214. package/dist/plugins/shell/processTools.spec.js +2 -3
  215. package/dist/plugins/shell/processTools.spec.js.map +1 -1
  216. package/dist/plugins/shell/tool.d.ts.map +1 -1
  217. package/dist/plugins/shell/tool.js +90 -486
  218. package/dist/plugins/shell/tool.js.map +1 -1
  219. package/dist/plugins/shell/tool.spec.js +11 -20
  220. package/dist/plugins/shell/tool.spec.js.map +1 -1
  221. package/dist/prompts/SYSTEM_ENVIRONMENT.md +6 -0
  222. package/dist/prompts/SYSTEM_MEMORY.md +4 -4
  223. package/dist/prompts/SYSTEM_PERMISSIONS.md +3 -19
  224. package/dist/sandbox/docker/dockerContainerEnsure.d.ts +8 -0
  225. package/dist/sandbox/docker/dockerContainerEnsure.d.ts.map +1 -0
  226. package/dist/sandbox/docker/dockerContainerEnsure.js +56 -0
  227. package/dist/sandbox/docker/dockerContainerEnsure.js.map +1 -0
  228. package/dist/sandbox/docker/dockerContainerEnsure.spec.d.ts +2 -0
  229. package/dist/sandbox/docker/dockerContainerEnsure.spec.d.ts.map +1 -0
  230. package/dist/sandbox/docker/dockerContainerEnsure.spec.js +66 -0
  231. package/dist/sandbox/docker/dockerContainerEnsure.spec.js.map +1 -0
  232. package/dist/sandbox/docker/dockerContainerExec.d.ts +8 -0
  233. package/dist/sandbox/docker/dockerContainerExec.d.ts.map +1 -0
  234. package/dist/sandbox/docker/dockerContainerExec.js +109 -0
  235. package/dist/sandbox/docker/dockerContainerExec.js.map +1 -0
  236. package/dist/sandbox/docker/dockerContainerExec.spec.d.ts +2 -0
  237. package/dist/sandbox/docker/dockerContainerExec.spec.d.ts.map +1 -0
  238. package/dist/sandbox/docker/dockerContainerExec.spec.js +75 -0
  239. package/dist/sandbox/docker/dockerContainerExec.spec.js.map +1 -0
  240. package/dist/sandbox/docker/dockerContainerNameBuild.d.ts +6 -0
  241. package/dist/sandbox/docker/dockerContainerNameBuild.d.ts.map +1 -0
  242. package/dist/sandbox/docker/dockerContainerNameBuild.js +15 -0
  243. package/dist/sandbox/docker/dockerContainerNameBuild.js.map +1 -0
  244. package/dist/sandbox/docker/dockerContainerNameBuild.spec.d.ts +2 -0
  245. package/dist/sandbox/docker/dockerContainerNameBuild.spec.d.ts.map +1 -0
  246. package/dist/sandbox/docker/dockerContainerNameBuild.spec.js +17 -0
  247. package/dist/sandbox/docker/dockerContainerNameBuild.spec.js.map +1 -0
  248. package/dist/sandbox/docker/dockerContainers.d.ts +13 -0
  249. package/dist/sandbox/docker/dockerContainers.d.ts.map +1 -0
  250. package/dist/sandbox/docker/dockerContainers.js +42 -0
  251. package/dist/sandbox/docker/dockerContainers.js.map +1 -0
  252. package/dist/sandbox/docker/dockerContainersShared.d.ts +3 -0
  253. package/dist/sandbox/docker/dockerContainersShared.d.ts.map +1 -0
  254. package/dist/sandbox/docker/dockerContainersShared.js +3 -0
  255. package/dist/sandbox/docker/dockerContainersShared.js.map +1 -0
  256. package/dist/sandbox/docker/dockerRunInSandbox.d.ts +19 -0
  257. package/dist/sandbox/docker/dockerRunInSandbox.d.ts.map +1 -0
  258. package/dist/sandbox/docker/dockerRunInSandbox.integration.spec.d.ts +2 -0
  259. package/dist/sandbox/docker/dockerRunInSandbox.integration.spec.d.ts.map +1 -0
  260. package/dist/sandbox/docker/dockerRunInSandbox.integration.spec.js +143 -0
  261. package/dist/sandbox/docker/dockerRunInSandbox.integration.spec.js.map +1 -0
  262. package/dist/sandbox/docker/dockerRunInSandbox.js +117 -0
  263. package/dist/sandbox/docker/dockerRunInSandbox.js.map +1 -0
  264. package/dist/sandbox/docker/dockerRunInSandbox.spec.d.ts +2 -0
  265. package/dist/sandbox/docker/dockerRunInSandbox.spec.d.ts.map +1 -0
  266. package/dist/sandbox/docker/dockerRunInSandbox.spec.js +127 -0
  267. package/dist/sandbox/docker/dockerRunInSandbox.spec.js.map +1 -0
  268. package/dist/sandbox/docker/dockerTypes.d.ts +23 -0
  269. package/dist/sandbox/docker/dockerTypes.d.ts.map +1 -0
  270. package/dist/sandbox/docker/dockerTypes.js +2 -0
  271. package/dist/sandbox/docker/dockerTypes.js.map +1 -0
  272. package/dist/sandbox/sandbox.d.ts +28 -0
  273. package/dist/sandbox/sandbox.d.ts.map +1 -0
  274. package/dist/sandbox/sandbox.js +499 -0
  275. package/dist/sandbox/sandbox.js.map +1 -0
  276. package/dist/sandbox/sandbox.spec.d.ts +2 -0
  277. package/dist/sandbox/sandbox.spec.d.ts.map +1 -0
  278. package/dist/sandbox/sandbox.spec.js +167 -0
  279. package/dist/sandbox/sandbox.spec.js.map +1 -0
  280. package/dist/sandbox/sandboxCanRead.d.ts.map +1 -1
  281. package/dist/sandbox/sandboxCanRead.js +6 -6
  282. package/dist/sandbox/sandboxCanRead.js.map +1 -1
  283. package/dist/sandbox/sandboxCanRead.spec.js +15 -7
  284. package/dist/sandbox/sandboxCanRead.spec.js.map +1 -1
  285. package/dist/sandbox/sandboxCanWrite.d.ts.map +1 -1
  286. package/dist/sandbox/sandboxCanWrite.js +25 -0
  287. package/dist/sandbox/sandboxCanWrite.js.map +1 -1
  288. package/dist/sandbox/sandboxCanWrite.spec.js +6 -1
  289. package/dist/sandbox/sandboxCanWrite.spec.js.map +1 -1
  290. package/dist/sandbox/sandboxDocker.spec.d.ts +2 -0
  291. package/dist/sandbox/sandboxDocker.spec.d.ts.map +1 -0
  292. package/dist/sandbox/sandboxDocker.spec.js +121 -0
  293. package/dist/sandbox/sandboxDocker.spec.js.map +1 -0
  294. package/dist/sandbox/sandboxFilesystemPolicyBuild.d.ts +1 -1
  295. package/dist/sandbox/sandboxFilesystemPolicyBuild.d.ts.map +1 -1
  296. package/dist/sandbox/sandboxFilesystemPolicyBuild.js +14 -6
  297. package/dist/sandbox/sandboxFilesystemPolicyBuild.js.map +1 -1
  298. package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.js +7 -2
  299. package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.js.map +1 -1
  300. package/dist/sandbox/sandboxPathContainerToHost.d.ts +6 -0
  301. package/dist/sandbox/sandboxPathContainerToHost.d.ts.map +1 -0
  302. package/dist/sandbox/sandboxPathContainerToHost.js +24 -0
  303. package/dist/sandbox/sandboxPathContainerToHost.js.map +1 -0
  304. package/dist/sandbox/sandboxPathContainerToHost.spec.d.ts +2 -0
  305. package/dist/sandbox/sandboxPathContainerToHost.spec.d.ts.map +1 -0
  306. package/dist/sandbox/sandboxPathContainerToHost.spec.js +25 -0
  307. package/dist/sandbox/sandboxPathContainerToHost.spec.js.map +1 -0
  308. package/dist/sandbox/sandboxPathHostToContainer.d.ts +6 -0
  309. package/dist/sandbox/sandboxPathHostToContainer.d.ts.map +1 -0
  310. package/dist/sandbox/sandboxPathHostToContainer.js +23 -0
  311. package/dist/sandbox/sandboxPathHostToContainer.js.map +1 -0
  312. package/dist/sandbox/sandboxPathHostToContainer.spec.d.ts +2 -0
  313. package/dist/sandbox/sandboxPathHostToContainer.spec.d.ts.map +1 -0
  314. package/dist/sandbox/sandboxPathHostToContainer.spec.js +32 -0
  315. package/dist/sandbox/sandboxPathHostToContainer.spec.js.map +1 -0
  316. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.d.ts +11 -0
  317. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.d.ts.map +1 -0
  318. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.js +20 -0
  319. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.js.map +1 -0
  320. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.spec.d.ts +2 -0
  321. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.spec.d.ts.map +1 -0
  322. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.spec.js +20 -0
  323. package/dist/sandbox/sandboxReadBoundaryDenyPathsBuild.spec.js.map +1 -0
  324. package/dist/sandbox/sandboxReadDenyPathsBuild.d.ts +13 -0
  325. package/dist/sandbox/sandboxReadDenyPathsBuild.d.ts.map +1 -0
  326. package/dist/sandbox/sandboxReadDenyPathsBuild.js +28 -0
  327. package/dist/sandbox/sandboxReadDenyPathsBuild.js.map +1 -0
  328. package/dist/sandbox/sandboxReadDenyPathsBuild.spec.d.ts +2 -0
  329. package/dist/sandbox/sandboxReadDenyPathsBuild.spec.d.ts.map +1 -0
  330. package/dist/sandbox/sandboxReadDenyPathsBuild.spec.js +29 -0
  331. package/dist/sandbox/sandboxReadDenyPathsBuild.spec.js.map +1 -0
  332. package/dist/sandbox/sandboxTypes.d.ts +76 -0
  333. package/dist/sandbox/sandboxTypes.d.ts.map +1 -0
  334. package/dist/sandbox/sandboxTypes.js +2 -0
  335. package/dist/sandbox/sandboxTypes.js.map +1 -0
  336. package/dist/settings.d.ts +17 -1
  337. package/dist/settings.d.ts.map +1 -1
  338. package/dist/settings.js.map +1 -1
  339. package/dist/skills/daycare-friendship/SKILL.md +295 -0
  340. package/dist/skills/skills/daycare-friendship/SKILL.md +295 -0
  341. package/dist/storage/agentsRepository.d.ts +1 -0
  342. package/dist/storage/agentsRepository.d.ts.map +1 -1
  343. package/dist/storage/agentsRepository.js +16 -0
  344. package/dist/storage/agentsRepository.js.map +1 -1
  345. package/dist/storage/agentsRepository.spec.js +45 -0
  346. package/dist/storage/agentsRepository.spec.js.map +1 -1
  347. package/dist/storage/connectionsRepository.d.ts +18 -0
  348. package/dist/storage/connectionsRepository.d.ts.map +1 -0
  349. package/dist/storage/connectionsRepository.js +163 -0
  350. package/dist/storage/connectionsRepository.js.map +1 -0
  351. package/dist/storage/connectionsRepository.spec.d.ts +2 -0
  352. package/dist/storage/connectionsRepository.spec.d.ts.map +1 -0
  353. package/dist/storage/connectionsRepository.spec.js +115 -0
  354. package/dist/storage/connectionsRepository.spec.js.map +1 -0
  355. package/dist/storage/databaseTypes.d.ts +19 -0
  356. package/dist/storage/databaseTypes.d.ts.map +1 -1
  357. package/dist/storage/migrations/20260222_add_usertag_connections.d.ts +7 -0
  358. package/dist/storage/migrations/20260222_add_usertag_connections.d.ts.map +1 -0
  359. package/dist/storage/migrations/20260222_add_usertag_connections.js +32 -0
  360. package/dist/storage/migrations/20260222_add_usertag_connections.js.map +1 -0
  361. package/dist/storage/migrations/20260222_add_usertag_connections.spec.d.ts +2 -0
  362. package/dist/storage/migrations/20260222_add_usertag_connections.spec.d.ts.map +1 -0
  363. package/dist/storage/migrations/20260222_add_usertag_connections.spec.js +55 -0
  364. package/dist/storage/migrations/20260222_add_usertag_connections.spec.js.map +1 -0
  365. package/dist/storage/migrations/20260225_require_usertag.d.ts +7 -0
  366. package/dist/storage/migrations/20260225_require_usertag.d.ts.map +1 -0
  367. package/dist/storage/migrations/20260225_require_usertag.js +60 -0
  368. package/dist/storage/migrations/20260225_require_usertag.js.map +1 -0
  369. package/dist/storage/migrations/20260225_require_usertag.spec.d.ts +2 -0
  370. package/dist/storage/migrations/20260225_require_usertag.spec.d.ts.map +1 -0
  371. package/dist/storage/migrations/20260225_require_usertag.spec.js +70 -0
  372. package/dist/storage/migrations/20260225_require_usertag.spec.js.map +1 -0
  373. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.d.ts +7 -0
  374. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.d.ts.map +1 -0
  375. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.js +47 -0
  376. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.js.map +1 -0
  377. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.spec.d.ts +2 -0
  378. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.spec.d.ts.map +1 -0
  379. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.spec.js +59 -0
  380. package/dist/storage/migrations/20260226_rename_usertag_to_nametag.spec.js.map +1 -0
  381. package/dist/storage/migrations/_migrations.d.ts.map +1 -1
  382. package/dist/storage/migrations/_migrations.js +7 -1
  383. package/dist/storage/migrations/_migrations.js.map +1 -1
  384. package/dist/storage/storage.d.ts +3 -0
  385. package/dist/storage/storage.d.ts.map +1 -1
  386. package/dist/storage/storage.js +35 -3
  387. package/dist/storage/storage.js.map +1 -1
  388. package/dist/storage/storage.spec.js +1 -0
  389. package/dist/storage/storage.spec.js.map +1 -1
  390. package/dist/storage/usersRepository.d.ts +2 -0
  391. package/dist/storage/usersRepository.d.ts.map +1 -1
  392. package/dist/storage/usersRepository.js +63 -3
  393. package/dist/storage/usersRepository.js.map +1 -1
  394. package/dist/storage/usersRepository.spec.js +9 -2
  395. package/dist/storage/usersRepository.spec.js.map +1 -1
  396. package/dist/types.d.ts +2 -0
  397. package/dist/types.d.ts.map +1 -1
  398. package/dist/types.js +2 -0
  399. package/dist/types.js.map +1 -1
  400. package/package.json +6 -3
  401. /package/dist/plugins/dashboard/site/_next/static/{X_oqQhoSTmj1_qmNPx-r5 → fEfvfa55gmpjx9cT66rjx}/_buildManifest.js +0 -0
  402. /package/dist/plugins/dashboard/site/_next/static/{X_oqQhoSTmj1_qmNPx-r5 → fEfvfa55gmpjx9cT66rjx}/_ssgManifest.js +0 -0
@@ -0,0 +1,75 @@
1
+ import { PassThrough } from "node:stream";
2
+ import { describe, expect, it, vi } from "vitest";
3
+ import { dockerContainerExec } from "./dockerContainerExec.js";
4
+ describe("dockerContainerExec", () => {
5
+ it("executes command and returns stdout/stderr with exit code", async () => {
6
+ const stream = new PassThrough();
7
+ const execHandle = {
8
+ start: vi.fn().mockImplementation(async () => {
9
+ setTimeout(() => {
10
+ stream.end();
11
+ }, 0);
12
+ return stream;
13
+ }),
14
+ inspect: vi.fn().mockResolvedValue({ ExitCode: 7 })
15
+ };
16
+ const container = {
17
+ exec: vi.fn().mockResolvedValue(execHandle)
18
+ };
19
+ const docker = {
20
+ modem: {
21
+ demuxStream: vi.fn((_stream, stdout, stderr) => {
22
+ stdout.write("hello");
23
+ stderr.write("warn");
24
+ })
25
+ }
26
+ };
27
+ const result = await dockerContainerExec(docker, container, {
28
+ command: ["echo", "ok"],
29
+ cwd: "/home",
30
+ env: {
31
+ HOME: "/home",
32
+ DEBUG: "1"
33
+ }
34
+ });
35
+ expect(container.exec).toHaveBeenCalledWith({
36
+ Cmd: ["echo", "ok"],
37
+ AttachStdout: true,
38
+ AttachStderr: true,
39
+ WorkingDir: "/home",
40
+ Env: ["HOME=/home", "DEBUG=1"]
41
+ });
42
+ expect(result).toEqual({
43
+ stdout: "hello",
44
+ stderr: "warn",
45
+ exitCode: 7
46
+ });
47
+ });
48
+ it("fails when output exceeds max buffer", async () => {
49
+ const stream = new PassThrough();
50
+ const execHandle = {
51
+ start: vi.fn().mockImplementation(async () => {
52
+ setTimeout(() => {
53
+ stream.end();
54
+ }, 0);
55
+ return stream;
56
+ }),
57
+ inspect: vi.fn().mockResolvedValue({ ExitCode: 0 })
58
+ };
59
+ const container = {
60
+ exec: vi.fn().mockResolvedValue(execHandle)
61
+ };
62
+ const docker = {
63
+ modem: {
64
+ demuxStream: vi.fn((_stream, stdout) => {
65
+ stdout.write("12345");
66
+ })
67
+ }
68
+ };
69
+ await expect(dockerContainerExec(docker, container, {
70
+ command: ["echo", "ok"],
71
+ maxBufferBytes: 3
72
+ })).rejects.toThrow("maxBufferBytes");
73
+ });
74
+ });
75
+ //# sourceMappingURL=dockerContainerExec.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainerExec.spec.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainerExec.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Builds a stable Docker container name for a sandbox user.
3
+ * Expects: userId is stable across the user's agent sessions.
4
+ */
5
+ export declare function dockerContainerNameBuild(userId: string): string;
6
+ //# sourceMappingURL=dockerContainerNameBuild.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainerNameBuild.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainerNameBuild.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAS/D"}
@@ -0,0 +1,15 @@
1
+ const DEFAULT_CONTAINER_SUFFIX = "user";
2
+ /**
3
+ * Builds a stable Docker container name for a sandbox user.
4
+ * Expects: userId is stable across the user's agent sessions.
5
+ */
6
+ export function dockerContainerNameBuild(userId) {
7
+ const suffix = userId
8
+ .toLowerCase()
9
+ .replace(/[^a-z0-9]+/g, "-")
10
+ .replace(/^-+/, "")
11
+ .replace(/-+$/, "");
12
+ const safeSuffix = suffix.length > 0 ? suffix : DEFAULT_CONTAINER_SUFFIX;
13
+ return `daycare-sandbox-${safeSuffix}`;
14
+ }
15
+ //# sourceMappingURL=dockerContainerNameBuild.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainerNameBuild.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainerNameBuild.ts"],"names":[],"mappings":"AAAA,MAAM,wBAAwB,GAAG,MAAM,CAAC;AAExC;;;GAGG;AACH,MAAM,UAAU,wBAAwB,CAAC,MAAc;IACnD,MAAM,MAAM,GAAG,MAAM;SAChB,WAAW,EAAE;SACb,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC;SAC3B,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;SAClB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAExB,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,wBAAwB,CAAC;IACzE,OAAO,mBAAmB,UAAU,EAAE,CAAC;AAC3C,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=dockerContainerNameBuild.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainerNameBuild.spec.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainerNameBuild.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,17 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { dockerContainerNameBuild } from "./dockerContainerNameBuild.js";
3
+ describe("dockerContainerNameBuild", () => {
4
+ it("creates a docker-safe container name from user id", () => {
5
+ const name = dockerContainerNameBuild("User_42");
6
+ expect(name).toBe("daycare-sandbox-user-42");
7
+ });
8
+ it("trims non-alphanumeric boundaries", () => {
9
+ const name = dockerContainerNameBuild("---user---");
10
+ expect(name).toBe("daycare-sandbox-user");
11
+ });
12
+ it("falls back when user id has no safe characters", () => {
13
+ const name = dockerContainerNameBuild("---");
14
+ expect(name).toBe("daycare-sandbox-user");
15
+ });
16
+ });
17
+ //# sourceMappingURL=dockerContainerNameBuild.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainerNameBuild.spec.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainerNameBuild.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAEzE,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACtC,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QACzD,MAAM,IAAI,GAAG,wBAAwB,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QACzC,MAAM,IAAI,GAAG,wBAAwB,CAAC,YAAY,CAAC,CAAC;QACpD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACtD,MAAM,IAAI,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { DockerContainerConfig, DockerContainerExecArgs, DockerContainerExecResult } from "./dockerTypes.js";
2
+ /**
3
+ * Facade for per-user long-lived Docker sandbox containers.
4
+ * Expects: callers pass stable userId + hostHomeDir for each execution.
5
+ */
6
+ export declare class DockerContainers {
7
+ private readonly clientsBySocket;
8
+ private readonly ensureInFlight;
9
+ exec(config: DockerContainerConfig, args: DockerContainerExecArgs): Promise<DockerContainerExecResult>;
10
+ private dockerClientResolve;
11
+ private containerEnsure;
12
+ }
13
+ //# sourceMappingURL=dockerContainers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainers.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainers.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAER,qBAAqB,EACrB,uBAAuB,EACvB,yBAAyB,EAC5B,MAAM,kBAAkB,CAAC;AAE1B;;;GAGG;AACH,qBAAa,gBAAgB;IACzB,OAAO,CAAC,QAAQ,CAAC,eAAe,CAA6B;IAC7D,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA+C;IAExE,IAAI,CAAC,MAAM,EAAE,qBAAqB,EAAE,IAAI,EAAE,uBAAuB,GAAG,OAAO,CAAC,yBAAyB,CAAC;IAM5G,OAAO,CAAC,mBAAmB;YAYb,eAAe;CAgBhC"}
@@ -0,0 +1,42 @@
1
+ import Docker from "dockerode";
2
+ import { dockerContainerEnsure } from "./dockerContainerEnsure.js";
3
+ import { dockerContainerExec } from "./dockerContainerExec.js";
4
+ /**
5
+ * Facade for per-user long-lived Docker sandbox containers.
6
+ * Expects: callers pass stable userId + hostHomeDir for each execution.
7
+ */
8
+ export class DockerContainers {
9
+ clientsBySocket = new Map();
10
+ ensureInFlight = new Map();
11
+ async exec(config, args) {
12
+ const docker = this.dockerClientResolve(config.socketPath);
13
+ const container = await this.containerEnsure(docker, config);
14
+ return dockerContainerExec(docker, container, args);
15
+ }
16
+ dockerClientResolve(socketPath) {
17
+ const key = socketPath ?? "default";
18
+ const cached = this.clientsBySocket.get(key);
19
+ if (cached) {
20
+ return cached;
21
+ }
22
+ const docker = socketPath ? new Docker({ socketPath }) : new Docker();
23
+ this.clientsBySocket.set(key, docker);
24
+ return docker;
25
+ }
26
+ async containerEnsure(docker, config) {
27
+ const key = `${config.socketPath ?? "default"}:${config.userId}`;
28
+ const pending = this.ensureInFlight.get(key);
29
+ if (pending) {
30
+ return pending;
31
+ }
32
+ const operation = dockerContainerEnsure(docker, config);
33
+ this.ensureInFlight.set(key, operation);
34
+ try {
35
+ return await operation;
36
+ }
37
+ finally {
38
+ this.ensureInFlight.delete(key);
39
+ }
40
+ }
41
+ }
42
+ //# sourceMappingURL=dockerContainers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainers.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainers.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,WAAW,CAAC;AAE/B,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAQ/D;;;GAGG;AACH,MAAM,OAAO,gBAAgB;IACR,eAAe,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC5C,cAAc,GAAG,IAAI,GAAG,EAAoC,CAAC;IAE9E,KAAK,CAAC,IAAI,CAAC,MAA6B,EAAE,IAA6B;QACnE,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC3D,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAC7D,OAAO,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAEO,mBAAmB,CAAC,UAAmB;QAC3C,MAAM,GAAG,GAAG,UAAU,IAAI,SAAS,CAAC;QACpC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC7C,IAAI,MAAM,EAAE,CAAC;YACT,OAAO,MAAM,CAAC;QAClB,CAAC;QAED,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC;QACtE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACtC,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,KAAK,CAAC,eAAe,CAAC,MAAc,EAAE,MAA6B;QACvE,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,UAAU,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC7C,IAAI,OAAO,EAAE,CAAC;YACV,OAAO,OAAO,CAAC;QACnB,CAAC;QAED,MAAM,SAAS,GAAG,qBAAqB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACxD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAExC,IAAI,CAAC;YACD,OAAO,MAAM,SAAS,CAAC;QAC3B,CAAC;gBAAS,CAAC;YACP,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;IACL,CAAC;CACJ"}
@@ -0,0 +1,3 @@
1
+ import { DockerContainers } from "./dockerContainers.js";
2
+ export declare const dockerContainersShared: DockerContainers;
3
+ //# sourceMappingURL=dockerContainersShared.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainersShared.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainersShared.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,eAAO,MAAM,sBAAsB,kBAAyB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { DockerContainers } from "./dockerContainers.js";
2
+ export const dockerContainersShared = new DockerContainers();
3
+ //# sourceMappingURL=dockerContainersShared.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerContainersShared.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerContainersShared.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,MAAM,CAAC,MAAM,sBAAsB,GAAG,IAAI,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { SandboxRuntimeConfig } from "@anthropic-ai/sandbox-runtime";
2
+ import type { DockerContainerConfig } from "./dockerTypes.js";
3
+ export type DockerRunInSandboxOptions = {
4
+ cwd?: string;
5
+ env?: NodeJS.ProcessEnv;
6
+ home: string;
7
+ timeoutMs?: number;
8
+ maxBufferBytes?: number;
9
+ docker: Omit<DockerContainerConfig, "hostHomeDir">;
10
+ };
11
+ /**
12
+ * Runs sandbox-runtime inside a per-user Docker container.
13
+ * Expects: docker image is local and options.home is mounted to /home/<userId>.
14
+ */
15
+ export declare function dockerRunInSandbox(command: string, config: SandboxRuntimeConfig, options: DockerRunInSandboxOptions): Promise<{
16
+ stdout: string;
17
+ stderr: string;
18
+ }>;
19
+ //# sourceMappingURL=dockerRunInSandbox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerRunInSandbox.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerRunInSandbox.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAO1E,OAAO,KAAK,EAAE,qBAAqB,EAA6B,MAAM,kBAAkB,CAAC;AAMzF,MAAM,MAAM,yBAAyB,GAAG;IACpC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,IAAI,CAAC,qBAAqB,EAAE,aAAa,CAAC,CAAC;CACtD,CAAC;AAEF;;;GAGG;AACH,wBAAsB,kBAAkB,CACpC,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,oBAAoB,EAC5B,OAAO,EAAE,yBAAyB,GACnC,OAAO,CAAC;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,CAmE7C"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=dockerRunInSandbox.integration.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerRunInSandbox.integration.spec.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerRunInSandbox.integration.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,143 @@
1
+ import { execSync } from "node:child_process";
2
+ import { promises as fs } from "node:fs";
3
+ import os from "node:os";
4
+ import path from "node:path";
5
+ import { afterEach, beforeEach, describe, expect, it } from "vitest";
6
+ import { DockerContainers } from "./dockerContainers.js";
7
+ const IMAGE = "daycare-runtime";
8
+ const TAG = "latest";
9
+ /** Returns true when Docker is reachable and daycare-runtime:latest exists locally. */
10
+ function dockerAvailable() {
11
+ try {
12
+ const output = execSync(`docker image inspect ${IMAGE}:${TAG}`, {
13
+ stdio: ["pipe", "pipe", "pipe"],
14
+ timeout: 5000
15
+ });
16
+ return output.length > 0;
17
+ }
18
+ catch {
19
+ return false;
20
+ }
21
+ }
22
+ const describeIfDocker = process.env.CI || !dockerAvailable() ? describe.skip : describe;
23
+ describeIfDocker("dockerRunInSandbox integration (live Docker)", () => {
24
+ const userId = `test-${process.pid}`;
25
+ let rootDir;
26
+ let homeDir;
27
+ let containers;
28
+ let config;
29
+ beforeEach(async () => {
30
+ rootDir = await fs.mkdtemp(path.join(os.tmpdir(), "daycare-docker-integration-"));
31
+ homeDir = path.join(rootDir, "home");
32
+ await fs.mkdir(homeDir, { recursive: true });
33
+ containers = new DockerContainers();
34
+ config = {
35
+ image: IMAGE,
36
+ tag: TAG,
37
+ userId,
38
+ hostHomeDir: homeDir
39
+ };
40
+ });
41
+ afterEach(async () => {
42
+ // Stop and remove the test container
43
+ try {
44
+ execSync(`docker rm -f daycare-sandbox-${userId}`, {
45
+ stdio: ["pipe", "pipe", "pipe"],
46
+ timeout: 10_000
47
+ });
48
+ }
49
+ catch {
50
+ // Container may not exist
51
+ }
52
+ await fs.rm(rootDir, { recursive: true, force: true });
53
+ });
54
+ it("runs a simple command and returns stdout", async () => {
55
+ const result = await containers.exec(config, {
56
+ command: ["echo", "hello from docker"],
57
+ timeoutMs: 30_000
58
+ });
59
+ expect(result.exitCode).toBe(0);
60
+ expect(result.stdout.trim()).toBe("hello from docker");
61
+ });
62
+ it("returns non-zero exit code for failing commands", async () => {
63
+ const result = await containers.exec(config, {
64
+ command: ["sh", "-c", "exit 42"],
65
+ timeoutMs: 10_000
66
+ });
67
+ expect(result.exitCode).toBe(42);
68
+ });
69
+ it("captures stderr from commands", async () => {
70
+ const result = await containers.exec(config, {
71
+ command: ["sh", "-c", "echo err >&2"],
72
+ timeoutMs: 10_000
73
+ });
74
+ expect(result.stderr.trim()).toBe("err");
75
+ });
76
+ // nvm is sourced via /etc/profile — use login shell for node commands
77
+ it("runs node inside the container", async () => {
78
+ const result = await containers.exec(config, {
79
+ command: ["bash", "-lc", "node -e \"console.log(JSON.stringify({v: process.version, ok: true}))\""],
80
+ timeoutMs: 30_000
81
+ });
82
+ expect(result.exitCode).toBe(0);
83
+ const parsed = JSON.parse(result.stdout.trim());
84
+ expect(parsed.ok).toBe(true);
85
+ expect(parsed.v).toMatch(/^v\d+/);
86
+ });
87
+ it("can resolve sandbox-runtime CLI path", async () => {
88
+ // sandbox-runtime is installed globally — resolve from nvm's global node_modules
89
+ const result = await containers.exec(config, {
90
+ command: [
91
+ "bash",
92
+ "-lc",
93
+ "node -e \"console.log(require.resolve('@anthropic-ai/sandbox-runtime/dist/cli.js'))\""
94
+ ],
95
+ timeoutMs: 30_000
96
+ });
97
+ if (result.exitCode !== 0) {
98
+ // May fail if sandbox-runtime isn't globally installed in this image build
99
+ expect(result.stderr).toContain("MODULE_NOT_FOUND");
100
+ return;
101
+ }
102
+ expect(result.stdout.trim()).toMatch(/cli\.js$/);
103
+ });
104
+ it("mounts host home directory into container", async () => {
105
+ const marker = `marker-${Date.now()}`;
106
+ await fs.writeFile(path.join(homeDir, "test.txt"), marker, "utf8");
107
+ const result = await containers.exec(config, {
108
+ command: ["cat", "/home/test.txt"],
109
+ timeoutMs: 10_000
110
+ });
111
+ expect(result.exitCode).toBe(0);
112
+ expect(result.stdout.trim()).toBe(marker);
113
+ });
114
+ it("writes from container are visible on host", async () => {
115
+ await containers.exec(config, {
116
+ command: ["sh", "-c", "echo written-by-container > /home/output.txt"],
117
+ timeoutMs: 10_000
118
+ });
119
+ const content = await fs.readFile(path.join(homeDir, "output.txt"), "utf8");
120
+ expect(content.trim()).toBe("written-by-container");
121
+ });
122
+ it("respects cwd option", async () => {
123
+ const subDir = path.join(homeDir, "subdir");
124
+ await fs.mkdir(subDir, { recursive: true });
125
+ const result = await containers.exec(config, {
126
+ command: ["pwd"],
127
+ cwd: "/home/subdir",
128
+ timeoutMs: 10_000
129
+ });
130
+ expect(result.exitCode).toBe(0);
131
+ expect(result.stdout.trim()).toBe("/home/subdir");
132
+ });
133
+ it("passes environment variables to the container", async () => {
134
+ const result = await containers.exec(config, {
135
+ command: ["sh", "-c", "echo $DAYCARE_TEST_VAR"],
136
+ env: { DAYCARE_TEST_VAR: "hello-env" },
137
+ timeoutMs: 10_000
138
+ });
139
+ expect(result.exitCode).toBe(0);
140
+ expect(result.stdout.trim()).toBe("hello-env");
141
+ });
142
+ });
143
+ //# sourceMappingURL=dockerRunInSandbox.integration.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerRunInSandbox.integration.spec.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerRunInSandbox.integration.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,117 @@
1
+ import { promises as fs } from "node:fs";
2
+ import path from "node:path";
3
+ import { getLogger } from "../../log.js";
4
+ import { shellQuote } from "../../util/shellQuote.js";
5
+ import { sandboxHomeRedefine } from "../sandboxHomeRedefine.js";
6
+ import { sandboxPathHostToContainer } from "../sandboxPathHostToContainer.js";
7
+ import { dockerContainersShared } from "./dockerContainersShared.js";
8
+ const logger = getLogger("sandbox.docker");
9
+ const DEFAULT_TIMEOUT_MS = 30_000;
10
+ const DEFAULT_MAX_BUFFER_BYTES = 1_000_000;
11
+ /**
12
+ * Runs sandbox-runtime inside a per-user Docker container.
13
+ * Expects: docker image is local and options.home is mounted to /home/<userId>.
14
+ */
15
+ export async function dockerRunInSandbox(command, config, options) {
16
+ const hostHomeDir = path.resolve(options.home);
17
+ const dockerConfig = {
18
+ ...options.docker,
19
+ hostHomeDir
20
+ };
21
+ const runtimeConfig = runtimeConfigPathRewrite(config, hostHomeDir, options.docker.userId);
22
+ const settingsHostPath = path.join(hostHomeDir, ".tmp", `daycare-srt-${process.pid}-${Date.now()}-${Math.random().toString(36).slice(2)}.json`);
23
+ const { env } = await sandboxHomeRedefine({
24
+ env: options.env ?? process.env,
25
+ home: hostHomeDir
26
+ });
27
+ const containerEnv = envPathRewrite(env, hostHomeDir, options.docker.userId);
28
+ const containerCwd = options.cwd
29
+ ? sandboxPathHostToContainer(hostHomeDir, options.docker.userId, options.cwd)
30
+ : undefined;
31
+ const settingsContainerPath = sandboxPathHostToContainer(hostHomeDir, options.docker.userId, settingsHostPath);
32
+ await fs.mkdir(path.dirname(settingsHostPath), { recursive: true });
33
+ await fs.writeFile(settingsHostPath, JSON.stringify(runtimeConfig), "utf8");
34
+ try {
35
+ logger.debug(`exec: resolving sandbox-runtime CLI path in container`);
36
+ const cliResolveResult = await dockerContainersShared.exec(dockerConfig, {
37
+ command: [
38
+ "bash",
39
+ "-lc",
40
+ "node -p \"require.resolve('@anthropic-ai/sandbox-runtime/dist/cli.js')\""
41
+ ],
42
+ cwd: containerCwd,
43
+ env: containerEnv,
44
+ timeoutMs: options.timeoutMs ?? DEFAULT_TIMEOUT_MS,
45
+ maxBufferBytes: options.maxBufferBytes ?? DEFAULT_MAX_BUFFER_BYTES
46
+ });
47
+ const srtCliPath = cliPathResolveFromResult(cliResolveResult);
48
+ logger.debug(`exec: resolved CLI path=${srtCliPath} cwd=${containerCwd} command=${JSON.stringify(command)}`);
49
+ const result = await dockerContainersShared.exec(dockerConfig, {
50
+ command: ["bash", "-lc", `node ${srtCliPath} --settings ${settingsContainerPath} -c ${shellQuote(command)}`],
51
+ cwd: containerCwd,
52
+ env: containerEnv,
53
+ timeoutMs: options.timeoutMs ?? DEFAULT_TIMEOUT_MS,
54
+ maxBufferBytes: options.maxBufferBytes ?? DEFAULT_MAX_BUFFER_BYTES
55
+ });
56
+ logger.debug(`exec: completed exitCode=${result.exitCode}`);
57
+ if (result.exitCode !== 0) {
58
+ logger.warn(`exec: non-zero exit exitCode=${result.exitCode}` +
59
+ (result.stderr ? ` stderr=${result.stderr.slice(0, 500)}` : ""));
60
+ throw dockerExecErrorBuild(result);
61
+ }
62
+ return {
63
+ stdout: result.stdout,
64
+ stderr: result.stderr
65
+ };
66
+ }
67
+ finally {
68
+ await fs.rm(settingsHostPath, { force: true });
69
+ }
70
+ }
71
+ function runtimeConfigPathRewrite(config, hostHomeDir, userId) {
72
+ if (!config.filesystem) {
73
+ return config;
74
+ }
75
+ return {
76
+ ...config,
77
+ filesystem: {
78
+ ...config.filesystem,
79
+ allowWrite: config.filesystem.allowWrite.map((entry) => sandboxPathHostToContainer(hostHomeDir, userId, entry)),
80
+ denyRead: config.filesystem.denyRead.map((entry) => sandboxPathHostToContainer(hostHomeDir, userId, entry)),
81
+ denyWrite: config.filesystem.denyWrite.map((entry) => sandboxPathHostToContainer(hostHomeDir, userId, entry))
82
+ }
83
+ };
84
+ }
85
+ function envPathRewrite(env, hostHomeDir, userId) {
86
+ const rewritten = {};
87
+ for (const [key, value] of Object.entries(env)) {
88
+ if (value === undefined) {
89
+ continue;
90
+ }
91
+ rewritten[key] = sandboxPathHostToContainer(hostHomeDir, userId, value);
92
+ }
93
+ return rewritten;
94
+ }
95
+ function cliPathResolveFromResult(result) {
96
+ if (result.exitCode !== 0) {
97
+ throw dockerExecErrorBuild(result);
98
+ }
99
+ const lines = result.stdout
100
+ .split(/\r?\n/)
101
+ .map((line) => line.trim())
102
+ .filter((line) => line.length > 0);
103
+ const cliPath = lines.at(-1);
104
+ if (!cliPath) {
105
+ throw new Error("Failed to resolve sandbox-runtime CLI path inside Docker container.");
106
+ }
107
+ return cliPath;
108
+ }
109
+ function dockerExecErrorBuild(result) {
110
+ const error = new Error(`docker exec failed with code ${result.exitCode ?? "unknown"}`);
111
+ error.stdout = result.stdout;
112
+ error.stderr = result.stderr;
113
+ error.code = result.exitCode;
114
+ error.signal = null;
115
+ return error;
116
+ }
117
+ //# sourceMappingURL=dockerRunInSandbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerRunInSandbox.js","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerRunInSandbox.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=dockerRunInSandbox.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dockerRunInSandbox.spec.d.ts","sourceRoot":"","sources":["../../../sources/sandbox/docker/dockerRunInSandbox.spec.ts"],"names":[],"mappings":""}