@tschmz/imp 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (377) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/LICENSE +201 -0
  3. package/README.md +21 -0
  4. package/config.example.json +143 -0
  5. package/dist/agents/default-system-prompt.d.ts +1 -0
  6. package/dist/agents/default-system-prompt.js +67 -0
  7. package/dist/agents/default-system-prompt.js.map +1 -0
  8. package/dist/agents/registry.d.ts +6 -0
  9. package/dist/agents/registry.js +12 -0
  10. package/dist/agents/registry.js.map +1 -0
  11. package/dist/application/backup-use-cases.d.ts +28 -0
  12. package/dist/application/backup-use-cases.js +571 -0
  13. package/dist/application/backup-use-cases.js.map +1 -0
  14. package/dist/application/commands/agent-command.d.ts +2 -0
  15. package/dist/application/commands/agent-command.js +61 -0
  16. package/dist/application/commands/agent-command.js.map +1 -0
  17. package/dist/application/commands/config-command.d.ts +2 -0
  18. package/dist/application/commands/config-command.js +39 -0
  19. package/dist/application/commands/config-command.js.map +1 -0
  20. package/dist/application/commands/conversation-context.d.ts +6 -0
  21. package/dist/application/commands/conversation-context.js +35 -0
  22. package/dist/application/commands/conversation-context.js.map +1 -0
  23. package/dist/application/commands/export-command.d.ts +2 -0
  24. package/dist/application/commands/export-command.js +25 -0
  25. package/dist/application/commands/export-command.js.map +1 -0
  26. package/dist/application/commands/help-command.d.ts +3 -0
  27. package/dist/application/commands/help-command.js +40 -0
  28. package/dist/application/commands/help-command.js.map +1 -0
  29. package/dist/application/commands/history-command.d.ts +2 -0
  30. package/dist/application/commands/history-command.js +23 -0
  31. package/dist/application/commands/history-command.js.map +1 -0
  32. package/dist/application/commands/logs-command.d.ts +2 -0
  33. package/dist/application/commands/logs-command.js +42 -0
  34. package/dist/application/commands/logs-command.js.map +1 -0
  35. package/dist/application/commands/new-command.d.ts +2 -0
  36. package/dist/application/commands/new-command.js +37 -0
  37. package/dist/application/commands/new-command.js.map +1 -0
  38. package/dist/application/commands/parse-inbound-command.d.ts +15 -0
  39. package/dist/application/commands/parse-inbound-command.js +33 -0
  40. package/dist/application/commands/parse-inbound-command.js.map +1 -0
  41. package/dist/application/commands/ping-command.d.ts +2 -0
  42. package/dist/application/commands/ping-command.js +18 -0
  43. package/dist/application/commands/ping-command.js.map +1 -0
  44. package/dist/application/commands/priority-inbound-commands.d.ts +2 -0
  45. package/dist/application/commands/priority-inbound-commands.js +14 -0
  46. package/dist/application/commands/priority-inbound-commands.js.map +1 -0
  47. package/dist/application/commands/registry.d.ts +7 -0
  48. package/dist/application/commands/registry.js +38 -0
  49. package/dist/application/commands/registry.js.map +1 -0
  50. package/dist/application/commands/reload-command.d.ts +2 -0
  51. package/dist/application/commands/reload-command.js +23 -0
  52. package/dist/application/commands/reload-command.js.map +1 -0
  53. package/dist/application/commands/rename-command.d.ts +2 -0
  54. package/dist/application/commands/rename-command.js +36 -0
  55. package/dist/application/commands/rename-command.js.map +1 -0
  56. package/dist/application/commands/renderers.d.ts +13 -0
  57. package/dist/application/commands/renderers.js +238 -0
  58. package/dist/application/commands/renderers.js.map +1 -0
  59. package/dist/application/commands/reset-command.d.ts +2 -0
  60. package/dist/application/commands/reset-command.js +36 -0
  61. package/dist/application/commands/reset-command.js.map +1 -0
  62. package/dist/application/commands/restart-command.d.ts +2 -0
  63. package/dist/application/commands/restart-command.js +23 -0
  64. package/dist/application/commands/restart-command.js.map +1 -0
  65. package/dist/application/commands/restore-command.d.ts +2 -0
  66. package/dist/application/commands/restore-command.js +52 -0
  67. package/dist/application/commands/restore-command.js.map +1 -0
  68. package/dist/application/commands/status-command.d.ts +2 -0
  69. package/dist/application/commands/status-command.js +24 -0
  70. package/dist/application/commands/status-command.js.map +1 -0
  71. package/dist/application/commands/types.d.ts +49 -0
  72. package/dist/application/commands/types.js +2 -0
  73. package/dist/application/commands/types.js.map +1 -0
  74. package/dist/application/commands/utils.d.ts +4 -0
  75. package/dist/application/commands/utils.js +26 -0
  76. package/dist/application/commands/utils.js.map +1 -0
  77. package/dist/application/commands/whoami-command.d.ts +2 -0
  78. package/dist/application/commands/whoami-command.js +27 -0
  79. package/dist/application/commands/whoami-command.js.map +1 -0
  80. package/dist/application/config-key-path.d.ts +2 -0
  81. package/dist/application/config-key-path.js +65 -0
  82. package/dist/application/config-key-path.js.map +1 -0
  83. package/dist/application/get-config-value-use-case.d.ts +4 -0
  84. package/dist/application/get-config-value-use-case.js +30 -0
  85. package/dist/application/get-config-value-use-case.js.map +1 -0
  86. package/dist/application/handle-incoming-message.d.ts +7 -0
  87. package/dist/application/handle-incoming-message.js +56 -0
  88. package/dist/application/handle-incoming-message.js.map +1 -0
  89. package/dist/application/inbound/dispatch-command.d.ts +2 -0
  90. package/dist/application/inbound/dispatch-command.js +23 -0
  91. package/dist/application/inbound/dispatch-command.js.map +1 -0
  92. package/dist/application/inbound/execute-agent.d.ts +2 -0
  93. package/dist/application/inbound/execute-agent.js +41 -0
  94. package/dist/application/inbound/execute-agent.js.map +1 -0
  95. package/dist/application/inbound/persist-conversation.d.ts +2 -0
  96. package/dist/application/inbound/persist-conversation.js +7 -0
  97. package/dist/application/inbound/persist-conversation.js.map +1 -0
  98. package/dist/application/inbound/resolve-conversation.d.ts +2 -0
  99. package/dist/application/inbound/resolve-conversation.js +19 -0
  100. package/dist/application/inbound/resolve-conversation.js.map +1 -0
  101. package/dist/application/inbound/resolve-skills.d.ts +2 -0
  102. package/dist/application/inbound/resolve-skills.js +73 -0
  103. package/dist/application/inbound/resolve-skills.js.map +1 -0
  104. package/dist/application/inbound/run-hooks-start.d.ts +2 -0
  105. package/dist/application/inbound/run-hooks-start.js +4 -0
  106. package/dist/application/inbound/run-hooks-start.js.map +1 -0
  107. package/dist/application/inbound/run-hooks-success-error.d.ts +3 -0
  108. package/dist/application/inbound/run-hooks-success-error.js +18 -0
  109. package/dist/application/inbound/run-hooks-success-error.js.map +1 -0
  110. package/dist/application/inbound/types.d.ts +21 -0
  111. package/dist/application/inbound/types.js +2 -0
  112. package/dist/application/inbound/types.js.map +1 -0
  113. package/dist/application/init-config-use-case.d.ts +5 -0
  114. package/dist/application/init-config-use-case.js +62 -0
  115. package/dist/application/init-config-use-case.js.map +1 -0
  116. package/dist/application/message-processor.d.ts +19 -0
  117. package/dist/application/message-processor.js +122 -0
  118. package/dist/application/message-processor.js.map +1 -0
  119. package/dist/application/reload-config-use-case.d.ts +15 -0
  120. package/dist/application/reload-config-use-case.js +26 -0
  121. package/dist/application/reload-config-use-case.js.map +1 -0
  122. package/dist/application/run-daemon-use-case.d.ts +27 -0
  123. package/dist/application/run-daemon-use-case.js +42 -0
  124. package/dist/application/run-daemon-use-case.js.map +1 -0
  125. package/dist/application/runtime-target.d.ts +25 -0
  126. package/dist/application/runtime-target.js +41 -0
  127. package/dist/application/runtime-target.js.map +1 -0
  128. package/dist/application/service-use-cases.d.ts +45 -0
  129. package/dist/application/service-use-cases.js +100 -0
  130. package/dist/application/service-use-cases.js.map +1 -0
  131. package/dist/application/set-config-value-use-case.d.ts +5 -0
  132. package/dist/application/set-config-value-use-case.js +87 -0
  133. package/dist/application/set-config-value-use-case.js.map +1 -0
  134. package/dist/application/validate-config-use-case.d.ts +3 -0
  135. package/dist/application/validate-config-use-case.js +14 -0
  136. package/dist/application/validate-config-use-case.js.map +1 -0
  137. package/dist/application/view-logs-use-case.d.ts +6 -0
  138. package/dist/application/view-logs-use-case.js +14 -0
  139. package/dist/application/view-logs-use-case.js.map +1 -0
  140. package/dist/cli/create-cli.d.ts +68 -0
  141. package/dist/cli/create-cli.js +188 -0
  142. package/dist/cli/create-cli.js.map +1 -0
  143. package/dist/config/default-app-config.d.ts +20 -0
  144. package/dist/config/default-app-config.js +138 -0
  145. package/dist/config/default-app-config.js.map +1 -0
  146. package/dist/config/discover-config-path.d.ts +10 -0
  147. package/dist/config/discover-config-path.js +71 -0
  148. package/dist/config/discover-config-path.js.map +1 -0
  149. package/dist/config/init-app-config.d.ts +13 -0
  150. package/dist/config/init-app-config.js +31 -0
  151. package/dist/config/init-app-config.js.map +1 -0
  152. package/dist/config/load-app-config.d.ts +2 -0
  153. package/dist/config/load-app-config.js +29 -0
  154. package/dist/config/load-app-config.js.map +1 -0
  155. package/dist/config/prompt-init-config.d.ts +15 -0
  156. package/dist/config/prompt-init-config.js +201 -0
  157. package/dist/config/prompt-init-config.js.map +1 -0
  158. package/dist/config/resolve-runtime-config.d.ts +8 -0
  159. package/dist/config/resolve-runtime-config.js +122 -0
  160. package/dist/config/resolve-runtime-config.js.map +1 -0
  161. package/dist/config/schema.d.ts +3 -0
  162. package/dist/config/schema.js +203 -0
  163. package/dist/config/schema.js.map +1 -0
  164. package/dist/config/secret-value.d.ts +20 -0
  165. package/dist/config/secret-value.js +69 -0
  166. package/dist/config/secret-value.js.map +1 -0
  167. package/dist/config/types.d.ts +76 -0
  168. package/dist/config/types.js +2 -0
  169. package/dist/config/types.js.map +1 -0
  170. package/dist/config/validate-secret-references.d.ts +7 -0
  171. package/dist/config/validate-secret-references.js +14 -0
  172. package/dist/config/validate-secret-references.js.map +1 -0
  173. package/dist/daemon/bootstrap/acquire-runtime-state.d.ts +6 -0
  174. package/dist/daemon/bootstrap/acquire-runtime-state.js +19 -0
  175. package/dist/daemon/bootstrap/acquire-runtime-state.js.map +1 -0
  176. package/dist/daemon/bootstrap/build-runtime-components.d.ts +21 -0
  177. package/dist/daemon/bootstrap/build-runtime-components.js +26 -0
  178. package/dist/daemon/bootstrap/build-runtime-components.js.map +1 -0
  179. package/dist/daemon/bootstrap/prepare-runtime-filesystem.d.ts +2 -0
  180. package/dist/daemon/bootstrap/prepare-runtime-filesystem.js +11 -0
  181. package/dist/daemon/bootstrap/prepare-runtime-filesystem.js.map +1 -0
  182. package/dist/daemon/create-daemon.d.ts +13 -0
  183. package/dist/daemon/create-daemon.js +98 -0
  184. package/dist/daemon/create-daemon.js.map +1 -0
  185. package/dist/daemon/runtime-bootstrap.d.ts +12 -0
  186. package/dist/daemon/runtime-bootstrap.js +24 -0
  187. package/dist/daemon/runtime-bootstrap.js.map +1 -0
  188. package/dist/daemon/runtime-runner.d.ts +18 -0
  189. package/dist/daemon/runtime-runner.js +126 -0
  190. package/dist/daemon/runtime-runner.js.map +1 -0
  191. package/dist/daemon/runtime-shutdown.d.ts +15 -0
  192. package/dist/daemon/runtime-shutdown.js +50 -0
  193. package/dist/daemon/runtime-shutdown.js.map +1 -0
  194. package/dist/daemon/runtime-state.d.ts +10 -0
  195. package/dist/daemon/runtime-state.js +90 -0
  196. package/dist/daemon/runtime-state.js.map +1 -0
  197. package/dist/daemon/types.d.ts +63 -0
  198. package/dist/daemon/types.js +2 -0
  199. package/dist/daemon/types.js.map +1 -0
  200. package/dist/domain/agent.d.ts +51 -0
  201. package/dist/domain/agent.js +2 -0
  202. package/dist/domain/agent.js.map +1 -0
  203. package/dist/domain/conversation.d.ts +51 -0
  204. package/dist/domain/conversation.js +2 -0
  205. package/dist/domain/conversation.js.map +1 -0
  206. package/dist/domain/errors.d.ts +13 -0
  207. package/dist/domain/errors.js +27 -0
  208. package/dist/domain/errors.js.map +1 -0
  209. package/dist/domain/message.d.ts +27 -0
  210. package/dist/domain/message.js +2 -0
  211. package/dist/domain/message.js.map +1 -0
  212. package/dist/files/backup.d.ts +2 -0
  213. package/dist/files/backup.js +7 -0
  214. package/dist/files/backup.js.map +1 -0
  215. package/dist/files/managed-file.d.ts +11 -0
  216. package/dist/files/managed-file.js +82 -0
  217. package/dist/files/managed-file.js.map +1 -0
  218. package/dist/files/tar-archive.d.ts +7 -0
  219. package/dist/files/tar-archive.js +308 -0
  220. package/dist/files/tar-archive.js.map +1 -0
  221. package/dist/index.d.ts +2 -0
  222. package/dist/index.js +2 -0
  223. package/dist/index.js.map +1 -0
  224. package/dist/logging/daemon-startup-failure-reporter.d.ts +2 -0
  225. package/dist/logging/daemon-startup-failure-reporter.js +19 -0
  226. package/dist/logging/daemon-startup-failure-reporter.js.map +1 -0
  227. package/dist/logging/file-logger.d.ts +3 -0
  228. package/dist/logging/file-logger.js +87 -0
  229. package/dist/logging/file-logger.js.map +1 -0
  230. package/dist/logging/types.d.ts +34 -0
  231. package/dist/logging/types.js +2 -0
  232. package/dist/logging/types.js.map +1 -0
  233. package/dist/logging/view-logs.d.ts +27 -0
  234. package/dist/logging/view-logs.js +171 -0
  235. package/dist/logging/view-logs.js.map +1 -0
  236. package/dist/main.d.ts +2 -0
  237. package/dist/main.js +109 -0
  238. package/dist/main.js.map +1 -0
  239. package/dist/plugins/hook-runner.d.ts +11 -0
  240. package/dist/plugins/hook-runner.js +41 -0
  241. package/dist/plugins/hook-runner.js.map +1 -0
  242. package/dist/plugins/index.d.ts +2 -0
  243. package/dist/plugins/index.js +2 -0
  244. package/dist/plugins/index.js.map +1 -0
  245. package/dist/plugins/types.d.ts +64 -0
  246. package/dist/plugins/types.js +2 -0
  247. package/dist/plugins/types.js.map +1 -0
  248. package/dist/runtime/agent-execution.d.ts +42 -0
  249. package/dist/runtime/agent-execution.js +109 -0
  250. package/dist/runtime/agent-execution.js.map +1 -0
  251. package/dist/runtime/context.d.ts +20 -0
  252. package/dist/runtime/context.js +2 -0
  253. package/dist/runtime/context.js.map +1 -0
  254. package/dist/runtime/create-oauth-api-key-resolver.d.ts +9 -0
  255. package/dist/runtime/create-oauth-api-key-resolver.js +66 -0
  256. package/dist/runtime/create-oauth-api-key-resolver.js.map +1 -0
  257. package/dist/runtime/create-pi-agent-engine.d.ts +28 -0
  258. package/dist/runtime/create-pi-agent-engine.js +150 -0
  259. package/dist/runtime/create-pi-agent-engine.js.map +1 -0
  260. package/dist/runtime/mcp-tool-cache.d.ts +13 -0
  261. package/dist/runtime/mcp-tool-cache.js +43 -0
  262. package/dist/runtime/mcp-tool-cache.js.map +1 -0
  263. package/dist/runtime/mcp-tool-runtime.d.ts +76 -0
  264. package/dist/runtime/mcp-tool-runtime.js +180 -0
  265. package/dist/runtime/mcp-tool-runtime.js.map +1 -0
  266. package/dist/runtime/message-mapping.d.ts +11 -0
  267. package/dist/runtime/message-mapping.js +129 -0
  268. package/dist/runtime/message-mapping.js.map +1 -0
  269. package/dist/runtime/model-resolution.d.ts +5 -0
  270. package/dist/runtime/model-resolution.js +13 -0
  271. package/dist/runtime/model-resolution.js.map +1 -0
  272. package/dist/runtime/pipeline/execute-agent-stage.d.ts +12 -0
  273. package/dist/runtime/pipeline/execute-agent-stage.js +25 -0
  274. package/dist/runtime/pipeline/execute-agent-stage.js.map +1 -0
  275. package/dist/runtime/pipeline/resolve-model-stage.d.ts +8 -0
  276. package/dist/runtime/pipeline/resolve-model-stage.js +9 -0
  277. package/dist/runtime/pipeline/resolve-model-stage.js.map +1 -0
  278. package/dist/runtime/pipeline/resolve-prompt-stage.d.ts +12 -0
  279. package/dist/runtime/pipeline/resolve-prompt-stage.js +30 -0
  280. package/dist/runtime/pipeline/resolve-prompt-stage.js.map +1 -0
  281. package/dist/runtime/pipeline/resolve-tools-stage.d.ts +27 -0
  282. package/dist/runtime/pipeline/resolve-tools-stage.js +46 -0
  283. package/dist/runtime/pipeline/resolve-tools-stage.js.map +1 -0
  284. package/dist/runtime/prompt-template.d.ts +54 -0
  285. package/dist/runtime/prompt-template.js +78 -0
  286. package/dist/runtime/prompt-template.js.map +1 -0
  287. package/dist/runtime/system-prompt-cache.d.ts +33 -0
  288. package/dist/runtime/system-prompt-cache.js +77 -0
  289. package/dist/runtime/system-prompt-cache.js.map +1 -0
  290. package/dist/runtime/system-prompt-resolution.d.ts +22 -0
  291. package/dist/runtime/system-prompt-resolution.js +170 -0
  292. package/dist/runtime/system-prompt-resolution.js.map +1 -0
  293. package/dist/runtime/tool-resolution.d.ts +19 -0
  294. package/dist/runtime/tool-resolution.js +281 -0
  295. package/dist/runtime/tool-resolution.js.map +1 -0
  296. package/dist/runtime/types.d.ts +23 -0
  297. package/dist/runtime/types.js +2 -0
  298. package/dist/runtime/types.js.map +1 -0
  299. package/dist/service/install-plan.d.ts +21 -0
  300. package/dist/service/install-plan.js +71 -0
  301. package/dist/service/install-plan.js.map +1 -0
  302. package/dist/service/install-service.d.ts +32 -0
  303. package/dist/service/install-service.js +80 -0
  304. package/dist/service/install-service.js.map +1 -0
  305. package/dist/service/linux-service-environment.d.ts +5 -0
  306. package/dist/service/linux-service-environment.js +61 -0
  307. package/dist/service/linux-service-environment.js.map +1 -0
  308. package/dist/service/manage-service.d.ts +14 -0
  309. package/dist/service/manage-service.js +36 -0
  310. package/dist/service/manage-service.js.map +1 -0
  311. package/dist/service/platforms/get-service-platform-adapter.d.ts +3 -0
  312. package/dist/service/platforms/get-service-platform-adapter.js +12 -0
  313. package/dist/service/platforms/get-service-platform-adapter.js.map +1 -0
  314. package/dist/service/platforms/linux-systemd-user-adapter.d.ts +2 -0
  315. package/dist/service/platforms/linux-systemd-user-adapter.js +99 -0
  316. package/dist/service/platforms/linux-systemd-user-adapter.js.map +1 -0
  317. package/dist/service/platforms/macos-launchd-adapter.d.ts +2 -0
  318. package/dist/service/platforms/macos-launchd-adapter.js +122 -0
  319. package/dist/service/platforms/macos-launchd-adapter.js.map +1 -0
  320. package/dist/service/platforms/service-platform-adapter.d.ts +35 -0
  321. package/dist/service/platforms/service-platform-adapter.js +16 -0
  322. package/dist/service/platforms/service-platform-adapter.js.map +1 -0
  323. package/dist/service/platforms/windows-winsw-adapter.d.ts +2 -0
  324. package/dist/service/platforms/windows-winsw-adapter.js +47 -0
  325. package/dist/service/platforms/windows-winsw-adapter.js.map +1 -0
  326. package/dist/service/service-error.d.ts +7 -0
  327. package/dist/service/service-error.js +45 -0
  328. package/dist/service/service-error.js.map +1 -0
  329. package/dist/service/service-installer.d.ts +8 -0
  330. package/dist/service/service-installer.js +40 -0
  331. package/dist/service/service-installer.js.map +1 -0
  332. package/dist/service/service-operation-result.d.ts +9 -0
  333. package/dist/service/service-operation-result.js +2 -0
  334. package/dist/service/service-operation-result.js.map +1 -0
  335. package/dist/service/uninstall-service.d.ts +13 -0
  336. package/dist/service/uninstall-service.js +45 -0
  337. package/dist/service/uninstall-service.js.map +1 -0
  338. package/dist/skills/discovery.d.ts +10 -0
  339. package/dist/skills/discovery.js +216 -0
  340. package/dist/skills/discovery.js.map +1 -0
  341. package/dist/skills/types.d.ts +20 -0
  342. package/dist/skills/types.js +2 -0
  343. package/dist/skills/types.js.map +1 -0
  344. package/dist/storage/fs-store.d.ts +3 -0
  345. package/dist/storage/fs-store.js +707 -0
  346. package/dist/storage/fs-store.js.map +1 -0
  347. package/dist/storage/types.d.ts +29 -0
  348. package/dist/storage/types.js +2 -0
  349. package/dist/storage/types.js.map +1 -0
  350. package/dist/tools/registry.d.ts +7 -0
  351. package/dist/tools/registry.js +18 -0
  352. package/dist/tools/registry.js.map +1 -0
  353. package/dist/tools/types.d.ts +14 -0
  354. package/dist/tools/types.js +2 -0
  355. package/dist/tools/types.js.map +1 -0
  356. package/dist/transports/builtins.d.ts +1 -0
  357. package/dist/transports/builtins.js +15 -0
  358. package/dist/transports/builtins.js.map +1 -0
  359. package/dist/transports/registry.d.ts +21 -0
  360. package/dist/transports/registry.js +28 -0
  361. package/dist/transports/registry.js.map +1 -0
  362. package/dist/transports/telegram/openai-voice-transcriber.d.ts +18 -0
  363. package/dist/transports/telegram/openai-voice-transcriber.js +75 -0
  364. package/dist/transports/telegram/openai-voice-transcriber.js.map +1 -0
  365. package/dist/transports/telegram/render-telegram-message.d.ts +2 -0
  366. package/dist/transports/telegram/render-telegram-message.js +458 -0
  367. package/dist/transports/telegram/render-telegram-message.js.map +1 -0
  368. package/dist/transports/telegram/telegram-transport.d.ts +56 -0
  369. package/dist/transports/telegram/telegram-transport.js +414 -0
  370. package/dist/transports/telegram/telegram-transport.js.map +1 -0
  371. package/dist/transports/telegram/transport-adapter.d.ts +33 -0
  372. package/dist/transports/telegram/transport-adapter.js +62 -0
  373. package/dist/transports/telegram/transport-adapter.js.map +1 -0
  374. package/dist/transports/types.d.ts +15 -0
  375. package/dist/transports/types.js +2 -0
  376. package/dist/transports/types.js.map +1 -0
  377. package/package.json +49 -0
