agent-relay 1.2.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitattributes +3 -0
- package/.nvmrc +1 -0
- package/.trajectories/agent-relay-322-324.md +17 -0
- package/.trajectories/completed/2026-01/traj_03zupyv1s7b9.json +49 -0
- package/.trajectories/completed/2026-01/traj_03zupyv1s7b9.md +31 -0
- package/.trajectories/completed/2026-01/traj_0zacdjl1g4ht.json +125 -0
- package/.trajectories/completed/2026-01/traj_0zacdjl1g4ht.md +62 -0
- package/.trajectories/completed/2026-01/traj_1dviorhnkcb5.json +65 -0
- package/.trajectories/completed/2026-01/traj_1dviorhnkcb5.md +37 -0
- package/.trajectories/completed/2026-01/traj_1k5if5snst2e.json +65 -0
- package/.trajectories/completed/2026-01/traj_1k5if5snst2e.md +37 -0
- package/.trajectories/completed/2026-01/traj_1rp3rges5811.json +49 -0
- package/.trajectories/completed/2026-01/traj_1rp3rges5811.md +31 -0
- package/.trajectories/completed/2026-01/traj_22bhyulruouw.json +113 -0
- package/.trajectories/completed/2026-01/traj_22bhyulruouw.md +57 -0
- package/.trajectories/completed/2026-01/traj_2dao7ddgnta0.json +53 -0
- package/.trajectories/completed/2026-01/traj_2dao7ddgnta0.md +32 -0
- package/.trajectories/completed/2026-01/traj_33iuy72sezbk.json +49 -0
- package/.trajectories/completed/2026-01/traj_33iuy72sezbk.md +31 -0
- package/.trajectories/completed/2026-01/traj_3t0440mjeunc.json +26 -0
- package/.trajectories/completed/2026-01/traj_3t0440mjeunc.md +6 -0
- package/.trajectories/completed/2026-01/traj_45x9494d9xnr.json +47 -0
- package/.trajectories/completed/2026-01/traj_45x9494d9xnr.md +32 -0
- package/.trajectories/completed/2026-01/traj_4aa0bb77s4nh.json +53 -0
- package/.trajectories/completed/2026-01/traj_4aa0bb77s4nh.md +32 -0
- package/.trajectories/completed/2026-01/traj_5ammh5qtvklq.json +77 -0
- package/.trajectories/completed/2026-01/traj_5ammh5qtvklq.md +42 -0
- package/.trajectories/completed/2026-01/traj_5lhmzq8rxpqv.json +59 -0
- package/.trajectories/completed/2026-01/traj_5lhmzq8rxpqv.md +33 -0
- package/.trajectories/completed/2026-01/traj_5vr4e9erb1fs.json +53 -0
- package/.trajectories/completed/2026-01/traj_5vr4e9erb1fs.md +32 -0
- package/.trajectories/completed/2026-01/traj_6fgiwdoklvym.json +48 -0
- package/.trajectories/completed/2026-01/traj_6fgiwdoklvym.md +24 -0
- package/.trajectories/completed/2026-01/traj_6mieijqyvaag.json +77 -0
- package/.trajectories/completed/2026-01/traj_6mieijqyvaag.md +42 -0
- package/.trajectories/completed/2026-01/traj_78ffm31jn3uk.json +77 -0
- package/.trajectories/completed/2026-01/traj_78ffm31jn3uk.md +42 -0
- package/.trajectories/completed/2026-01/traj_7ludwvz45veh.json +209 -0
- package/.trajectories/completed/2026-01/traj_7ludwvz45veh.md +97 -0
- package/.trajectories/completed/2026-01/traj_94gnp3k30goq.json +66 -0
- package/.trajectories/completed/2026-01/traj_94gnp3k30goq.md +36 -0
- package/.trajectories/completed/2026-01/traj_9921cuhel0pj.json +48 -0
- package/.trajectories/completed/2026-01/traj_9921cuhel0pj.md +24 -0
- package/.trajectories/completed/2026-01/traj_ajs7zqfux4wc.json +49 -0
- package/.trajectories/completed/2026-01/traj_ajs7zqfux4wc.md +23 -0
- package/.trajectories/completed/2026-01/traj_avqeghu6pz5a.json +40 -0
- package/.trajectories/completed/2026-01/traj_avqeghu6pz5a.md +22 -0
- package/.trajectories/completed/2026-01/traj_cvtqhlwcq9s0.json +53 -0
- package/.trajectories/completed/2026-01/traj_cvtqhlwcq9s0.md +32 -0
- package/.trajectories/completed/2026-01/traj_cxofprm2m2en.json +49 -0
- package/.trajectories/completed/2026-01/traj_cxofprm2m2en.md +31 -0
- package/.trajectories/completed/2026-01/traj_d2hhz3k0vrhn.json +26 -0
- package/.trajectories/completed/2026-01/traj_d2hhz3k0vrhn.md +6 -0
- package/.trajectories/completed/2026-01/traj_dcsp9s8y01ra.json +121 -0
- package/.trajectories/completed/2026-01/traj_dcsp9s8y01ra.md +29 -0
- package/.trajectories/completed/2026-01/traj_dfuvww9pege5.json +59 -0
- package/.trajectories/completed/2026-01/traj_dfuvww9pege5.md +37 -0
- package/.trajectories/completed/2026-01/traj_fhx9irlckht6.json +53 -0
- package/.trajectories/completed/2026-01/traj_fhx9irlckht6.md +32 -0
- package/.trajectories/completed/2026-01/traj_fqduidx3xbtp.json +101 -0
- package/.trajectories/completed/2026-01/traj_fqduidx3xbtp.md +52 -0
- package/.trajectories/completed/2026-01/traj_g0fisy9h51mf.json +77 -0
- package/.trajectories/completed/2026-01/traj_g0fisy9h51mf.md +42 -0
- package/.trajectories/completed/2026-01/traj_gjdre5voouod.json +53 -0
- package/.trajectories/completed/2026-01/traj_gjdre5voouod.md +32 -0
- package/.trajectories/completed/2026-01/traj_gtlyqtta3x8l.json +25 -0
- package/.trajectories/completed/2026-01/traj_gtlyqtta3x8l.md +15 -0
- package/.trajectories/completed/2026-01/traj_h4xijiuip3w4.json +101 -0
- package/.trajectories/completed/2026-01/traj_h4xijiuip3w4.md +44 -0
- package/.trajectories/completed/2026-01/traj_hf81ey93uz6t.json +49 -0
- package/.trajectories/completed/2026-01/traj_hf81ey93uz6t.md +31 -0
- package/.trajectories/completed/2026-01/traj_hfmki2jr9d4r.json +65 -0
- package/.trajectories/completed/2026-01/traj_hfmki2jr9d4r.md +37 -0
- package/.trajectories/completed/2026-01/traj_hhxte7w4gjjx.json +22 -0
- package/.trajectories/completed/2026-01/traj_hhxte7w4gjjx.md +5 -0
- package/.trajectories/completed/2026-01/traj_hpungyhoj6v5.json +53 -0
- package/.trajectories/completed/2026-01/traj_hpungyhoj6v5.md +32 -0
- package/.trajectories/completed/2026-01/traj_lq450ly148uw.json +49 -0
- package/.trajectories/completed/2026-01/traj_lq450ly148uw.md +31 -0
- package/.trajectories/completed/2026-01/traj_m2xkjv0w2sq7.json +25 -0
- package/.trajectories/completed/2026-01/traj_m2xkjv0w2sq7.md +15 -0
- package/.trajectories/completed/2026-01/traj_multi_server_arch.md +101 -0
- package/.trajectories/completed/2026-01/traj_noq5zbvnrdvz.json +53 -0
- package/.trajectories/completed/2026-01/traj_noq5zbvnrdvz.md +32 -0
- package/.trajectories/completed/2026-01/traj_ntbs6ppopf46.json +53 -0
- package/.trajectories/completed/2026-01/traj_ntbs6ppopf46.md +32 -0
- package/.trajectories/completed/2026-01/traj_ozd98si6a7ns.json +48 -0
- package/.trajectories/completed/2026-01/traj_ozd98si6a7ns.md +24 -0
- package/.trajectories/completed/2026-01/traj_prdza7a5cxp5.json +53 -0
- package/.trajectories/completed/2026-01/traj_prdza7a5cxp5.md +32 -0
- package/.trajectories/completed/2026-01/traj_psd9ob0j2ru3.json +27 -0
- package/.trajectories/completed/2026-01/traj_psd9ob0j2ru3.md +14 -0
- package/.trajectories/completed/2026-01/traj_qb3twvvywfwi.json +77 -0
- package/.trajectories/completed/2026-01/traj_qb3twvvywfwi.md +42 -0
- package/.trajectories/completed/2026-01/traj_qft54mi7nfor.json +53 -0
- package/.trajectories/completed/2026-01/traj_qft54mi7nfor.md +32 -0
- package/.trajectories/completed/2026-01/traj_qx9uhf8whhxo.json +83 -0
- package/.trajectories/completed/2026-01/traj_qx9uhf8whhxo.md +47 -0
- package/.trajectories/completed/2026-01/traj_rd9toccj18a0.json +59 -0
- package/.trajectories/completed/2026-01/traj_rd9toccj18a0.md +37 -0
- package/.trajectories/completed/2026-01/traj_rt4fiw3ecp50.json +48 -0
- package/.trajectories/completed/2026-01/traj_rt4fiw3ecp50.md +16 -0
- package/.trajectories/completed/2026-01/traj_st8j35b0hrlc.json +59 -0
- package/.trajectories/completed/2026-01/traj_st8j35b0hrlc.md +37 -0
- package/.trajectories/completed/2026-01/traj_t1yy8m7hbuxp.json +53 -0
- package/.trajectories/completed/2026-01/traj_t1yy8m7hbuxp.md +32 -0
- package/.trajectories/completed/2026-01/traj_tmux_orchestrator_analysis.json +84 -0
- package/.trajectories/completed/2026-01/traj_tmux_orchestrator_analysis.md +109 -0
- package/.trajectories/completed/2026-01/traj_u9n9eqasw16k.json +53 -0
- package/.trajectories/completed/2026-01/traj_u9n9eqasw16k.md +32 -0
- package/.trajectories/completed/2026-01/traj_ub8csuv3lcv4.json +53 -0
- package/.trajectories/completed/2026-01/traj_ub8csuv3lcv4.md +32 -0
- package/.trajectories/completed/2026-01/traj_uc29tlso8i9s.json +186 -0
- package/.trajectories/completed/2026-01/traj_uc29tlso8i9s.md +86 -0
- package/.trajectories/completed/2026-01/traj_ui9b4tqxoa7j.json +77 -0
- package/.trajectories/completed/2026-01/traj_ui9b4tqxoa7j.md +42 -0
- package/.trajectories/completed/2026-01/traj_v87hypnongqx.json +71 -0
- package/.trajectories/completed/2026-01/traj_v87hypnongqx.md +42 -0
- package/.trajectories/completed/2026-01/traj_v9dkdoxylyid.json +89 -0
- package/.trajectories/completed/2026-01/traj_v9dkdoxylyid.md +47 -0
- package/.trajectories/completed/2026-01/traj_wkp2fgzdyinb.json +53 -0
- package/.trajectories/completed/2026-01/traj_wkp2fgzdyinb.md +32 -0
- package/.trajectories/completed/2026-01/traj_x14t8w8rn7xg.json +20 -0
- package/.trajectories/completed/2026-01/traj_x14t8w8rn7xg.md +6 -0
- package/.trajectories/completed/2026-01/traj_xnwbznkvv8ua.json +175 -0
- package/.trajectories/completed/2026-01/traj_xnwbznkvv8ua.md +82 -0
- package/.trajectories/completed/2026-01/traj_xy9vifpqet80.json +65 -0
- package/.trajectories/completed/2026-01/traj_xy9vifpqet80.md +37 -0
- package/.trajectories/completed/2026-01/traj_y7aiwijyfmmv.json +49 -0
- package/.trajectories/completed/2026-01/traj_y7aiwijyfmmv.md +31 -0
- package/.trajectories/completed/2026-01/traj_ysjc8zaeqtd3.json +47 -0
- package/.trajectories/completed/2026-01/traj_ysjc8zaeqtd3.md +32 -0
- package/.trajectories/completed/2026-01/traj_yvdadtvdgnz3.json +59 -0
- package/.trajectories/completed/2026-01/traj_yvdadtvdgnz3.md +37 -0
- package/.trajectories/completed/2026-01/traj_z0vcw1wrzide.json +53 -0
- package/.trajectories/completed/2026-01/traj_z0vcw1wrzide.md +32 -0
- package/.trajectories/consolidate-settings-panel.md +24 -0
- package/.trajectories/gh-cli-user-token.md +26 -0
- package/.trajectories/index.json +468 -0
- package/ARCHITECTURE.md +1245 -0
- package/TESTING.md +278 -0
- package/deploy/init-db.sql +5 -0
- package/deploy/scripts/setup-fly-workspaces.sh +69 -0
- package/deploy/scripts/setup-railway.sh +75 -0
- package/deploy/workspace/codex.config.toml +15 -0
- package/deploy/workspace/entrypoint-browser.sh +118 -0
- package/deploy/workspace/entrypoint.sh +508 -0
- package/deploy/workspace/git-credential-relay +126 -0
- package/dist/bridge/spawner.d.ts +7 -0
- package/dist/bridge/spawner.js +40 -9
- package/dist/bridge/types.d.ts +2 -0
- package/dist/cli/index.js +260 -1
- package/dist/cloud/api/admin.d.ts +8 -0
- package/dist/cloud/api/admin.js +212 -0
- package/dist/cloud/api/auth.js +8 -0
- package/dist/cloud/api/billing.d.ts +0 -10
- package/dist/cloud/api/billing.js +278 -67
- package/dist/cloud/api/codex-auth-helper.d.ts +21 -0
- package/dist/cloud/api/codex-auth-helper.js +307 -0
- package/dist/cloud/api/coordinators.js +402 -0
- package/dist/cloud/api/daemons.js +15 -11
- package/dist/cloud/api/git.js +127 -19
- package/dist/cloud/api/github-app.js +42 -8
- package/dist/cloud/api/nango-auth.js +297 -16
- package/dist/cloud/api/onboarding.js +112 -35
- package/dist/cloud/api/providers.js +12 -16
- package/dist/cloud/api/repos.d.ts +1 -0
- package/dist/cloud/api/repos.js +311 -49
- package/dist/cloud/api/test-helpers.js +40 -0
- package/dist/cloud/api/usage.js +13 -0
- package/dist/cloud/api/webhooks.d.ts +1 -0
- package/dist/cloud/api/webhooks.js +149 -0
- package/dist/cloud/api/workspaces.d.ts +18 -0
- package/dist/cloud/api/workspaces.js +1042 -21
- package/dist/cloud/billing/plans.js +19 -19
- package/dist/cloud/config.d.ts +8 -0
- package/dist/cloud/config.js +15 -0
- package/dist/cloud/db/drizzle.d.ts +5 -2
- package/dist/cloud/db/drizzle.js +27 -20
- package/dist/cloud/db/schema.d.ts +19 -51
- package/dist/cloud/db/schema.js +5 -4
- package/dist/cloud/index.d.ts +0 -1
- package/dist/cloud/index.js +0 -1
- package/dist/cloud/provisioner/index.d.ts +125 -1
- package/dist/cloud/provisioner/index.js +939 -53
- package/dist/cloud/server.js +161 -16
- package/dist/cloud/services/compute-enforcement.d.ts +57 -0
- package/dist/cloud/services/compute-enforcement.js +175 -0
- package/dist/cloud/services/index.d.ts +2 -0
- package/dist/cloud/services/index.js +4 -0
- package/dist/cloud/services/intro-expiration.d.ts +55 -0
- package/dist/cloud/services/intro-expiration.js +211 -0
- package/dist/cloud/services/nango.d.ts +74 -0
- package/dist/cloud/services/nango.js +218 -5
- package/dist/cloud/services/planLimits.d.ts +22 -0
- package/dist/cloud/services/planLimits.js +58 -5
- package/dist/cloud/services/ssh-security.d.ts +31 -0
- package/dist/cloud/services/ssh-security.js +63 -0
- package/dist/continuity/manager.d.ts +5 -0
- package/dist/continuity/manager.js +56 -2
- package/dist/daemon/api.d.ts +2 -0
- package/dist/daemon/api.js +214 -5
- package/dist/daemon/cli-auth.d.ts +13 -1
- package/dist/daemon/cli-auth.js +166 -47
- package/dist/daemon/connection.d.ts +7 -1
- package/dist/daemon/connection.js +15 -0
- package/dist/daemon/orchestrator.d.ts +2 -0
- package/dist/daemon/orchestrator.js +26 -0
- package/dist/daemon/repo-manager.d.ts +116 -0
- package/dist/daemon/repo-manager.js +384 -0
- package/dist/daemon/router.d.ts +60 -1
- package/dist/daemon/router.js +281 -20
- package/dist/daemon/user-directory.d.ts +111 -0
- package/dist/daemon/user-directory.js +233 -0
- package/dist/dashboard/out/404.html +1 -1
- package/dist/dashboard/out/_next/static/T1tgCqVWHFIkV7ClEtzD7/_ssgManifest.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/532-bace199897eeab37.js +9 -0
- package/dist/dashboard/out/_next/static/chunks/766-b54f0853794b78c3.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/83-b51836037078006c.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/891-6cd50de1224f70bb.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/899-bb19a9b3d9b39ea6.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/onboarding/page-8939b0fc700f7eca.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/page-5af1b6b439858aa6.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-ac39dc0cc3c26fa7.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/{page-daf87e86f783f980.js → page-4a5938c18a11a654.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/app/providers/page-ac3a6ac433fd6001.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/providers/setup/[provider]/page-09f9caae98a18c09.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/{main-97850e03d723ea8c.js → main-2ee6beb2ae96d210.js} +1 -1
- package/dist/dashboard/out/_next/static/css/85d2af9c7ac74d62.css +1 -0
- package/dist/dashboard/out/_next/static/css/fe4b28883eeff359.css +1 -0
- package/dist/dashboard/out/app/onboarding.html +1 -0
- package/dist/dashboard/out/app/onboarding.txt +7 -0
- package/dist/dashboard/out/app.html +1 -1
- package/dist/dashboard/out/app.txt +3 -3
- package/dist/dashboard/out/apple-icon.png +0 -0
- package/dist/dashboard/out/connect-repos.html +1 -1
- package/dist/dashboard/out/connect-repos.txt +3 -3
- package/dist/dashboard/out/history.html +1 -1
- package/dist/dashboard/out/history.txt +3 -3
- package/dist/dashboard/out/index.html +1 -1
- package/dist/dashboard/out/index.txt +3 -3
- package/dist/dashboard/out/login.html +2 -2
- package/dist/dashboard/out/login.txt +3 -3
- package/dist/dashboard/out/metrics.html +1 -1
- package/dist/dashboard/out/metrics.txt +3 -3
- package/dist/dashboard/out/pricing.html +3 -3
- package/dist/dashboard/out/pricing.txt +3 -3
- package/dist/dashboard/out/providers/setup/claude.html +1 -0
- package/dist/dashboard/out/providers/setup/claude.txt +8 -0
- package/dist/dashboard/out/providers/setup/codex.html +1 -0
- package/dist/dashboard/out/providers/setup/codex.txt +8 -0
- package/dist/dashboard/out/providers.html +1 -1
- package/dist/dashboard/out/providers.txt +3 -3
- package/dist/dashboard/out/signup.html +2 -2
- package/dist/dashboard/out/signup.txt +3 -3
- package/dist/dashboard-server/server.js +316 -12
- package/dist/dashboard-server/user-bridge.d.ts +103 -0
- package/dist/dashboard-server/user-bridge.js +189 -0
- package/dist/protocol/channels.d.ts +205 -0
- package/dist/protocol/channels.js +154 -0
- package/dist/protocol/types.d.ts +13 -1
- package/dist/resiliency/provider-context.js +2 -0
- package/dist/shared/cli-auth-config.d.ts +19 -0
- package/dist/shared/cli-auth-config.js +58 -2
- package/dist/utils/agent-config.js +1 -1
- package/dist/wrapper/auth-detection.d.ts +49 -0
- package/dist/wrapper/auth-detection.js +192 -0
- package/dist/wrapper/base-wrapper.d.ts +153 -0
- package/dist/wrapper/base-wrapper.js +393 -0
- package/dist/wrapper/client.d.ts +7 -1
- package/dist/wrapper/client.js +3 -0
- package/dist/wrapper/index.d.ts +1 -0
- package/dist/wrapper/index.js +4 -3
- package/dist/wrapper/pty-wrapper.d.ts +62 -84
- package/dist/wrapper/pty-wrapper.js +154 -180
- package/dist/wrapper/tmux-wrapper.d.ts +41 -66
- package/dist/wrapper/tmux-wrapper.js +90 -134
- package/package.json +5 -12
- package/scripts/postinstall.js +11 -155
- package/scripts/test-interactive-terminal.sh +248 -0
- package/test-push.txt +1 -0
- package/bin/tmux +0 -0
- package/dist/bridge/config.d.ts.map +0 -1
- package/dist/bridge/config.js.map +0 -1
- package/dist/bridge/index.d.ts.map +0 -1
- package/dist/bridge/index.js.map +0 -1
- package/dist/bridge/multi-project-client.d.ts.map +0 -1
- package/dist/bridge/multi-project-client.js.map +0 -1
- package/dist/bridge/shadow-cli.d.ts.map +0 -1
- package/dist/bridge/shadow-cli.js.map +0 -1
- package/dist/bridge/shadow-config.d.ts.map +0 -1
- package/dist/bridge/shadow-config.js.map +0 -1
- package/dist/bridge/spawner.d.ts.map +0 -1
- package/dist/bridge/spawner.js.map +0 -1
- package/dist/bridge/teams-config.d.ts.map +0 -1
- package/dist/bridge/teams-config.js.map +0 -1
- package/dist/bridge/types.d.ts.map +0 -1
- package/dist/bridge/types.js.map +0 -1
- package/dist/bridge/utils.d.ts.map +0 -1
- package/dist/bridge/utils.js.map +0 -1
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/index.js.map +0 -1
- package/dist/cloud/api/auth.d.ts.map +0 -1
- package/dist/cloud/api/auth.js.map +0 -1
- package/dist/cloud/api/billing.d.ts.map +0 -1
- package/dist/cloud/api/billing.js.map +0 -1
- package/dist/cloud/api/cli-pty-runner.d.ts.map +0 -1
- package/dist/cloud/api/cli-pty-runner.js.map +0 -1
- package/dist/cloud/api/coordinators.d.ts.map +0 -1
- package/dist/cloud/api/coordinators.js.map +0 -1
- package/dist/cloud/api/daemons.d.ts.map +0 -1
- package/dist/cloud/api/daemons.js.map +0 -1
- package/dist/cloud/api/generic-webhooks.d.ts.map +0 -1
- package/dist/cloud/api/generic-webhooks.js.map +0 -1
- package/dist/cloud/api/git.d.ts.map +0 -1
- package/dist/cloud/api/git.js.map +0 -1
- package/dist/cloud/api/github-app.d.ts.map +0 -1
- package/dist/cloud/api/github-app.js.map +0 -1
- package/dist/cloud/api/middleware/planLimits.d.ts.map +0 -1
- package/dist/cloud/api/middleware/planLimits.js.map +0 -1
- package/dist/cloud/api/monitoring.d.ts.map +0 -1
- package/dist/cloud/api/monitoring.js.map +0 -1
- package/dist/cloud/api/nango-auth.d.ts.map +0 -1
- package/dist/cloud/api/nango-auth.js.map +0 -1
- package/dist/cloud/api/onboarding.d.ts.map +0 -1
- package/dist/cloud/api/onboarding.js.map +0 -1
- package/dist/cloud/api/policy.d.ts.map +0 -1
- package/dist/cloud/api/policy.js.map +0 -1
- package/dist/cloud/api/providers.d.ts.map +0 -1
- package/dist/cloud/api/providers.js.map +0 -1
- package/dist/cloud/api/repos.d.ts.map +0 -1
- package/dist/cloud/api/repos.js.map +0 -1
- package/dist/cloud/api/teams.d.ts.map +0 -1
- package/dist/cloud/api/teams.js.map +0 -1
- package/dist/cloud/api/test-helpers.d.ts.map +0 -1
- package/dist/cloud/api/test-helpers.js.map +0 -1
- package/dist/cloud/api/usage.d.ts.map +0 -1
- package/dist/cloud/api/usage.js.map +0 -1
- package/dist/cloud/api/webhooks.d.ts.map +0 -1
- package/dist/cloud/api/webhooks.js.map +0 -1
- package/dist/cloud/api/workspaces.d.ts.map +0 -1
- package/dist/cloud/api/workspaces.js.map +0 -1
- package/dist/cloud/billing/index.d.ts.map +0 -1
- package/dist/cloud/billing/index.js.map +0 -1
- package/dist/cloud/billing/plans.d.ts.map +0 -1
- package/dist/cloud/billing/plans.js.map +0 -1
- package/dist/cloud/billing/service.d.ts.map +0 -1
- package/dist/cloud/billing/service.js.map +0 -1
- package/dist/cloud/billing/types.d.ts.map +0 -1
- package/dist/cloud/billing/types.js.map +0 -1
- package/dist/cloud/config.d.ts.map +0 -1
- package/dist/cloud/config.js.map +0 -1
- package/dist/cloud/db/drizzle.d.ts.map +0 -1
- package/dist/cloud/db/drizzle.js.map +0 -1
- package/dist/cloud/db/index.d.ts.map +0 -1
- package/dist/cloud/db/index.js.map +0 -1
- package/dist/cloud/db/schema.d.ts.map +0 -1
- package/dist/cloud/db/schema.js.map +0 -1
- package/dist/cloud/index.d.ts.map +0 -1
- package/dist/cloud/index.js.map +0 -1
- package/dist/cloud/provisioner/index.d.ts.map +0 -1
- package/dist/cloud/provisioner/index.js.map +0 -1
- package/dist/cloud/server.d.ts.map +0 -1
- package/dist/cloud/server.js.map +0 -1
- package/dist/cloud/services/auto-scaler.d.ts.map +0 -1
- package/dist/cloud/services/auto-scaler.js.map +0 -1
- package/dist/cloud/services/capacity-manager.d.ts.map +0 -1
- package/dist/cloud/services/capacity-manager.js.map +0 -1
- package/dist/cloud/services/ci-agent-spawner.d.ts.map +0 -1
- package/dist/cloud/services/ci-agent-spawner.js.map +0 -1
- package/dist/cloud/services/coordinator.d.ts.map +0 -1
- package/dist/cloud/services/coordinator.js.map +0 -1
- package/dist/cloud/services/index.d.ts.map +0 -1
- package/dist/cloud/services/index.js.map +0 -1
- package/dist/cloud/services/mention-handler.d.ts.map +0 -1
- package/dist/cloud/services/mention-handler.js.map +0 -1
- package/dist/cloud/services/nango.d.ts.map +0 -1
- package/dist/cloud/services/nango.js.map +0 -1
- package/dist/cloud/services/persistence.d.ts.map +0 -1
- package/dist/cloud/services/persistence.js.map +0 -1
- package/dist/cloud/services/planLimits.d.ts.map +0 -1
- package/dist/cloud/services/planLimits.js.map +0 -1
- package/dist/cloud/services/scaling-orchestrator.d.ts.map +0 -1
- package/dist/cloud/services/scaling-orchestrator.js.map +0 -1
- package/dist/cloud/services/scaling-policy.d.ts.map +0 -1
- package/dist/cloud/services/scaling-policy.js.map +0 -1
- package/dist/cloud/vault/index.d.ts +0 -76
- package/dist/cloud/vault/index.d.ts.map +0 -1
- package/dist/cloud/vault/index.js +0 -219
- package/dist/cloud/vault/index.js.map +0 -1
- package/dist/cloud/webhooks/index.d.ts.map +0 -1
- package/dist/cloud/webhooks/index.js.map +0 -1
- package/dist/cloud/webhooks/parsers/github.d.ts.map +0 -1
- package/dist/cloud/webhooks/parsers/github.js.map +0 -1
- package/dist/cloud/webhooks/parsers/index.d.ts.map +0 -1
- package/dist/cloud/webhooks/parsers/index.js.map +0 -1
- package/dist/cloud/webhooks/parsers/linear.d.ts.map +0 -1
- package/dist/cloud/webhooks/parsers/linear.js.map +0 -1
- package/dist/cloud/webhooks/parsers/slack.d.ts.map +0 -1
- package/dist/cloud/webhooks/parsers/slack.js.map +0 -1
- package/dist/cloud/webhooks/responders/github.d.ts.map +0 -1
- package/dist/cloud/webhooks/responders/github.js.map +0 -1
- package/dist/cloud/webhooks/responders/index.d.ts.map +0 -1
- package/dist/cloud/webhooks/responders/index.js.map +0 -1
- package/dist/cloud/webhooks/responders/linear.d.ts.map +0 -1
- package/dist/cloud/webhooks/responders/linear.js.map +0 -1
- package/dist/cloud/webhooks/responders/slack.d.ts.map +0 -1
- package/dist/cloud/webhooks/responders/slack.js.map +0 -1
- package/dist/cloud/webhooks/router.d.ts.map +0 -1
- package/dist/cloud/webhooks/router.js.map +0 -1
- package/dist/cloud/webhooks/rules-engine.d.ts.map +0 -1
- package/dist/cloud/webhooks/rules-engine.js.map +0 -1
- package/dist/cloud/webhooks/types.d.ts.map +0 -1
- package/dist/cloud/webhooks/types.js.map +0 -1
- package/dist/continuity/formatter.d.ts.map +0 -1
- package/dist/continuity/formatter.js.map +0 -1
- package/dist/continuity/handoff-store.d.ts.map +0 -1
- package/dist/continuity/handoff-store.js.map +0 -1
- package/dist/continuity/index.d.ts.map +0 -1
- package/dist/continuity/index.js.map +0 -1
- package/dist/continuity/ledger-store.d.ts.map +0 -1
- package/dist/continuity/ledger-store.js.map +0 -1
- package/dist/continuity/manager.d.ts.map +0 -1
- package/dist/continuity/manager.js.map +0 -1
- package/dist/continuity/parser.d.ts.map +0 -1
- package/dist/continuity/parser.js.map +0 -1
- package/dist/continuity/types.d.ts.map +0 -1
- package/dist/continuity/types.js.map +0 -1
- package/dist/daemon/agent-manager.d.ts.map +0 -1
- package/dist/daemon/agent-manager.js.map +0 -1
- package/dist/daemon/agent-registry.d.ts.map +0 -1
- package/dist/daemon/agent-registry.js.map +0 -1
- package/dist/daemon/api.d.ts.map +0 -1
- package/dist/daemon/api.js.map +0 -1
- package/dist/daemon/auth.d.ts.map +0 -1
- package/dist/daemon/auth.js.map +0 -1
- package/dist/daemon/cli-auth.d.ts.map +0 -1
- package/dist/daemon/cli-auth.js.map +0 -1
- package/dist/daemon/cloud-sync.d.ts.map +0 -1
- package/dist/daemon/cloud-sync.js.map +0 -1
- package/dist/daemon/connection.d.ts.map +0 -1
- package/dist/daemon/connection.js.map +0 -1
- package/dist/daemon/index.d.ts.map +0 -1
- package/dist/daemon/index.js.map +0 -1
- package/dist/daemon/orchestrator.d.ts.map +0 -1
- package/dist/daemon/orchestrator.js.map +0 -1
- package/dist/daemon/registry.d.ts.map +0 -1
- package/dist/daemon/registry.js.map +0 -1
- package/dist/daemon/router.d.ts.map +0 -1
- package/dist/daemon/router.js.map +0 -1
- package/dist/daemon/server.d.ts.map +0 -1
- package/dist/daemon/server.js.map +0 -1
- package/dist/daemon/services/browser-testing.d.ts.map +0 -1
- package/dist/daemon/services/browser-testing.js.map +0 -1
- package/dist/daemon/services/container-spawner.d.ts.map +0 -1
- package/dist/daemon/services/container-spawner.js.map +0 -1
- package/dist/daemon/types.d.ts.map +0 -1
- package/dist/daemon/types.js.map +0 -1
- package/dist/daemon/workspace-manager.d.ts.map +0 -1
- package/dist/daemon/workspace-manager.js.map +0 -1
- package/dist/dashboard/out/_next/static/H5aWG0udPB4iOUIl_gytz/_ssgManifest.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/480-2d4111711d4e473c.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/724-73c1ee5f60abe860.js +0 -9
- package/dist/dashboard/out/_next/static/chunks/766-c3a14283c88d815b.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/app/page-7120be68bea622f3.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-1081dd190a331a91.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/providers/page-b68a681526eb145e.js +0 -1
- package/dist/dashboard/out/_next/static/css/29852f26181969a0.css +0 -1
- package/dist/dashboard/out/_next/static/css/411ce23ffeae9f76.css +0 -1
- package/dist/dashboard-server/metrics.d.ts.map +0 -1
- package/dist/dashboard-server/metrics.js.map +0 -1
- package/dist/dashboard-server/needs-attention.d.ts.map +0 -1
- package/dist/dashboard-server/needs-attention.js.map +0 -1
- package/dist/dashboard-server/server.d.ts.map +0 -1
- package/dist/dashboard-server/server.js.map +0 -1
- package/dist/dashboard-server/start.d.ts.map +0 -1
- package/dist/dashboard-server/start.js.map +0 -1
- package/dist/hooks/emitter.d.ts.map +0 -1
- package/dist/hooks/emitter.js.map +0 -1
- package/dist/hooks/inbox-check/hook.d.ts.map +0 -1
- package/dist/hooks/inbox-check/hook.js.map +0 -1
- package/dist/hooks/inbox-check/index.d.ts.map +0 -1
- package/dist/hooks/inbox-check/index.js.map +0 -1
- package/dist/hooks/inbox-check/types.d.ts.map +0 -1
- package/dist/hooks/inbox-check/types.js.map +0 -1
- package/dist/hooks/inbox-check/utils.d.ts.map +0 -1
- package/dist/hooks/inbox-check/utils.js.map +0 -1
- package/dist/hooks/index.d.ts.map +0 -1
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/registry.d.ts.map +0 -1
- package/dist/hooks/registry.js.map +0 -1
- package/dist/hooks/trajectory-hooks.d.ts.map +0 -1
- package/dist/hooks/trajectory-hooks.js.map +0 -1
- package/dist/hooks/types.d.ts.map +0 -1
- package/dist/hooks/types.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/memory/adapters/index.d.ts.map +0 -1
- package/dist/memory/adapters/index.js.map +0 -1
- package/dist/memory/adapters/inmemory.d.ts.map +0 -1
- package/dist/memory/adapters/inmemory.js.map +0 -1
- package/dist/memory/adapters/supermemory.d.ts.map +0 -1
- package/dist/memory/adapters/supermemory.js.map +0 -1
- package/dist/memory/factory.d.ts.map +0 -1
- package/dist/memory/factory.js.map +0 -1
- package/dist/memory/index.d.ts.map +0 -1
- package/dist/memory/index.js.map +0 -1
- package/dist/memory/memory-hooks.d.ts.map +0 -1
- package/dist/memory/memory-hooks.js.map +0 -1
- package/dist/memory/service.d.ts.map +0 -1
- package/dist/memory/service.js.map +0 -1
- package/dist/memory/types.d.ts.map +0 -1
- package/dist/memory/types.js.map +0 -1
- package/dist/policy/agent-policy.d.ts.map +0 -1
- package/dist/policy/agent-policy.js.map +0 -1
- package/dist/policy/cloud-policy-fetcher.d.ts.map +0 -1
- package/dist/policy/cloud-policy-fetcher.js.map +0 -1
- package/dist/protocol/framing.d.ts.map +0 -1
- package/dist/protocol/framing.js.map +0 -1
- package/dist/protocol/index.d.ts.map +0 -1
- package/dist/protocol/index.js.map +0 -1
- package/dist/protocol/types.d.ts.map +0 -1
- package/dist/protocol/types.js.map +0 -1
- package/dist/resiliency/context-persistence.d.ts.map +0 -1
- package/dist/resiliency/context-persistence.js.map +0 -1
- package/dist/resiliency/crash-insights.d.ts.map +0 -1
- package/dist/resiliency/crash-insights.js.map +0 -1
- package/dist/resiliency/gossip-health.d.ts.map +0 -1
- package/dist/resiliency/gossip-health.js.map +0 -1
- package/dist/resiliency/health-monitor.d.ts.map +0 -1
- package/dist/resiliency/health-monitor.js.map +0 -1
- package/dist/resiliency/index.d.ts.map +0 -1
- package/dist/resiliency/index.js.map +0 -1
- package/dist/resiliency/leader-watchdog.d.ts.map +0 -1
- package/dist/resiliency/leader-watchdog.js.map +0 -1
- package/dist/resiliency/logger.d.ts.map +0 -1
- package/dist/resiliency/logger.js.map +0 -1
- package/dist/resiliency/memory-monitor.d.ts.map +0 -1
- package/dist/resiliency/memory-monitor.js.map +0 -1
- package/dist/resiliency/metrics.d.ts.map +0 -1
- package/dist/resiliency/metrics.js.map +0 -1
- package/dist/resiliency/provider-context.d.ts.map +0 -1
- package/dist/resiliency/provider-context.js.map +0 -1
- package/dist/resiliency/stateless-lead.d.ts.map +0 -1
- package/dist/resiliency/stateless-lead.js.map +0 -1
- package/dist/resiliency/supervisor.d.ts.map +0 -1
- package/dist/resiliency/supervisor.js.map +0 -1
- package/dist/shared/cli-auth-config.d.ts.map +0 -1
- package/dist/shared/cli-auth-config.js.map +0 -1
- package/dist/state/agent-state.d.ts.map +0 -1
- package/dist/state/agent-state.js.map +0 -1
- package/dist/storage/adapter.d.ts.map +0 -1
- package/dist/storage/adapter.js.map +0 -1
- package/dist/storage/sqlite-adapter.d.ts.map +0 -1
- package/dist/storage/sqlite-adapter.js.map +0 -1
- package/dist/trajectory/config.d.ts.map +0 -1
- package/dist/trajectory/config.js.map +0 -1
- package/dist/trajectory/index.d.ts.map +0 -1
- package/dist/trajectory/index.js.map +0 -1
- package/dist/trajectory/integration.d.ts.map +0 -1
- package/dist/trajectory/integration.js.map +0 -1
- package/dist/utils/agent-config.d.ts.map +0 -1
- package/dist/utils/agent-config.js.map +0 -1
- package/dist/utils/command-resolver.d.ts.map +0 -1
- package/dist/utils/command-resolver.js.map +0 -1
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/name-generator.d.ts.map +0 -1
- package/dist/utils/name-generator.js.map +0 -1
- package/dist/utils/project-namespace.d.ts.map +0 -1
- package/dist/utils/project-namespace.js.map +0 -1
- package/dist/utils/tmux-resolver.d.ts.map +0 -1
- package/dist/utils/tmux-resolver.js.map +0 -1
- package/dist/utils/update-checker.d.ts.map +0 -1
- package/dist/utils/update-checker.js.map +0 -1
- package/dist/wrapper/client.d.ts.map +0 -1
- package/dist/wrapper/client.js.map +0 -1
- package/dist/wrapper/inbox.d.ts.map +0 -1
- package/dist/wrapper/inbox.js.map +0 -1
- package/dist/wrapper/index.d.ts.map +0 -1
- package/dist/wrapper/index.js.map +0 -1
- package/dist/wrapper/parser.d.ts.map +0 -1
- package/dist/wrapper/parser.js.map +0 -1
- package/dist/wrapper/pty-wrapper.d.ts.map +0 -1
- package/dist/wrapper/pty-wrapper.js.map +0 -1
- package/dist/wrapper/shared.d.ts.map +0 -1
- package/dist/wrapper/shared.js.map +0 -1
- package/dist/wrapper/tmux-wrapper.d.ts.map +0 -1
- package/dist/wrapper/tmux-wrapper.js.map +0 -1
- package/docs/AGENTS.md +0 -513
- package/docs/ARCHITECTURE_DECISIONS.md +0 -175
- package/docs/CLOUD-ARCHITECTURE.md +0 -804
- package/docs/CLOUD-ONBOARDING-DESIGN.md +0 -1983
- package/docs/CONTRIBUTING.md +0 -151
- package/docs/HOOKS_API.md +0 -394
- package/docs/INTEGRATION-GUIDE.md +0 -926
- package/docs/PROTOCOL.md +0 -325
- package/docs/WRAPPER_EVENTS.md +0 -358
- package/docs/agent-policy-snippet.md +0 -40
- package/docs/agent-relay-protocol.md +0 -238
- package/docs/agent-relay-snippet.md +0 -174
- package/docs/archive/CHANGELOG.md +0 -11
- package/docs/archive/CLI-SIMPLIFICATION-COMPLETE.md +0 -48
- package/docs/archive/DESIGN_BRIDGE_STAFFING.md +0 -878
- package/docs/archive/DESIGN_V2.md +0 -1079
- package/docs/archive/EXECUTIVE_SUMMARY.md +0 -358
- package/docs/archive/MONETIZATION.md +0 -1679
- package/docs/archive/PROPOSAL-trajectories.md +0 -1582
- package/docs/archive/ROADMAP.md +0 -329
- package/docs/archive/SCALING_ANALYSIS.md +0 -280
- package/docs/archive/TESTING_PRESENCE_FEATURES.md +0 -327
- package/docs/archive/TMUX_IMPLEMENTATION_NOTES.md +0 -364
- package/docs/archive/TMUX_IMPROVEMENTS.md +0 -968
- package/docs/archive/dashboard-v2-plan.md +0 -179
- package/docs/archive/removable-code-analysis.md +0 -24
- package/docs/competitive/GASTOWN.md +0 -451
- package/docs/competitive/MCP_AGENT_MAIL.md +0 -389
- package/docs/competitive/OVERVIEW.md +0 -898
- package/docs/competitive/README.md +0 -34
- package/docs/competitive/TMUX_ORCHESTRATOR.md +0 -605
- package/docs/dashboard.png +0 -0
- package/docs/design/ci-failure-webhooks.md +0 -812
- package/docs/design/comprehensive-integrations.md +0 -238
- package/docs/design/e2b-sandbox-integration.md +0 -504
- package/docs/design/github-app-permissions.md +0 -264
- package/docs/guides/CLOUD.md +0 -236
- package/docs/guides/LOCAL.md +0 -535
- package/docs/guides/SELF-HOSTED.md +0 -494
- package/docs/local-testing.md +0 -428
- package/docs/proposals/continuous-claude-integration.md +0 -622
- package/docs/proposals/custom-commands.md +0 -368
- package/docs/proposals/shadow-as-subagent.md +0 -765
- package/docs/proposals/slack-bot-integration.md +0 -1457
- package/docs/tasks/global-skills-system.tasks.md +0 -230
- package/docs/tasks/webhook-integrations.tasks.md +0 -184
- package/docs/tasks/workspace-capabilities.tasks.md +0 -121
- package/docs/testing/RESILIENCY-TEST-PLAN-2026-01-01.md +0 -366
- package/scripts/cloud-setup.sh +0 -96
- package/scripts/dev/PUBLIC_RELEASE_PLAN.md +0 -88
- package/scripts/dev/dev-team-setup.sh +0 -431
- package/scripts/e2e-test.sh +0 -119
- package/scripts/games/game-protocol.md +0 -79
- package/scripts/games/hearts-setup.sh +0 -264
- package/scripts/manual-qa.sh +0 -293
- package/scripts/run-cloud-qa.sh +0 -220
- package/scripts/test-cli-auth/Dockerfile +0 -44
- package/scripts/test-cli-auth/Dockerfile.real +0 -79
- package/scripts/test-cli-auth/README.md +0 -286
- package/scripts/test-cli-auth/ci-test-real-clis.ts +0 -251
- package/scripts/test-cli-auth/ci-test-runner.ts +0 -263
- package/scripts/test-cli-auth/mock-cli.sh +0 -147
- package/scripts/test-cli-auth/package.json +0 -14
- package/scripts/test-cli-auth/test-oauth-flow.ts +0 -220
- package/scripts/test-pty-input-auto.js +0 -222
- package/scripts/test-pty-input.js +0 -150
- package/scripts/tictactoe-setup.sh +0 -181
- /package/dist/dashboard/out/_next/static/{H5aWG0udPB4iOUIl_gytz → T1tgCqVWHFIkV7ClEtzD7}/_buildManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{117-b100311aff8d5c61.js → 117-f7b8ab0809342e77.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{648-a13d3c2b1be45466.js → 648-5cc6e1921389a58a.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-a4973f3e3c82fb67.js → page-53b8a69f76db17d0.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/connect-repos/{page-dc2e3a1a22478efc.js → page-f45ecbc3e06134fc.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/history/{page-56a8b4616a90dc43.js → page-8c8bed33beb2bf1c.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/login/{page-3eac37ea6f5dd153.js → page-16f3b49e55b1e0ed.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/pricing/{page-4d72d5a5d8a9b618.js → page-982a7000fee44014.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/signup/{page-fee4ed1709070bcd.js → page-547dd0ca55ecd0ba.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{fd9d1056-bf46c09eb57e019c.js → fd9d1056-609918ca7b6280bb.js} +0 -0
|
@@ -1,220 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env npx tsx
|
|
2
|
-
/**
|
|
3
|
-
* CLI OAuth Flow Integration Test
|
|
4
|
-
*
|
|
5
|
-
* Tests the prompt handling and URL extraction for each provider
|
|
6
|
-
* using mock CLIs that simulate the real interactive flows.
|
|
7
|
-
*
|
|
8
|
-
* Usage:
|
|
9
|
-
* npx tsx scripts/test-cli-auth/test-oauth-flow.ts [provider]
|
|
10
|
-
*
|
|
11
|
-
* Examples:
|
|
12
|
-
* npx tsx scripts/test-cli-auth/test-oauth-flow.ts # Test all providers
|
|
13
|
-
* npx tsx scripts/test-cli-auth/test-oauth-flow.ts claude # Test Claude only
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
import * as pty from 'node-pty';
|
|
17
|
-
import path from 'path';
|
|
18
|
-
import { fileURLToPath } from 'url';
|
|
19
|
-
import {
|
|
20
|
-
CLI_AUTH_CONFIG,
|
|
21
|
-
stripAnsiCodes,
|
|
22
|
-
matchesSuccessPattern,
|
|
23
|
-
findMatchingPrompt,
|
|
24
|
-
} from '../../src/cloud/api/onboarding.js';
|
|
25
|
-
|
|
26
|
-
const __filename = fileURLToPath(import.meta.url);
|
|
27
|
-
const __dirname = path.dirname(__filename);
|
|
28
|
-
|
|
29
|
-
interface TestResult {
|
|
30
|
-
provider: string;
|
|
31
|
-
passed: boolean;
|
|
32
|
-
urlExtracted: string | null;
|
|
33
|
-
promptsResponded: string[];
|
|
34
|
-
successDetected: boolean;
|
|
35
|
-
output: string;
|
|
36
|
-
error?: string;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Test a single provider's OAuth flow using the mock CLI
|
|
41
|
-
*/
|
|
42
|
-
async function testProvider(providerId: string): Promise<TestResult> {
|
|
43
|
-
const config = CLI_AUTH_CONFIG[providerId];
|
|
44
|
-
if (!config) {
|
|
45
|
-
return {
|
|
46
|
-
provider: providerId,
|
|
47
|
-
passed: false,
|
|
48
|
-
urlExtracted: null,
|
|
49
|
-
promptsResponded: [],
|
|
50
|
-
successDetected: false,
|
|
51
|
-
output: '',
|
|
52
|
-
error: `Unknown provider: ${providerId}`,
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const result: TestResult = {
|
|
57
|
-
provider: providerId,
|
|
58
|
-
passed: false,
|
|
59
|
-
urlExtracted: null,
|
|
60
|
-
promptsResponded: [],
|
|
61
|
-
successDetected: false,
|
|
62
|
-
output: '',
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
return new Promise((resolve) => {
|
|
66
|
-
const mockCliPath = path.join(__dirname, 'mock-cli.sh');
|
|
67
|
-
const respondedPrompts = new Set<string>();
|
|
68
|
-
|
|
69
|
-
// Map provider IDs to mock CLI provider names
|
|
70
|
-
const mockProviderName = providerId === 'anthropic' ? 'claude' :
|
|
71
|
-
providerId === 'openai' ? 'codex' :
|
|
72
|
-
providerId === 'google' ? 'gemini' : providerId;
|
|
73
|
-
|
|
74
|
-
const proc = pty.spawn('bash', [mockCliPath, mockProviderName, '0.2'], {
|
|
75
|
-
name: 'xterm-256color',
|
|
76
|
-
cols: 120,
|
|
77
|
-
rows: 30,
|
|
78
|
-
cwd: __dirname,
|
|
79
|
-
env: { ...process.env, TERM: 'xterm-256color' },
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
const timeout = setTimeout(() => {
|
|
83
|
-
proc.kill();
|
|
84
|
-
result.error = 'Timeout waiting for completion';
|
|
85
|
-
resolve(result);
|
|
86
|
-
}, 10000);
|
|
87
|
-
|
|
88
|
-
proc.onData((data: string) => {
|
|
89
|
-
result.output += data;
|
|
90
|
-
|
|
91
|
-
// Check for matching prompts and auto-respond
|
|
92
|
-
const matchingPrompt = findMatchingPrompt(data, config.prompts, respondedPrompts);
|
|
93
|
-
if (matchingPrompt) {
|
|
94
|
-
respondedPrompts.add(matchingPrompt.description);
|
|
95
|
-
result.promptsResponded.push(matchingPrompt.description);
|
|
96
|
-
setTimeout(() => {
|
|
97
|
-
try {
|
|
98
|
-
proc.write(matchingPrompt.response);
|
|
99
|
-
} catch {
|
|
100
|
-
// Process may have exited
|
|
101
|
-
}
|
|
102
|
-
}, matchingPrompt.delay ?? 50);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// Look for auth URL
|
|
106
|
-
const cleanText = stripAnsiCodes(data);
|
|
107
|
-
const match = cleanText.match(config.urlPattern);
|
|
108
|
-
if (match && match[1] && !result.urlExtracted) {
|
|
109
|
-
result.urlExtracted = match[1];
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
// Check for success indicators
|
|
113
|
-
if (matchesSuccessPattern(data, config.successPatterns)) {
|
|
114
|
-
result.successDetected = true;
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
proc.onExit(({ exitCode }) => {
|
|
119
|
-
clearTimeout(timeout);
|
|
120
|
-
|
|
121
|
-
// Determine if test passed
|
|
122
|
-
result.passed = !!(
|
|
123
|
-
result.urlExtracted &&
|
|
124
|
-
result.successDetected &&
|
|
125
|
-
exitCode === 0
|
|
126
|
-
);
|
|
127
|
-
|
|
128
|
-
// Send completion signal to mock CLI
|
|
129
|
-
setTimeout(() => resolve(result), 100);
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
// For mock CLI, send signal to continue after prompts
|
|
133
|
-
setTimeout(() => {
|
|
134
|
-
try {
|
|
135
|
-
proc.write('\n'); // Signal to continue
|
|
136
|
-
} catch {
|
|
137
|
-
// Ignore
|
|
138
|
-
}
|
|
139
|
-
}, 3000);
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Run tests for specified providers or all providers
|
|
145
|
-
*/
|
|
146
|
-
async function runTests(providers?: string[]) {
|
|
147
|
-
const providerIds = providers ?? Object.keys(CLI_AUTH_CONFIG);
|
|
148
|
-
|
|
149
|
-
console.log('╔══════════════════════════════════════════════════════════════╗');
|
|
150
|
-
console.log('║ CLI OAuth Flow Integration Tests ║');
|
|
151
|
-
console.log('╚══════════════════════════════════════════════════════════════╝');
|
|
152
|
-
console.log('');
|
|
153
|
-
|
|
154
|
-
const results: TestResult[] = [];
|
|
155
|
-
|
|
156
|
-
for (const providerId of providerIds) {
|
|
157
|
-
const config = CLI_AUTH_CONFIG[providerId];
|
|
158
|
-
if (!config) {
|
|
159
|
-
console.log(`⚠️ Unknown provider: ${providerId}`);
|
|
160
|
-
continue;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
console.log(`Testing ${config.displayName} (${providerId})...`);
|
|
164
|
-
|
|
165
|
-
const result = await testProvider(providerId);
|
|
166
|
-
results.push(result);
|
|
167
|
-
|
|
168
|
-
if (result.passed) {
|
|
169
|
-
console.log(` ✅ PASSED`);
|
|
170
|
-
} else {
|
|
171
|
-
console.log(` ❌ FAILED${result.error ? `: ${result.error}` : ''}`);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
console.log(` URL extracted: ${result.urlExtracted ? '✓' : '✗'}`);
|
|
175
|
-
console.log(` Success detected: ${result.successDetected ? '✓' : '✗'}`);
|
|
176
|
-
if (result.promptsResponded.length > 0) {
|
|
177
|
-
console.log(` Prompts responded: ${result.promptsResponded.join(', ')}`);
|
|
178
|
-
}
|
|
179
|
-
console.log('');
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
// Summary
|
|
183
|
-
const passed = results.filter(r => r.passed).length;
|
|
184
|
-
const failed = results.filter(r => !r.passed).length;
|
|
185
|
-
|
|
186
|
-
console.log('═══════════════════════════════════════════════════════════════');
|
|
187
|
-
console.log(`Summary: ${passed} passed, ${failed} failed`);
|
|
188
|
-
console.log('═══════════════════════════════════════════════════════════════');
|
|
189
|
-
|
|
190
|
-
// Exit with error if any tests failed
|
|
191
|
-
if (failed > 0) {
|
|
192
|
-
console.log('\nFailed tests:');
|
|
193
|
-
for (const result of results.filter(r => !r.passed)) {
|
|
194
|
-
console.log(` - ${result.provider}: ${result.error || 'See details above'}`);
|
|
195
|
-
}
|
|
196
|
-
process.exit(1);
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
// Parse CLI args
|
|
201
|
-
const args = process.argv.slice(2);
|
|
202
|
-
if (args.includes('--help') || args.includes('-h')) {
|
|
203
|
-
console.log(`
|
|
204
|
-
CLI OAuth Flow Integration Test
|
|
205
|
-
|
|
206
|
-
Usage:
|
|
207
|
-
npx tsx scripts/test-cli-auth/test-oauth-flow.ts [provider...]
|
|
208
|
-
|
|
209
|
-
Examples:
|
|
210
|
-
npx tsx scripts/test-cli-auth/test-oauth-flow.ts # Test all providers
|
|
211
|
-
npx tsx scripts/test-cli-auth/test-oauth-flow.ts anthropic # Test Claude only
|
|
212
|
-
npx tsx scripts/test-cli-auth/test-oauth-flow.ts anthropic openai # Test multiple
|
|
213
|
-
|
|
214
|
-
Providers:
|
|
215
|
-
${Object.keys(CLI_AUTH_CONFIG).join(', ')}
|
|
216
|
-
`);
|
|
217
|
-
process.exit(0);
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
runTests(args.length > 0 ? args : undefined).catch(console.error);
|
|
@@ -1,222 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* Automated PTY input test for Claude CLI
|
|
4
|
-
* Tests different input methods without user interaction
|
|
5
|
-
* Run inside workspace container: node /app/dist/scripts/test-pty-input-auto.js
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import * as pty from 'node-pty';
|
|
9
|
-
|
|
10
|
-
const TEST_CODE = 'test-auth-code-12345';
|
|
11
|
-
const INPUT_METHOD = process.argv[2] || '1';
|
|
12
|
-
|
|
13
|
-
// Debug: Log all escape sequences we send
|
|
14
|
-
function logHex(label, data) {
|
|
15
|
-
const hex = Buffer.from(data).toString('hex').replace(/(.{2})/g, '$1 ').trim();
|
|
16
|
-
console.log(`[HEX] ${label}: ${hex}`);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function stripAnsi(str) {
|
|
20
|
-
return str.replace(/\x1b\[[0-9;]*[a-zA-Z]/g, '');
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
async function main() {
|
|
24
|
-
console.log(`\nTesting PTY input method ${INPUT_METHOD} with code: ${TEST_CODE}\n`);
|
|
25
|
-
|
|
26
|
-
const proc = pty.spawn('claude', [], {
|
|
27
|
-
name: 'xterm-256color',
|
|
28
|
-
cols: 120,
|
|
29
|
-
rows: 30,
|
|
30
|
-
cwd: '/workspace',
|
|
31
|
-
env: {
|
|
32
|
-
...process.env,
|
|
33
|
-
NO_COLOR: '1',
|
|
34
|
-
TERM: 'xterm-256color',
|
|
35
|
-
DISPLAY: '',
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
let output = '';
|
|
40
|
-
let authUrl = null;
|
|
41
|
-
let codePromptSeen = false;
|
|
42
|
-
let codeSent = false;
|
|
43
|
-
const prompts = [
|
|
44
|
-
{ pattern: /dark\s*(mode|theme)/i, response: '\r', name: 'dark mode' },
|
|
45
|
-
{ pattern: /select\s*login|how\s*would\s*you\s*like|subscription\s*or.*api/i, response: '\r', name: 'login method' },
|
|
46
|
-
];
|
|
47
|
-
const respondedPrompts = new Set();
|
|
48
|
-
|
|
49
|
-
proc.onData((data) => {
|
|
50
|
-
output += data;
|
|
51
|
-
const clean = stripAnsi(data);
|
|
52
|
-
|
|
53
|
-
// Log meaningful output
|
|
54
|
-
if (clean.trim()) {
|
|
55
|
-
const lines = clean.trim().split('\n').map(l => l.trim()).filter(l => l);
|
|
56
|
-
for (const line of lines) {
|
|
57
|
-
if (line.length > 3 && !line.match(/^[·✢*✶✻✽]+$/)) {
|
|
58
|
-
console.log('[PTY]', line.substring(0, 120));
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
// Auto-respond to prompts
|
|
64
|
-
for (const prompt of prompts) {
|
|
65
|
-
if (!respondedPrompts.has(prompt.name) && prompt.pattern.test(clean)) {
|
|
66
|
-
respondedPrompts.add(prompt.name);
|
|
67
|
-
console.log(`\n[AUTO] Responding to: ${prompt.name}`);
|
|
68
|
-
setTimeout(() => proc.write(prompt.response), 100);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
// Capture auth URL
|
|
73
|
-
const urlMatch = clean.match(/(https:\/\/[^\s]+)/);
|
|
74
|
-
if (urlMatch && !authUrl) {
|
|
75
|
-
authUrl = urlMatch[1];
|
|
76
|
-
console.log('\n[CAPTURED] Auth URL detected');
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
// Look for code paste prompt - various patterns Claude might use
|
|
80
|
-
const codePromptPatterns = [
|
|
81
|
-
/paste.*code/i,
|
|
82
|
-
/enter.*code/i,
|
|
83
|
-
/authorization.*code/i,
|
|
84
|
-
/code.*here/i,
|
|
85
|
-
/waiting.*code/i,
|
|
86
|
-
/input.*code/i,
|
|
87
|
-
];
|
|
88
|
-
|
|
89
|
-
if (authUrl && !codePromptSeen && !codeSent) {
|
|
90
|
-
for (const pattern of codePromptPatterns) {
|
|
91
|
-
if (pattern.test(clean)) {
|
|
92
|
-
codePromptSeen = true;
|
|
93
|
-
console.log('\n[DETECTED] Code prompt pattern:', pattern.toString());
|
|
94
|
-
break;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// Also look for the text input box indicator from Ink
|
|
100
|
-
// After URL is shown and some time passes, try sending the code
|
|
101
|
-
if (authUrl && !codeSent) {
|
|
102
|
-
// Check if we see any indication we should enter the code
|
|
103
|
-
const outputLower = stripAnsi(output).toLowerCase();
|
|
104
|
-
const hasCodePrompt = outputLower.includes('paste') ||
|
|
105
|
-
outputLower.includes('enter the code') ||
|
|
106
|
-
outputLower.includes('authorization code') ||
|
|
107
|
-
outputLower.includes("browser didn't open");
|
|
108
|
-
|
|
109
|
-
if (hasCodePrompt || output.length > 5000) {
|
|
110
|
-
codeSent = true;
|
|
111
|
-
console.log('\n[SENDING] Sending code after prompt/timeout...');
|
|
112
|
-
setTimeout(() => sendCode(proc), 500);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
proc.onExit(({ exitCode }) => {
|
|
118
|
-
console.log('\n[EXIT] Claude exited with code:', exitCode);
|
|
119
|
-
console.log('[TOTAL OUTPUT LENGTH]', output.length);
|
|
120
|
-
|
|
121
|
-
// Check for credentials
|
|
122
|
-
import('fs').then(fs => {
|
|
123
|
-
const credPath = '/home/workspace/.claude/.credentials.json';
|
|
124
|
-
if (fs.existsSync(credPath)) {
|
|
125
|
-
console.log('[SUCCESS] Credentials file found!');
|
|
126
|
-
const creds = fs.readFileSync(credPath, 'utf8');
|
|
127
|
-
console.log('[CREDS]', creds.substring(0, 200));
|
|
128
|
-
} else {
|
|
129
|
-
console.log('[RESULT] No credentials file created (expected with test code)');
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
setTimeout(() => process.exit(exitCode), 1000);
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
async function sendCode(ptyProc) {
|
|
137
|
-
const PASTE_START = '\x1b[200~';
|
|
138
|
-
const PASTE_END = '\x1b[201~';
|
|
139
|
-
|
|
140
|
-
console.log(`[METHOD ${INPUT_METHOD}] Sending test code...`);
|
|
141
|
-
|
|
142
|
-
switch (INPUT_METHOD) {
|
|
143
|
-
case '1':
|
|
144
|
-
console.log('[1] Plain code + \\r (carriage return)');
|
|
145
|
-
logHex('sending', TEST_CODE + '\r');
|
|
146
|
-
ptyProc.write(TEST_CODE + '\r');
|
|
147
|
-
break;
|
|
148
|
-
case '2':
|
|
149
|
-
console.log('[2] Plain code + \\n (newline)');
|
|
150
|
-
logHex('sending', TEST_CODE + '\n');
|
|
151
|
-
ptyProc.write(TEST_CODE + '\n');
|
|
152
|
-
break;
|
|
153
|
-
case '3':
|
|
154
|
-
console.log('[3] Bracketed paste + \\r');
|
|
155
|
-
logHex('paste start', PASTE_START);
|
|
156
|
-
logHex('code', TEST_CODE);
|
|
157
|
-
logHex('paste end', PASTE_END);
|
|
158
|
-
ptyProc.write(PASTE_START + TEST_CODE + PASTE_END);
|
|
159
|
-
await new Promise(r => setTimeout(r, 200));
|
|
160
|
-
logHex('enter', '\r');
|
|
161
|
-
ptyProc.write('\r');
|
|
162
|
-
break;
|
|
163
|
-
case '4':
|
|
164
|
-
console.log('[4] Plain code + \\r\\n (CRLF)');
|
|
165
|
-
logHex('sending', TEST_CODE + '\r\n');
|
|
166
|
-
ptyProc.write(TEST_CODE + '\r\n');
|
|
167
|
-
break;
|
|
168
|
-
case '5':
|
|
169
|
-
console.log('[5] Character by character + \\r');
|
|
170
|
-
for (const char of TEST_CODE) {
|
|
171
|
-
ptyProc.write(char);
|
|
172
|
-
await new Promise(r => setTimeout(r, 10));
|
|
173
|
-
}
|
|
174
|
-
await new Promise(r => setTimeout(r, 200));
|
|
175
|
-
logHex('enter', '\r');
|
|
176
|
-
ptyProc.write('\r');
|
|
177
|
-
break;
|
|
178
|
-
case '6':
|
|
179
|
-
console.log('[6] Code then wait, then Enter separately');
|
|
180
|
-
logHex('code only', TEST_CODE);
|
|
181
|
-
ptyProc.write(TEST_CODE);
|
|
182
|
-
await new Promise(r => setTimeout(r, 1000));
|
|
183
|
-
console.log('[6] Now sending Enter...');
|
|
184
|
-
logHex('enter', '\r');
|
|
185
|
-
ptyProc.write('\r');
|
|
186
|
-
break;
|
|
187
|
-
case '7':
|
|
188
|
-
console.log('[7] Send Enter first then code then Enter');
|
|
189
|
-
ptyProc.write('\r'); // Clear any existing state
|
|
190
|
-
await new Promise(r => setTimeout(r, 200));
|
|
191
|
-
logHex('code + enter', TEST_CODE + '\r');
|
|
192
|
-
ptyProc.write(TEST_CODE + '\r');
|
|
193
|
-
break;
|
|
194
|
-
case '8':
|
|
195
|
-
console.log('[8] Ctrl+M (same as \\r but explicit)');
|
|
196
|
-
logHex('code + ctrl-m', TEST_CODE + '\x0d');
|
|
197
|
-
ptyProc.write(TEST_CODE + '\x0d');
|
|
198
|
-
break;
|
|
199
|
-
default:
|
|
200
|
-
console.log('[DEFAULT] Plain code + \\r');
|
|
201
|
-
ptyProc.write(TEST_CODE + '\r');
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
console.log('[SENT] Waiting for response...');
|
|
205
|
-
|
|
206
|
-
// Give it more time to process and show error
|
|
207
|
-
setTimeout(() => {
|
|
208
|
-
console.log('\n[TIMEOUT] Test complete, terminating...');
|
|
209
|
-
console.log('[FINAL OUTPUT CHECK] Last 500 chars of output:');
|
|
210
|
-
console.log(stripAnsi(output).slice(-500));
|
|
211
|
-
ptyProc.kill();
|
|
212
|
-
}, 20000);
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
// Failsafe timeout
|
|
216
|
-
setTimeout(() => {
|
|
217
|
-
console.log('\n[FAILSAFE] Max time reached, terminating...');
|
|
218
|
-
proc.kill();
|
|
219
|
-
}, 60000);
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
main().catch(console.error);
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* Test PTY input methods for Claude CLI
|
|
4
|
-
* Run inside workspace container: node /app/dist/scripts/test-pty-input.js
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import * as pty from 'node-pty';
|
|
8
|
-
import * as readline from 'readline';
|
|
9
|
-
|
|
10
|
-
const rl = readline.createInterface({
|
|
11
|
-
input: process.stdin,
|
|
12
|
-
output: process.stdout
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
function ask(question) {
|
|
16
|
-
return new Promise(resolve => rl.question(question, resolve));
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function stripAnsi(str) {
|
|
20
|
-
return str.replace(/\x1b\[[0-9;]*[a-zA-Z]/g, '');
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
async function main() {
|
|
24
|
-
console.log('Starting Claude CLI via PTY...\n');
|
|
25
|
-
|
|
26
|
-
const proc = pty.spawn('claude', [], {
|
|
27
|
-
name: 'xterm-256color',
|
|
28
|
-
cols: 120,
|
|
29
|
-
rows: 30,
|
|
30
|
-
cwd: '/workspace',
|
|
31
|
-
env: {
|
|
32
|
-
...process.env,
|
|
33
|
-
NO_COLOR: '1',
|
|
34
|
-
TERM: 'xterm-256color',
|
|
35
|
-
DISPLAY: '',
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
let output = '';
|
|
40
|
-
let authUrl = null;
|
|
41
|
-
const prompts = [
|
|
42
|
-
{ pattern: /dark\s*(mode|theme)/i, response: '\r', name: 'dark mode' },
|
|
43
|
-
{ pattern: /select\s*login|how\s*would\s*you\s*like|subscription\s*or.*api/i, response: '\r', name: 'login method' },
|
|
44
|
-
];
|
|
45
|
-
const respondedPrompts = new Set();
|
|
46
|
-
|
|
47
|
-
proc.onData((data) => {
|
|
48
|
-
output += data;
|
|
49
|
-
const clean = stripAnsi(data);
|
|
50
|
-
|
|
51
|
-
// Log output
|
|
52
|
-
if (clean.trim()) {
|
|
53
|
-
console.log('[PTY]', clean.substring(0, 200));
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
// Auto-respond to prompts
|
|
57
|
-
for (const prompt of prompts) {
|
|
58
|
-
if (!respondedPrompts.has(prompt.name) && prompt.pattern.test(clean)) {
|
|
59
|
-
respondedPrompts.add(prompt.name);
|
|
60
|
-
console.log(`\n[AUTO] Responding to: ${prompt.name}`);
|
|
61
|
-
setTimeout(() => proc.write(prompt.response), 100);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// Capture auth URL
|
|
66
|
-
const urlMatch = clean.match(/(https:\/\/[^\s]+)/);
|
|
67
|
-
if (urlMatch && !authUrl) {
|
|
68
|
-
authUrl = urlMatch[1];
|
|
69
|
-
console.log('\n[CAPTURED] Auth URL:', authUrl.substring(0, 80) + '...');
|
|
70
|
-
promptForCode();
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
proc.onExit(({ exitCode }) => {
|
|
75
|
-
console.log('\n[EXIT] Claude exited with code:', exitCode);
|
|
76
|
-
console.log('[OUTPUT LENGTH]', output.length);
|
|
77
|
-
rl.close();
|
|
78
|
-
process.exit(exitCode);
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
async function promptForCode() {
|
|
82
|
-
console.log('\n========================================');
|
|
83
|
-
console.log('Complete OAuth in browser, then paste the code here.');
|
|
84
|
-
console.log('========================================\n');
|
|
85
|
-
|
|
86
|
-
const code = await ask('Paste auth code: ');
|
|
87
|
-
|
|
88
|
-
console.log('\nSelect input method:');
|
|
89
|
-
console.log('1. Plain code + \\r');
|
|
90
|
-
console.log('2. Plain code + \\n');
|
|
91
|
-
console.log('3. Bracketed paste + \\r');
|
|
92
|
-
console.log('4. Bracketed paste + \\n');
|
|
93
|
-
console.log('5. Character by character + \\r');
|
|
94
|
-
|
|
95
|
-
const method = await ask('Choice (1-5): ');
|
|
96
|
-
|
|
97
|
-
const PASTE_START = '\x1b[200~';
|
|
98
|
-
const PASTE_END = '\x1b[201~';
|
|
99
|
-
const cleanCode = code.trim();
|
|
100
|
-
|
|
101
|
-
console.log(`\n[SENDING] Using method ${method}...`);
|
|
102
|
-
|
|
103
|
-
switch (method) {
|
|
104
|
-
case '1':
|
|
105
|
-
proc.write(cleanCode + '\r');
|
|
106
|
-
break;
|
|
107
|
-
case '2':
|
|
108
|
-
proc.write(cleanCode + '\n');
|
|
109
|
-
break;
|
|
110
|
-
case '3':
|
|
111
|
-
proc.write(PASTE_START + cleanCode + PASTE_END);
|
|
112
|
-
await new Promise(r => setTimeout(r, 200));
|
|
113
|
-
proc.write('\r');
|
|
114
|
-
break;
|
|
115
|
-
case '4':
|
|
116
|
-
proc.write(PASTE_START + cleanCode + PASTE_END);
|
|
117
|
-
await new Promise(r => setTimeout(r, 200));
|
|
118
|
-
proc.write('\n');
|
|
119
|
-
break;
|
|
120
|
-
case '5':
|
|
121
|
-
for (const char of cleanCode) {
|
|
122
|
-
proc.write(char);
|
|
123
|
-
await new Promise(r => setTimeout(r, 10));
|
|
124
|
-
}
|
|
125
|
-
await new Promise(r => setTimeout(r, 200));
|
|
126
|
-
proc.write('\r');
|
|
127
|
-
break;
|
|
128
|
-
default:
|
|
129
|
-
proc.write(cleanCode + '\r');
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
console.log('[SENT] Waiting for response...\n');
|
|
133
|
-
|
|
134
|
-
// Wait and watch output
|
|
135
|
-
setTimeout(() => {
|
|
136
|
-
console.log('\n[CHECK] Checking for credentials file...');
|
|
137
|
-
import('fs').then(fs => {
|
|
138
|
-
const credPath = '/home/workspace/.claude/.credentials.json';
|
|
139
|
-
if (fs.existsSync(credPath)) {
|
|
140
|
-
console.log('[SUCCESS] Credentials file found!');
|
|
141
|
-
console.log(fs.readFileSync(credPath, 'utf8').substring(0, 200));
|
|
142
|
-
} else {
|
|
143
|
-
console.log('[FAIL] No credentials file yet');
|
|
144
|
-
}
|
|
145
|
-
});
|
|
146
|
-
}, 5000);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
main().catch(console.error);
|