agent-relay 1.1.0 → 1.2.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/README.md +1 -1
- package/dist/bridge/spawner.d.ts +53 -0
- package/dist/bridge/spawner.d.ts.map +1 -1
- package/dist/bridge/spawner.js +203 -19
- package/dist/bridge/spawner.js.map +1 -1
- package/dist/bridge/types.d.ts +12 -0
- package/dist/bridge/types.d.ts.map +1 -1
- package/dist/cli/index.js +401 -5
- package/dist/cli/index.js.map +1 -1
- package/dist/cloud/api/auth.d.ts +3 -2
- package/dist/cloud/api/auth.d.ts.map +1 -1
- package/dist/cloud/api/auth.js +10 -98
- package/dist/cloud/api/auth.js.map +1 -1
- package/dist/cloud/api/cli-pty-runner.d.ts +54 -0
- package/dist/cloud/api/cli-pty-runner.d.ts.map +1 -0
- package/dist/cloud/api/cli-pty-runner.js +119 -0
- package/dist/cloud/api/cli-pty-runner.js.map +1 -0
- package/dist/cloud/api/generic-webhooks.d.ts +8 -0
- package/dist/cloud/api/generic-webhooks.d.ts.map +1 -0
- package/dist/cloud/api/generic-webhooks.js +129 -0
- package/dist/cloud/api/generic-webhooks.js.map +1 -0
- package/dist/cloud/api/git.d.ts +8 -0
- package/dist/cloud/api/git.d.ts.map +1 -0
- package/dist/cloud/api/git.js +131 -0
- package/dist/cloud/api/git.js.map +1 -0
- package/dist/cloud/api/github-app.d.ts +11 -0
- package/dist/cloud/api/github-app.d.ts.map +1 -0
- package/dist/cloud/api/github-app.js +189 -0
- package/dist/cloud/api/github-app.js.map +1 -0
- package/dist/cloud/api/middleware/planLimits.d.ts +7 -0
- package/dist/cloud/api/middleware/planLimits.d.ts.map +1 -1
- package/dist/cloud/api/middleware/planLimits.js +39 -1
- package/dist/cloud/api/middleware/planLimits.js.map +1 -1
- package/dist/cloud/api/monitoring.d.ts +11 -0
- package/dist/cloud/api/monitoring.d.ts.map +1 -0
- package/dist/cloud/api/monitoring.js +578 -0
- package/dist/cloud/api/monitoring.js.map +1 -0
- package/dist/cloud/api/nango-auth.d.ts +9 -0
- package/dist/cloud/api/nango-auth.d.ts.map +1 -0
- package/dist/cloud/api/nango-auth.js +377 -0
- package/dist/cloud/api/nango-auth.js.map +1 -0
- package/dist/cloud/api/onboarding.d.ts +8 -1
- package/dist/cloud/api/onboarding.d.ts.map +1 -1
- package/dist/cloud/api/onboarding.js +300 -119
- package/dist/cloud/api/onboarding.js.map +1 -1
- package/dist/cloud/api/policy.d.ts +8 -0
- package/dist/cloud/api/policy.d.ts.map +1 -0
- package/dist/cloud/api/policy.js +229 -0
- package/dist/cloud/api/policy.js.map +1 -0
- package/dist/cloud/api/providers.js +114 -42
- package/dist/cloud/api/providers.js.map +1 -1
- package/dist/cloud/api/test-helpers.d.ts +10 -0
- package/dist/cloud/api/test-helpers.d.ts.map +1 -0
- package/dist/cloud/api/test-helpers.js +575 -0
- package/dist/cloud/api/test-helpers.js.map +1 -0
- package/dist/cloud/api/webhooks.d.ts +7 -0
- package/dist/cloud/api/webhooks.d.ts.map +1 -0
- package/dist/cloud/api/webhooks.js +496 -0
- package/dist/cloud/api/webhooks.js.map +1 -0
- package/dist/cloud/api/workspaces.js +225 -8
- package/dist/cloud/api/workspaces.js.map +1 -1
- package/dist/cloud/billing/plans.d.ts.map +1 -1
- package/dist/cloud/billing/plans.js +13 -0
- package/dist/cloud/billing/plans.js.map +1 -1
- package/dist/cloud/billing/types.d.ts +9 -3
- package/dist/cloud/billing/types.d.ts.map +1 -1
- package/dist/cloud/config.d.ts +9 -2
- package/dist/cloud/config.d.ts.map +1 -1
- package/dist/cloud/config.js +13 -4
- package/dist/cloud/config.js.map +1 -1
- package/dist/cloud/db/drizzle.d.ts +84 -1
- package/dist/cloud/db/drizzle.d.ts.map +1 -1
- package/dist/cloud/db/drizzle.js +470 -0
- package/dist/cloud/db/drizzle.js.map +1 -1
- package/dist/cloud/db/index.d.ts +9 -4
- package/dist/cloud/db/index.d.ts.map +1 -1
- package/dist/cloud/db/index.js +11 -3
- package/dist/cloud/db/index.js.map +1 -1
- package/dist/cloud/db/schema.d.ts +3283 -556
- package/dist/cloud/db/schema.d.ts.map +1 -1
- package/dist/cloud/db/schema.js +314 -1
- package/dist/cloud/db/schema.js.map +1 -1
- package/dist/cloud/index.d.ts +1 -0
- package/dist/cloud/index.d.ts.map +1 -1
- package/dist/cloud/index.js +2 -0
- package/dist/cloud/index.js.map +1 -1
- package/dist/cloud/provisioner/index.d.ts +24 -0
- package/dist/cloud/provisioner/index.d.ts.map +1 -1
- package/dist/cloud/provisioner/index.js +319 -18
- package/dist/cloud/provisioner/index.js.map +1 -1
- package/dist/cloud/server.d.ts +1 -0
- package/dist/cloud/server.d.ts.map +1 -1
- package/dist/cloud/server.js +357 -13
- package/dist/cloud/server.js.map +1 -1
- package/dist/cloud/services/auto-scaler.d.ts +152 -0
- package/dist/cloud/services/auto-scaler.d.ts.map +1 -0
- package/dist/cloud/services/auto-scaler.js +439 -0
- package/dist/cloud/services/auto-scaler.js.map +1 -0
- package/dist/cloud/services/capacity-manager.d.ts +148 -0
- package/dist/cloud/services/capacity-manager.d.ts.map +1 -0
- package/dist/cloud/services/capacity-manager.js +449 -0
- package/dist/cloud/services/capacity-manager.js.map +1 -0
- package/dist/cloud/services/ci-agent-spawner.d.ts +49 -0
- package/dist/cloud/services/ci-agent-spawner.d.ts.map +1 -0
- package/dist/cloud/services/ci-agent-spawner.js +373 -0
- package/dist/cloud/services/ci-agent-spawner.js.map +1 -0
- package/dist/cloud/services/index.d.ts +12 -0
- package/dist/cloud/services/index.d.ts.map +1 -0
- package/dist/cloud/services/index.js +15 -0
- package/dist/cloud/services/index.js.map +1 -0
- package/dist/cloud/services/mention-handler.d.ts +65 -0
- package/dist/cloud/services/mention-handler.d.ts.map +1 -0
- package/dist/cloud/services/mention-handler.js +405 -0
- package/dist/cloud/services/mention-handler.js.map +1 -0
- package/dist/cloud/services/nango.d.ts +126 -0
- package/dist/cloud/services/nango.d.ts.map +1 -0
- package/dist/cloud/services/nango.js +191 -0
- package/dist/cloud/services/nango.js.map +1 -0
- package/dist/cloud/services/persistence.d.ts +131 -0
- package/dist/cloud/services/persistence.d.ts.map +1 -0
- package/dist/cloud/services/persistence.js +200 -0
- package/dist/cloud/services/persistence.js.map +1 -0
- package/dist/cloud/services/planLimits.d.ts +15 -0
- package/dist/cloud/services/planLimits.d.ts.map +1 -1
- package/dist/cloud/services/planLimits.js +28 -0
- package/dist/cloud/services/planLimits.js.map +1 -1
- package/dist/cloud/services/scaling-orchestrator.d.ts +159 -0
- package/dist/cloud/services/scaling-orchestrator.d.ts.map +1 -0
- package/dist/cloud/services/scaling-orchestrator.js +502 -0
- package/dist/cloud/services/scaling-orchestrator.js.map +1 -0
- package/dist/cloud/services/scaling-policy.d.ts +121 -0
- package/dist/cloud/services/scaling-policy.d.ts.map +1 -0
- package/dist/cloud/services/scaling-policy.js +415 -0
- package/dist/cloud/services/scaling-policy.js.map +1 -0
- package/dist/cloud/vault/index.js +1 -1
- package/dist/cloud/vault/index.js.map +1 -1
- package/dist/cloud/webhooks/index.d.ts +24 -0
- package/dist/cloud/webhooks/index.d.ts.map +1 -0
- package/dist/cloud/webhooks/index.js +29 -0
- package/dist/cloud/webhooks/index.js.map +1 -0
- package/dist/cloud/webhooks/parsers/github.d.ts +8 -0
- package/dist/cloud/webhooks/parsers/github.d.ts.map +1 -0
- package/dist/cloud/webhooks/parsers/github.js +234 -0
- package/dist/cloud/webhooks/parsers/github.js.map +1 -0
- package/dist/cloud/webhooks/parsers/index.d.ts +23 -0
- package/dist/cloud/webhooks/parsers/index.d.ts.map +1 -0
- package/dist/cloud/webhooks/parsers/index.js +30 -0
- package/dist/cloud/webhooks/parsers/index.js.map +1 -0
- package/dist/cloud/webhooks/parsers/linear.d.ts +9 -0
- package/dist/cloud/webhooks/parsers/linear.d.ts.map +1 -0
- package/dist/cloud/webhooks/parsers/linear.js +258 -0
- package/dist/cloud/webhooks/parsers/linear.js.map +1 -0
- package/dist/cloud/webhooks/parsers/slack.d.ts +9 -0
- package/dist/cloud/webhooks/parsers/slack.d.ts.map +1 -0
- package/dist/cloud/webhooks/parsers/slack.js +214 -0
- package/dist/cloud/webhooks/parsers/slack.js.map +1 -0
- package/dist/cloud/webhooks/responders/github.d.ts +8 -0
- package/dist/cloud/webhooks/responders/github.d.ts.map +1 -0
- package/dist/cloud/webhooks/responders/github.js +73 -0
- package/dist/cloud/webhooks/responders/github.js.map +1 -0
- package/dist/cloud/webhooks/responders/index.d.ts +23 -0
- package/dist/cloud/webhooks/responders/index.d.ts.map +1 -0
- package/dist/cloud/webhooks/responders/index.js +30 -0
- package/dist/cloud/webhooks/responders/index.js.map +1 -0
- package/dist/cloud/webhooks/responders/linear.d.ts +9 -0
- package/dist/cloud/webhooks/responders/linear.d.ts.map +1 -0
- package/dist/cloud/webhooks/responders/linear.js +149 -0
- package/dist/cloud/webhooks/responders/linear.js.map +1 -0
- package/dist/cloud/webhooks/responders/slack.d.ts +20 -0
- package/dist/cloud/webhooks/responders/slack.d.ts.map +1 -0
- package/dist/cloud/webhooks/responders/slack.js +178 -0
- package/dist/cloud/webhooks/responders/slack.js.map +1 -0
- package/dist/cloud/webhooks/router.d.ts +25 -0
- package/dist/cloud/webhooks/router.d.ts.map +1 -0
- package/dist/cloud/webhooks/router.js +504 -0
- package/dist/cloud/webhooks/router.js.map +1 -0
- package/dist/cloud/webhooks/rules-engine.d.ts +24 -0
- package/dist/cloud/webhooks/rules-engine.d.ts.map +1 -0
- package/dist/cloud/webhooks/rules-engine.js +287 -0
- package/dist/cloud/webhooks/rules-engine.js.map +1 -0
- package/dist/cloud/webhooks/types.d.ts +186 -0
- package/dist/cloud/webhooks/types.d.ts.map +1 -0
- package/dist/cloud/webhooks/types.js +8 -0
- package/dist/cloud/webhooks/types.js.map +1 -0
- package/dist/continuity/formatter.d.ts +51 -0
- package/dist/continuity/formatter.d.ts.map +1 -0
- package/dist/continuity/formatter.js +313 -0
- package/dist/continuity/formatter.js.map +1 -0
- package/dist/continuity/handoff-store.d.ts +67 -0
- package/dist/continuity/handoff-store.d.ts.map +1 -0
- package/dist/continuity/handoff-store.js +472 -0
- package/dist/continuity/handoff-store.js.map +1 -0
- package/dist/continuity/index.d.ts +45 -0
- package/dist/continuity/index.d.ts.map +1 -0
- package/dist/continuity/index.js +48 -0
- package/dist/continuity/index.js.map +1 -0
- package/dist/continuity/ledger-store.d.ts +110 -0
- package/dist/continuity/ledger-store.d.ts.map +1 -0
- package/dist/continuity/ledger-store.js +500 -0
- package/dist/continuity/ledger-store.js.map +1 -0
- package/dist/continuity/manager.d.ts +178 -0
- package/dist/continuity/manager.d.ts.map +1 -0
- package/dist/continuity/manager.js +562 -0
- package/dist/continuity/manager.js.map +1 -0
- package/dist/continuity/parser.d.ts +76 -0
- package/dist/continuity/parser.d.ts.map +1 -0
- package/dist/continuity/parser.js +579 -0
- package/dist/continuity/parser.js.map +1 -0
- package/dist/continuity/types.d.ts +180 -0
- package/dist/continuity/types.d.ts.map +1 -0
- package/dist/continuity/types.js +9 -0
- package/dist/continuity/types.js.map +1 -0
- package/dist/daemon/agent-manager.d.ts +27 -0
- package/dist/daemon/agent-manager.d.ts.map +1 -1
- package/dist/daemon/agent-manager.js +107 -6
- package/dist/daemon/agent-manager.js.map +1 -1
- package/dist/daemon/agent-registry.d.ts +32 -0
- package/dist/daemon/agent-registry.d.ts.map +1 -1
- package/dist/daemon/agent-registry.js +42 -2
- package/dist/daemon/agent-registry.js.map +1 -1
- package/dist/daemon/api.d.ts +12 -0
- package/dist/daemon/api.d.ts.map +1 -1
- package/dist/daemon/api.js +131 -2
- package/dist/daemon/api.js.map +1 -1
- package/dist/daemon/cli-auth.d.ts +67 -0
- package/dist/daemon/cli-auth.d.ts.map +1 -0
- package/dist/daemon/cli-auth.js +537 -0
- package/dist/daemon/cli-auth.js.map +1 -0
- package/dist/daemon/cloud-sync.d.ts.map +1 -1
- package/dist/daemon/cloud-sync.js +9 -7
- package/dist/daemon/cloud-sync.js.map +1 -1
- package/dist/daemon/orchestrator.d.ts.map +1 -1
- package/dist/daemon/orchestrator.js +30 -0
- package/dist/daemon/orchestrator.js.map +1 -1
- package/dist/daemon/router.d.ts +5 -0
- package/dist/daemon/router.d.ts.map +1 -1
- package/dist/daemon/router.js +78 -26
- package/dist/daemon/router.js.map +1 -1
- package/dist/daemon/server.d.ts +5 -0
- package/dist/daemon/server.d.ts.map +1 -1
- package/dist/daemon/server.js +9 -1
- package/dist/daemon/server.js.map +1 -1
- package/dist/daemon/services/browser-testing.d.ts +88 -0
- package/dist/daemon/services/browser-testing.d.ts.map +1 -0
- package/dist/daemon/services/browser-testing.js +244 -0
- package/dist/daemon/services/browser-testing.js.map +1 -0
- package/dist/daemon/services/container-spawner.d.ts +135 -0
- package/dist/daemon/services/container-spawner.d.ts.map +1 -0
- package/dist/daemon/services/container-spawner.js +313 -0
- package/dist/daemon/services/container-spawner.js.map +1 -0
- package/dist/daemon/types.d.ts +5 -1
- package/dist/daemon/types.d.ts.map +1 -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/480-2d4111711d4e473c.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/724-73c1ee5f60abe860.js +9 -0
- package/dist/dashboard/out/_next/static/chunks/766-c3a14283c88d815b.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/page-7120be68bea622f3.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/connect-repos/page-dc2e3a1a22478efc.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/history/{page-b6edd4dde8d08194.js → page-56a8b4616a90dc43.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/app/login/page-3eac37ea6f5dd153.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-1081dd190a331a91.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/page-daf87e86f783f980.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/providers/page-b68a681526eb145e.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/signup/page-fee4ed1709070bcd.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/e868780c-48e5f147c90a3a41.js +18 -0
- package/dist/dashboard/out/_next/static/chunks/{main-c2f423b9c9f4591b.js → main-97850e03d723ea8c.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/411ce23ffeae9f76.css +1 -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 +2 -2
- 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.d.ts.map +1 -1
- package/dist/dashboard-server/server.js +1308 -8
- package/dist/dashboard-server/server.js.map +1 -1
- package/dist/hooks/emitter.d.ts +40 -0
- package/dist/hooks/emitter.d.ts.map +1 -0
- package/dist/hooks/emitter.js +63 -0
- package/dist/hooks/emitter.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/registry.d.ts +173 -0
- package/dist/hooks/registry.d.ts.map +1 -0
- package/dist/hooks/registry.js +476 -0
- package/dist/hooks/registry.js.map +1 -0
- package/dist/hooks/trajectory-hooks.d.ts +52 -0
- package/dist/hooks/trajectory-hooks.d.ts.map +1 -0
- package/dist/hooks/trajectory-hooks.js +183 -0
- package/dist/hooks/trajectory-hooks.js.map +1 -0
- package/dist/hooks/types.d.ts +141 -0
- package/dist/hooks/types.d.ts.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/memory/adapters/index.d.ts +8 -0
- package/dist/memory/adapters/index.d.ts.map +1 -0
- package/dist/memory/adapters/index.js +8 -0
- package/dist/memory/adapters/index.js.map +1 -0
- package/dist/memory/adapters/inmemory.d.ts +59 -0
- package/dist/memory/adapters/inmemory.d.ts.map +1 -0
- package/dist/memory/adapters/inmemory.js +195 -0
- package/dist/memory/adapters/inmemory.js.map +1 -0
- package/dist/memory/adapters/supermemory.d.ts +71 -0
- package/dist/memory/adapters/supermemory.d.ts.map +1 -0
- package/dist/memory/adapters/supermemory.js +338 -0
- package/dist/memory/adapters/supermemory.js.map +1 -0
- package/dist/memory/factory.d.ts +48 -0
- package/dist/memory/factory.d.ts.map +1 -0
- package/dist/memory/factory.js +143 -0
- package/dist/memory/factory.js.map +1 -0
- package/dist/memory/index.d.ts +32 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +32 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/memory-hooks.d.ts +60 -0
- package/dist/memory/memory-hooks.d.ts.map +1 -0
- package/dist/memory/memory-hooks.js +313 -0
- package/dist/memory/memory-hooks.js.map +1 -0
- package/dist/memory/service.d.ts +49 -0
- package/dist/memory/service.d.ts.map +1 -0
- package/dist/memory/service.js +146 -0
- package/dist/memory/service.js.map +1 -0
- package/dist/memory/types.d.ts +195 -0
- package/dist/memory/types.d.ts.map +1 -0
- package/dist/memory/types.js +8 -0
- package/dist/memory/types.js.map +1 -0
- package/dist/policy/agent-policy.d.ts +225 -0
- package/dist/policy/agent-policy.d.ts.map +1 -0
- package/dist/policy/agent-policy.js +665 -0
- package/dist/policy/agent-policy.js.map +1 -0
- package/dist/policy/cloud-policy-fetcher.d.ts +12 -0
- package/dist/policy/cloud-policy-fetcher.d.ts.map +1 -0
- package/dist/policy/cloud-policy-fetcher.js +64 -0
- package/dist/policy/cloud-policy-fetcher.js.map +1 -0
- package/dist/resiliency/crash-insights.d.ts +156 -0
- package/dist/resiliency/crash-insights.d.ts.map +1 -0
- package/dist/resiliency/crash-insights.js +492 -0
- package/dist/resiliency/crash-insights.js.map +1 -0
- package/dist/resiliency/gossip-health.d.ts +137 -0
- package/dist/resiliency/gossip-health.d.ts.map +1 -0
- package/dist/resiliency/gossip-health.js +241 -0
- package/dist/resiliency/gossip-health.js.map +1 -0
- package/dist/resiliency/index.d.ts +5 -0
- package/dist/resiliency/index.d.ts.map +1 -1
- package/dist/resiliency/index.js +5 -0
- package/dist/resiliency/index.js.map +1 -1
- package/dist/resiliency/leader-watchdog.d.ts +109 -0
- package/dist/resiliency/leader-watchdog.d.ts.map +1 -0
- package/dist/resiliency/leader-watchdog.js +189 -0
- package/dist/resiliency/leader-watchdog.js.map +1 -0
- package/dist/resiliency/memory-monitor.d.ts +172 -0
- package/dist/resiliency/memory-monitor.d.ts.map +1 -0
- package/dist/resiliency/memory-monitor.js +593 -0
- package/dist/resiliency/memory-monitor.js.map +1 -0
- package/dist/resiliency/stateless-lead.d.ts +149 -0
- package/dist/resiliency/stateless-lead.d.ts.map +1 -0
- package/dist/resiliency/stateless-lead.js +308 -0
- package/dist/resiliency/stateless-lead.js.map +1 -0
- package/dist/resiliency/supervisor.d.ts +38 -0
- package/dist/resiliency/supervisor.d.ts.map +1 -1
- package/dist/resiliency/supervisor.js +122 -0
- package/dist/resiliency/supervisor.js.map +1 -1
- package/dist/shared/cli-auth-config.d.ts +91 -0
- package/dist/shared/cli-auth-config.d.ts.map +1 -0
- package/dist/shared/cli-auth-config.js +264 -0
- package/dist/shared/cli-auth-config.js.map +1 -0
- package/dist/storage/adapter.d.ts +1 -1
- package/dist/storage/adapter.d.ts.map +1 -1
- package/dist/trajectory/config.d.ts +84 -0
- package/dist/trajectory/config.d.ts.map +1 -0
- package/dist/trajectory/config.js +163 -0
- package/dist/trajectory/config.js.map +1 -0
- package/dist/trajectory/index.d.ts +8 -0
- package/dist/trajectory/index.d.ts.map +1 -0
- package/dist/trajectory/index.js +8 -0
- package/dist/trajectory/index.js.map +1 -0
- package/dist/trajectory/integration.d.ts +292 -0
- package/dist/trajectory/integration.d.ts.map +1 -0
- package/dist/trajectory/integration.js +834 -0
- package/dist/trajectory/integration.js.map +1 -0
- package/dist/utils/logger.js +1 -1
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/project-namespace.d.ts +24 -0
- package/dist/utils/project-namespace.d.ts.map +1 -1
- package/dist/utils/project-namespace.js +84 -0
- package/dist/utils/project-namespace.js.map +1 -1
- package/dist/wrapper/parser.d.ts +10 -0
- package/dist/wrapper/parser.d.ts.map +1 -1
- package/dist/wrapper/parser.js +100 -33
- package/dist/wrapper/parser.js.map +1 -1
- package/dist/wrapper/pty-wrapper.d.ts +197 -16
- package/dist/wrapper/pty-wrapper.d.ts.map +1 -1
- package/dist/wrapper/pty-wrapper.js +943 -106
- package/dist/wrapper/pty-wrapper.js.map +1 -1
- package/dist/wrapper/shared.d.ts +165 -0
- package/dist/wrapper/shared.d.ts.map +1 -0
- package/dist/wrapper/shared.js +270 -0
- package/dist/wrapper/shared.js.map +1 -0
- package/dist/wrapper/tmux-wrapper.d.ts +73 -11
- package/dist/wrapper/tmux-wrapper.d.ts.map +1 -1
- package/dist/wrapper/tmux-wrapper.js +541 -120
- package/dist/wrapper/tmux-wrapper.js.map +1 -1
- package/docs/CLOUD-ARCHITECTURE.md +152 -0
- package/docs/HOOKS_API.md +394 -0
- package/docs/WRAPPER_EVENTS.md +358 -0
- package/docs/agent-policy-snippet.md +40 -0
- package/docs/agent-relay-protocol.md +238 -0
- package/docs/agent-relay-snippet.md +53 -47
- package/docs/archive/EXECUTIVE_SUMMARY.md +358 -0
- package/docs/archive/ROADMAP.md +329 -0
- package/docs/competitive/GASTOWN.md +451 -0
- package/docs/{COMPETITIVE_ANALYSIS.md → competitive/OVERVIEW.md} +1 -0
- package/docs/competitive/README.md +34 -0
- package/docs/competitive/TMUX_ORCHESTRATOR.md +605 -0
- package/docs/dashboard.png +0 -0
- package/docs/design/ci-failure-webhooks.md +812 -0
- package/docs/design/comprehensive-integrations.md +238 -0
- package/docs/design/e2b-sandbox-integration.md +504 -0
- package/docs/design/github-app-permissions.md +264 -0
- package/docs/local-testing.md +428 -0
- package/docs/proposals/continuous-claude-integration.md +622 -0
- package/docs/proposals/custom-commands.md +368 -0
- package/docs/tasks/global-skills-system.tasks.md +230 -0
- package/docs/tasks/webhook-integrations.tasks.md +184 -0
- package/docs/tasks/workspace-capabilities.tasks.md +121 -0
- package/docs/testing/RESILIENCY-TEST-PLAN-2026-01-01.md +366 -0
- package/package.json +16 -7
- package/scripts/cloud-setup.sh +96 -0
- package/scripts/manual-qa.sh +293 -0
- package/scripts/postinstall.js +60 -0
- package/scripts/run-cloud-qa.sh +220 -0
- package/scripts/test-cli-auth/Dockerfile +44 -0
- package/scripts/test-cli-auth/Dockerfile.real +79 -0
- package/scripts/test-cli-auth/README.md +286 -0
- package/scripts/test-cli-auth/ci-test-real-clis.ts +251 -0
- package/scripts/test-cli-auth/ci-test-runner.ts +263 -0
- package/scripts/test-cli-auth/mock-cli.sh +147 -0
- package/scripts/test-cli-auth/package.json +14 -0
- package/scripts/test-cli-auth/test-oauth-flow.ts +220 -0
- package/scripts/test-pty-input-auto.js +222 -0
- package/scripts/test-pty-input.js +150 -0
- 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/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/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/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → H5aWG0udPB4iOUIl_gytz}/_buildManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/{6HHWb2ZmnJ4OSm0zUP7h4 → H5aWG0udPB4iOUIl_gytz}/_ssgManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{117-b2cd8d6485aacf2b.js → 117-b100311aff8d5c61.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{648-8f3f26864ce515e5.js → 648-a13d3c2b1be45466.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-0b990dbb71d72a98.js → page-a4973f3e3c82fb67.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/pricing/{page-d80e03a5297f95b6.js → page-4d72d5a5d8a9b618.js} +0 -0
- /package/docs/{CHANGELOG.md → archive/CHANGELOG.md} +0 -0
- /package/docs/{CLI-SIMPLIFICATION-COMPLETE.md → archive/CLI-SIMPLIFICATION-COMPLETE.md} +0 -0
- /package/docs/{DESIGN_BRIDGE_STAFFING.md → archive/DESIGN_BRIDGE_STAFFING.md} +0 -0
- /package/docs/{DESIGN_V2.md → archive/DESIGN_V2.md} +0 -0
- /package/docs/{MONETIZATION.md → archive/MONETIZATION.md} +0 -0
- /package/docs/{PROPOSAL-trajectories.md → archive/PROPOSAL-trajectories.md} +0 -0
- /package/docs/{SCALING_ANALYSIS.md → archive/SCALING_ANALYSIS.md} +0 -0
- /package/docs/{TESTING_PRESENCE_FEATURES.md → archive/TESTING_PRESENCE_FEATURES.md} +0 -0
- /package/docs/{TMUX_IMPLEMENTATION_NOTES.md → archive/TMUX_IMPLEMENTATION_NOTES.md} +0 -0
- /package/docs/{TMUX_IMPROVEMENTS.md → archive/TMUX_IMPROVEMENTS.md} +0 -0
- /package/docs/{dashboard-v2-plan.md → archive/dashboard-v2-plan.md} +0 -0
- /package/docs/{removable-code-analysis.md → archive/removable-code-analysis.md} +0 -0
- /package/docs/{competitive-analysis-mcp-agent-mail.md → competitive/MCP_AGENT_MAIL.md} +0 -0
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Slack Webhook Parser
|
|
3
|
+
*
|
|
4
|
+
* Transforms Slack Events API payloads into normalized events.
|
|
5
|
+
* https://api.slack.com/apis/connections/events-api
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Extract user mentions from Slack message text
|
|
9
|
+
* Slack format: <@U12345678> or <@U12345678|username>
|
|
10
|
+
*/
|
|
11
|
+
function extractSlackMentions(text) {
|
|
12
|
+
if (!text)
|
|
13
|
+
return [];
|
|
14
|
+
const mentionPattern = /<@([A-Z0-9]+)(?:\|([^>]+))?>/g;
|
|
15
|
+
const mentions = [];
|
|
16
|
+
let match;
|
|
17
|
+
while ((match = mentionPattern.exec(text)) !== null) {
|
|
18
|
+
// Prefer display name if available, otherwise use ID
|
|
19
|
+
mentions.push(match[2] || match[1]);
|
|
20
|
+
}
|
|
21
|
+
return [...new Set(mentions)];
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Extract agent mentions from text (our custom @agent-name format)
|
|
25
|
+
*/
|
|
26
|
+
function extractAgentMentions(text) {
|
|
27
|
+
if (!text)
|
|
28
|
+
return [];
|
|
29
|
+
// Match @agent-name patterns that aren't Slack user mentions
|
|
30
|
+
const mentionPattern = /(?<![<])@([a-zA-Z][a-zA-Z0-9_-]*)(?![>])/g;
|
|
31
|
+
const mentions = [];
|
|
32
|
+
let match;
|
|
33
|
+
while ((match = mentionPattern.exec(text)) !== null) {
|
|
34
|
+
mentions.push(match[1].toLowerCase());
|
|
35
|
+
}
|
|
36
|
+
return [...new Set(mentions)];
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Clean Slack message text (remove user mention formatting)
|
|
40
|
+
*/
|
|
41
|
+
function cleanSlackText(text) {
|
|
42
|
+
if (!text)
|
|
43
|
+
return '';
|
|
44
|
+
// Replace <@U12345678|username> with @username
|
|
45
|
+
return text.replace(/<@[A-Z0-9]+\|([^>]+)>/g, '@$1')
|
|
46
|
+
.replace(/<@[A-Z0-9]+>/g, '@user')
|
|
47
|
+
// Replace <URL|text> with text
|
|
48
|
+
.replace(/<([^|>]+)\|([^>]+)>/g, '$2')
|
|
49
|
+
// Replace <URL> with URL
|
|
50
|
+
.replace(/<([^>]+)>/g, '$1');
|
|
51
|
+
}
|
|
52
|
+
export const slackParser = {
|
|
53
|
+
id: 'slack',
|
|
54
|
+
parse(payload) {
|
|
55
|
+
const data = payload;
|
|
56
|
+
const events = [];
|
|
57
|
+
// Handle URL verification challenge
|
|
58
|
+
if (data.type === 'url_verification') {
|
|
59
|
+
// This is handled separately in the router
|
|
60
|
+
return [];
|
|
61
|
+
}
|
|
62
|
+
// Events API wrapper
|
|
63
|
+
if (data.type !== 'event_callback') {
|
|
64
|
+
return [];
|
|
65
|
+
}
|
|
66
|
+
const event = data.event;
|
|
67
|
+
if (!event)
|
|
68
|
+
return [];
|
|
69
|
+
const eventType = event.type;
|
|
70
|
+
const teamId = data.team_id || 'unknown';
|
|
71
|
+
const eventId = data.event_id || `slack-${Date.now()}`;
|
|
72
|
+
const eventTime = data.event_time;
|
|
73
|
+
const baseEvent = {
|
|
74
|
+
id: eventId,
|
|
75
|
+
source: 'slack',
|
|
76
|
+
timestamp: eventTime ? new Date(eventTime * 1000) : new Date(),
|
|
77
|
+
actor: {
|
|
78
|
+
id: String(event.user || 'unknown'),
|
|
79
|
+
name: String(event.user || 'unknown'),
|
|
80
|
+
},
|
|
81
|
+
context: {
|
|
82
|
+
name: teamId,
|
|
83
|
+
},
|
|
84
|
+
labels: [],
|
|
85
|
+
mentions: [],
|
|
86
|
+
metadata: {
|
|
87
|
+
teamId,
|
|
88
|
+
channelId: event.channel,
|
|
89
|
+
channelType: event.channel_type,
|
|
90
|
+
},
|
|
91
|
+
rawPayload: payload,
|
|
92
|
+
};
|
|
93
|
+
switch (eventType) {
|
|
94
|
+
case 'app_mention': {
|
|
95
|
+
// Bot was mentioned in a channel
|
|
96
|
+
const text = event.text;
|
|
97
|
+
const agentMentions = extractAgentMentions(text);
|
|
98
|
+
events.push({
|
|
99
|
+
...baseEvent,
|
|
100
|
+
type: 'mention',
|
|
101
|
+
item: {
|
|
102
|
+
type: 'message',
|
|
103
|
+
id: String(event.ts),
|
|
104
|
+
body: cleanSlackText(text),
|
|
105
|
+
},
|
|
106
|
+
mentions: agentMentions.length > 0 ? agentMentions : ['lead'], // Default to lead if no specific agent
|
|
107
|
+
metadata: {
|
|
108
|
+
...baseEvent.metadata,
|
|
109
|
+
ts: event.ts,
|
|
110
|
+
threadTs: event.thread_ts,
|
|
111
|
+
userMentions: extractSlackMentions(text),
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
break;
|
|
115
|
+
}
|
|
116
|
+
case 'message': {
|
|
117
|
+
// Regular message in channel
|
|
118
|
+
const text = event.text;
|
|
119
|
+
const subtype = event.subtype;
|
|
120
|
+
// Ignore bot messages, message changes, etc.
|
|
121
|
+
if (subtype && subtype !== 'thread_broadcast') {
|
|
122
|
+
break;
|
|
123
|
+
}
|
|
124
|
+
const agentMentions = extractAgentMentions(text);
|
|
125
|
+
// Only create event if there are agent mentions
|
|
126
|
+
if (agentMentions.length > 0) {
|
|
127
|
+
events.push({
|
|
128
|
+
...baseEvent,
|
|
129
|
+
type: 'mention',
|
|
130
|
+
item: {
|
|
131
|
+
type: 'message',
|
|
132
|
+
id: String(event.ts),
|
|
133
|
+
body: cleanSlackText(text),
|
|
134
|
+
},
|
|
135
|
+
mentions: agentMentions,
|
|
136
|
+
metadata: {
|
|
137
|
+
...baseEvent.metadata,
|
|
138
|
+
ts: event.ts,
|
|
139
|
+
threadTs: event.thread_ts,
|
|
140
|
+
userMentions: extractSlackMentions(text),
|
|
141
|
+
},
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
break;
|
|
145
|
+
}
|
|
146
|
+
case 'reaction_added': {
|
|
147
|
+
// Reaction added to a message
|
|
148
|
+
const reaction = event.reaction;
|
|
149
|
+
const item = event.item;
|
|
150
|
+
events.push({
|
|
151
|
+
...baseEvent,
|
|
152
|
+
type: 'reaction_added',
|
|
153
|
+
item: {
|
|
154
|
+
type: 'message',
|
|
155
|
+
id: String(item?.ts || 'unknown'),
|
|
156
|
+
},
|
|
157
|
+
labels: [reaction],
|
|
158
|
+
metadata: {
|
|
159
|
+
...baseEvent.metadata,
|
|
160
|
+
reaction,
|
|
161
|
+
itemType: item?.type,
|
|
162
|
+
itemChannel: item?.channel,
|
|
163
|
+
itemTs: item?.ts,
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
break;
|
|
167
|
+
}
|
|
168
|
+
case 'channel_created': {
|
|
169
|
+
const channel = event.channel;
|
|
170
|
+
events.push({
|
|
171
|
+
...baseEvent,
|
|
172
|
+
type: 'channel_created',
|
|
173
|
+
context: {
|
|
174
|
+
name: String(channel?.name || 'unknown'),
|
|
175
|
+
},
|
|
176
|
+
metadata: {
|
|
177
|
+
...baseEvent.metadata,
|
|
178
|
+
channelId: channel?.id,
|
|
179
|
+
channelName: channel?.name,
|
|
180
|
+
creator: channel?.creator,
|
|
181
|
+
},
|
|
182
|
+
});
|
|
183
|
+
break;
|
|
184
|
+
}
|
|
185
|
+
case 'member_joined_channel': {
|
|
186
|
+
events.push({
|
|
187
|
+
...baseEvent,
|
|
188
|
+
type: 'member_joined',
|
|
189
|
+
actor: {
|
|
190
|
+
id: String(event.user),
|
|
191
|
+
name: String(event.user),
|
|
192
|
+
},
|
|
193
|
+
metadata: {
|
|
194
|
+
...baseEvent.metadata,
|
|
195
|
+
inviter: event.inviter,
|
|
196
|
+
},
|
|
197
|
+
});
|
|
198
|
+
break;
|
|
199
|
+
}
|
|
200
|
+
default:
|
|
201
|
+
// Unknown event type
|
|
202
|
+
events.push({
|
|
203
|
+
...baseEvent,
|
|
204
|
+
type: `slack.${eventType}`,
|
|
205
|
+
metadata: {
|
|
206
|
+
...baseEvent.metadata,
|
|
207
|
+
subtype: event.subtype,
|
|
208
|
+
},
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
return events;
|
|
212
|
+
},
|
|
213
|
+
};
|
|
214
|
+
//# sourceMappingURL=slack.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slack.js","sourceRoot":"","sources":["../../../../src/cloud/webhooks/parsers/slack.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH;;;GAGG;AACH,SAAS,oBAAoB,CAAC,IAA+B;IAC3D,IAAI,CAAC,IAAI;QAAE,OAAO,EAAE,CAAC;IACrB,MAAM,cAAc,GAAG,+BAA+B,CAAC;IACvD,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC;IACV,OAAO,CAAC,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;QACpD,qDAAqD;QACrD,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC;IACD,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;AAChC,CAAC;AAED;;GAEG;AACH,SAAS,oBAAoB,CAAC,IAA+B;IAC3D,IAAI,CAAC,IAAI;QAAE,OAAO,EAAE,CAAC;IACrB,6DAA6D;IAC7D,MAAM,cAAc,GAAG,2CAA2C,CAAC;IACnE,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC;IACV,OAAO,CAAC,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;QACpD,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACxC,CAAC;IACD,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;AAChC,CAAC;AAED;;GAEG;AACH,SAAS,cAAc,CAAC,IAA+B;IACrD,IAAI,CAAC,IAAI;QAAE,OAAO,EAAE,CAAC;IACrB,+CAA+C;IAC/C,OAAO,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,KAAK,CAAC;SACjD,OAAO,CAAC,eAAe,EAAE,OAAO,CAAC;QAClC,+BAA+B;SAC9B,OAAO,CAAC,sBAAsB,EAAE,IAAI,CAAC;QACtC,yBAAyB;SACxB,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;AACjC,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GAAkB;IACxC,EAAE,EAAE,OAAO;IAEX,KAAK,CAAC,OAAgB;QACpB,MAAM,IAAI,GAAG,OAAkC,CAAC;QAChD,MAAM,MAAM,GAAsB,EAAE,CAAC;QAErC,oCAAoC;QACpC,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YACrC,2CAA2C;YAC3C,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,qBAAqB;QACrB,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;YACnC,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAA4C,CAAC;QAChE,IAAI,CAAC,KAAK;YAAE,OAAO,EAAE,CAAC;QAEtB,MAAM,SAAS,GAAG,KAAK,CAAC,IAAc,CAAC;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAiB,IAAI,SAAS,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAkB,IAAI,SAAS,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QACjE,MAAM,SAAS,GAAG,IAAI,CAAC,UAAgC,CAAC;QAExD,MAAM,SAAS,GAA6B;YAC1C,EAAE,EAAE,OAAO;YACX,MAAM,EAAE,OAAO;YACf,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;YAC9D,KAAK,EAAE;gBACL,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,SAAS,CAAC;gBACnC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,SAAS,CAAC;aACtC;YACD,OAAO,EAAE;gBACP,IAAI,EAAE,MAAM;aACb;YACD,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,EAAE;YACZ,QAAQ,EAAE;gBACR,MAAM;gBACN,SAAS,EAAE,KAAK,CAAC,OAAO;gBACxB,WAAW,EAAE,KAAK,CAAC,YAAY;aAChC;YACD,UAAU,EAAE,OAAO;SACpB,CAAC;QAEF,QAAQ,SAAS,EAAE,CAAC;YAClB,KAAK,aAAa,CAAC,CAAC,CAAC;gBACnB,iCAAiC;gBACjC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAc,CAAC;gBAClC,MAAM,aAAa,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;gBAEjD,MAAM,CAAC,IAAI,CAAC;oBACV,GAAG,SAAS;oBACZ,IAAI,EAAE,SAAS;oBACf,IAAI,EAAE;wBACJ,IAAI,EAAE,SAAS;wBACf,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;wBACpB,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC;qBAC3B;oBACD,QAAQ,EAAE,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,uCAAuC;oBACtG,QAAQ,EAAE;wBACR,GAAG,SAAS,CAAC,QAAQ;wBACrB,EAAE,EAAE,KAAK,CAAC,EAAE;wBACZ,QAAQ,EAAE,KAAK,CAAC,SAAS;wBACzB,YAAY,EAAE,oBAAoB,CAAC,IAAI,CAAC;qBACzC;iBACiB,CAAC,CAAC;gBACtB,MAAM;YACR,CAAC;YAED,KAAK,SAAS,CAAC,CAAC,CAAC;gBACf,6BAA6B;gBAC7B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAc,CAAC;gBAClC,MAAM,OAAO,GAAG,KAAK,CAAC,OAA6B,CAAC;gBAEpD,6CAA6C;gBAC7C,IAAI,OAAO,IAAI,OAAO,KAAK,kBAAkB,EAAE,CAAC;oBAC9C,MAAM;gBACR,CAAC;gBAED,MAAM,aAAa,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;gBAEjD,gDAAgD;gBAChD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC7B,MAAM,CAAC,IAAI,CAAC;wBACV,GAAG,SAAS;wBACZ,IAAI,EAAE,SAAS;wBACf,IAAI,EAAE;4BACJ,IAAI,EAAE,SAAS;4BACf,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;4BACpB,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC;yBAC3B;wBACD,QAAQ,EAAE,aAAa;wBACvB,QAAQ,EAAE;4BACR,GAAG,SAAS,CAAC,QAAQ;4BACrB,EAAE,EAAE,KAAK,CAAC,EAAE;4BACZ,QAAQ,EAAE,KAAK,CAAC,SAAS;4BACzB,YAAY,EAAE,oBAAoB,CAAC,IAAI,CAAC;yBACzC;qBACiB,CAAC,CAAC;gBACxB,CAAC;gBACD,MAAM;YACR,CAAC;YAED,KAAK,gBAAgB,CAAC,CAAC,CAAC;gBACtB,8BAA8B;gBAC9B,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAkB,CAAC;gBAC1C,MAAM,IAAI,GAAG,KAAK,CAAC,IAA+B,CAAC;gBAEnD,MAAM,CAAC,IAAI,CAAC;oBACV,GAAG,SAAS;oBACZ,IAAI,EAAE,gBAAgB;oBACtB,IAAI,EAAE;wBACJ,IAAI,EAAE,SAAS;wBACf,EAAE,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,IAAI,SAAS,CAAC;qBAClC;oBACD,MAAM,EAAE,CAAC,QAAQ,CAAC;oBAClB,QAAQ,EAAE;wBACR,GAAG,SAAS,CAAC,QAAQ;wBACrB,QAAQ;wBACR,QAAQ,EAAE,IAAI,EAAE,IAAI;wBACpB,WAAW,EAAE,IAAI,EAAE,OAAO;wBAC1B,MAAM,EAAE,IAAI,EAAE,EAAE;qBACjB;iBACiB,CAAC,CAAC;gBACtB,MAAM;YACR,CAAC;YAED,KAAK,iBAAiB,CAAC,CAAC,CAAC;gBACvB,MAAM,OAAO,GAAG,KAAK,CAAC,OAAkC,CAAC;gBAEzD,MAAM,CAAC,IAAI,CAAC;oBACV,GAAG,SAAS;oBACZ,IAAI,EAAE,iBAAiB;oBACvB,OAAO,EAAE;wBACP,IAAI,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,IAAI,SAAS,CAAC;qBACzC;oBACD,QAAQ,EAAE;wBACR,GAAG,SAAS,CAAC,QAAQ;wBACrB,SAAS,EAAE,OAAO,EAAE,EAAE;wBACtB,WAAW,EAAE,OAAO,EAAE,IAAI;wBAC1B,OAAO,EAAE,OAAO,EAAE,OAAO;qBAC1B;iBACiB,CAAC,CAAC;gBACtB,MAAM;YACR,CAAC;YAED,KAAK,uBAAuB,CAAC,CAAC,CAAC;gBAC7B,MAAM,CAAC,IAAI,CAAC;oBACV,GAAG,SAAS;oBACZ,IAAI,EAAE,eAAe;oBACrB,KAAK,EAAE;wBACL,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;wBACtB,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;qBACzB;oBACD,QAAQ,EAAE;wBACR,GAAG,SAAS,CAAC,QAAQ;wBACrB,OAAO,EAAE,KAAK,CAAC,OAAO;qBACvB;iBACiB,CAAC,CAAC;gBACtB,MAAM;YACR,CAAC;YAED;gBACE,qBAAqB;gBACrB,MAAM,CAAC,IAAI,CAAC;oBACV,GAAG,SAAS;oBACZ,IAAI,EAAE,SAAS,SAAS,EAAE;oBAC1B,QAAQ,EAAE;wBACR,GAAG,SAAS,CAAC,QAAQ;wBACrB,OAAO,EAAE,KAAK,CAAC,OAAO;qBACvB;iBACiB,CAAC,CAAC;QAC1B,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/github.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAmB,gBAAgB,EAAmB,MAAM,aAAa,CAAC;AAItF,eAAO,MAAM,eAAe,EAAE,gBAmF7B,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitHub Responder
|
|
3
|
+
*
|
|
4
|
+
* Sends responses back to GitHub via the GitHub App API.
|
|
5
|
+
*/
|
|
6
|
+
import { nangoService } from '../../services/nango.js';
|
|
7
|
+
import { db } from '../../db/index.js';
|
|
8
|
+
export const githubResponder = {
|
|
9
|
+
id: 'github',
|
|
10
|
+
async respond(event, response, _config) {
|
|
11
|
+
try {
|
|
12
|
+
// Get repository info from event context
|
|
13
|
+
const repoFullName = event.context.name;
|
|
14
|
+
const [owner, repo] = repoFullName.split('/');
|
|
15
|
+
if (!owner || !repo) {
|
|
16
|
+
return { success: false, error: `Invalid repository name: ${repoFullName}` };
|
|
17
|
+
}
|
|
18
|
+
// Find the repository in our database to get the Nango connection
|
|
19
|
+
const repository = await db.repositories.findByFullName(repoFullName);
|
|
20
|
+
if (!repository?.nangoConnectionId) {
|
|
21
|
+
return {
|
|
22
|
+
success: false,
|
|
23
|
+
error: `Repository ${repoFullName} not found or has no Nango connection`,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
switch (response.type) {
|
|
27
|
+
case 'comment': {
|
|
28
|
+
// Post a comment on an issue or PR
|
|
29
|
+
const issueNumber = typeof response.target === 'number'
|
|
30
|
+
? response.target
|
|
31
|
+
: parseInt(String(response.target), 10);
|
|
32
|
+
if (isNaN(issueNumber)) {
|
|
33
|
+
return { success: false, error: `Invalid issue number: ${response.target}` };
|
|
34
|
+
}
|
|
35
|
+
const result = await nangoService.addGithubIssueComment(repository.nangoConnectionId, owner, repo, issueNumber, response.body);
|
|
36
|
+
return {
|
|
37
|
+
success: true,
|
|
38
|
+
id: String(result.id),
|
|
39
|
+
url: result.html_url,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
case 'reaction': {
|
|
43
|
+
// Add a reaction to a comment or issue
|
|
44
|
+
// Note: This would need to be added to NangoService
|
|
45
|
+
return {
|
|
46
|
+
success: false,
|
|
47
|
+
error: 'Reactions not yet implemented for GitHub',
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
case 'status': {
|
|
51
|
+
// Update a check run status
|
|
52
|
+
// Note: This would need to be added to NangoService
|
|
53
|
+
return {
|
|
54
|
+
success: false,
|
|
55
|
+
error: 'Status updates not yet implemented for GitHub',
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
default:
|
|
59
|
+
return {
|
|
60
|
+
success: false,
|
|
61
|
+
error: `Unknown response type: ${response.type}`,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
return {
|
|
67
|
+
success: false,
|
|
68
|
+
error: error instanceof Error ? error.message : 'Unknown error',
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
//# sourceMappingURL=github.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github.js","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/github.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,EAAE,EAAE,MAAM,mBAAmB,CAAC;AAEvC,MAAM,CAAC,MAAM,eAAe,GAAqB;IAC/C,EAAE,EAAE,QAAQ;IAEZ,KAAK,CAAC,OAAO,CACX,KAAsB,EACtB,QAAyB,EACzB,OAAiC;QAEjC,IAAI,CAAC;YACH,yCAAyC;YACzC,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;YACxC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAE9C,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC;gBACpB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,4BAA4B,YAAY,EAAE,EAAE,CAAC;YAC/E,CAAC;YAED,kEAAkE;YAClE,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,YAAY,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;YACtE,IAAI,CAAC,UAAU,EAAE,iBAAiB,EAAE,CAAC;gBACnC,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,cAAc,YAAY,uCAAuC;iBACzE,CAAC;YACJ,CAAC;YAED,QAAQ,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtB,KAAK,SAAS,CAAC,CAAC,CAAC;oBACf,mCAAmC;oBACnC,MAAM,WAAW,GAAG,OAAO,QAAQ,CAAC,MAAM,KAAK,QAAQ;wBACrD,CAAC,CAAC,QAAQ,CAAC,MAAM;wBACjB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;oBAE1C,IAAI,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC;wBACvB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,yBAAyB,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;oBAC/E,CAAC;oBAED,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,qBAAqB,CACrD,UAAU,CAAC,iBAAiB,EAC5B,KAAK,EACL,IAAI,EACJ,WAAW,EACX,QAAQ,CAAC,IAAI,CACd,CAAC;oBAEF,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;wBACrB,GAAG,EAAE,MAAM,CAAC,QAAQ;qBACrB,CAAC;gBACJ,CAAC;gBAED,KAAK,UAAU,CAAC,CAAC,CAAC;oBAChB,uCAAuC;oBACvC,oDAAoD;oBACpD,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,0CAA0C;qBAClD,CAAC;gBACJ,CAAC;gBAED,KAAK,QAAQ,CAAC,CAAC,CAAC;oBACd,4BAA4B;oBAC5B,oDAAoD;oBACpD,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,+CAA+C;qBACvD,CAAC;gBACJ,CAAC;gBAED;oBACE,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,KAAK,EAAE,0BAA0B,QAAQ,CAAC,IAAI,EAAE;qBACjD,CAAC;YACN,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe;aAChE,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Webhook Responders Index
|
|
3
|
+
*
|
|
4
|
+
* Registry of all available responders.
|
|
5
|
+
*/
|
|
6
|
+
import type { WebhookResponder } from '../types.js';
|
|
7
|
+
import { githubResponder } from './github.js';
|
|
8
|
+
import { linearResponder } from './linear.js';
|
|
9
|
+
import { slackResponder, formatSlackBlocks } from './slack.js';
|
|
10
|
+
/**
|
|
11
|
+
* Registry of all available responders
|
|
12
|
+
*/
|
|
13
|
+
export declare const responders: Record<string, WebhookResponder>;
|
|
14
|
+
/**
|
|
15
|
+
* Get a responder by ID
|
|
16
|
+
*/
|
|
17
|
+
export declare function getResponder(id: string): WebhookResponder | undefined;
|
|
18
|
+
/**
|
|
19
|
+
* Register a custom responder
|
|
20
|
+
*/
|
|
21
|
+
export declare function registerResponder(responder: WebhookResponder): void;
|
|
22
|
+
export { githubResponder, linearResponder, slackResponder, formatSlackBlocks };
|
|
23
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAE/D;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAIvD,CAAC;AAEF;;GAEG;AACH,wBAAgB,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS,CAErE;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,gBAAgB,GAAG,IAAI,CAEnE;AAED,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Webhook Responders Index
|
|
3
|
+
*
|
|
4
|
+
* Registry of all available responders.
|
|
5
|
+
*/
|
|
6
|
+
import { githubResponder } from './github.js';
|
|
7
|
+
import { linearResponder } from './linear.js';
|
|
8
|
+
import { slackResponder, formatSlackBlocks } from './slack.js';
|
|
9
|
+
/**
|
|
10
|
+
* Registry of all available responders
|
|
11
|
+
*/
|
|
12
|
+
export const responders = {
|
|
13
|
+
github: githubResponder,
|
|
14
|
+
linear: linearResponder,
|
|
15
|
+
slack: slackResponder,
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Get a responder by ID
|
|
19
|
+
*/
|
|
20
|
+
export function getResponder(id) {
|
|
21
|
+
return responders[id];
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Register a custom responder
|
|
25
|
+
*/
|
|
26
|
+
export function registerResponder(responder) {
|
|
27
|
+
responders[responder.id] = responder;
|
|
28
|
+
}
|
|
29
|
+
export { githubResponder, linearResponder, slackResponder, formatSlackBlocks };
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAE/D;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAqC;IAC1D,MAAM,EAAE,eAAe;IACvB,MAAM,EAAE,eAAe;IACvB,KAAK,EAAE,cAAc;CACtB,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,EAAU;IACrC,OAAO,UAAU,CAAC,EAAE,CAAC,CAAC;AACxB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAAC,SAA2B;IAC3D,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC;AACvC,CAAC;AAED,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,cAAc,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear Responder
|
|
3
|
+
*
|
|
4
|
+
* Sends responses back to Linear via their GraphQL API.
|
|
5
|
+
* https://developers.linear.app/docs/graphql/working-with-the-graphql-api
|
|
6
|
+
*/
|
|
7
|
+
import type { WebhookResponder } from '../types.js';
|
|
8
|
+
export declare const linearResponder: WebhookResponder;
|
|
9
|
+
//# sourceMappingURL=linear.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear.d.ts","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/linear.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAmB,gBAAgB,EAAmB,MAAM,aAAa,CAAC;AAsBtF,eAAO,MAAM,eAAe,EAAE,gBAuJ7B,CAAC"}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear Responder
|
|
3
|
+
*
|
|
4
|
+
* Sends responses back to Linear via their GraphQL API.
|
|
5
|
+
* https://developers.linear.app/docs/graphql/working-with-the-graphql-api
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Execute a Linear GraphQL mutation
|
|
9
|
+
*/
|
|
10
|
+
async function linearGraphQL(apiKey, query, variables) {
|
|
11
|
+
const response = await fetch('https://api.linear.app/graphql', {
|
|
12
|
+
method: 'POST',
|
|
13
|
+
headers: {
|
|
14
|
+
'Content-Type': 'application/json',
|
|
15
|
+
'Authorization': apiKey,
|
|
16
|
+
},
|
|
17
|
+
body: JSON.stringify({ query, variables }),
|
|
18
|
+
});
|
|
19
|
+
return response.json();
|
|
20
|
+
}
|
|
21
|
+
export const linearResponder = {
|
|
22
|
+
id: 'linear',
|
|
23
|
+
async respond(event, response, config) {
|
|
24
|
+
const apiKey = config?.apiKey || process.env.LINEAR_API_KEY;
|
|
25
|
+
if (!apiKey) {
|
|
26
|
+
return {
|
|
27
|
+
success: false,
|
|
28
|
+
error: 'Linear API key not configured',
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
try {
|
|
32
|
+
switch (response.type) {
|
|
33
|
+
case 'comment': {
|
|
34
|
+
// Create a comment on an issue
|
|
35
|
+
const issueId = String(response.target);
|
|
36
|
+
const mutation = `
|
|
37
|
+
mutation CreateComment($issueId: String!, $body: String!) {
|
|
38
|
+
commentCreate(input: { issueId: $issueId, body: $body }) {
|
|
39
|
+
success
|
|
40
|
+
comment {
|
|
41
|
+
id
|
|
42
|
+
url
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
`;
|
|
47
|
+
const result = await linearGraphQL(apiKey, mutation, {
|
|
48
|
+
issueId,
|
|
49
|
+
body: response.body,
|
|
50
|
+
});
|
|
51
|
+
if (result.errors?.length) {
|
|
52
|
+
return {
|
|
53
|
+
success: false,
|
|
54
|
+
error: result.errors.map(e => e.message).join(', '),
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const commentCreate = result.data?.commentCreate;
|
|
58
|
+
const comment = commentCreate?.comment;
|
|
59
|
+
return {
|
|
60
|
+
success: !!commentCreate?.success,
|
|
61
|
+
id: comment?.id,
|
|
62
|
+
url: comment?.url,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
case 'reaction': {
|
|
66
|
+
// Add a reaction/emoji to a comment
|
|
67
|
+
const commentId = String(response.target);
|
|
68
|
+
const emoji = response.metadata?.emoji || '👍';
|
|
69
|
+
const mutation = `
|
|
70
|
+
mutation CreateReaction($commentId: String!, $emoji: String!) {
|
|
71
|
+
reactionCreate(input: { commentId: $commentId, emoji: $emoji }) {
|
|
72
|
+
success
|
|
73
|
+
reaction {
|
|
74
|
+
id
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
`;
|
|
79
|
+
const result = await linearGraphQL(apiKey, mutation, {
|
|
80
|
+
commentId,
|
|
81
|
+
emoji,
|
|
82
|
+
});
|
|
83
|
+
if (result.errors?.length) {
|
|
84
|
+
return {
|
|
85
|
+
success: false,
|
|
86
|
+
error: result.errors.map(e => e.message).join(', '),
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
const reactionCreate = result.data?.reactionCreate;
|
|
90
|
+
return {
|
|
91
|
+
success: !!reactionCreate?.success,
|
|
92
|
+
id: reactionCreate?.reaction?.id,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
case 'status': {
|
|
96
|
+
// Update issue state
|
|
97
|
+
const issueId = String(response.target);
|
|
98
|
+
const stateId = response.metadata?.stateId;
|
|
99
|
+
if (!stateId) {
|
|
100
|
+
return {
|
|
101
|
+
success: false,
|
|
102
|
+
error: 'State ID required for status update',
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
const mutation = `
|
|
106
|
+
mutation UpdateIssue($issueId: String!, $stateId: String!) {
|
|
107
|
+
issueUpdate(id: $issueId, input: { stateId: $stateId }) {
|
|
108
|
+
success
|
|
109
|
+
issue {
|
|
110
|
+
id
|
|
111
|
+
url
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
`;
|
|
116
|
+
const result = await linearGraphQL(apiKey, mutation, {
|
|
117
|
+
issueId,
|
|
118
|
+
stateId,
|
|
119
|
+
});
|
|
120
|
+
if (result.errors?.length) {
|
|
121
|
+
return {
|
|
122
|
+
success: false,
|
|
123
|
+
error: result.errors.map(e => e.message).join(', '),
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
const issueUpdate = result.data?.issueUpdate;
|
|
127
|
+
const issue = issueUpdate?.issue;
|
|
128
|
+
return {
|
|
129
|
+
success: !!issueUpdate?.success,
|
|
130
|
+
id: issue?.id,
|
|
131
|
+
url: issue?.url,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
default:
|
|
135
|
+
return {
|
|
136
|
+
success: false,
|
|
137
|
+
error: `Unknown response type: ${response.type}`,
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
catch (error) {
|
|
142
|
+
return {
|
|
143
|
+
success: false,
|
|
144
|
+
error: error instanceof Error ? error.message : 'Unknown error',
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
};
|
|
149
|
+
//# sourceMappingURL=linear.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear.js","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/linear.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Slack Responder
|
|
3
|
+
*
|
|
4
|
+
* Sends responses back to Slack via their Web API.
|
|
5
|
+
* https://api.slack.com/methods
|
|
6
|
+
*/
|
|
7
|
+
import type { WebhookResponder } from '../types.js';
|
|
8
|
+
export declare const slackResponder: WebhookResponder;
|
|
9
|
+
/**
|
|
10
|
+
* Helper to format a message with blocks for richer formatting
|
|
11
|
+
*/
|
|
12
|
+
export declare function formatSlackBlocks(text: string, options?: {
|
|
13
|
+
header?: string;
|
|
14
|
+
context?: string;
|
|
15
|
+
actions?: Array<{
|
|
16
|
+
text: string;
|
|
17
|
+
url: string;
|
|
18
|
+
}>;
|
|
19
|
+
}): Array<Record<string, unknown>>;
|
|
20
|
+
//# sourceMappingURL=slack.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slack.d.ts","sourceRoot":"","sources":["../../../../src/cloud/webhooks/responders/slack.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAmB,gBAAgB,EAAmB,MAAM,aAAa,CAAC;AAsBtF,eAAO,MAAM,cAAc,EAAE,gBAgI5B,CAAC;AAEF;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;IACR,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAChD,GACA,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAkDhC"}
|