agent-relay 1.1.0 → 1.2.3
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/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_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_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_7ludwvz45veh.json +209 -0
- package/.trajectories/completed/2026-01/traj_7ludwvz45veh.md +97 -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_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_dfuvww9pege5.json +59 -0
- package/.trajectories/completed/2026-01/traj_dfuvww9pege5.md +37 -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_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_m2xkjv0w2sq7.json +25 -0
- package/.trajectories/completed/2026-01/traj_m2xkjv0w2sq7.md +15 -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_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_v87hypnongqx.json +71 -0
- package/.trajectories/completed/2026-01/traj_v87hypnongqx.md +42 -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_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/index.json +314 -0
- package/ARCHITECTURE.md +1245 -0
- package/README.md +1 -1
- 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/entrypoint-browser.sh +118 -0
- package/deploy/workspace/entrypoint.sh +348 -0
- package/deploy/workspace/git-credential-relay +111 -0
- package/dist/bridge/spawner.d.ts +53 -0
- package/dist/bridge/spawner.js +203 -19
- package/dist/bridge/types.d.ts +12 -0
- package/dist/cli/index.js +618 -5
- package/dist/cloud/api/auth.d.ts +3 -2
- package/dist/cloud/api/auth.js +10 -98
- package/dist/cloud/api/billing.js +30 -9
- package/dist/cloud/api/cli-pty-runner.d.ts +54 -0
- package/dist/cloud/api/cli-pty-runner.js +119 -0
- package/dist/cloud/api/codex-auth-helper.d.ts +15 -0
- package/dist/cloud/api/codex-auth-helper.js +100 -0
- package/dist/cloud/api/generic-webhooks.d.ts +8 -0
- package/dist/cloud/api/generic-webhooks.js +129 -0
- package/dist/cloud/api/git.d.ts +8 -0
- package/dist/cloud/api/git.js +152 -0
- package/dist/cloud/api/github-app.d.ts +11 -0
- package/dist/cloud/api/github-app.js +189 -0
- package/dist/cloud/api/middleware/planLimits.d.ts +7 -0
- package/dist/cloud/api/middleware/planLimits.js +39 -1
- package/dist/cloud/api/monitoring.d.ts +11 -0
- package/dist/cloud/api/monitoring.js +578 -0
- package/dist/cloud/api/nango-auth.d.ts +9 -0
- package/dist/cloud/api/nango-auth.js +377 -0
- package/dist/cloud/api/onboarding.d.ts +8 -1
- package/dist/cloud/api/onboarding.js +313 -119
- package/dist/cloud/api/policy.d.ts +8 -0
- package/dist/cloud/api/policy.js +229 -0
- package/dist/cloud/api/providers.js +114 -42
- package/dist/cloud/api/repos.d.ts +1 -0
- package/dist/cloud/api/repos.js +186 -0
- package/dist/cloud/api/test-helpers.d.ts +10 -0
- package/dist/cloud/api/test-helpers.js +575 -0
- package/dist/cloud/api/webhooks.d.ts +8 -0
- package/dist/cloud/api/webhooks.js +645 -0
- package/dist/cloud/api/workspaces.js +320 -12
- package/dist/cloud/billing/plans.js +32 -19
- package/dist/cloud/billing/types.d.ts +9 -3
- package/dist/cloud/config.d.ts +9 -2
- package/dist/cloud/config.js +13 -4
- package/dist/cloud/db/drizzle.d.ts +84 -1
- package/dist/cloud/db/drizzle.js +470 -0
- package/dist/cloud/db/index.d.ts +9 -4
- package/dist/cloud/db/index.js +11 -3
- package/dist/cloud/db/schema.d.ts +3283 -556
- package/dist/cloud/db/schema.js +314 -1
- package/dist/cloud/index.d.ts +1 -0
- package/dist/cloud/index.js +2 -0
- package/dist/cloud/provisioner/index.d.ts +56 -0
- package/dist/cloud/provisioner/index.js +676 -34
- package/dist/cloud/server.d.ts +1 -0
- package/dist/cloud/server.js +362 -13
- package/dist/cloud/services/auto-scaler.d.ts +152 -0
- package/dist/cloud/services/auto-scaler.js +439 -0
- package/dist/cloud/services/capacity-manager.d.ts +148 -0
- package/dist/cloud/services/capacity-manager.js +449 -0
- package/dist/cloud/services/ci-agent-spawner.d.ts +49 -0
- package/dist/cloud/services/ci-agent-spawner.js +373 -0
- package/dist/cloud/services/index.d.ts +12 -0
- package/dist/cloud/services/index.js +15 -0
- package/dist/cloud/services/mention-handler.d.ts +65 -0
- package/dist/cloud/services/mention-handler.js +405 -0
- package/dist/cloud/services/nango.d.ts +186 -0
- package/dist/cloud/services/nango.js +344 -0
- package/dist/cloud/services/persistence.d.ts +131 -0
- package/dist/cloud/services/persistence.js +200 -0
- package/dist/cloud/services/planLimits.d.ts +37 -0
- package/dist/cloud/services/planLimits.js +86 -5
- package/dist/cloud/services/scaling-orchestrator.d.ts +159 -0
- package/dist/cloud/services/scaling-orchestrator.js +502 -0
- package/dist/cloud/services/scaling-policy.d.ts +121 -0
- package/dist/cloud/services/scaling-policy.js +415 -0
- package/dist/cloud/vault/index.js +1 -1
- package/dist/cloud/webhooks/index.d.ts +24 -0
- package/dist/cloud/webhooks/index.js +29 -0
- package/dist/cloud/webhooks/parsers/github.d.ts +8 -0
- package/dist/cloud/webhooks/parsers/github.js +234 -0
- package/dist/cloud/webhooks/parsers/index.d.ts +23 -0
- package/dist/cloud/webhooks/parsers/index.js +30 -0
- package/dist/cloud/webhooks/parsers/linear.d.ts +9 -0
- package/dist/cloud/webhooks/parsers/linear.js +258 -0
- package/dist/cloud/webhooks/parsers/slack.d.ts +9 -0
- package/dist/cloud/webhooks/parsers/slack.js +214 -0
- package/dist/cloud/webhooks/responders/github.d.ts +8 -0
- package/dist/cloud/webhooks/responders/github.js +73 -0
- package/dist/cloud/webhooks/responders/index.d.ts +23 -0
- package/dist/cloud/webhooks/responders/index.js +30 -0
- package/dist/cloud/webhooks/responders/linear.d.ts +9 -0
- package/dist/cloud/webhooks/responders/linear.js +149 -0
- package/dist/cloud/webhooks/responders/slack.d.ts +20 -0
- package/dist/cloud/webhooks/responders/slack.js +178 -0
- package/dist/cloud/webhooks/router.d.ts +25 -0
- package/dist/cloud/webhooks/router.js +504 -0
- package/dist/cloud/webhooks/rules-engine.d.ts +24 -0
- package/dist/cloud/webhooks/rules-engine.js +287 -0
- package/dist/cloud/webhooks/types.d.ts +186 -0
- package/dist/cloud/webhooks/types.js +8 -0
- package/dist/continuity/formatter.d.ts +51 -0
- package/dist/continuity/formatter.js +313 -0
- package/dist/continuity/handoff-store.d.ts +67 -0
- package/dist/continuity/handoff-store.js +472 -0
- package/dist/continuity/index.d.ts +45 -0
- package/dist/continuity/index.js +48 -0
- package/dist/continuity/ledger-store.d.ts +110 -0
- package/dist/continuity/ledger-store.js +500 -0
- package/dist/continuity/manager.d.ts +178 -0
- package/dist/continuity/manager.js +562 -0
- package/dist/continuity/parser.d.ts +76 -0
- package/dist/continuity/parser.js +579 -0
- package/dist/continuity/types.d.ts +180 -0
- package/dist/continuity/types.js +9 -0
- package/dist/daemon/agent-manager.d.ts +27 -0
- package/dist/daemon/agent-manager.js +107 -6
- package/dist/daemon/agent-registry.d.ts +32 -0
- package/dist/daemon/agent-registry.js +42 -2
- package/dist/daemon/api.d.ts +12 -0
- package/dist/daemon/api.js +131 -2
- package/dist/daemon/cli-auth.d.ts +67 -0
- package/dist/daemon/cli-auth.js +537 -0
- package/dist/daemon/cloud-sync.js +9 -7
- package/dist/daemon/orchestrator.js +30 -0
- package/dist/daemon/router.d.ts +5 -0
- package/dist/daemon/router.js +78 -26
- package/dist/daemon/server.d.ts +5 -0
- package/dist/daemon/server.js +9 -1
- package/dist/daemon/services/browser-testing.d.ts +88 -0
- package/dist/daemon/services/browser-testing.js +244 -0
- package/dist/daemon/services/container-spawner.d.ts +135 -0
- package/dist/daemon/services/container-spawner.js +313 -0
- package/dist/daemon/types.d.ts +5 -1
- package/dist/dashboard/out/404.html +1 -1
- package/dist/dashboard/out/_next/static/chunks/116-2502180def231162.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/282-980c2eb8fff20123.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/699-3b1cd6618a45d259.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/724-2dae7627550ab88f.js +9 -0
- package/dist/dashboard/out/_next/static/chunks/766-1f2dd8cb7f766b0b.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/onboarding/page-3fdfa60e53f2810d.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/page-e6381e5a6e1fbcfd.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/connect-repos/page-3538dfe0ffe984b8.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/history/{page-b6edd4dde8d08194.js → page-abb9ab2d329f56e9.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/app/layout-c0d118c0f92d969c.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/login/page-c22d080201cbd9fb.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-67a3e98d9a43a6ed.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/page-77e9c65420a06cfb.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/pricing/page-b08ed1c34d14434a.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/providers/page-e88bc117ef7671c3.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/signup/page-68d34f50baa8ab6b.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/e868780c-48e5f147c90a3a41.js +18 -0
- package/dist/dashboard/out/_next/static/chunks/{main-app-5d692157a8eb1fd9.js → main-app-6e8e8d3ef4e0192a.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/{main-c2f423b9c9f4591b.js → main-ed4e1fb6f29c34cf.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +1 -0
- package/dist/dashboard/out/_next/static/css/29852f26181969a0.css +1 -0
- package/dist/dashboard/out/_next/static/css/7c3ae9e8617d42a5.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 -14
- package/dist/dashboard/out/app.txt +2 -2
- package/dist/dashboard/out/connect-repos.html +1 -0
- package/dist/dashboard/out/connect-repos.txt +7 -0
- package/dist/dashboard/out/history.html +1 -1
- package/dist/dashboard/out/history.txt +2 -2
- package/dist/dashboard/out/index.html +1 -1
- package/dist/dashboard/out/index.txt +2 -2
- package/dist/dashboard/out/login.html +6 -0
- package/dist/dashboard/out/login.txt +7 -0
- package/dist/dashboard/out/metrics.html +1 -1
- package/dist/dashboard/out/metrics.txt +2 -2
- package/dist/dashboard/out/pricing.html +3 -3
- package/dist/dashboard/out/pricing.txt +2 -2
- package/dist/dashboard/out/providers.html +1 -0
- package/dist/dashboard/out/providers.txt +7 -0
- package/dist/dashboard/out/signup.html +6 -0
- package/dist/dashboard/out/signup.txt +7 -0
- package/dist/dashboard-server/server.js +1308 -8
- package/dist/hooks/emitter.d.ts +40 -0
- package/dist/hooks/emitter.js +63 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/registry.d.ts +173 -0
- package/dist/hooks/registry.js +476 -0
- package/dist/hooks/trajectory-hooks.d.ts +52 -0
- package/dist/hooks/trajectory-hooks.js +183 -0
- package/dist/hooks/types.d.ts +141 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +3 -0
- package/dist/memory/adapters/index.d.ts +8 -0
- package/dist/memory/adapters/index.js +8 -0
- package/dist/memory/adapters/inmemory.d.ts +59 -0
- package/dist/memory/adapters/inmemory.js +195 -0
- package/dist/memory/adapters/supermemory.d.ts +71 -0
- package/dist/memory/adapters/supermemory.js +338 -0
- package/dist/memory/factory.d.ts +48 -0
- package/dist/memory/factory.js +143 -0
- package/dist/memory/index.d.ts +32 -0
- package/dist/memory/index.js +32 -0
- package/dist/memory/memory-hooks.d.ts +60 -0
- package/dist/memory/memory-hooks.js +313 -0
- package/dist/memory/service.d.ts +49 -0
- package/dist/memory/service.js +146 -0
- package/dist/memory/types.d.ts +195 -0
- package/dist/memory/types.js +8 -0
- package/dist/policy/agent-policy.d.ts +225 -0
- package/dist/policy/agent-policy.js +665 -0
- package/dist/policy/cloud-policy-fetcher.d.ts +12 -0
- package/dist/policy/cloud-policy-fetcher.js +64 -0
- package/dist/resiliency/crash-insights.d.ts +156 -0
- package/dist/resiliency/crash-insights.js +492 -0
- package/dist/resiliency/gossip-health.d.ts +137 -0
- package/dist/resiliency/gossip-health.js +241 -0
- package/dist/resiliency/index.d.ts +5 -0
- package/dist/resiliency/index.js +5 -0
- package/dist/resiliency/leader-watchdog.d.ts +109 -0
- package/dist/resiliency/leader-watchdog.js +189 -0
- package/dist/resiliency/memory-monitor.d.ts +172 -0
- package/dist/resiliency/memory-monitor.js +593 -0
- package/dist/resiliency/stateless-lead.d.ts +149 -0
- package/dist/resiliency/stateless-lead.js +308 -0
- package/dist/resiliency/supervisor.d.ts +38 -0
- package/dist/resiliency/supervisor.js +122 -0
- package/dist/shared/cli-auth-config.d.ts +91 -0
- package/dist/shared/cli-auth-config.js +264 -0
- package/dist/storage/adapter.d.ts +1 -1
- package/dist/trajectory/config.d.ts +84 -0
- package/dist/trajectory/config.js +163 -0
- package/dist/trajectory/index.d.ts +8 -0
- package/dist/trajectory/index.js +8 -0
- package/dist/trajectory/integration.d.ts +292 -0
- package/dist/trajectory/integration.js +834 -0
- package/dist/utils/logger.js +1 -1
- package/dist/utils/project-namespace.d.ts +24 -0
- package/dist/utils/project-namespace.js +84 -0
- package/dist/wrapper/parser.d.ts +10 -0
- package/dist/wrapper/parser.js +100 -33
- package/dist/wrapper/pty-wrapper.d.ts +197 -16
- package/dist/wrapper/pty-wrapper.js +943 -106
- package/dist/wrapper/shared.d.ts +165 -0
- package/dist/wrapper/shared.js +270 -0
- package/dist/wrapper/tmux-wrapper.d.ts +73 -11
- package/dist/wrapper/tmux-wrapper.js +541 -120
- package/package.json +16 -16
- package/scripts/postinstall.js +60 -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/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/middleware/planLimits.d.ts.map +0 -1
- package/dist/cloud/api/middleware/planLimits.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/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/usage.d.ts.map +0 -1
- package/dist/cloud/api/usage.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/coordinator.d.ts.map +0 -1
- package/dist/cloud/services/coordinator.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/vault/index.d.ts.map +0 -1
- package/dist/cloud/vault/index.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/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/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/chunks/693-7b3301d8f6bc5014.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/713-f78477eb185f1f4d.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/766-e53e1cfe39b0b5b5.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/900-037c64bfd797fb2a.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/app/page-e3d9e1f4466b9bae.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/layout-2433bb48965f4333.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-e68825a81db67ba1.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/page-cc108bf68c8a657f.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/pricing/page-d80e03a5297f95b6.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/webpack-a5acc2831d094776.js +0 -1
- package/dist/dashboard/out/_next/static/css/79b80143647a07d7.css +0 -1
- package/dist/dashboard/out/_next/static/css/8cf277370ad48cfe.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/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/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/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/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/logger.d.ts.map +0 -1
- package/dist/resiliency/logger.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/supervisor.d.ts.map +0 -1
- package/dist/resiliency/supervisor.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/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/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/CHANGELOG.md +0 -11
- package/docs/CLI-SIMPLIFICATION-COMPLETE.md +0 -48
- package/docs/CLOUD-ARCHITECTURE.md +0 -652
- package/docs/CLOUD-ONBOARDING-DESIGN.md +0 -1983
- package/docs/COMPETITIVE_ANALYSIS.md +0 -897
- package/docs/CONTRIBUTING.md +0 -151
- package/docs/DESIGN_BRIDGE_STAFFING.md +0 -878
- package/docs/DESIGN_V2.md +0 -1079
- package/docs/INTEGRATION-GUIDE.md +0 -926
- package/docs/MONETIZATION.md +0 -1679
- package/docs/PROPOSAL-trajectories.md +0 -1582
- package/docs/PROTOCOL.md +0 -325
- package/docs/SCALING_ANALYSIS.md +0 -280
- package/docs/TESTING_PRESENCE_FEATURES.md +0 -327
- package/docs/TMUX_IMPLEMENTATION_NOTES.md +0 -364
- package/docs/TMUX_IMPROVEMENTS.md +0 -968
- package/docs/agent-relay-snippet.md +0 -168
- package/docs/competitive-analysis-mcp-agent-mail.md +0 -389
- package/docs/dashboard-v2-plan.md +0 -179
- package/docs/guides/CLOUD.md +0 -236
- package/docs/guides/LOCAL.md +0 -535
- package/docs/guides/SELF-HOSTED.md +0 -494
- package/docs/proposals/shadow-as-subagent.md +0 -765
- package/docs/proposals/slack-bot-integration.md +0 -1457
- package/docs/removable-code-analysis.md +0 -24
- 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/tictactoe-setup.sh +0 -181
- /package/dist/dashboard/out/_next/static/chunks/{117-b2cd8d6485aacf2b.js → 117-f7b8ab0809342e77.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{648-8f3f26864ce515e5.js → 648-5cc6e1921389a58a.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-0b990dbb71d72a98.js → page-53b8a69f76db17d0.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{fd9d1056-bf46c09eb57e019c.js → fd9d1056-609918ca7b6280bb.js} +0 -0
- /package/dist/dashboard/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → wPgKJtcOmTFLpUncDg16A}/_buildManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → wPgKJtcOmTFLpUncDg16A}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Git Gateway API Routes
|
|
3
|
+
*
|
|
4
|
+
* Provides fresh GitHub tokens to workspace containers for git operations.
|
|
5
|
+
* This gateway pattern ensures tokens are always valid (Nango handles refresh).
|
|
6
|
+
*/
|
|
7
|
+
import crypto from 'crypto';
|
|
8
|
+
import { Router } from 'express';
|
|
9
|
+
import { db } from '../db/index.js';
|
|
10
|
+
import { nangoService } from '../services/nango.js';
|
|
11
|
+
import { getConfig } from '../config.js';
|
|
12
|
+
export const gitRouter = Router();
|
|
13
|
+
/**
|
|
14
|
+
* Generate expected workspace token using HMAC
|
|
15
|
+
*/
|
|
16
|
+
function generateExpectedToken(workspaceId) {
|
|
17
|
+
const config = getConfig();
|
|
18
|
+
return crypto
|
|
19
|
+
.createHmac('sha256', config.sessionSecret)
|
|
20
|
+
.update(`workspace:${workspaceId}`)
|
|
21
|
+
.digest('hex');
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Verify workspace access token
|
|
25
|
+
* Workspaces authenticate with a secret passed at provisioning time
|
|
26
|
+
*/
|
|
27
|
+
function verifyWorkspaceToken(req, workspaceId) {
|
|
28
|
+
const authHeader = req.get('authorization');
|
|
29
|
+
if (!authHeader?.startsWith('Bearer ')) {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
const providedToken = authHeader.slice(7);
|
|
33
|
+
const expectedToken = generateExpectedToken(workspaceId);
|
|
34
|
+
// Use timing-safe comparison to prevent timing attacks
|
|
35
|
+
try {
|
|
36
|
+
return crypto.timingSafeEqual(Buffer.from(providedToken), Buffer.from(expectedToken));
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* GET /api/git/token
|
|
44
|
+
* Get a fresh GitHub token for git operations
|
|
45
|
+
*
|
|
46
|
+
* Query params:
|
|
47
|
+
* - workspaceId: The workspace requesting the token
|
|
48
|
+
*
|
|
49
|
+
* Returns: { token: string, expiresAt?: string }
|
|
50
|
+
*
|
|
51
|
+
* This endpoint is called by the git credential helper in workspace containers.
|
|
52
|
+
* It fetches a fresh GitHub App installation token via Nango.
|
|
53
|
+
*/
|
|
54
|
+
gitRouter.get('/token', async (req, res) => {
|
|
55
|
+
const { workspaceId } = req.query;
|
|
56
|
+
if (!workspaceId || typeof workspaceId !== 'string') {
|
|
57
|
+
return res.status(400).json({ error: 'workspaceId is required' });
|
|
58
|
+
}
|
|
59
|
+
// Verify the request is from a valid workspace
|
|
60
|
+
if (!verifyWorkspaceToken(req, workspaceId)) {
|
|
61
|
+
return res.status(401).json({ error: 'Invalid workspace token' });
|
|
62
|
+
}
|
|
63
|
+
try {
|
|
64
|
+
// Get workspace to find the user
|
|
65
|
+
const workspace = await db.workspaces.findById(workspaceId);
|
|
66
|
+
if (!workspace) {
|
|
67
|
+
return res.status(404).json({ error: 'Workspace not found' });
|
|
68
|
+
}
|
|
69
|
+
const userId = workspace.userId;
|
|
70
|
+
// Find a repository with a Nango connection for this user
|
|
71
|
+
const repos = await db.repositories.findByUserId(userId);
|
|
72
|
+
const repoWithConnection = repos.find(r => r.nangoConnectionId);
|
|
73
|
+
if (!repoWithConnection?.nangoConnectionId) {
|
|
74
|
+
return res.status(404).json({
|
|
75
|
+
error: 'No GitHub App connection found',
|
|
76
|
+
hint: 'Connect a repository via the GitHub App to enable git operations',
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
// Get fresh tokens from Nango (auto-refreshes if needed)
|
|
80
|
+
// - installationToken: for git operations (clone, push, pull)
|
|
81
|
+
// - userToken: for gh CLI operations (requires user context)
|
|
82
|
+
const installationToken = await nangoService.getGithubAppToken(repoWithConnection.nangoConnectionId);
|
|
83
|
+
// Try to get user OAuth token from github-app-oauth connection_config first
|
|
84
|
+
// Fall back to separate 'github' user connection if available
|
|
85
|
+
let userToken = null;
|
|
86
|
+
try {
|
|
87
|
+
userToken = await nangoService.getGithubUserOAuthToken(repoWithConnection.nangoConnectionId);
|
|
88
|
+
}
|
|
89
|
+
catch {
|
|
90
|
+
// Try the separate github user connection if available
|
|
91
|
+
const userRepo = repos.find(r => r.nangoConnectionId && r.nangoConnectionId !== repoWithConnection.nangoConnectionId);
|
|
92
|
+
if (userRepo?.nangoConnectionId) {
|
|
93
|
+
try {
|
|
94
|
+
userToken = await nangoService.getGithubUserToken(userRepo.nangoConnectionId);
|
|
95
|
+
}
|
|
96
|
+
catch {
|
|
97
|
+
console.log('[git] No github user token available');
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
// GitHub App installation tokens expire after 1 hour
|
|
102
|
+
const expiresAt = new Date(Date.now() + 55 * 60 * 1000).toISOString(); // 55 min buffer
|
|
103
|
+
res.json({
|
|
104
|
+
token: installationToken,
|
|
105
|
+
userToken, // For gh CLI - may be null if not available
|
|
106
|
+
expiresAt,
|
|
107
|
+
username: 'x-access-token', // GitHub App tokens use this as username
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
console.error('[git] Error getting token:', error);
|
|
112
|
+
res.status(500).json({ error: 'Failed to get GitHub token' });
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
/**
|
|
116
|
+
* POST /api/git/token
|
|
117
|
+
* Same as GET but accepts body params (for compatibility with some git credential helpers)
|
|
118
|
+
*/
|
|
119
|
+
gitRouter.post('/token', async (req, res) => {
|
|
120
|
+
const workspaceId = req.body.workspaceId || req.query.workspaceId;
|
|
121
|
+
if (!workspaceId || typeof workspaceId !== 'string') {
|
|
122
|
+
return res.status(400).json({ error: 'workspaceId is required' });
|
|
123
|
+
}
|
|
124
|
+
if (!verifyWorkspaceToken(req, workspaceId)) {
|
|
125
|
+
return res.status(401).json({ error: 'Invalid workspace token' });
|
|
126
|
+
}
|
|
127
|
+
try {
|
|
128
|
+
const workspace = await db.workspaces.findById(workspaceId);
|
|
129
|
+
if (!workspace) {
|
|
130
|
+
return res.status(404).json({ error: 'Workspace not found' });
|
|
131
|
+
}
|
|
132
|
+
const repos = await db.repositories.findByUserId(workspace.userId);
|
|
133
|
+
const repoWithConnection = repos.find(r => r.nangoConnectionId);
|
|
134
|
+
if (!repoWithConnection?.nangoConnectionId) {
|
|
135
|
+
return res.status(404).json({
|
|
136
|
+
error: 'No GitHub App connection found',
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
const token = await nangoService.getGithubAppToken(repoWithConnection.nangoConnectionId);
|
|
140
|
+
const expiresAt = new Date(Date.now() + 55 * 60 * 1000).toISOString();
|
|
141
|
+
res.json({
|
|
142
|
+
token,
|
|
143
|
+
expiresAt,
|
|
144
|
+
username: 'x-access-token',
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
catch (error) {
|
|
148
|
+
console.error('[git] Error getting token:', error);
|
|
149
|
+
res.status(500).json({ error: 'Failed to get GitHub token' });
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
//# sourceMappingURL=git.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitHub App API Routes
|
|
3
|
+
*
|
|
4
|
+
* Repo operations via Nango's github-app-oauth connection:
|
|
5
|
+
* - Get clone token for repositories
|
|
6
|
+
* - Create issues, PRs, and comments
|
|
7
|
+
*
|
|
8
|
+
* Auth flow is handled by nango-auth.ts
|
|
9
|
+
*/
|
|
10
|
+
export declare const githubAppRouter: import("express-serve-static-core").Router;
|
|
11
|
+
//# sourceMappingURL=github-app.d.ts.map
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitHub App API Routes
|
|
3
|
+
*
|
|
4
|
+
* Repo operations via Nango's github-app-oauth connection:
|
|
5
|
+
* - Get clone token for repositories
|
|
6
|
+
* - Create issues, PRs, and comments
|
|
7
|
+
*
|
|
8
|
+
* Auth flow is handled by nango-auth.ts
|
|
9
|
+
*/
|
|
10
|
+
import { Router } from 'express';
|
|
11
|
+
import { requireAuth } from './auth.js';
|
|
12
|
+
import { db } from '../db/index.js';
|
|
13
|
+
import { nangoService, NANGO_INTEGRATIONS } from '../services/nango.js';
|
|
14
|
+
export const githubAppRouter = Router();
|
|
15
|
+
// All routes require authentication
|
|
16
|
+
githubAppRouter.use(requireAuth);
|
|
17
|
+
/**
|
|
18
|
+
* GET /api/github-app/status
|
|
19
|
+
* Check if Nango GitHub App OAuth is configured
|
|
20
|
+
*/
|
|
21
|
+
githubAppRouter.get('/status', (_req, res) => {
|
|
22
|
+
res.json({
|
|
23
|
+
configured: true,
|
|
24
|
+
integrations: NANGO_INTEGRATIONS,
|
|
25
|
+
connectUrl: '/connect-repos',
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
/**
|
|
29
|
+
* GET /api/github-app/repos
|
|
30
|
+
* List repositories the user has connected via Nango
|
|
31
|
+
*/
|
|
32
|
+
githubAppRouter.get('/repos', async (req, res) => {
|
|
33
|
+
const userId = req.session.userId;
|
|
34
|
+
try {
|
|
35
|
+
const repos = await db.repositories.findByUserId(userId);
|
|
36
|
+
res.json({
|
|
37
|
+
repositories: repos.map((r) => ({
|
|
38
|
+
id: r.id,
|
|
39
|
+
fullName: r.githubFullName,
|
|
40
|
+
isPrivate: r.isPrivate,
|
|
41
|
+
defaultBranch: r.defaultBranch,
|
|
42
|
+
syncStatus: r.syncStatus,
|
|
43
|
+
hasNangoConnection: !!r.nangoConnectionId,
|
|
44
|
+
lastSyncedAt: r.lastSyncedAt,
|
|
45
|
+
})),
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
console.error('Error listing repos:', error);
|
|
50
|
+
res.status(500).json({ error: 'Failed to list repositories' });
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
/**
|
|
54
|
+
* GET /api/github-app/clone-token
|
|
55
|
+
* Get a clone token for a repository
|
|
56
|
+
* Used by workspace provisioner to clone private repos
|
|
57
|
+
*/
|
|
58
|
+
githubAppRouter.get('/clone-token', async (req, res) => {
|
|
59
|
+
const userId = req.session.userId;
|
|
60
|
+
const { repo } = req.query;
|
|
61
|
+
if (!repo || typeof repo !== 'string') {
|
|
62
|
+
return res.status(400).json({ error: 'Repository name is required (owner/repo)' });
|
|
63
|
+
}
|
|
64
|
+
try {
|
|
65
|
+
// Find the repository in our database
|
|
66
|
+
const userRepos = await db.repositories.findByUserId(userId);
|
|
67
|
+
const repository = userRepos.find((r) => r.githubFullName === repo);
|
|
68
|
+
if (!repository) {
|
|
69
|
+
return res.status(404).json({ error: 'Repository not found' });
|
|
70
|
+
}
|
|
71
|
+
if (!repository.nangoConnectionId) {
|
|
72
|
+
return res.status(400).json({
|
|
73
|
+
error: 'Repository not connected via Nango',
|
|
74
|
+
hint: 'Connect your GitHub repos through the Nango flow first',
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
// Get token from Nango connection
|
|
78
|
+
const token = await nangoService.getGithubAppToken(repository.nangoConnectionId);
|
|
79
|
+
const cloneUrl = `https://x-access-token:${token}@github.com/${repo}.git`;
|
|
80
|
+
res.json({
|
|
81
|
+
token,
|
|
82
|
+
cloneUrl,
|
|
83
|
+
expiresIn: '1 hour',
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
console.error('Error getting clone token:', error);
|
|
88
|
+
res.status(500).json({ error: 'Failed to get clone token' });
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
/**
|
|
92
|
+
* POST /api/github-app/repos/:id/issues
|
|
93
|
+
* Create an issue on a repository
|
|
94
|
+
*/
|
|
95
|
+
githubAppRouter.post('/repos/:id/issues', async (req, res) => {
|
|
96
|
+
const userId = req.session.userId;
|
|
97
|
+
const { id } = req.params;
|
|
98
|
+
const { title, body, labels } = req.body;
|
|
99
|
+
if (!title || typeof title !== 'string') {
|
|
100
|
+
return res.status(400).json({ error: 'Issue title is required' });
|
|
101
|
+
}
|
|
102
|
+
try {
|
|
103
|
+
// Find the repository
|
|
104
|
+
const repository = await db.repositories.findById(id);
|
|
105
|
+
if (!repository || repository.userId !== userId) {
|
|
106
|
+
return res.status(404).json({ error: 'Repository not found' });
|
|
107
|
+
}
|
|
108
|
+
if (!repository.nangoConnectionId) {
|
|
109
|
+
return res.status(400).json({ error: 'Repository not connected via Nango' });
|
|
110
|
+
}
|
|
111
|
+
// Create issue via Nango Proxy (handles token injection automatically)
|
|
112
|
+
const [owner, repo] = repository.githubFullName.split('/');
|
|
113
|
+
const issue = await nangoService.createGithubIssue(repository.nangoConnectionId, owner, repo, { title, body: body || '', labels });
|
|
114
|
+
res.json({
|
|
115
|
+
number: issue.number,
|
|
116
|
+
url: issue.html_url,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
catch (error) {
|
|
120
|
+
console.error('Error creating issue:', error);
|
|
121
|
+
res.status(500).json({ error: 'Failed to create issue' });
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
/**
|
|
125
|
+
* POST /api/github-app/repos/:id/pulls
|
|
126
|
+
* Create a pull request on a repository
|
|
127
|
+
*/
|
|
128
|
+
githubAppRouter.post('/repos/:id/pulls', async (req, res) => {
|
|
129
|
+
const userId = req.session.userId;
|
|
130
|
+
const { id } = req.params;
|
|
131
|
+
const { title, body, head, base } = req.body;
|
|
132
|
+
if (!title || !head || !base) {
|
|
133
|
+
return res.status(400).json({ error: 'title, head, and base are required' });
|
|
134
|
+
}
|
|
135
|
+
try {
|
|
136
|
+
// Find the repository
|
|
137
|
+
const repository = await db.repositories.findById(id);
|
|
138
|
+
if (!repository || repository.userId !== userId) {
|
|
139
|
+
return res.status(404).json({ error: 'Repository not found' });
|
|
140
|
+
}
|
|
141
|
+
if (!repository.nangoConnectionId) {
|
|
142
|
+
return res.status(400).json({ error: 'Repository not connected via Nango' });
|
|
143
|
+
}
|
|
144
|
+
// Create PR via Nango Proxy (handles token injection automatically)
|
|
145
|
+
const [owner, repo] = repository.githubFullName.split('/');
|
|
146
|
+
const pr = await nangoService.createGithubPullRequest(repository.nangoConnectionId, owner, repo, { title, body: body || '', head, base });
|
|
147
|
+
res.json({
|
|
148
|
+
number: pr.number,
|
|
149
|
+
url: pr.html_url,
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
catch (error) {
|
|
153
|
+
console.error('Error creating PR:', error);
|
|
154
|
+
res.status(500).json({ error: 'Failed to create pull request' });
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
/**
|
|
158
|
+
* POST /api/github-app/repos/:id/comments
|
|
159
|
+
* Add a comment to an issue or PR
|
|
160
|
+
*/
|
|
161
|
+
githubAppRouter.post('/repos/:id/comments', async (req, res) => {
|
|
162
|
+
const userId = req.session.userId;
|
|
163
|
+
const { id } = req.params;
|
|
164
|
+
const { issueNumber, body } = req.body;
|
|
165
|
+
if (!issueNumber || !body) {
|
|
166
|
+
return res.status(400).json({ error: 'issueNumber and body are required' });
|
|
167
|
+
}
|
|
168
|
+
try {
|
|
169
|
+
const repository = await db.repositories.findById(id);
|
|
170
|
+
if (!repository || repository.userId !== userId) {
|
|
171
|
+
return res.status(404).json({ error: 'Repository not found' });
|
|
172
|
+
}
|
|
173
|
+
if (!repository.nangoConnectionId) {
|
|
174
|
+
return res.status(400).json({ error: 'Repository not connected via Nango' });
|
|
175
|
+
}
|
|
176
|
+
// Add comment via Nango Proxy (handles token injection automatically)
|
|
177
|
+
const [owner, repo] = repository.githubFullName.split('/');
|
|
178
|
+
const comment = await nangoService.addGithubIssueComment(repository.nangoConnectionId, owner, repo, issueNumber, body);
|
|
179
|
+
res.json({
|
|
180
|
+
id: comment.id,
|
|
181
|
+
url: comment.html_url,
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
catch (error) {
|
|
185
|
+
console.error('Error adding comment:', error);
|
|
186
|
+
res.status(500).json({ error: 'Failed to add comment' });
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
//# sourceMappingURL=github-app.js.map
|
|
@@ -33,4 +33,11 @@ export declare function checkAgentLimit(req: Request, res: Response, next: NextF
|
|
|
33
33
|
* Coordinators are only available on Pro plan and above.
|
|
34
34
|
*/
|
|
35
35
|
export declare function checkCoordinatorAccess(req: Request, res: Response, next: NextFunction): Promise<void>;
|
|
36
|
+
/**
|
|
37
|
+
* Middleware to check session persistence access
|
|
38
|
+
*
|
|
39
|
+
* Use this middleware on endpoints that enable cloud session persistence.
|
|
40
|
+
* Session persistence is only available on Pro plan and above.
|
|
41
|
+
*/
|
|
42
|
+
export declare function checkSessionPersistenceAccess(req: Request, res: Response, next: NextFunction): Promise<void>;
|
|
36
43
|
//# sourceMappingURL=planLimits.d.ts.map
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Express middleware to enforce plan-based resource limits.
|
|
5
5
|
*/
|
|
6
|
-
import { canCreateWorkspace, canAddRepo, canSpawnAgent, canUseCoordinator, } from '../../services/planLimits.js';
|
|
6
|
+
import { canCreateWorkspace, canAddRepo, canSpawnAgent, canUseCoordinator, canUseSessionPersistence, } from '../../services/planLimits.js';
|
|
7
7
|
/**
|
|
8
8
|
* Middleware to check workspace creation limit
|
|
9
9
|
*
|
|
@@ -161,4 +161,42 @@ export async function checkCoordinatorAccess(req, res, next) {
|
|
|
161
161
|
res.status(500).json({ error: 'Failed to check coordinator access' });
|
|
162
162
|
}
|
|
163
163
|
}
|
|
164
|
+
/**
|
|
165
|
+
* Middleware to check session persistence access
|
|
166
|
+
*
|
|
167
|
+
* Use this middleware on endpoints that enable cloud session persistence.
|
|
168
|
+
* Session persistence is only available on Pro plan and above.
|
|
169
|
+
*/
|
|
170
|
+
export async function checkSessionPersistenceAccess(req, res, next) {
|
|
171
|
+
const userId = req.session.userId;
|
|
172
|
+
if (!userId) {
|
|
173
|
+
res.status(401).json({ error: 'Authentication required' });
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
try {
|
|
177
|
+
const check = await canUseSessionPersistence(userId);
|
|
178
|
+
if (!check.allowed) {
|
|
179
|
+
const response = {
|
|
180
|
+
error: check.reason || 'Session persistence not available',
|
|
181
|
+
code: 'FEATURE_NOT_AVAILABLE',
|
|
182
|
+
details: {
|
|
183
|
+
plan: 'current',
|
|
184
|
+
resource: 'sessionPersistence',
|
|
185
|
+
requiredPlan: check.requiredPlan,
|
|
186
|
+
},
|
|
187
|
+
upgrade: {
|
|
188
|
+
message: 'Upgrade to Pro to enable cloud session persistence',
|
|
189
|
+
url: '/settings/billing',
|
|
190
|
+
},
|
|
191
|
+
};
|
|
192
|
+
res.status(402).json(response);
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
next();
|
|
196
|
+
}
|
|
197
|
+
catch (error) {
|
|
198
|
+
console.error('Error checking session persistence access:', error);
|
|
199
|
+
res.status(500).json({ error: 'Failed to check session persistence access' });
|
|
200
|
+
}
|
|
201
|
+
}
|
|
164
202
|
//# sourceMappingURL=planLimits.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Monitoring API Routes
|
|
3
|
+
*
|
|
4
|
+
* Provides endpoints for:
|
|
5
|
+
* - Real-time memory metrics collection
|
|
6
|
+
* - Crash insights and history
|
|
7
|
+
* - Proactive alerting
|
|
8
|
+
* - System health dashboard
|
|
9
|
+
*/
|
|
10
|
+
export declare const monitoringRouter: import("express-serve-static-core").Router;
|
|
11
|
+
//# sourceMappingURL=monitoring.d.ts.map
|