@@ -0,0 +1,308 @@
1
+ import { createReadStream } from "node:fs";
2
+ import { chmod, mkdir, open, readdir, stat, writeFile } from "node:fs/promises";
3
+ import { dirname, join, posix, relative, resolve, sep } from "node:path";
4
+ const tarBlockSize = 512;
5
+ const zeroBlock = Buffer.alloc(tarBlockSize, 0);
6
+ const defaultReadChunkSize = 64 * 1024;
7
+ const defaultExtractLimits = {
8
+ maxEntrySizeBytes: 512 * 1024 * 1024,
9
+ maxEntries: 10_000,
10
+ };
11
+ export async function createTarArchive(sourceDir, outputPath) {
12
+ const archive = await open(outputPath, "w", 0o600);
13
+ try {
14
+ for (const entry of await listTarEntries(sourceDir)) {
15
+ await archive.write(buildTarHeader(entry));
16
+ if (entry.type === "file") {
17
+ const sourcePath = join(sourceDir, entry.path);
18
+ await writeFileContentToArchive(archive, sourcePath, entry.size);
19
+ }
20
+ }
21
+ await archive.write(zeroBlock);
22
+ await archive.write(zeroBlock);
23
+ await archive.chmod(0o600);
24
+ }
25
+ finally {
26
+ await archive.close();
27
+ }
28
+ }
29
+ export async function extractTarArchive(archivePath, outputDir, options = {}) {
30
+ const archive = await open(archivePath, "r");
31
+ const reader = new TarArchiveReader(archive);
32
+ const directoryModes = new Map();
33
+ const limits = { ...defaultExtractLimits, ...options };
34
+ let entries = 0;
35
+ try {
36
+ while (true) {
37
+ const header = await reader.readBlock();
38
+ if (header === null) {
39
+ break;
40
+ }
41
+ if (isZeroBlock(header)) {
42
+ break;
43
+ }
44
+ entries += 1;
45
+ if (entries > limits.maxEntries) {
46
+ throw new Error(`Invalid backup archive: entry count exceeds limit (${limits.maxEntries})`);
47
+ }
48
+ assertHeaderChecksum(header);
49
+ const entry = parseTarHeader(header);
50
+ const targetPath = resolve(outputDir, entry.path);
51
+ assertArchivePath(targetPath, outputDir);
52
+ if (entry.size > limits.maxEntrySizeBytes) {
53
+ throw new Error(`Invalid backup archive: tar entry too large for ${entry.path} (${entry.size} bytes exceeds ${limits.maxEntrySizeBytes})`);
54
+ }
55
+ if (entry.type === "directory") {
56
+ await mkdir(targetPath, { recursive: true, mode: 0o700 });
57
+ directoryModes.set(targetPath, normalizeExtractedDirectoryMode(entry.mode));
58
+ continue;
59
+ }
60
+ await mkdir(dirname(targetPath), { recursive: true });
61
+ await streamEntryContentToFile(reader, targetPath, entry);
62
+ await reader.skipPadding(entry.size);
63
+ }
64
+ }
65
+ finally {
66
+ await archive.close();
67
+ }
68
+ for (const [path, mode] of [...directoryModes.entries()].sort(([left], [right]) => right.length - left.length)) {
69
+ await chmod(path, mode);
70
+ }
71
+ }
72
+ async function listTarEntries(root, currentDir = root) {
73
+ const dirEntries = await readdir(currentDir, { withFileTypes: true });
74
+ const entries = [];
75
+ for (const dirEntry of dirEntries.sort((left, right) => left.name.localeCompare(right.name))) {
76
+ const absolutePath = join(currentDir, dirEntry.name);
77
+ const relativePath = toTarPath(relative(root, absolutePath));
78
+ const fileStat = await stat(absolutePath);
79
+ if (dirEntry.isDirectory()) {
80
+ entries.push({
81
+ path: `${relativePath}/`,
82
+ type: "directory",
83
+ mode: fileStat.mode & 0o777,
84
+ size: 0,
85
+ mtime: Math.floor(fileStat.mtimeMs / 1000),
86
+ });
87
+ entries.push(...(await listTarEntries(root, absolutePath)));
88
+ continue;
89
+ }
90
+ if (dirEntry.isFile()) {
91
+ entries.push({
92
+ path: relativePath,
93
+ type: "file",
94
+ mode: fileStat.mode & 0o777,
95
+ size: fileStat.size,
96
+ mtime: Math.floor(fileStat.mtimeMs / 1000),
97
+ });
98
+ }
99
+ }
100
+ return entries;
101
+ }
102
+ function buildTarHeader(entry) {
103
+ const header = Buffer.alloc(tarBlockSize, 0);
104
+ const { name, prefix } = splitTarPath(entry.path);
105
+ writeStringField(header, 0, 100, name);
106
+ writeOctalField(header, 100, 8, entry.mode);
107
+ writeOctalField(header, 108, 8, 0);
108
+ writeOctalField(header, 116, 8, 0);
109
+ writeOctalField(header, 124, 12, entry.size);
110
+ writeOctalField(header, 136, 12, entry.mtime);
111
+ header.fill(0x20, 148, 156);
112
+ header[156] = entry.type === "directory" ? "5".charCodeAt(0) : "0".charCodeAt(0);
113
+ writeStringField(header, 257, 6, "ustar");
114
+ writeStringField(header, 263, 2, "00");
115
+ writeStringField(header, 265, 32, "root");
116
+ writeStringField(header, 297, 32, "root");
117
+ writeStringField(header, 345, 155, prefix);
118
+ const checksum = calculateChecksum(header);
119
+ writeChecksumField(header, checksum);
120
+ return header;
121
+ }
122
+ function parseTarHeader(header) {
123
+ const name = readStringField(header, 0, 100);
124
+ const prefix = readStringField(header, 345, 155);
125
+ const path = prefix ? `${prefix}/${name}` : name;
126
+ const typeFlag = String.fromCharCode(header[156] || "0".charCodeAt(0));
127
+ const type = typeFlag === "5" ? "directory" : "file";
128
+ return {
129
+ path,
130
+ type,
131
+ mode: readOctalField(header, 100, 8) || 0o600,
132
+ size: readOctalField(header, 124, 12),
133
+ mtime: readOctalField(header, 136, 12),
134
+ };
135
+ }
136
+ function splitTarPath(path) {
137
+ if (Buffer.byteLength(path) <= 100) {
138
+ return { name: path, prefix: "" };
139
+ }
140
+ const normalized = path.endsWith("/") ? path.slice(0, -1) : path;
141
+ const segments = normalized.split("/");
142
+ for (let index = segments.length - 1; index > 0; index -= 1) {
143
+ const prefix = segments.slice(0, index).join("/");
144
+ const name = segments.slice(index).join("/");
145
+ if (Buffer.byteLength(name) <= 100 && Buffer.byteLength(prefix) <= 155) {
146
+ return {
147
+ name: path.endsWith("/") ? `${name}/` : name,
148
+ prefix,
149
+ };
150
+ }
151
+ }
152
+ throw new Error(`Archive entry path is too long for tar format: ${path}`);
153
+ }
154
+ function writeStringField(buffer, offset, length, value) {
155
+ const encoded = Buffer.from(value, "utf8");
156
+ if (encoded.byteLength > length) {
157
+ throw new Error(`Value does not fit in tar header field: ${value}`);
158
+ }
159
+ encoded.copy(buffer, offset);
160
+ }
161
+ function writeOctalField(buffer, offset, length, value) {
162
+ const encoded = Buffer.from(value.toString(8).padStart(length - 1, "0").slice(-(length - 1)), "ascii");
163
+ encoded.copy(buffer, offset);
164
+ buffer[offset + length - 1] = 0;
165
+ }
166
+ function writeChecksumField(buffer, checksum) {
167
+ const encoded = Buffer.from(checksum.toString(8).padStart(6, "0"), "ascii");
168
+ encoded.copy(buffer, 148);
169
+ buffer[154] = 0;
170
+ buffer[155] = 0x20;
171
+ }
172
+ function readStringField(buffer, offset, length) {
173
+ return buffer
174
+ .subarray(offset, offset + length)
175
+ .toString("utf8")
176
+ .replace(/\0.*$/, "")
177
+ .trim();
178
+ }
179
+ function readOctalField(buffer, offset, length) {
180
+ const raw = buffer
181
+ .subarray(offset, offset + length)
182
+ .toString("ascii")
183
+ .replace(/\0.*$/, "")
184
+ .trim();
185
+ if (!raw) {
186
+ return 0;
187
+ }
188
+ return Number.parseInt(raw, 8);
189
+ }
190
+ function calculateChecksum(buffer) {
191
+ let sum = 0;
192
+ for (const byte of buffer) {
193
+ sum += byte;
194
+ }
195
+ return sum;
196
+ }
197
+ function assertHeaderChecksum(header) {
198
+ const expected = readOctalField(header, 148, 8);
199
+ const copy = Buffer.from(header);
200
+ copy.fill(0x20, 148, 156);
201
+ const actual = calculateChecksum(copy);
202
+ if (expected !== actual) {
203
+ throw new Error("Invalid backup archive: tar header checksum mismatch");
204
+ }
205
+ }
206
+ function isZeroBlock(block) {
207
+ return block.equals(zeroBlock);
208
+ }
209
+ function getPaddingSize(size) {
210
+ const remainder = size % tarBlockSize;
211
+ return remainder === 0 ? 0 : tarBlockSize - remainder;
212
+ }
213
+ function normalizeExtractedDirectoryMode(mode) {
214
+ return mode | 0o100;
215
+ }
216
+ function toTarPath(path) {
217
+ return path.split(sep).join(posix.sep);
218
+ }
219
+ function assertArchivePath(targetPath, outputDir) {
220
+ const normalizedOutputDir = resolve(outputDir);
221
+ if (targetPath !== normalizedOutputDir &&
222
+ !targetPath.startsWith(`${normalizedOutputDir}${sep}`)) {
223
+ throw new Error("Invalid backup archive: contains path traversal entry");
224
+ }
225
+ }
226
+ async function writeFileContentToArchive(archive, sourcePath, size) {
227
+ for await (const chunk of createReadStream(sourcePath)) {
228
+ await archive.write(chunk);
229
+ }
230
+ await writePadding(archive, size);
231
+ }
232
+ async function writePadding(archive, size) {
233
+ const paddingSize = getPaddingSize(size);
234
+ if (paddingSize > 0) {
235
+ await archive.write(Buffer.alloc(paddingSize, 0));
236
+ }
237
+ }
238
+ async function streamEntryContentToFile(reader, targetPath, entry) {
239
+ if (entry.size === 0) {
240
+ await writeFile(targetPath, Buffer.alloc(0), { mode: entry.mode });
241
+ return;
242
+ }
243
+ const output = await open(targetPath, "w", entry.mode);
244
+ try {
245
+ let remaining = entry.size;
246
+ while (remaining > 0) {
247
+ const chunkSize = Math.min(remaining, defaultReadChunkSize);
248
+ const chunk = await reader.readExact(chunkSize, `Invalid backup archive: truncated tar entry for ${entry.path}`);
249
+ let writeOffset = 0;
250
+ while (writeOffset < chunk.byteLength) {
251
+ const { bytesWritten } = await output.write(chunk, writeOffset, chunk.byteLength - writeOffset);
252
+ if (bytesWritten === 0) {
253
+ throw new Error(`Failed to extract tar entry: short write for ${entry.path}`);
254
+ }
255
+ writeOffset += bytesWritten;
256
+ }
257
+ remaining -= chunk.byteLength;
258
+ }
259
+ }
260
+ finally {
261
+ await output.close();
262
+ }
263
+ }
264
+ class TarArchiveReader {
265
+ archive;
266
+ offset = 0;
267
+ constructor(archive) {
268
+ this.archive = archive;
269
+ }
270
+ async readBlock() {
271
+ const block = await this.readChunk(tarBlockSize);
272
+ if (block.byteLength === 0) {
273
+ return null;
274
+ }
275
+ if (block.byteLength < tarBlockSize) {
276
+ throw new Error("Invalid backup archive: truncated tar header");
277
+ }
278
+ return block;
279
+ }
280
+ async readExact(size, errorMessage) {
281
+ const chunk = await this.readChunk(size);
282
+ if (chunk.byteLength !== size) {
283
+ throw new Error(errorMessage);
284
+ }
285
+ return chunk;
286
+ }
287
+ async skipPadding(size) {
288
+ const paddingSize = getPaddingSize(size);
289
+ if (paddingSize === 0) {
290
+ return;
291
+ }
292
+ await this.readExact(paddingSize, "Invalid backup archive: truncated tar padding");
293
+ }
294
+ async readChunk(size) {
295
+ const buffer = Buffer.allocUnsafe(size);
296
+ let totalBytesRead = 0;
297
+ while (totalBytesRead < size) {
298
+ const { bytesRead } = await this.archive.read(buffer, totalBytesRead, size - totalBytesRead, this.offset);
299
+ if (bytesRead === 0) {
300
+ break;
301
+ }
302
+ totalBytesRead += bytesRead;
303
+ this.offset += bytesRead;
304
+ }
305
+ return buffer.subarray(0, totalBytesRead);
306
+ }
307
+ }
308
+ //# sourceMappingURL=tar-archive.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tar-archive.js","sourceRoot":"","sources":["../../src/files/tar-archive.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { createDaemon } from "./daemon/create-daemon.js";
2
+ export type { Daemon, DaemonConfig } from "./daemon/types.js";
package/dist/index.js ADDED
@@ -0,0 +1,2 @@
1
+ export { createDaemon } from "./daemon/create-daemon.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { DaemonStartupFailureReporter } from "../application/run-daemon-use-case.js";
2
+ export declare function createDaemonStartupFailureReporter(): DaemonStartupFailureReporter;
@@ -0,0 +1,19 @@
1
+ import { mkdir, writeFile } from "node:fs/promises";
2
+ import { dirname } from "node:path";
3
+ import { createFileLogger } from "./file-logger.js";
4
+ export function createDaemonStartupFailureReporter() {
5
+ return {
6
+ report: async ({ runtimeConfig, error }) => {
7
+ await Promise.all(runtimeConfig.activeEndpoints.map(async (endpoint) => {
8
+ await ensureStartupLogFile(endpoint.paths.logFilePath);
9
+ const logger = createFileLogger(endpoint.paths.logFilePath, runtimeConfig.logging.level);
10
+ await logger.error("daemon failed to start", { endpointId: endpoint.id }, error);
11
+ }));
12
+ },
13
+ };
14
+ }
15
+ async function ensureStartupLogFile(path) {
16
+ await mkdir(dirname(path), { recursive: true });
17
+ await writeFile(path, "", { encoding: "utf8", flag: "a" });
18
+ }
19
+ //# sourceMappingURL=daemon-startup-failure-reporter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"daemon-startup-failure-reporter.js","sourceRoot":"","sources":["../../src/logging/daemon-startup-failure-reporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEpD,MAAM,UAAU,kCAAkC;IAChD,OAAO;QACL,MAAM,EAAE,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,EAAE,EAAE;YACzC,MAAM,OAAO,CAAC,GAAG,CACf,aAAa,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;gBACnD,MAAM,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;gBACvD,MAAM,MAAM,GAAG,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBACzF,MAAM,MAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;YACnF,CAAC,CAAC,CACH,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,oBAAoB,CAAC,IAAY;IAC9C,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAChD,MAAM,SAAS,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;AAC7D,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Logger, LogLevel } from "./types.js";
2
+ export declare function createFileLogger(path: string, level?: LogLevel): Logger;
3
+ export declare function rotateLogFileOnStartup(path: string): Promise<void>;
@@ -0,0 +1,87 @@
1
+ import { appendFile, mkdir, rename, stat, writeFile } from "node:fs/promises";
2
+ import { dirname } from "node:path";
3
+ const LOG_LEVEL_PRIORITY = {
4
+ debug: 10,
5
+ info: 20,
6
+ warn: 30,
7
+ error: 40,
8
+ };
9
+ export function createFileLogger(path, level = "info") {
10
+ return {
11
+ async debug(message, fields) {
12
+ if (!shouldLog("debug", level)) {
13
+ return;
14
+ }
15
+ await writeLogLine(path, "DEBUG", message, fields);
16
+ console.debug(formatConsoleLog(message, fields));
17
+ },
18
+ async info(message, fields) {
19
+ if (!shouldLog("info", level)) {
20
+ return;
21
+ }
22
+ await writeLogLine(path, "INFO", message, fields);
23
+ console.log(formatConsoleLog(message, fields));
24
+ },
25
+ async error(message, fields, error) {
26
+ if (!shouldLog("error", level)) {
27
+ return;
28
+ }
29
+ await writeLogLine(path, "ERROR", message, fields);
30
+ if (error !== undefined) {
31
+ await writeLogLine(path, "ERROR", formatError(error), fields);
32
+ }
33
+ console.error(formatConsoleLog(message, fields));
34
+ if (error !== undefined) {
35
+ console.error(error);
36
+ }
37
+ },
38
+ };
39
+ }
40
+ export async function rotateLogFileOnStartup(path) {
41
+ await mkdir(dirname(path), { recursive: true });
42
+ const hasContent = await hasExistingLogContent(path);
43
+ if (hasContent) {
44
+ await rename(path, `${path}.1`);
45
+ }
46
+ await writeFile(path, "", { encoding: "utf8", flag: "w" });
47
+ }
48
+ async function hasExistingLogContent(path) {
49
+ try {
50
+ const fileStats = await stat(path);
51
+ return fileStats.size > 0;
52
+ }
53
+ catch (error) {
54
+ if (isMissingFileError(error)) {
55
+ return false;
56
+ }
57
+ throw error;
58
+ }
59
+ }
60
+ function shouldLog(entryLevel, configuredLevel) {
61
+ return LOG_LEVEL_PRIORITY[entryLevel] >= LOG_LEVEL_PRIORITY[configuredLevel];
62
+ }
63
+ async function writeLogLine(path, level, message, fields) {
64
+ const payload = {
65
+ ts: new Date().toISOString(),
66
+ level,
67
+ message,
68
+ ...(fields ?? {}),
69
+ };
70
+ await appendFile(path, `${JSON.stringify(payload)}\n`, "utf8");
71
+ }
72
+ function isMissingFileError(error) {
73
+ return error instanceof Error && "code" in error && error.code === "ENOENT";
74
+ }
75
+ function formatError(error) {
76
+ if (error instanceof Error) {
77
+ return error.stack ?? `${error.name}: ${error.message}`;
78
+ }
79
+ return String(error);
80
+ }
81
+ function formatConsoleLog(message, fields) {
82
+ if (!fields || Object.keys(fields).length === 0) {
83
+ return message;
84
+ }
85
+ return `${message} ${JSON.stringify(fields)}`;
86
+ }
87
+ //# sourceMappingURL=file-logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-logger.js","sourceRoot":"","sources":["../../src/logging/file-logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ export type LogLevel = "debug" | "info" | "warn" | "error";
2
+ export interface LogFields {
3
+ endpointId?: string;
4
+ transport?: string;
5
+ conversationId?: string;
6
+ messageId?: string;
7
+ agentId?: string;
8
+ correlationId?: string;
9
+ command?: string;
10
+ backupId?: string;
11
+ durationMs?: number;
12
+ errorType?: string;
13
+ hookName?: string;
14
+ hookRegistrationName?: string;
15
+ skillCount?: number;
16
+ skillNames?: string[];
17
+ workspaceDirectory?: string;
18
+ workspaceSkillsPath?: string;
19
+ overriddenSkillNames?: string[];
20
+ initialWorkingDirectory?: string;
21
+ configuredBuiltInTools?: string[];
22
+ resolvedBuiltInTools?: string[];
23
+ missingBuiltInTools?: string[];
24
+ configuredMcpServers?: string[];
25
+ initializedMcpServers?: string[];
26
+ failedMcpServers?: string[];
27
+ resolvedMcpTools?: string[];
28
+ resolvedTools?: string[];
29
+ }
30
+ export interface Logger {
31
+ debug(message: string, fields?: LogFields): Promise<void>;
32
+ info(message: string, fields?: LogFields): Promise<void>;
33
+ error(message: string, fields?: LogFields, error?: unknown): Promise<void>;
34
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,27 @@
1
+ import type { DaemonConfig } from "../daemon/types.js";
2
+ export interface LogTarget {
3
+ endpointId: string;
4
+ logFilePath: string;
5
+ }
6
+ type ReadLogFile = (path: string, encoding: "utf8") => Promise<string>;
7
+ type WatchLogFile = (path: string, options: {
8
+ signal?: AbortSignal;
9
+ }) => AsyncIterable<{
10
+ eventType: string;
11
+ }>;
12
+ interface ViewLogsDependencies {
13
+ readFile?: ReadLogFile;
14
+ watch?: WatchLogFile;
15
+ }
16
+ export declare function viewDaemonLogs(options: {
17
+ runtimeConfig: DaemonConfig;
18
+ endpointId?: string;
19
+ lines?: number;
20
+ follow?: boolean;
21
+ stdout?: NodeJS.WritableStream;
22
+ signal?: AbortSignal;
23
+ dependencies?: ViewLogsDependencies;
24
+ }): Promise<void>;
25
+ export declare function resolveLogTargets(runtimeConfig: DaemonConfig, endpointId?: string): LogTarget[];
26
+ export declare function readRecentLogLines(logFilePath: string, lines: number, readFileImpl?: ReadLogFile): Promise<string[]>;
27
+ export {};