@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.
- package/LICENSE +182 -0
- package/README.md +324 -0
- package/dist/cli/auth.d.ts +2 -0
- package/dist/cli/auth.d.ts.map +1 -0
- package/dist/cli/auth.js +210 -0
- package/dist/cli/auth.js.map +1 -0
- package/dist/cli/config.d.ts +30 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +157 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/install.d.ts +37 -0
- package/dist/cli/install.d.ts.map +1 -0
- package/dist/cli/install.js +630 -0
- package/dist/cli/install.js.map +1 -0
- package/dist/cli/secret.d.ts +2 -0
- package/dist/cli/secret.d.ts.map +1 -0
- package/dist/cli/secret.js +366 -0
- package/dist/cli/secret.js.map +1 -0
- package/dist/cli/uninstall.d.ts +2 -0
- package/dist/cli/uninstall.d.ts.map +1 -0
- package/dist/cli/uninstall.js +312 -0
- package/dist/cli/uninstall.js.map +1 -0
- package/dist/cli/update.d.ts +2 -0
- package/dist/cli/update.d.ts.map +1 -0
- package/dist/cli/update.js +105 -0
- package/dist/cli/update.js.map +1 -0
- package/dist/delivery-mode.d.ts +19 -0
- package/dist/delivery-mode.d.ts.map +1 -0
- package/dist/delivery-mode.js +26 -0
- package/dist/delivery-mode.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +272 -0
- package/dist/index.js.map +1 -0
- package/dist/onboarding/text.d.ts +83 -0
- package/dist/onboarding/text.d.ts.map +1 -0
- package/dist/onboarding/text.js +126 -0
- package/dist/onboarding/text.js.map +1 -0
- package/dist/os/index.d.ts +9 -0
- package/dist/os/index.d.ts.map +1 -0
- package/dist/os/index.js +16 -0
- package/dist/os/index.js.map +1 -0
- package/dist/os/linux.d.ts +50 -0
- package/dist/os/linux.d.ts.map +1 -0
- package/dist/os/linux.js +244 -0
- package/dist/os/linux.js.map +1 -0
- package/dist/os/macos.d.ts +12 -0
- package/dist/os/macos.d.ts.map +1 -0
- package/dist/os/macos.js +41 -0
- package/dist/os/macos.js.map +1 -0
- package/dist/os/os-commands.d.ts +47 -0
- package/dist/os/os-commands.d.ts.map +1 -0
- package/dist/os/os-commands.js +3 -0
- package/dist/os/os-commands.js.map +1 -0
- package/dist/os/windows-wrapper.d.ts +6 -0
- package/dist/os/windows-wrapper.d.ts.map +1 -0
- package/dist/os/windows-wrapper.js +9 -0
- package/dist/os/windows-wrapper.js.map +1 -0
- package/dist/os/windows.d.ts +44 -0
- package/dist/os/windows.d.ts.map +1 -0
- package/dist/os/windows.js +269 -0
- package/dist/os/windows.js.map +1 -0
- package/dist/paths.d.ts +2 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +4 -0
- package/dist/paths.js.map +1 -0
- package/dist/providers/agy.d.ts +41 -0
- package/dist/providers/agy.d.ts.map +1 -0
- package/dist/providers/agy.js +208 -0
- package/dist/providers/agy.js.map +1 -0
- package/dist/providers/claude.d.ts +40 -0
- package/dist/providers/claude.d.ts.map +1 -0
- package/dist/providers/claude.js +178 -0
- package/dist/providers/claude.js.map +1 -0
- package/dist/providers/codex.d.ts +44 -0
- package/dist/providers/codex.d.ts.map +1 -0
- package/dist/providers/codex.js +173 -0
- package/dist/providers/codex.js.map +1 -0
- package/dist/providers/copilot.d.ts +40 -0
- package/dist/providers/copilot.d.ts.map +1 -0
- package/dist/providers/copilot.js +172 -0
- package/dist/providers/copilot.js.map +1 -0
- package/dist/providers/gemini.d.ts +41 -0
- package/dist/providers/gemini.d.ts.map +1 -0
- package/dist/providers/gemini.js +192 -0
- package/dist/providers/gemini.js.map +1 -0
- package/dist/providers/index.d.ts +10 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +27 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/provider.d.ts +85 -0
- package/dist/providers/provider.d.ts.map +1 -0
- package/dist/providers/provider.js +21 -0
- package/dist/providers/provider.js.map +1 -0
- package/dist/services/auth-socket.d.ts +87 -0
- package/dist/services/auth-socket.d.ts.map +1 -0
- package/dist/services/auth-socket.js +684 -0
- package/dist/services/auth-socket.js.map +1 -0
- package/dist/services/auth-web.d.ts +31 -0
- package/dist/services/auth-web.d.ts.map +1 -0
- package/dist/services/auth-web.js +202 -0
- package/dist/services/auth-web.js.map +1 -0
- package/dist/services/cloud/activity.d.ts +16 -0
- package/dist/services/cloud/activity.d.ts.map +1 -0
- package/dist/services/cloud/activity.js +61 -0
- package/dist/services/cloud/activity.js.map +1 -0
- package/dist/services/cloud/aws.d.ts +24 -0
- package/dist/services/cloud/aws.d.ts.map +1 -0
- package/dist/services/cloud/aws.js +114 -0
- package/dist/services/cloud/aws.js.map +1 -0
- package/dist/services/cloud/cost.d.ts +46 -0
- package/dist/services/cloud/cost.d.ts.map +1 -0
- package/dist/services/cloud/cost.js +161 -0
- package/dist/services/cloud/cost.js.map +1 -0
- package/dist/services/cloud/idle-manager.d.ts +20 -0
- package/dist/services/cloud/idle-manager.d.ts.map +1 -0
- package/dist/services/cloud/idle-manager.js +103 -0
- package/dist/services/cloud/idle-manager.js.map +1 -0
- package/dist/services/cloud/lifecycle.d.ts +14 -0
- package/dist/services/cloud/lifecycle.d.ts.map +1 -0
- package/dist/services/cloud/lifecycle.js +128 -0
- package/dist/services/cloud/lifecycle.js.map +1 -0
- package/dist/services/cloud/task-wrapper.d.ts +30 -0
- package/dist/services/cloud/task-wrapper.d.ts.map +1 -0
- package/dist/services/cloud/task-wrapper.js +116 -0
- package/dist/services/cloud/task-wrapper.js.map +1 -0
- package/dist/services/cloud/types.d.ts +26 -0
- package/dist/services/cloud/types.d.ts.map +1 -0
- package/dist/services/cloud/types.js +2 -0
- package/dist/services/cloud/types.js.map +1 -0
- package/dist/services/credential-cleanup.d.ts +4 -0
- package/dist/services/credential-cleanup.d.ts.map +1 -0
- package/dist/services/credential-cleanup.js +61 -0
- package/dist/services/credential-cleanup.js.map +1 -0
- package/dist/services/credential-store.d.ts +56 -0
- package/dist/services/credential-store.d.ts.map +1 -0
- package/dist/services/credential-store.js +280 -0
- package/dist/services/credential-store.js.map +1 -0
- package/dist/services/file-transfer.d.ts +22 -0
- package/dist/services/file-transfer.d.ts.map +1 -0
- package/dist/services/file-transfer.js +14 -0
- package/dist/services/file-transfer.js.map +1 -0
- package/dist/services/git-config.d.ts +6 -0
- package/dist/services/git-config.d.ts.map +1 -0
- package/dist/services/git-config.js +31 -0
- package/dist/services/git-config.js.map +1 -0
- package/dist/services/github-app.d.ts +30 -0
- package/dist/services/github-app.d.ts.map +1 -0
- package/dist/services/github-app.js +96 -0
- package/dist/services/github-app.js.map +1 -0
- package/dist/services/icons.d.ts +16 -0
- package/dist/services/icons.d.ts.map +1 -0
- package/dist/services/icons.js +67 -0
- package/dist/services/icons.js.map +1 -0
- package/dist/services/known-hosts.d.ts +23 -0
- package/dist/services/known-hosts.d.ts.map +1 -0
- package/dist/services/known-hosts.js +86 -0
- package/dist/services/known-hosts.js.map +1 -0
- package/dist/services/onboarding.d.ts +68 -0
- package/dist/services/onboarding.d.ts.map +1 -0
- package/dist/services/onboarding.js +205 -0
- package/dist/services/onboarding.js.map +1 -0
- package/dist/services/registry.d.ts +16 -0
- package/dist/services/registry.d.ts.map +1 -0
- package/dist/services/registry.js +156 -0
- package/dist/services/registry.js.map +1 -0
- package/dist/services/sftp.d.ts +16 -0
- package/dist/services/sftp.d.ts.map +1 -0
- package/dist/services/sftp.js +104 -0
- package/dist/services/sftp.js.map +1 -0
- package/dist/services/ssh.d.ts +29 -0
- package/dist/services/ssh.d.ts.map +1 -0
- package/dist/services/ssh.js +297 -0
- package/dist/services/ssh.js.map +1 -0
- package/dist/services/stall/find-log-file.d.ts +2 -0
- package/dist/services/stall/find-log-file.d.ts.map +1 -0
- package/dist/services/stall/find-log-file.js +153 -0
- package/dist/services/stall/find-log-file.js.map +1 -0
- package/dist/services/stall/index.d.ts +4 -0
- package/dist/services/stall/index.d.ts.map +1 -0
- package/dist/services/stall/index.js +4 -0
- package/dist/services/stall/index.js.map +1 -0
- package/dist/services/stall/log-path-resolver.d.ts +4 -0
- package/dist/services/stall/log-path-resolver.d.ts.map +1 -0
- package/dist/services/stall/log-path-resolver.js +32 -0
- package/dist/services/stall/log-path-resolver.js.map +1 -0
- package/dist/services/stall/log-path-resolver.test.d.ts +2 -0
- package/dist/services/stall/log-path-resolver.test.d.ts.map +1 -0
- package/dist/services/stall/log-path-resolver.test.js +76 -0
- package/dist/services/stall/log-path-resolver.test.js.map +1 -0
- package/dist/services/stall/read-log-tail.d.ts +6 -0
- package/dist/services/stall/read-log-tail.d.ts.map +1 -0
- package/dist/services/stall/read-log-tail.js +44 -0
- package/dist/services/stall/read-log-tail.js.map +1 -0
- package/dist/services/stall/stall-detector.d.ts +25 -0
- package/dist/services/stall/stall-detector.d.ts.map +1 -0
- package/dist/services/stall/stall-detector.js +153 -0
- package/dist/services/stall/stall-detector.js.map +1 -0
- package/dist/services/stall/stall-poller.d.ts +6 -0
- package/dist/services/stall/stall-poller.d.ts.map +1 -0
- package/dist/services/stall/stall-poller.js +75 -0
- package/dist/services/stall/stall-poller.js.map +1 -0
- package/dist/services/stall/time-utils.d.ts +4 -0
- package/dist/services/stall/time-utils.d.ts.map +1 -0
- package/dist/services/stall/time-utils.js +22 -0
- package/dist/services/stall/time-utils.js.map +1 -0
- package/dist/services/statusline.d.ts +10 -0
- package/dist/services/statusline.d.ts.map +1 -0
- package/dist/services/statusline.js +84 -0
- package/dist/services/statusline.js.map +1 -0
- package/dist/services/strategy.d.ts +16 -0
- package/dist/services/strategy.d.ts.map +1 -0
- package/dist/services/strategy.js +241 -0
- package/dist/services/strategy.js.map +1 -0
- package/dist/services/task-cleanup.d.ts +3 -0
- package/dist/services/task-cleanup.d.ts.map +1 -0
- package/dist/services/task-cleanup.js +81 -0
- package/dist/services/task-cleanup.js.map +1 -0
- package/dist/services/update-check.d.ts +15 -0
- package/dist/services/update-check.d.ts.map +1 -0
- package/dist/services/update-check.js +67 -0
- package/dist/services/update-check.js.map +1 -0
- package/dist/services/user-config.d.ts +12 -0
- package/dist/services/user-config.d.ts.map +1 -0
- package/dist/services/user-config.js +73 -0
- package/dist/services/user-config.js.map +1 -0
- package/dist/services/vcs/azure-devops.d.ts +7 -0
- package/dist/services/vcs/azure-devops.d.ts.map +1 -0
- package/dist/services/vcs/azure-devops.js +38 -0
- package/dist/services/vcs/azure-devops.js.map +1 -0
- package/dist/services/vcs/bitbucket.d.ts +6 -0
- package/dist/services/vcs/bitbucket.d.ts.map +1 -0
- package/dist/services/vcs/bitbucket.js +31 -0
- package/dist/services/vcs/bitbucket.js.map +1 -0
- package/dist/services/vcs/constants.d.ts +2 -0
- package/dist/services/vcs/constants.d.ts.map +1 -0
- package/dist/services/vcs/constants.js +6 -0
- package/dist/services/vcs/constants.js.map +1 -0
- package/dist/services/vcs/github.d.ts +6 -0
- package/dist/services/vcs/github.d.ts.map +1 -0
- package/dist/services/vcs/github.js +81 -0
- package/dist/services/vcs/github.js.map +1 -0
- package/dist/services/vcs/types.d.ts +52 -0
- package/dist/services/vcs/types.d.ts.map +1 -0
- package/dist/services/vcs/types.js +8 -0
- package/dist/services/vcs/types.js.map +1 -0
- package/dist/smoke-test.d.ts +10 -0
- package/dist/smoke-test.d.ts.map +1 -0
- package/dist/smoke-test.js +102 -0
- package/dist/smoke-test.js.map +1 -0
- package/dist/tools/check-status.d.ts +11 -0
- package/dist/tools/check-status.d.ts.map +1 -0
- package/dist/tools/check-status.js +247 -0
- package/dist/tools/check-status.js.map +1 -0
- package/dist/tools/cloud-control.d.ts +17 -0
- package/dist/tools/cloud-control.d.ts.map +1 -0
- package/dist/tools/cloud-control.js +102 -0
- package/dist/tools/cloud-control.js.map +1 -0
- package/dist/tools/compose-permissions.d.ts +26 -0
- package/dist/tools/compose-permissions.d.ts.map +1 -0
- package/dist/tools/compose-permissions.js +217 -0
- package/dist/tools/compose-permissions.js.map +1 -0
- package/dist/tools/credential-store-delete.d.ts +11 -0
- package/dist/tools/credential-store-delete.d.ts.map +1 -0
- package/dist/tools/credential-store-delete.js +15 -0
- package/dist/tools/credential-store-delete.js.map +1 -0
- package/dist/tools/credential-store-list.d.ts +4 -0
- package/dist/tools/credential-store-list.d.ts.map +1 -0
- package/dist/tools/credential-store-list.js +30 -0
- package/dist/tools/credential-store-list.js.map +1 -0
- package/dist/tools/credential-store-set.d.ts +26 -0
- package/dist/tools/credential-store-set.d.ts.map +1 -0
- package/dist/tools/credential-store-set.js +28 -0
- package/dist/tools/credential-store-set.js.map +1 -0
- package/dist/tools/credential-store-update.d.ts +20 -0
- package/dist/tools/credential-store-update.d.ts.map +1 -0
- package/dist/tools/credential-store-update.js +38 -0
- package/dist/tools/credential-store-update.js.map +1 -0
- package/dist/tools/execute-command.d.ts +33 -0
- package/dist/tools/execute-command.d.ts.map +1 -0
- package/dist/tools/execute-command.js +231 -0
- package/dist/tools/execute-command.js.map +1 -0
- package/dist/tools/execute-prompt.d.ts +36 -0
- package/dist/tools/execute-prompt.d.ts.map +1 -0
- package/dist/tools/execute-prompt.js +310 -0
- package/dist/tools/execute-prompt.js.map +1 -0
- package/dist/tools/list-members.d.ts +11 -0
- package/dist/tools/list-members.d.ts.map +1 -0
- package/dist/tools/list-members.js +108 -0
- package/dist/tools/list-members.js.map +1 -0
- package/dist/tools/member-detail.d.ts +17 -0
- package/dist/tools/member-detail.d.ts.map +1 -0
- package/dist/tools/member-detail.js +263 -0
- package/dist/tools/member-detail.js.map +1 -0
- package/dist/tools/monitor-task.d.ts +20 -0
- package/dist/tools/monitor-task.d.ts.map +1 -0
- package/dist/tools/monitor-task.js +89 -0
- package/dist/tools/monitor-task.js.map +1 -0
- package/dist/tools/provision-auth.d.ts +17 -0
- package/dist/tools/provision-auth.d.ts.map +1 -0
- package/dist/tools/provision-auth.js +256 -0
- package/dist/tools/provision-auth.js.map +1 -0
- package/dist/tools/provision-vcs-auth.d.ts +50 -0
- package/dist/tools/provision-vcs-auth.d.ts.map +1 -0
- package/dist/tools/provision-vcs-auth.js +187 -0
- package/dist/tools/provision-vcs-auth.js.map +1 -0
- package/dist/tools/receive-files.d.ts +20 -0
- package/dist/tools/receive-files.d.ts.map +1 -0
- package/dist/tools/receive-files.js +82 -0
- package/dist/tools/receive-files.js.map +1 -0
- package/dist/tools/register-member.d.ts +74 -0
- package/dist/tools/register-member.d.ts.map +1 -0
- package/dist/tools/register-member.js +310 -0
- package/dist/tools/register-member.js.map +1 -0
- package/dist/tools/remove-member.d.ts +17 -0
- package/dist/tools/remove-member.d.ts.map +1 -0
- package/dist/tools/remove-member.js +126 -0
- package/dist/tools/remove-member.js.map +1 -0
- package/dist/tools/revoke-vcs-auth.d.ts +23 -0
- package/dist/tools/revoke-vcs-auth.d.ts.map +1 -0
- package/dist/tools/revoke-vcs-auth.js +55 -0
- package/dist/tools/revoke-vcs-auth.js.map +1 -0
- package/dist/tools/send-files.d.ts +20 -0
- package/dist/tools/send-files.d.ts.map +1 -0
- package/dist/tools/send-files.js +103 -0
- package/dist/tools/send-files.js.map +1 -0
- package/dist/tools/setup-git-app.d.ts +17 -0
- package/dist/tools/setup-git-app.d.ts.map +1 -0
- package/dist/tools/setup-git-app.js +89 -0
- package/dist/tools/setup-git-app.js.map +1 -0
- package/dist/tools/setup-ssh-key.d.ts +14 -0
- package/dist/tools/setup-ssh-key.d.ts.map +1 -0
- package/dist/tools/setup-ssh-key.js +119 -0
- package/dist/tools/setup-ssh-key.js.map +1 -0
- package/dist/tools/shutdown-server.d.ts +4 -0
- package/dist/tools/shutdown-server.d.ts.map +1 -0
- package/dist/tools/shutdown-server.js +9 -0
- package/dist/tools/shutdown-server.js.map +1 -0
- package/dist/tools/stop-prompt.d.ts +14 -0
- package/dist/tools/stop-prompt.d.ts.map +1 -0
- package/dist/tools/stop-prompt.js +44 -0
- package/dist/tools/stop-prompt.js.map +1 -0
- package/dist/tools/update-agent-cli.d.ts +17 -0
- package/dist/tools/update-agent-cli.d.ts.map +1 -0
- package/dist/tools/update-agent-cli.js +110 -0
- package/dist/tools/update-agent-cli.js.map +1 -0
- package/dist/tools/update-member.d.ts +77 -0
- package/dist/tools/update-member.d.ts.map +1 -0
- package/dist/tools/update-member.js +202 -0
- package/dist/tools/update-member.js.map +1 -0
- package/dist/tools/version.d.ts +4 -0
- package/dist/tools/version.d.ts.map +1 -0
- package/dist/tools/version.js +7 -0
- package/dist/tools/version.js.map +1 -0
- package/dist/types.d.ts +70 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/agent-helpers.d.ts +41 -0
- package/dist/utils/agent-helpers.d.ts.map +1 -0
- package/dist/utils/agent-helpers.js +84 -0
- package/dist/utils/agent-helpers.js.map +1 -0
- package/dist/utils/ansi.d.ts +6 -0
- package/dist/utils/ansi.d.ts.map +1 -0
- package/dist/utils/ansi.js +20 -0
- package/dist/utils/ansi.js.map +1 -0
- package/dist/utils/auth-env.d.ts +8 -0
- package/dist/utils/auth-env.d.ts.map +1 -0
- package/dist/utils/auth-env.js +30 -0
- package/dist/utils/auth-env.js.map +1 -0
- package/dist/utils/collect-secret.d.ts +2 -0
- package/dist/utils/collect-secret.d.ts.map +1 -0
- package/dist/utils/collect-secret.js +80 -0
- package/dist/utils/collect-secret.js.map +1 -0
- package/dist/utils/credential-validation.d.ts +13 -0
- package/dist/utils/credential-validation.d.ts.map +1 -0
- package/dist/utils/credential-validation.js +35 -0
- package/dist/utils/credential-validation.js.map +1 -0
- package/dist/utils/crypto.d.ts +3 -0
- package/dist/utils/crypto.d.ts.map +1 -0
- package/dist/utils/crypto.js +61 -0
- package/dist/utils/crypto.js.map +1 -0
- package/dist/utils/deep-merge.d.ts +3 -0
- package/dist/utils/deep-merge.d.ts.map +1 -0
- package/dist/utils/deep-merge.js +23 -0
- package/dist/utils/deep-merge.js.map +1 -0
- package/dist/utils/file-permissions.d.ts +8 -0
- package/dist/utils/file-permissions.d.ts.map +1 -0
- package/dist/utils/file-permissions.js +13 -0
- package/dist/utils/file-permissions.js.map +1 -0
- package/dist/utils/gpu-parser.d.ts +6 -0
- package/dist/utils/gpu-parser.d.ts.map +1 -0
- package/dist/utils/gpu-parser.js +15 -0
- package/dist/utils/gpu-parser.js.map +1 -0
- package/dist/utils/log-helpers.d.ts +29 -0
- package/dist/utils/log-helpers.d.ts.map +1 -0
- package/dist/utils/log-helpers.js +128 -0
- package/dist/utils/log-helpers.js.map +1 -0
- package/dist/utils/oob-timeout.d.ts +2 -0
- package/dist/utils/oob-timeout.d.ts.map +1 -0
- package/dist/utils/oob-timeout.js +2 -0
- package/dist/utils/oob-timeout.js.map +1 -0
- package/dist/utils/pid-helpers.d.ts +11 -0
- package/dist/utils/pid-helpers.d.ts.map +1 -0
- package/dist/utils/pid-helpers.js +21 -0
- package/dist/utils/pid-helpers.js.map +1 -0
- package/dist/utils/platform.d.ts +13 -0
- package/dist/utils/platform.d.ts.map +1 -0
- package/dist/utils/platform.js +60 -0
- package/dist/utils/platform.js.map +1 -0
- package/dist/utils/prompt-errors.d.ts +5 -0
- package/dist/utils/prompt-errors.d.ts.map +1 -0
- package/dist/utils/prompt-errors.js +15 -0
- package/dist/utils/prompt-errors.js.map +1 -0
- package/dist/utils/resolve-member.d.ts +18 -0
- package/dist/utils/resolve-member.d.ts.map +1 -0
- package/dist/utils/resolve-member.js +23 -0
- package/dist/utils/resolve-member.js.map +1 -0
- package/dist/utils/secure-input.d.ts +6 -0
- package/dist/utils/secure-input.d.ts.map +1 -0
- package/dist/utils/secure-input.js +60 -0
- package/dist/utils/secure-input.js.map +1 -0
- package/dist/utils/shell-escape.d.ts +43 -0
- package/dist/utils/shell-escape.d.ts.map +1 -0
- package/dist/utils/shell-escape.js +67 -0
- package/dist/utils/shell-escape.js.map +1 -0
- package/dist/utils/ssh-error-messages.d.ts +5 -0
- package/dist/utils/ssh-error-messages.d.ts.map +1 -0
- package/dist/utils/ssh-error-messages.js +20 -0
- package/dist/utils/ssh-error-messages.js.map +1 -0
- package/dist/version.d.ts +18 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +101 -0
- package/dist/version.js.map +1 -0
- package/hooks/hooks-config.json +15 -0
- package/hooks/post-register-member.sh +10 -0
- package/package.json +82 -0
- package/scripts/agy-settings-merge.js +27 -0
- package/scripts/agy-transcript-reader.js +62 -0
- package/scripts/fleet-statusline.sh +43 -0
- package/skills/fleet/SKILL.md +262 -0
- package/skills/fleet/auth-azdevops.md +72 -0
- package/skills/fleet/auth-bitbucket.md +65 -0
- package/skills/fleet/auth-github.md +86 -0
- package/skills/fleet/beads.md +90 -0
- package/skills/fleet/onboarding.md +92 -0
- package/skills/fleet/permissions.md +23 -0
- package/skills/fleet/profiles/base-dev.json +18 -0
- package/skills/fleet/profiles/base-reviewer.json +14 -0
- package/skills/fleet/profiles/cpp.json +4 -0
- package/skills/fleet/profiles/dotnet.json +4 -0
- package/skills/fleet/profiles/go.json +4 -0
- package/skills/fleet/profiles/jvm.json +4 -0
- package/skills/fleet/profiles/node.json +4 -0
- package/skills/fleet/profiles/python.json +4 -0
- package/skills/fleet/profiles/rust.json +4 -0
- package/skills/fleet/profiles/tpl-permissions.json +5 -0
- package/skills/fleet/skill-matrix.md +34 -0
- package/skills/fleet/troubleshooting.md +13 -0
- package/skills/pm/SKILL.md +110 -0
- package/skills/pm/backlog-item.md +65 -0
- package/skills/pm/beads.md +192 -0
- package/skills/pm/cleanup.md +15 -0
- package/skills/pm/context-file.md +40 -0
- package/skills/pm/doer-reviewer.md +123 -0
- package/skills/pm/init.md +25 -0
- package/skills/pm/multi-pair-sprint.md +64 -0
- package/skills/pm/plan-prompt.md +94 -0
- package/skills/pm/simple-sprint.md +42 -0
- package/skills/pm/single-pair-sprint.md +178 -0
- package/skills/pm/tpl-deploy.md +24 -0
- package/skills/pm/tpl-design.md +29 -0
- package/skills/pm/tpl-doer.md +43 -0
- package/skills/pm/tpl-plan.md +72 -0
- package/skills/pm/tpl-pm.md +2 -0
- package/skills/pm/tpl-progress.json +28 -0
- package/skills/pm/tpl-projects.md +4 -0
- package/skills/pm/tpl-requirements.md +21 -0
- package/skills/pm/tpl-reviewer-plan.md +53 -0
- package/skills/pm/tpl-reviewer.md +72 -0
- package/skills/pm/tpl-status.md +29 -0
- 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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"}
|