@apralabs/apra-fleet 0.2.2

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 (482) hide show
  1. package/LICENSE +182 -0
  2. package/README.md +324 -0
  3. package/dist/cli/auth.d.ts +2 -0
  4. package/dist/cli/auth.d.ts.map +1 -0
  5. package/dist/cli/auth.js +210 -0
  6. package/dist/cli/auth.js.map +1 -0
  7. package/dist/cli/config.d.ts +30 -0
  8. package/dist/cli/config.d.ts.map +1 -0
  9. package/dist/cli/config.js +157 -0
  10. package/dist/cli/config.js.map +1 -0
  11. package/dist/cli/install.d.ts +37 -0
  12. package/dist/cli/install.d.ts.map +1 -0
  13. package/dist/cli/install.js +630 -0
  14. package/dist/cli/install.js.map +1 -0
  15. package/dist/cli/secret.d.ts +2 -0
  16. package/dist/cli/secret.d.ts.map +1 -0
  17. package/dist/cli/secret.js +366 -0
  18. package/dist/cli/secret.js.map +1 -0
  19. package/dist/cli/uninstall.d.ts +2 -0
  20. package/dist/cli/uninstall.d.ts.map +1 -0
  21. package/dist/cli/uninstall.js +312 -0
  22. package/dist/cli/uninstall.js.map +1 -0
  23. package/dist/cli/update.d.ts +2 -0
  24. package/dist/cli/update.d.ts.map +1 -0
  25. package/dist/cli/update.js +105 -0
  26. package/dist/cli/update.js.map +1 -0
  27. package/dist/delivery-mode.d.ts +19 -0
  28. package/dist/delivery-mode.d.ts.map +1 -0
  29. package/dist/delivery-mode.js +26 -0
  30. package/dist/delivery-mode.js.map +1 -0
  31. package/dist/index.d.ts +3 -0
  32. package/dist/index.d.ts.map +1 -0
  33. package/dist/index.js +272 -0
  34. package/dist/index.js.map +1 -0
  35. package/dist/onboarding/text.d.ts +83 -0
  36. package/dist/onboarding/text.d.ts.map +1 -0
  37. package/dist/onboarding/text.js +126 -0
  38. package/dist/onboarding/text.js.map +1 -0
  39. package/dist/os/index.d.ts +9 -0
  40. package/dist/os/index.d.ts.map +1 -0
  41. package/dist/os/index.js +16 -0
  42. package/dist/os/index.js.map +1 -0
  43. package/dist/os/linux.d.ts +50 -0
  44. package/dist/os/linux.d.ts.map +1 -0
  45. package/dist/os/linux.js +244 -0
  46. package/dist/os/linux.js.map +1 -0
  47. package/dist/os/macos.d.ts +12 -0
  48. package/dist/os/macos.d.ts.map +1 -0
  49. package/dist/os/macos.js +41 -0
  50. package/dist/os/macos.js.map +1 -0
  51. package/dist/os/os-commands.d.ts +47 -0
  52. package/dist/os/os-commands.d.ts.map +1 -0
  53. package/dist/os/os-commands.js +3 -0
  54. package/dist/os/os-commands.js.map +1 -0
  55. package/dist/os/windows-wrapper.d.ts +6 -0
  56. package/dist/os/windows-wrapper.d.ts.map +1 -0
  57. package/dist/os/windows-wrapper.js +9 -0
  58. package/dist/os/windows-wrapper.js.map +1 -0
  59. package/dist/os/windows.d.ts +44 -0
  60. package/dist/os/windows.d.ts.map +1 -0
  61. package/dist/os/windows.js +269 -0
  62. package/dist/os/windows.js.map +1 -0
  63. package/dist/paths.d.ts +2 -0
  64. package/dist/paths.d.ts.map +1 -0
  65. package/dist/paths.js +4 -0
  66. package/dist/paths.js.map +1 -0
  67. package/dist/providers/agy.d.ts +41 -0
  68. package/dist/providers/agy.d.ts.map +1 -0
  69. package/dist/providers/agy.js +208 -0
  70. package/dist/providers/agy.js.map +1 -0
  71. package/dist/providers/claude.d.ts +40 -0
  72. package/dist/providers/claude.d.ts.map +1 -0
  73. package/dist/providers/claude.js +178 -0
  74. package/dist/providers/claude.js.map +1 -0
  75. package/dist/providers/codex.d.ts +44 -0
  76. package/dist/providers/codex.d.ts.map +1 -0
  77. package/dist/providers/codex.js +173 -0
  78. package/dist/providers/codex.js.map +1 -0
  79. package/dist/providers/copilot.d.ts +40 -0
  80. package/dist/providers/copilot.d.ts.map +1 -0
  81. package/dist/providers/copilot.js +172 -0
  82. package/dist/providers/copilot.js.map +1 -0
  83. package/dist/providers/gemini.d.ts +41 -0
  84. package/dist/providers/gemini.d.ts.map +1 -0
  85. package/dist/providers/gemini.js +192 -0
  86. package/dist/providers/gemini.js.map +1 -0
  87. package/dist/providers/index.d.ts +10 -0
  88. package/dist/providers/index.d.ts.map +1 -0
  89. package/dist/providers/index.js +27 -0
  90. package/dist/providers/index.js.map +1 -0
  91. package/dist/providers/provider.d.ts +85 -0
  92. package/dist/providers/provider.d.ts.map +1 -0
  93. package/dist/providers/provider.js +21 -0
  94. package/dist/providers/provider.js.map +1 -0
  95. package/dist/services/auth-socket.d.ts +87 -0
  96. package/dist/services/auth-socket.d.ts.map +1 -0
  97. package/dist/services/auth-socket.js +684 -0
  98. package/dist/services/auth-socket.js.map +1 -0
  99. package/dist/services/auth-web.d.ts +31 -0
  100. package/dist/services/auth-web.d.ts.map +1 -0
  101. package/dist/services/auth-web.js +202 -0
  102. package/dist/services/auth-web.js.map +1 -0
  103. package/dist/services/cloud/activity.d.ts +16 -0
  104. package/dist/services/cloud/activity.d.ts.map +1 -0
  105. package/dist/services/cloud/activity.js +61 -0
  106. package/dist/services/cloud/activity.js.map +1 -0
  107. package/dist/services/cloud/aws.d.ts +24 -0
  108. package/dist/services/cloud/aws.d.ts.map +1 -0
  109. package/dist/services/cloud/aws.js +114 -0
  110. package/dist/services/cloud/aws.js.map +1 -0
  111. package/dist/services/cloud/cost.d.ts +46 -0
  112. package/dist/services/cloud/cost.d.ts.map +1 -0
  113. package/dist/services/cloud/cost.js +161 -0
  114. package/dist/services/cloud/cost.js.map +1 -0
  115. package/dist/services/cloud/idle-manager.d.ts +20 -0
  116. package/dist/services/cloud/idle-manager.d.ts.map +1 -0
  117. package/dist/services/cloud/idle-manager.js +103 -0
  118. package/dist/services/cloud/idle-manager.js.map +1 -0
  119. package/dist/services/cloud/lifecycle.d.ts +14 -0
  120. package/dist/services/cloud/lifecycle.d.ts.map +1 -0
  121. package/dist/services/cloud/lifecycle.js +128 -0
  122. package/dist/services/cloud/lifecycle.js.map +1 -0
  123. package/dist/services/cloud/task-wrapper.d.ts +30 -0
  124. package/dist/services/cloud/task-wrapper.d.ts.map +1 -0
  125. package/dist/services/cloud/task-wrapper.js +116 -0
  126. package/dist/services/cloud/task-wrapper.js.map +1 -0
  127. package/dist/services/cloud/types.d.ts +26 -0
  128. package/dist/services/cloud/types.d.ts.map +1 -0
  129. package/dist/services/cloud/types.js +2 -0
  130. package/dist/services/cloud/types.js.map +1 -0
  131. package/dist/services/credential-cleanup.d.ts +4 -0
  132. package/dist/services/credential-cleanup.d.ts.map +1 -0
  133. package/dist/services/credential-cleanup.js +61 -0
  134. package/dist/services/credential-cleanup.js.map +1 -0
  135. package/dist/services/credential-store.d.ts +56 -0
  136. package/dist/services/credential-store.d.ts.map +1 -0
  137. package/dist/services/credential-store.js +280 -0
  138. package/dist/services/credential-store.js.map +1 -0
  139. package/dist/services/file-transfer.d.ts +22 -0
  140. package/dist/services/file-transfer.d.ts.map +1 -0
  141. package/dist/services/file-transfer.js +14 -0
  142. package/dist/services/file-transfer.js.map +1 -0
  143. package/dist/services/git-config.d.ts +6 -0
  144. package/dist/services/git-config.d.ts.map +1 -0
  145. package/dist/services/git-config.js +31 -0
  146. package/dist/services/git-config.js.map +1 -0
  147. package/dist/services/github-app.d.ts +30 -0
  148. package/dist/services/github-app.d.ts.map +1 -0
  149. package/dist/services/github-app.js +96 -0
  150. package/dist/services/github-app.js.map +1 -0
  151. package/dist/services/icons.d.ts +16 -0
  152. package/dist/services/icons.d.ts.map +1 -0
  153. package/dist/services/icons.js +67 -0
  154. package/dist/services/icons.js.map +1 -0
  155. package/dist/services/known-hosts.d.ts +23 -0
  156. package/dist/services/known-hosts.d.ts.map +1 -0
  157. package/dist/services/known-hosts.js +86 -0
  158. package/dist/services/known-hosts.js.map +1 -0
  159. package/dist/services/onboarding.d.ts +68 -0
  160. package/dist/services/onboarding.d.ts.map +1 -0
  161. package/dist/services/onboarding.js +205 -0
  162. package/dist/services/onboarding.js.map +1 -0
  163. package/dist/services/registry.d.ts +16 -0
  164. package/dist/services/registry.d.ts.map +1 -0
  165. package/dist/services/registry.js +156 -0
  166. package/dist/services/registry.js.map +1 -0
  167. package/dist/services/sftp.d.ts +16 -0
  168. package/dist/services/sftp.d.ts.map +1 -0
  169. package/dist/services/sftp.js +104 -0
  170. package/dist/services/sftp.js.map +1 -0
  171. package/dist/services/ssh.d.ts +29 -0
  172. package/dist/services/ssh.d.ts.map +1 -0
  173. package/dist/services/ssh.js +297 -0
  174. package/dist/services/ssh.js.map +1 -0
  175. package/dist/services/stall/find-log-file.d.ts +2 -0
  176. package/dist/services/stall/find-log-file.d.ts.map +1 -0
  177. package/dist/services/stall/find-log-file.js +153 -0
  178. package/dist/services/stall/find-log-file.js.map +1 -0
  179. package/dist/services/stall/index.d.ts +4 -0
  180. package/dist/services/stall/index.d.ts.map +1 -0
  181. package/dist/services/stall/index.js +4 -0
  182. package/dist/services/stall/index.js.map +1 -0
  183. package/dist/services/stall/log-path-resolver.d.ts +4 -0
  184. package/dist/services/stall/log-path-resolver.d.ts.map +1 -0
  185. package/dist/services/stall/log-path-resolver.js +32 -0
  186. package/dist/services/stall/log-path-resolver.js.map +1 -0
  187. package/dist/services/stall/log-path-resolver.test.d.ts +2 -0
  188. package/dist/services/stall/log-path-resolver.test.d.ts.map +1 -0
  189. package/dist/services/stall/log-path-resolver.test.js +76 -0
  190. package/dist/services/stall/log-path-resolver.test.js.map +1 -0
  191. package/dist/services/stall/read-log-tail.d.ts +6 -0
  192. package/dist/services/stall/read-log-tail.d.ts.map +1 -0
  193. package/dist/services/stall/read-log-tail.js +44 -0
  194. package/dist/services/stall/read-log-tail.js.map +1 -0
  195. package/dist/services/stall/stall-detector.d.ts +25 -0
  196. package/dist/services/stall/stall-detector.d.ts.map +1 -0
  197. package/dist/services/stall/stall-detector.js +153 -0
  198. package/dist/services/stall/stall-detector.js.map +1 -0
  199. package/dist/services/stall/stall-poller.d.ts +6 -0
  200. package/dist/services/stall/stall-poller.d.ts.map +1 -0
  201. package/dist/services/stall/stall-poller.js +75 -0
  202. package/dist/services/stall/stall-poller.js.map +1 -0
  203. package/dist/services/stall/time-utils.d.ts +4 -0
  204. package/dist/services/stall/time-utils.d.ts.map +1 -0
  205. package/dist/services/stall/time-utils.js +22 -0
  206. package/dist/services/stall/time-utils.js.map +1 -0
  207. package/dist/services/statusline.d.ts +10 -0
  208. package/dist/services/statusline.d.ts.map +1 -0
  209. package/dist/services/statusline.js +84 -0
  210. package/dist/services/statusline.js.map +1 -0
  211. package/dist/services/strategy.d.ts +16 -0
  212. package/dist/services/strategy.d.ts.map +1 -0
  213. package/dist/services/strategy.js +241 -0
  214. package/dist/services/strategy.js.map +1 -0
  215. package/dist/services/task-cleanup.d.ts +3 -0
  216. package/dist/services/task-cleanup.d.ts.map +1 -0
  217. package/dist/services/task-cleanup.js +81 -0
  218. package/dist/services/task-cleanup.js.map +1 -0
  219. package/dist/services/update-check.d.ts +15 -0
  220. package/dist/services/update-check.d.ts.map +1 -0
  221. package/dist/services/update-check.js +67 -0
  222. package/dist/services/update-check.js.map +1 -0
  223. package/dist/services/user-config.d.ts +12 -0
  224. package/dist/services/user-config.d.ts.map +1 -0
  225. package/dist/services/user-config.js +73 -0
  226. package/dist/services/user-config.js.map +1 -0
  227. package/dist/services/vcs/azure-devops.d.ts +7 -0
  228. package/dist/services/vcs/azure-devops.d.ts.map +1 -0
  229. package/dist/services/vcs/azure-devops.js +38 -0
  230. package/dist/services/vcs/azure-devops.js.map +1 -0
  231. package/dist/services/vcs/bitbucket.d.ts +6 -0
  232. package/dist/services/vcs/bitbucket.d.ts.map +1 -0
  233. package/dist/services/vcs/bitbucket.js +31 -0
  234. package/dist/services/vcs/bitbucket.js.map +1 -0
  235. package/dist/services/vcs/constants.d.ts +2 -0
  236. package/dist/services/vcs/constants.d.ts.map +1 -0
  237. package/dist/services/vcs/constants.js +6 -0
  238. package/dist/services/vcs/constants.js.map +1 -0
  239. package/dist/services/vcs/github.d.ts +6 -0
  240. package/dist/services/vcs/github.d.ts.map +1 -0
  241. package/dist/services/vcs/github.js +81 -0
  242. package/dist/services/vcs/github.js.map +1 -0
  243. package/dist/services/vcs/types.d.ts +52 -0
  244. package/dist/services/vcs/types.d.ts.map +1 -0
  245. package/dist/services/vcs/types.js +8 -0
  246. package/dist/services/vcs/types.js.map +1 -0
  247. package/dist/smoke-test.d.ts +10 -0
  248. package/dist/smoke-test.d.ts.map +1 -0
  249. package/dist/smoke-test.js +102 -0
  250. package/dist/smoke-test.js.map +1 -0
  251. package/dist/tools/check-status.d.ts +11 -0
  252. package/dist/tools/check-status.d.ts.map +1 -0
  253. package/dist/tools/check-status.js +247 -0
  254. package/dist/tools/check-status.js.map +1 -0
  255. package/dist/tools/cloud-control.d.ts +17 -0
  256. package/dist/tools/cloud-control.d.ts.map +1 -0
  257. package/dist/tools/cloud-control.js +102 -0
  258. package/dist/tools/cloud-control.js.map +1 -0
  259. package/dist/tools/compose-permissions.d.ts +26 -0
  260. package/dist/tools/compose-permissions.d.ts.map +1 -0
  261. package/dist/tools/compose-permissions.js +217 -0
  262. package/dist/tools/compose-permissions.js.map +1 -0
  263. package/dist/tools/credential-store-delete.d.ts +11 -0
  264. package/dist/tools/credential-store-delete.d.ts.map +1 -0
  265. package/dist/tools/credential-store-delete.js +15 -0
  266. package/dist/tools/credential-store-delete.js.map +1 -0
  267. package/dist/tools/credential-store-list.d.ts +4 -0
  268. package/dist/tools/credential-store-list.d.ts.map +1 -0
  269. package/dist/tools/credential-store-list.js +30 -0
  270. package/dist/tools/credential-store-list.js.map +1 -0
  271. package/dist/tools/credential-store-set.d.ts +26 -0
  272. package/dist/tools/credential-store-set.d.ts.map +1 -0
  273. package/dist/tools/credential-store-set.js +28 -0
  274. package/dist/tools/credential-store-set.js.map +1 -0
  275. package/dist/tools/credential-store-update.d.ts +20 -0
  276. package/dist/tools/credential-store-update.d.ts.map +1 -0
  277. package/dist/tools/credential-store-update.js +38 -0
  278. package/dist/tools/credential-store-update.js.map +1 -0
  279. package/dist/tools/execute-command.d.ts +33 -0
  280. package/dist/tools/execute-command.d.ts.map +1 -0
  281. package/dist/tools/execute-command.js +231 -0
  282. package/dist/tools/execute-command.js.map +1 -0
  283. package/dist/tools/execute-prompt.d.ts +36 -0
  284. package/dist/tools/execute-prompt.d.ts.map +1 -0
  285. package/dist/tools/execute-prompt.js +310 -0
  286. package/dist/tools/execute-prompt.js.map +1 -0
  287. package/dist/tools/list-members.d.ts +11 -0
  288. package/dist/tools/list-members.d.ts.map +1 -0
  289. package/dist/tools/list-members.js +108 -0
  290. package/dist/tools/list-members.js.map +1 -0
  291. package/dist/tools/member-detail.d.ts +17 -0
  292. package/dist/tools/member-detail.d.ts.map +1 -0
  293. package/dist/tools/member-detail.js +263 -0
  294. package/dist/tools/member-detail.js.map +1 -0
  295. package/dist/tools/monitor-task.d.ts +20 -0
  296. package/dist/tools/monitor-task.d.ts.map +1 -0
  297. package/dist/tools/monitor-task.js +89 -0
  298. package/dist/tools/monitor-task.js.map +1 -0
  299. package/dist/tools/provision-auth.d.ts +17 -0
  300. package/dist/tools/provision-auth.d.ts.map +1 -0
  301. package/dist/tools/provision-auth.js +256 -0
  302. package/dist/tools/provision-auth.js.map +1 -0
  303. package/dist/tools/provision-vcs-auth.d.ts +50 -0
  304. package/dist/tools/provision-vcs-auth.d.ts.map +1 -0
  305. package/dist/tools/provision-vcs-auth.js +187 -0
  306. package/dist/tools/provision-vcs-auth.js.map +1 -0
  307. package/dist/tools/receive-files.d.ts +20 -0
  308. package/dist/tools/receive-files.d.ts.map +1 -0
  309. package/dist/tools/receive-files.js +82 -0
  310. package/dist/tools/receive-files.js.map +1 -0
  311. package/dist/tools/register-member.d.ts +74 -0
  312. package/dist/tools/register-member.d.ts.map +1 -0
  313. package/dist/tools/register-member.js +310 -0
  314. package/dist/tools/register-member.js.map +1 -0
  315. package/dist/tools/remove-member.d.ts +17 -0
  316. package/dist/tools/remove-member.d.ts.map +1 -0
  317. package/dist/tools/remove-member.js +126 -0
  318. package/dist/tools/remove-member.js.map +1 -0
  319. package/dist/tools/revoke-vcs-auth.d.ts +23 -0
  320. package/dist/tools/revoke-vcs-auth.d.ts.map +1 -0
  321. package/dist/tools/revoke-vcs-auth.js +55 -0
  322. package/dist/tools/revoke-vcs-auth.js.map +1 -0
  323. package/dist/tools/send-files.d.ts +20 -0
  324. package/dist/tools/send-files.d.ts.map +1 -0
  325. package/dist/tools/send-files.js +103 -0
  326. package/dist/tools/send-files.js.map +1 -0
  327. package/dist/tools/setup-git-app.d.ts +17 -0
  328. package/dist/tools/setup-git-app.d.ts.map +1 -0
  329. package/dist/tools/setup-git-app.js +89 -0
  330. package/dist/tools/setup-git-app.js.map +1 -0
  331. package/dist/tools/setup-ssh-key.d.ts +14 -0
  332. package/dist/tools/setup-ssh-key.d.ts.map +1 -0
  333. package/dist/tools/setup-ssh-key.js +119 -0
  334. package/dist/tools/setup-ssh-key.js.map +1 -0
  335. package/dist/tools/shutdown-server.d.ts +4 -0
  336. package/dist/tools/shutdown-server.d.ts.map +1 -0
  337. package/dist/tools/shutdown-server.js +9 -0
  338. package/dist/tools/shutdown-server.js.map +1 -0
  339. package/dist/tools/stop-prompt.d.ts +14 -0
  340. package/dist/tools/stop-prompt.d.ts.map +1 -0
  341. package/dist/tools/stop-prompt.js +44 -0
  342. package/dist/tools/stop-prompt.js.map +1 -0
  343. package/dist/tools/update-agent-cli.d.ts +17 -0
  344. package/dist/tools/update-agent-cli.d.ts.map +1 -0
  345. package/dist/tools/update-agent-cli.js +110 -0
  346. package/dist/tools/update-agent-cli.js.map +1 -0
  347. package/dist/tools/update-member.d.ts +77 -0
  348. package/dist/tools/update-member.d.ts.map +1 -0
  349. package/dist/tools/update-member.js +202 -0
  350. package/dist/tools/update-member.js.map +1 -0
  351. package/dist/tools/version.d.ts +4 -0
  352. package/dist/tools/version.d.ts.map +1 -0
  353. package/dist/tools/version.js +7 -0
  354. package/dist/tools/version.js.map +1 -0
  355. package/dist/types.d.ts +70 -0
  356. package/dist/types.d.ts.map +1 -0
  357. package/dist/types.js +2 -0
  358. package/dist/types.js.map +1 -0
  359. package/dist/utils/agent-helpers.d.ts +41 -0
  360. package/dist/utils/agent-helpers.d.ts.map +1 -0
  361. package/dist/utils/agent-helpers.js +84 -0
  362. package/dist/utils/agent-helpers.js.map +1 -0
  363. package/dist/utils/ansi.d.ts +6 -0
  364. package/dist/utils/ansi.d.ts.map +1 -0
  365. package/dist/utils/ansi.js +20 -0
  366. package/dist/utils/ansi.js.map +1 -0
  367. package/dist/utils/auth-env.d.ts +8 -0
  368. package/dist/utils/auth-env.d.ts.map +1 -0
  369. package/dist/utils/auth-env.js +30 -0
  370. package/dist/utils/auth-env.js.map +1 -0
  371. package/dist/utils/collect-secret.d.ts +2 -0
  372. package/dist/utils/collect-secret.d.ts.map +1 -0
  373. package/dist/utils/collect-secret.js +80 -0
  374. package/dist/utils/collect-secret.js.map +1 -0
  375. package/dist/utils/credential-validation.d.ts +13 -0
  376. package/dist/utils/credential-validation.d.ts.map +1 -0
  377. package/dist/utils/credential-validation.js +35 -0
  378. package/dist/utils/credential-validation.js.map +1 -0
  379. package/dist/utils/crypto.d.ts +3 -0
  380. package/dist/utils/crypto.d.ts.map +1 -0
  381. package/dist/utils/crypto.js +61 -0
  382. package/dist/utils/crypto.js.map +1 -0
  383. package/dist/utils/deep-merge.d.ts +3 -0
  384. package/dist/utils/deep-merge.d.ts.map +1 -0
  385. package/dist/utils/deep-merge.js +23 -0
  386. package/dist/utils/deep-merge.js.map +1 -0
  387. package/dist/utils/file-permissions.d.ts +8 -0
  388. package/dist/utils/file-permissions.d.ts.map +1 -0
  389. package/dist/utils/file-permissions.js +13 -0
  390. package/dist/utils/file-permissions.js.map +1 -0
  391. package/dist/utils/gpu-parser.d.ts +6 -0
  392. package/dist/utils/gpu-parser.d.ts.map +1 -0
  393. package/dist/utils/gpu-parser.js +15 -0
  394. package/dist/utils/gpu-parser.js.map +1 -0
  395. package/dist/utils/log-helpers.d.ts +29 -0
  396. package/dist/utils/log-helpers.d.ts.map +1 -0
  397. package/dist/utils/log-helpers.js +128 -0
  398. package/dist/utils/log-helpers.js.map +1 -0
  399. package/dist/utils/oob-timeout.d.ts +2 -0
  400. package/dist/utils/oob-timeout.d.ts.map +1 -0
  401. package/dist/utils/oob-timeout.js +2 -0
  402. package/dist/utils/oob-timeout.js.map +1 -0
  403. package/dist/utils/pid-helpers.d.ts +11 -0
  404. package/dist/utils/pid-helpers.d.ts.map +1 -0
  405. package/dist/utils/pid-helpers.js +21 -0
  406. package/dist/utils/pid-helpers.js.map +1 -0
  407. package/dist/utils/platform.d.ts +13 -0
  408. package/dist/utils/platform.d.ts.map +1 -0
  409. package/dist/utils/platform.js +60 -0
  410. package/dist/utils/platform.js.map +1 -0
  411. package/dist/utils/prompt-errors.d.ts +5 -0
  412. package/dist/utils/prompt-errors.d.ts.map +1 -0
  413. package/dist/utils/prompt-errors.js +15 -0
  414. package/dist/utils/prompt-errors.js.map +1 -0
  415. package/dist/utils/resolve-member.d.ts +18 -0
  416. package/dist/utils/resolve-member.d.ts.map +1 -0
  417. package/dist/utils/resolve-member.js +23 -0
  418. package/dist/utils/resolve-member.js.map +1 -0
  419. package/dist/utils/secure-input.d.ts +6 -0
  420. package/dist/utils/secure-input.d.ts.map +1 -0
  421. package/dist/utils/secure-input.js +60 -0
  422. package/dist/utils/secure-input.js.map +1 -0
  423. package/dist/utils/shell-escape.d.ts +43 -0
  424. package/dist/utils/shell-escape.d.ts.map +1 -0
  425. package/dist/utils/shell-escape.js +67 -0
  426. package/dist/utils/shell-escape.js.map +1 -0
  427. package/dist/utils/ssh-error-messages.d.ts +5 -0
  428. package/dist/utils/ssh-error-messages.d.ts.map +1 -0
  429. package/dist/utils/ssh-error-messages.js +20 -0
  430. package/dist/utils/ssh-error-messages.js.map +1 -0
  431. package/dist/version.d.ts +18 -0
  432. package/dist/version.d.ts.map +1 -0
  433. package/dist/version.js +101 -0
  434. package/dist/version.js.map +1 -0
  435. package/hooks/hooks-config.json +15 -0
  436. package/hooks/post-register-member.sh +10 -0
  437. package/package.json +82 -0
  438. package/scripts/agy-settings-merge.js +27 -0
  439. package/scripts/agy-transcript-reader.js +62 -0
  440. package/scripts/fleet-statusline.sh +43 -0
  441. package/skills/fleet/SKILL.md +262 -0
  442. package/skills/fleet/auth-azdevops.md +72 -0
  443. package/skills/fleet/auth-bitbucket.md +65 -0
  444. package/skills/fleet/auth-github.md +86 -0
  445. package/skills/fleet/beads.md +90 -0
  446. package/skills/fleet/onboarding.md +92 -0
  447. package/skills/fleet/permissions.md +23 -0
  448. package/skills/fleet/profiles/base-dev.json +18 -0
  449. package/skills/fleet/profiles/base-reviewer.json +14 -0
  450. package/skills/fleet/profiles/cpp.json +4 -0
  451. package/skills/fleet/profiles/dotnet.json +4 -0
  452. package/skills/fleet/profiles/go.json +4 -0
  453. package/skills/fleet/profiles/jvm.json +4 -0
  454. package/skills/fleet/profiles/node.json +4 -0
  455. package/skills/fleet/profiles/python.json +4 -0
  456. package/skills/fleet/profiles/rust.json +4 -0
  457. package/skills/fleet/profiles/tpl-permissions.json +5 -0
  458. package/skills/fleet/skill-matrix.md +34 -0
  459. package/skills/fleet/troubleshooting.md +13 -0
  460. package/skills/pm/SKILL.md +110 -0
  461. package/skills/pm/backlog-item.md +65 -0
  462. package/skills/pm/beads.md +192 -0
  463. package/skills/pm/cleanup.md +15 -0
  464. package/skills/pm/context-file.md +40 -0
  465. package/skills/pm/doer-reviewer.md +123 -0
  466. package/skills/pm/init.md +25 -0
  467. package/skills/pm/multi-pair-sprint.md +64 -0
  468. package/skills/pm/plan-prompt.md +94 -0
  469. package/skills/pm/simple-sprint.md +42 -0
  470. package/skills/pm/single-pair-sprint.md +178 -0
  471. package/skills/pm/tpl-deploy.md +24 -0
  472. package/skills/pm/tpl-design.md +29 -0
  473. package/skills/pm/tpl-doer.md +43 -0
  474. package/skills/pm/tpl-plan.md +72 -0
  475. package/skills/pm/tpl-pm.md +2 -0
  476. package/skills/pm/tpl-progress.json +28 -0
  477. package/skills/pm/tpl-projects.md +4 -0
  478. package/skills/pm/tpl-requirements.md +21 -0
  479. package/skills/pm/tpl-reviewer-plan.md +53 -0
  480. package/skills/pm/tpl-reviewer.md +72 -0
  481. package/skills/pm/tpl-status.md +29 -0
  482. package/version.json +3 -0
@@ -0,0 +1,256 @@
1
+ import { z } from 'zod';
2
+ import fs from 'node:fs';
3
+ import os from 'node:os';
4
+ import { getStrategy } from '../services/strategy.js';
5
+ import { getOsCommands } from '../os/index.js';
6
+ import { getProvider } from '../providers/index.js';
7
+ import { escapeDoubleQuoted } from '../utils/shell-escape.js';
8
+ import { getAgentOS, touchAgent } from '../utils/agent-helpers.js';
9
+ import { memberIdentifier, resolveMember } from '../utils/resolve-member.js';
10
+ import { validateCredentials, credentialStatusNote } from '../utils/credential-validation.js';
11
+ import { credentialResolve } from '../services/credential-store.js';
12
+ import { encryptPassword, decryptPassword } from '../utils/crypto.js';
13
+ import { updateAgent } from '../services/registry.js';
14
+ import { collectOobApiKey } from '../services/auth-socket.js';
15
+ import { logLine } from '../utils/log-helpers.js';
16
+ export const provisionAuthSchema = z.object({
17
+ ...memberIdentifier,
18
+ api_key: z.string().optional().describe(`Your AI provider API key. If omitted, your local OAuth session is copied to the member instead. Supports {{secure.NAME}} token — value is resolved from the credential store before use.`),
19
+ });
20
+ /**
21
+ * Real auth check via `claude -p "hello"` — makes an actual API call.
22
+ * This is the only reliable validation for both OAuth and API key auth,
23
+ * since `claude auth status` doesn't actually validate API keys.
24
+ * Claude-only: other providers use a version check for verification.
25
+ */
26
+ async function verifyWithClaudePrompt(agent, envPrefix) {
27
+ const cmds = getOsCommands(getAgentOS(agent));
28
+ const provider = getProvider('claude');
29
+ const strategy = getStrategy(agent);
30
+ const escapedFolder = escapeDoubleQuoted(agent.workFolder);
31
+ const prefix = envPrefix ? `${envPrefix} ` : '';
32
+ const cmd = `cd "${escapedFolder}" && ${prefix}${cmds.agentCommand(provider, '-p "hello" --output-format json --max-turns 1')}`;
33
+ try {
34
+ const result = await strategy.execCommand(cmd, 60000);
35
+ return result.code === 0;
36
+ }
37
+ catch {
38
+ return false;
39
+ }
40
+ }
41
+ /**
42
+ * Version-based CLI check with optional env prefix.
43
+ * Used to verify non-Claude providers after API key provisioning.
44
+ */
45
+ async function verifyWithVersion(agent, provider, envPrefix) {
46
+ const cmds = getOsCommands(getAgentOS(agent));
47
+ const strategy = getStrategy(agent);
48
+ const prefix = envPrefix ? `${envPrefix} ` : '';
49
+ const cmd = `${prefix}${cmds.agentVersion(provider)}`;
50
+ try {
51
+ const result = await strategy.execCommand(cmd, 30000);
52
+ return result.code === 0;
53
+ }
54
+ catch {
55
+ return false;
56
+ }
57
+ }
58
+ // ---------------------------------------------------------------------------
59
+ // Flow A: Copy OAuth credentials using the provider interface
60
+ // ---------------------------------------------------------------------------
61
+ async function provisionOAuthCopy(agent, provider) {
62
+ const cmds = getOsCommands(getAgentOS(agent));
63
+ const strategy = getStrategy(agent);
64
+ const credentialFiles = provider.oauthCredentialFiles();
65
+ if (!credentialFiles || credentialFiles.length === 0) {
66
+ return `❌ Provider "${provider.name}" does not support OAuth credential copy.`;
67
+ }
68
+ // 1. Copy credential files
69
+ let credStatus = null;
70
+ for (const file of credentialFiles) {
71
+ try {
72
+ const localPath = file.localPath.replace('~', os.homedir());
73
+ if (fs.existsSync(localPath)) {
74
+ const content = fs.readFileSync(localPath, 'utf-8');
75
+ // Validate credentials before sending
76
+ if (file.localPath.includes('.json')) {
77
+ credStatus = validateCredentials(content);
78
+ if (credStatus?.status === 'expired-no-refresh') {
79
+ return `❌ OAuth token in ${file.localPath} is expired with no refresh token.
80
+ `
81
+ + ` Run /login in your ${provider.name} session, then re-run provision_llm_auth.`;
82
+ }
83
+ }
84
+ const result = await strategy.execCommand(cmds.credentialFileWrite(content, file.remotePath), 10000);
85
+ if (result.code !== 0 && result.stderr) {
86
+ return `❌ Failed to write ${file.remotePath} on "${agent.friendlyName}": ${result.stderr}`;
87
+ }
88
+ }
89
+ else {
90
+ return `❌ Could not find local credential file: ${localPath}`;
91
+ }
92
+ }
93
+ catch (err) {
94
+ return `❌ Failed to copy ${file.localPath} to "${agent.friendlyName}": ${err.message}`;
95
+ }
96
+ }
97
+ // 2. Merge settings
98
+ const mergeObj = provider.oauthSettingsMerge();
99
+ if (mergeObj) {
100
+ const settingsFile = credentialFiles.find(f => f.remotePath.includes('settings.json'));
101
+ const remoteSettingsPath = settingsFile ? settingsFile.remotePath : `${provider.credentialPath.replace(/\/$/, '')}/settings.json`;
102
+ try {
103
+ const result = await strategy.execCommand(cmds.deepMergeJson(remoteSettingsPath, mergeObj), 10000);
104
+ if (result.code !== 0 && result.stderr) {
105
+ return `❌ Failed to merge settings on "${agent.friendlyName}": ${result.stderr}`;
106
+ }
107
+ }
108
+ catch (err) {
109
+ return `❌ Failed to merge settings on "${agent.friendlyName}": ${err.message}`;
110
+ }
111
+ }
112
+ // 3. Unset env vars
113
+ const varsToUnset = provider.oauthEnvVarsToUnset() ?? [];
114
+ for (const envVar of varsToUnset) {
115
+ const unsetCmds = cmds.unsetEnv(envVar);
116
+ for (const cmd of unsetCmds) {
117
+ // Best effort, fire and forget
118
+ await strategy.execCommand(cmd, 15000).catch(() => { });
119
+ }
120
+ }
121
+ // 4. Verify auth
122
+ const authWorks = provider.name === 'claude'
123
+ ? await verifyWithClaudePrompt(agent)
124
+ : await verifyWithVersion(agent, provider);
125
+ touchAgent(agent.id);
126
+ const statusNote = credentialStatusNote(credStatus);
127
+ const suffix = statusNote ? `\n ${statusNote}` : '';
128
+ if (authWorks) {
129
+ return `✅ OAuth credentials for ${provider.name} deployed to "${agent.friendlyName}"
130
+ `
131
+ + ` Auth: verified with a successful ${provider.name} API call.${suffix}`;
132
+ }
133
+ return `⚠️ ${provider.name} OAuth credentials deployed to "${agent.friendlyName}" but could not verify auth.
134
+ `
135
+ + ` Credential files were written — try running a prompt to confirm.${suffix}`;
136
+ }
137
+ // ---------------------------------------------------------------------------
138
+ // Flow B — API Key Override (all providers)
139
+ // ---------------------------------------------------------------------------
140
+ async function provisionApiKey(agent, apiKey, provider) {
141
+ const cmds = getOsCommands(getAgentOS(agent));
142
+ const strategy = getStrategy(agent);
143
+ const envVarName = provider.authEnvVarForToken(apiKey);
144
+ const commands = cmds.setEnv(envVarName, apiKey);
145
+ const errors = [];
146
+ for (const cmd of commands) {
147
+ try {
148
+ const result = await strategy.execCommand(cmd, 15000);
149
+ if (result.code !== 0 && result.stderr) {
150
+ errors.push(`Command "${cmd.substring(0, 40)}..." stderr: ${result.stderr}`);
151
+ }
152
+ }
153
+ catch (err) {
154
+ errors.push(`Command failed: ${err.message}`);
155
+ }
156
+ }
157
+ // Store encrypted API key in the agent's registry entry
158
+ updateAgent(agent.id, {
159
+ encryptedEnvVars: { ...agent.encryptedEnvVars, [envVarName]: encryptPassword(apiKey) },
160
+ });
161
+ // Verify the key was persisted in a new shell
162
+ let verified = false;
163
+ try {
164
+ const verifyResult = await strategy.execCommand(cmds.apiKeyCheck(envVarName), 10000);
165
+ verified = verifyResult.stdout.trim().length > 5;
166
+ }
167
+ catch {
168
+ // May still work after re-login
169
+ }
170
+ // Verify with a real CLI call
171
+ const envPrefix = cmds.envPrefix(envVarName, apiKey);
172
+ const authWorks = provider.name === 'claude'
173
+ ? await verifyWithClaudePrompt(agent, envPrefix)
174
+ : await verifyWithVersion(agent, provider, envPrefix);
175
+ touchAgent(agent.id);
176
+ let result = '';
177
+ if (errors.length === 0) {
178
+ result += `✅ API key provisioned on "${agent.friendlyName}"
179
+ `;
180
+ }
181
+ else {
182
+ result += `⚠️ API key provisioned with some issues on "${agent.friendlyName}":
183
+ `;
184
+ for (const e of errors) {
185
+ result += ` - ${e}
186
+ `;
187
+ }
188
+ }
189
+ result += `
190
+ Environment: ${envVarName} set in shell profiles and stored in member config
191
+ `;
192
+ result += ` Verification: ${verified ? 'Key visible in new shell' : 'Key will be available after re-login'}
193
+ `;
194
+ result += ` Auth test: ${authWorks ? `${provider.name} CLI authenticated successfully` : 'Could not verify — may need to re-login'}
195
+ `;
196
+ return result;
197
+ }
198
+ // ---------------------------------------------------------------------------
199
+ // Entry point
200
+ // ---------------------------------------------------------------------------
201
+ export async function provisionAuth(input) {
202
+ const agentOrError = resolveMember(input.member_id, input.member_name);
203
+ if (typeof agentOrError === 'string')
204
+ return agentOrError;
205
+ const agent = agentOrError;
206
+ if (agent.agentType === 'local') {
207
+ return `⏭️ Skipping "${agent.friendlyName}" — local members use this machine's credentials directly.`;
208
+ }
209
+ const strategy = getStrategy(agent);
210
+ const conn = await strategy.testConnection();
211
+ if (!conn.ok) {
212
+ return `❌ Member "${agent.friendlyName}" is offline: ${conn.error}`;
213
+ }
214
+ const provider = getProvider(agent.llmProvider);
215
+ // Flow B: API key is provided directly
216
+ if (input.api_key) {
217
+ const TOKEN_RE = /\{\{secure\.([a-zA-Z0-9_-]{1,64})\}\}/g;
218
+ const tokenNames = new Set();
219
+ let match;
220
+ while ((match = TOKEN_RE.exec(input.api_key)) !== null)
221
+ tokenNames.add(match[1]);
222
+ let resolvedKey = input.api_key;
223
+ for (const name of tokenNames) {
224
+ const entry = credentialResolve(name, agent.friendlyName);
225
+ if (!entry)
226
+ return `❌ Credential "${name}" not found. Run credential_store_set first.`;
227
+ if ('denied' in entry)
228
+ return `❌ ${entry.denied}`;
229
+ if ('expired' in entry)
230
+ return `❌ ${entry.expired}`;
231
+ resolvedKey = resolvedKey.replaceAll(`{{secure.${name}}}`, entry.plaintext);
232
+ }
233
+ const result = await provisionApiKey(agent, resolvedKey, provider);
234
+ if (!result.startsWith('❌'))
235
+ logLine('provision_llm_auth', `provider=${provider.name}`, agent);
236
+ return result;
237
+ }
238
+ // Flow A: OAuth credentials copy
239
+ if (provider.oauthCredentialFiles()?.length) {
240
+ const result = await provisionOAuthCopy(agent, provider);
241
+ if (!result.startsWith('❌'))
242
+ logLine('provision_llm_auth', `provider=${provider.name}`, agent);
243
+ return result;
244
+ }
245
+ // Fallback: OOB key collection for non-OAuth or non-copyable providers
246
+ const oob = await collectOobApiKey(agent.friendlyName, 'provision_llm_auth', {
247
+ prompt: `Enter API key for ${provider.name} on ${agent.friendlyName}`,
248
+ });
249
+ if ('fallback' in oob)
250
+ return oob.fallback ?? 'Error: OOB operation cancelled.';
251
+ const result = await provisionApiKey(agent, decryptPassword(oob.password), provider);
252
+ if (!result.startsWith('❌'))
253
+ logLine('provision_llm_auth', `provider=${provider.name}`, agent);
254
+ return result;
255
+ }
256
+ //# sourceMappingURL=provision-auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provision-auth.js","sourceRoot":"","sources":["../../src/tools/provision-auth.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ import { z } from 'zod';
2
+ export declare const provisionVcsAuthSchema: z.ZodObject<{
3
+ provider: z.ZodEnum<["github", "bitbucket", "azure-devops"]>;
4
+ label: z.ZodOptional<z.ZodString>;
5
+ scope_url: z.ZodOptional<z.ZodString>;
6
+ github_mode: z.ZodOptional<z.ZodEnum<["github-app", "pat"]>>;
7
+ token: z.ZodOptional<z.ZodString>;
8
+ git_access: z.ZodOptional<z.ZodEnum<["read", "push", "admin", "issues", "full"]>>;
9
+ repos: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
10
+ email: z.ZodOptional<z.ZodString>;
11
+ api_token: z.ZodOptional<z.ZodString>;
12
+ workspace: z.ZodOptional<z.ZodString>;
13
+ org_url: z.ZodOptional<z.ZodString>;
14
+ pat: z.ZodOptional<z.ZodString>;
15
+ member_id: z.ZodOptional<z.ZodString>;
16
+ member_name: z.ZodOptional<z.ZodString>;
17
+ }, "strip", z.ZodTypeAny, {
18
+ provider: "github" | "bitbucket" | "azure-devops";
19
+ token?: string | undefined;
20
+ git_access?: "read" | "push" | "admin" | "issues" | "full" | undefined;
21
+ pat?: string | undefined;
22
+ repos?: string[] | undefined;
23
+ workspace?: string | undefined;
24
+ email?: string | undefined;
25
+ member_id?: string | undefined;
26
+ member_name?: string | undefined;
27
+ label?: string | undefined;
28
+ scope_url?: string | undefined;
29
+ github_mode?: "github-app" | "pat" | undefined;
30
+ api_token?: string | undefined;
31
+ org_url?: string | undefined;
32
+ }, {
33
+ provider: "github" | "bitbucket" | "azure-devops";
34
+ token?: string | undefined;
35
+ git_access?: "read" | "push" | "admin" | "issues" | "full" | undefined;
36
+ pat?: string | undefined;
37
+ repos?: string[] | undefined;
38
+ workspace?: string | undefined;
39
+ email?: string | undefined;
40
+ member_id?: string | undefined;
41
+ member_name?: string | undefined;
42
+ label?: string | undefined;
43
+ scope_url?: string | undefined;
44
+ github_mode?: "github-app" | "pat" | undefined;
45
+ api_token?: string | undefined;
46
+ org_url?: string | undefined;
47
+ }>;
48
+ export type ProvisionVcsAuthInput = z.infer<typeof provisionVcsAuthSchema>;
49
+ export declare function provisionVcsAuth(input: ProvisionVcsAuthInput): Promise<string>;
50
+ //# sourceMappingURL=provision-vcs-auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provision-vcs-auth.d.ts","sourceRoot":"","sources":["../../src/tools/provision-vcs-auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AA0CxB,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAoBjC,CAAC;AAEH,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC;AA0B3E,wBAAsB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,GAAG,OAAO,CAAC,MAAM,CAAC,CA4GpF"}
@@ -0,0 +1,187 @@
1
+ import { z } from 'zod';
2
+ import { getStrategy } from '../services/strategy.js';
3
+ import { getOsCommands } from '../os/index.js';
4
+ import { getAgentOS, touchAgent, checkVcsTokenExpiry } from '../utils/agent-helpers.js';
5
+ import { memberIdentifier, resolveMember } from '../utils/resolve-member.js';
6
+ import { updateAgent } from '../services/registry.js';
7
+ import { credentialResolve } from '../services/credential-store.js';
8
+ import { collectOobApiKey } from '../services/auth-socket.js';
9
+ import { decryptPassword } from '../utils/crypto.js';
10
+ import { githubProvider } from '../services/vcs/github.js';
11
+ import { bitbucketProvider } from '../services/vcs/bitbucket.js';
12
+ import { azureDevOpsProvider } from '../services/vcs/azure-devops.js';
13
+ import { scheduleCredentialCleanup, cancelCredentialCleanup } from '../services/credential-cleanup.js';
14
+ import { PROVIDER_HOSTS } from '../services/vcs/constants.js';
15
+ import { logLine } from '../utils/log-helpers.js';
16
+ const TOKEN_RE = /\{\{secure\.([a-zA-Z0-9_-]{1,64})\}\}/g;
17
+ function resolveSecureField(value, callingMember) {
18
+ const tokenNames = new Set();
19
+ let match;
20
+ TOKEN_RE.lastIndex = 0;
21
+ while ((match = TOKEN_RE.exec(value)) !== null)
22
+ tokenNames.add(match[1]);
23
+ let resolved = value;
24
+ for (const name of tokenNames) {
25
+ const entry = credentialResolve(name, callingMember);
26
+ if (!entry)
27
+ return { error: `Credential "${name}" not found. Run credential_store_set first.` };
28
+ if ('denied' in entry)
29
+ return { error: entry.denied };
30
+ if ('expired' in entry)
31
+ return { error: entry.expired };
32
+ resolved = resolved.replaceAll(`{{secure.${name}}}`, entry.plaintext);
33
+ }
34
+ return { resolved };
35
+ }
36
+ const providers = {
37
+ 'github': githubProvider,
38
+ 'bitbucket': bitbucketProvider,
39
+ 'azure-devops': azureDevOpsProvider,
40
+ };
41
+ export const provisionVcsAuthSchema = z.object({
42
+ ...memberIdentifier,
43
+ provider: z.enum(['github', 'bitbucket', 'azure-devops']).describe('VCS provider to configure'),
44
+ label: z.string().regex(/^[a-zA-Z0-9_-]{1,64}$/).optional().describe('Credential label (slug, e.g. "work-github"). Defaults to provider name. Enables multiple credentials per provider.'),
45
+ scope_url: z.string().optional().describe('Git credential scope URL (e.g. "https://github.com/my-org"). Defaults to "https://<host>".'),
46
+ // GitHub fields
47
+ github_mode: z.enum(['github-app', 'pat']).optional().describe('GitHub auth mode: github-app (mint via configured app) or pat (personal access token)'),
48
+ token: z.string().optional().describe('Personal access token (GitHub PAT or Azure DevOps PAT). Supports {{secure.NAME}} token — value is resolved from the credential store before use.'),
49
+ git_access: z.enum(['read', 'push', 'admin', 'issues', 'full']).optional().describe('GitHub App access level override'),
50
+ repos: z.array(z.string()).optional().describe('GitHub App repository list override'),
51
+ // Bitbucket fields
52
+ email: z.string().optional().describe('Bitbucket account email'),
53
+ api_token: z.string().optional().describe('Bitbucket API token. Supports {{secure.NAME}} token — value is resolved from the credential store before use.'),
54
+ workspace: z.string().optional().describe('Bitbucket workspace slug'),
55
+ // Azure DevOps fields
56
+ org_url: z.string().optional().describe('Azure DevOps organization URL (e.g. https://dev.azure.com/myorg)'),
57
+ pat: z.string().optional().describe('Azure DevOps personal access token. Supports {{secure.NAME}} token — value is resolved from the credential store before use.'),
58
+ });
59
+ function buildCredentials(input) {
60
+ switch (input.provider) {
61
+ case 'github': {
62
+ const mode = input.github_mode ?? 'github-app';
63
+ if (mode === 'pat') {
64
+ if (!input.token)
65
+ return 'GitHub PAT mode requires "token" field.';
66
+ return { type: 'pat', token: input.token };
67
+ }
68
+ return { type: 'github-app', git_access: input.git_access, repos: input.repos };
69
+ }
70
+ case 'bitbucket': {
71
+ if (!input.email || !input.api_token || !input.workspace) {
72
+ return 'Bitbucket requires "email", "api_token", and "workspace" fields.';
73
+ }
74
+ return { email: input.email, api_token: input.api_token, workspace: input.workspace };
75
+ }
76
+ case 'azure-devops': {
77
+ const azPat = input.pat ?? input.token;
78
+ if (!input.org_url || !azPat)
79
+ return 'Azure DevOps requires "org_url" and "pat" (or "token") fields.';
80
+ return { org_url: input.org_url, pat: azPat };
81
+ }
82
+ }
83
+ }
84
+ export async function provisionVcsAuth(input) {
85
+ const agentOrError = resolveMember(input.member_id, input.member_name);
86
+ if (typeof agentOrError === 'string')
87
+ return agentOrError;
88
+ const agent = agentOrError;
89
+ const service = providers[input.provider];
90
+ // Resolve {{secure.NAME}} tokens in credential fields
91
+ const resolvedInput = { ...input };
92
+ for (const field of ['token', 'api_token', 'pat']) {
93
+ if (resolvedInput[field]) {
94
+ const r = resolveSecureField(resolvedInput[field], agent.friendlyName);
95
+ if ('error' in r)
96
+ return `❌ ${r.error}`;
97
+ resolvedInput[field] = r.resolved;
98
+ }
99
+ }
100
+ // OOB fallback for absent credential fields
101
+ if (resolvedInput.provider === 'github' && (resolvedInput.github_mode ?? 'github-app') === 'pat' && resolvedInput.token === undefined) {
102
+ const oob = await collectOobApiKey(agent.friendlyName, 'provision_vcs_auth', {
103
+ prompt: `Enter GitHub personal access token for ${agent.friendlyName}`,
104
+ });
105
+ if ('fallback' in oob)
106
+ return oob.fallback ?? 'Error: OOB operation cancelled.';
107
+ resolvedInput.token = decryptPassword(oob.password);
108
+ }
109
+ if (resolvedInput.provider === 'bitbucket' && resolvedInput.api_token === undefined) {
110
+ const oob = await collectOobApiKey(agent.friendlyName, 'provision_vcs_auth', {
111
+ prompt: `Enter Bitbucket API token for ${agent.friendlyName}`,
112
+ });
113
+ if ('fallback' in oob)
114
+ return oob.fallback ?? 'Error: OOB operation cancelled.';
115
+ resolvedInput.api_token = decryptPassword(oob.password);
116
+ }
117
+ if (resolvedInput.provider === 'azure-devops' && resolvedInput.pat === undefined && resolvedInput.token === undefined) {
118
+ const oob = await collectOobApiKey(agent.friendlyName, 'provision_vcs_auth', {
119
+ prompt: `Enter Azure DevOps personal access token for ${agent.friendlyName}`,
120
+ });
121
+ if ('fallback' in oob)
122
+ return oob.fallback ?? 'Error: OOB operation cancelled.';
123
+ resolvedInput.pat = decryptPassword(oob.password);
124
+ }
125
+ const creds = buildCredentials(resolvedInput);
126
+ if (typeof creds === 'string')
127
+ return `❌ ${creds}`;
128
+ const label = input.label ?? input.provider;
129
+ const host = PROVIDER_HOSTS[input.provider];
130
+ const scopeUrl = input.scope_url ?? `https://${host}`;
131
+ // Cancel any existing credential cleanup timer before re-provisioning
132
+ cancelCredentialCleanup(agent.id);
133
+ const strategy = getStrategy(agent);
134
+ const conn = await strategy.testConnection();
135
+ if (!conn.ok)
136
+ return `❌ Member "${agent.friendlyName}" is offline: ${conn.error}`;
137
+ const cmds = getOsCommands(getAgentOS(agent));
138
+ const exec = async (cmd) => {
139
+ const result = await strategy.execCommand(cmd, 15000);
140
+ if (result.code !== 0 && result.stderr)
141
+ throw new Error(result.stderr);
142
+ return result.stdout;
143
+ };
144
+ // Legacy migration: remove old single-file credential helpers
145
+ try {
146
+ await exec(cmds.gitCredentialHelperRemove(host));
147
+ }
148
+ catch { /* best-effort */ }
149
+ let deployResult;
150
+ try {
151
+ deployResult = await service.deploy(agent, cmds, exec, creds, label, scopeUrl);
152
+ }
153
+ catch (err) {
154
+ return `❌ Failed to deploy ${input.provider} credentials on "${agent.friendlyName}": ${err.message}`;
155
+ }
156
+ if (!deployResult.success)
157
+ return `❌ ${deployResult.message}`;
158
+ // Persist VCS provider and token expiry in the agent registry
159
+ updateAgent(agent.id, {
160
+ vcsProvider: input.provider,
161
+ vcsTokenExpiresAt: deployResult.metadata?.expiresAt,
162
+ });
163
+ // Schedule auto-cleanup when token expires
164
+ scheduleCredentialCleanup(agent.id, deployResult.metadata?.expiresAt);
165
+ // Best-effort connectivity test
166
+ let connectivity;
167
+ try {
168
+ connectivity = await service.testConnectivity(agent, exec);
169
+ }
170
+ catch {
171
+ connectivity = { success: false, message: 'connectivity test threw' };
172
+ }
173
+ touchAgent(agent.id);
174
+ logLine('provision_vcs_auth', `provider=${input.provider}`, agent);
175
+ const meta = deployResult.metadata
176
+ ? Object.entries(deployResult.metadata).map(([k, v]) => ` ${k}: ${v}`).join('\n')
177
+ : '';
178
+ // Check if the just-deployed token is already near expiry
179
+ const expiryWarning = deployResult.metadata?.expiresAt
180
+ ? checkVcsTokenExpiry({ ...agent, vcsTokenExpiresAt: deployResult.metadata.expiresAt })
181
+ : null;
182
+ return `✅ ${deployResult.message} on "${agent.friendlyName}"\n`
183
+ + (meta ? meta + '\n' : '')
184
+ + ` Verification: ${connectivity.success ? connectivity.message : `⚠️ ${connectivity.message}`}`
185
+ + (expiryWarning ? `\n ${expiryWarning}` : '');
186
+ }
187
+ //# sourceMappingURL=provision-vcs-auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provision-vcs-auth.js","sourceRoot":"","sources":["../../src/tools/provision-vcs-auth.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { z } from 'zod';
2
+ export declare const receiveFilesSchema: z.ZodObject<{
3
+ remote_paths: z.ZodArray<z.ZodString, "many">;
4
+ local_dest_dir: z.ZodString;
5
+ member_id: z.ZodOptional<z.ZodString>;
6
+ member_name: z.ZodOptional<z.ZodString>;
7
+ }, "strip", z.ZodTypeAny, {
8
+ remote_paths: string[];
9
+ local_dest_dir: string;
10
+ member_id?: string | undefined;
11
+ member_name?: string | undefined;
12
+ }, {
13
+ remote_paths: string[];
14
+ local_dest_dir: string;
15
+ member_id?: string | undefined;
16
+ member_name?: string | undefined;
17
+ }>;
18
+ export type ReceiveFilesInput = z.infer<typeof receiveFilesSchema>;
19
+ export declare function receiveFiles(input: ReceiveFilesInput, extra?: any): Promise<string>;
20
+ //# sourceMappingURL=receive-files.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"receive-files.d.ts","sourceRoot":"","sources":["../../src/tools/receive-files.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAUxB,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;EAW7B,CAAC;AAEH,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAEnE,wBAAsB,YAAY,CAAC,KAAK,EAAE,iBAAiB,EAAE,KAAK,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAuEzF"}
@@ -0,0 +1,82 @@
1
+ import path from 'node:path';
2
+ import { z } from 'zod';
3
+ import { getStrategy } from '../services/strategy.js';
4
+ import { touchAgent } from '../utils/agent-helpers.js';
5
+ import { memberIdentifier, resolveMember } from '../utils/resolve-member.js';
6
+ import { writeStatusline } from '../services/statusline.js';
7
+ import { ensureCloudReady } from '../services/cloud/lifecycle.js';
8
+ import { isContainedInWorkFolder } from '../utils/platform.js';
9
+ import { LogScope } from '../utils/log-helpers.js';
10
+ export const receiveFilesSchema = z.object({
11
+ ...memberIdentifier,
12
+ remote_paths: z.array(z.string()).describe('Paths on the member to download. Relative paths resolved from work_folder. ' +
13
+ 'Absolute paths must remain within work_folder — paths outside it are rejected. ' +
14
+ 'Always batch multiple files into a single call.'),
15
+ // No boundary restriction — caller controls their own local filesystem
16
+ local_dest_dir: z.string().describe('Required. Local directory to write the downloaded files into.'),
17
+ });
18
+ export async function receiveFiles(input, extra) {
19
+ const agentOrError = resolveMember(input.member_id, input.member_name);
20
+ if (typeof agentOrError === 'string')
21
+ return agentOrError;
22
+ let agent;
23
+ try {
24
+ agent = await ensureCloudReady(agentOrError); // auto-start if stopped
25
+ }
26
+ catch (err) {
27
+ return `Failed to download files from "${agentOrError.friendlyName}": ${err.message}`;
28
+ }
29
+ // Path security: verify each remote_path stays within work_folder
30
+ for (const remotePath of input.remote_paths) {
31
+ if (remotePath.includes('\0')) {
32
+ return `⛔ Invalid remote_path: null bytes are not allowed.`;
33
+ }
34
+ if (agent.agentType === 'local') {
35
+ const resolved = path.resolve(agent.workFolder, remotePath);
36
+ const workFolderNorm = path.resolve(agent.workFolder);
37
+ if (resolved !== workFolderNorm && !resolved.startsWith(workFolderNorm + path.sep)) {
38
+ return `remote_path "${remotePath}" resolves outside member work_folder — read blocked`;
39
+ }
40
+ }
41
+ else {
42
+ if (!isContainedInWorkFolder(agent.workFolder, remotePath)) {
43
+ return `remote_path "${remotePath}" resolves outside member work_folder — read blocked`;
44
+ }
45
+ }
46
+ }
47
+ const strategy = getStrategy(agent);
48
+ const pathSummary = input.remote_paths[0] ?? '';
49
+ const scope = new LogScope('receive_files', `${input.remote_paths.length} file(s) ← ${agent.friendlyName}:${pathSummary}`, agent);
50
+ writeStatusline(new Map([[agent.id, 'busy']]));
51
+ try {
52
+ const result = await strategy.receiveFiles(input.remote_paths, input.local_dest_dir, extra?.signal);
53
+ touchAgent(agent.id);
54
+ let output = '';
55
+ if (result.success.length > 0) {
56
+ output += `✅ Successfully downloaded ${result.success.length} file(s) from ${agent.friendlyName}:\n`;
57
+ for (const f of result.success) {
58
+ output += ` - ${f}\n`;
59
+ }
60
+ }
61
+ if (result.failed.length > 0) {
62
+ output += `\n❌ Failed to download ${result.failed.length} file(s):\n`;
63
+ for (const f of result.failed) {
64
+ output += ` - ${f.path}: ${f.error}\n`;
65
+ }
66
+ }
67
+ output += `\nLocal destination: ${input.local_dest_dir}`;
68
+ if (result.failed.length > 0 && result.success.length > 0)
69
+ scope.fail(`${result.success.length} ok, ${result.failed.length} failed`);
70
+ else if (result.failed.length > 0)
71
+ scope.abort(`all ${result.failed.length} file(s) failed`);
72
+ else
73
+ scope.ok(`${result.success.length} file(s)`);
74
+ return output;
75
+ }
76
+ catch (err) {
77
+ writeStatusline(new Map([[agent.id, 'offline']]));
78
+ scope.abort(err.message);
79
+ return `Failed to download files from "${agent.friendlyName}": ${err.message}`;
80
+ }
81
+ }
82
+ //# sourceMappingURL=receive-files.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"receive-files.js","sourceRoot":"","sources":["../../src/tools/receive-files.ts"],"names":[],"mappings":"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"}