{"id":"src_fEbiqZILrkWMXtGjcMsZk","slug":"trigger-dev","name":"Trigger.dev","type":"github","url":"https://github.com/triggerdotdev/trigger.dev","orgId":"org_5yvH88gy00QggErv1uBJN","productId":null,"productSlug":null,"org":{"id":"org_5yvH88gy00QggErv1uBJN","slug":"trigger-dev","name":"Trigger.dev"},"isPrimary":false,"isHidden":false,"discovery":"curated","metadata":"{\"evaluatedMethod\":\"github\",\"evaluatedAt\":\"2026-04-11T13:59:11.630Z\",\"changelogDetectedAt\":\"2026-04-11T14:01:42.332Z\",\"wellKnownSweptAt\":\"2026-06-16T06:00:58.356Z\"}","notice":null,"kind":"platform","stars":15452,"starsFetchedAt":"2026-06-23T22:03:59.597Z","releaseCount":103,"releasesLast30Days":0,"avgReleasesPerWeek":0.2,"latestVersion":"v4.4.6","latestDate":"2026-05-12T10:38:39.000Z","changelogUrl":null,"hasChangelogFile":true,"lastFetchedAt":"2026-06-23T22:03:59.597Z","lastPolledAt":"2026-06-23T22:03:58.484Z","trackingSince":"2025-11-11T14:33:34.000Z","releases":[{"id":"rel_JpVPDSQF2CMEAIckE4D2c","version":"v4.4.6","type":"feature","title":"trigger.dev v4.4.6","summary":"# trigger.dev v4.4.6\n\n## Upgrade\n\n```sh\nnpx trigger.dev@latest update  # npm\npnpm dlx trigger.dev@latest update  # pnpm\nyarn dlx trigger.dev@latest up...","titleGenerated":null,"titleShort":null,"content":"# trigger.dev v4.4.6\n\n## Upgrade\n\n```sh\nnpx trigger.dev@latest update  # npm\npnpm dlx trigger.dev@latest update  # pnpm\nyarn dlx trigger.dev@latest update  # yarn\nbunx trigger.dev@latest update  # bun\n```\n\nSelf-hosted Docker image: [`ghcr.io/triggerdotdev/trigger.dev:v4.4.6`](https://github.com/triggerdotdev/trigger.dev/pkgs/container/trigger.dev/858669743?tag=v4.4.6)\n\n## Release notes\n\nRead the full release notes: https://trigger.dev/changelog/v4-4-6\n\n## What's changed\n\n## Improvements\n- Fail attempts on uncaught exceptions instead of hanging to `MAX_DURATION_EXCEEDED`. A Node `EventEmitter` (e.g. `node-redis`) emitting `\"error\"` with no `.on(\"error\", ...)` listener escalates to `uncaughtException`, which the worker previously reported but did not act on — runs drifted to maxDuration with empty attempts. They now fail fast with the original error and status `FAILED`, and respect the task's normal retry policy. You should still attach `.on(\"error\", ...)` listeners to long-lived clients to handle errors gracefully. ([#3529](https://github.com/triggerdotdev/trigger.dev/pull/3529))\n\n## Bug fixes\n- Fix dev workers spinning at 100% CPU after the parent CLI disconnects. Orphaned `trigger-dev-run-worker` (and indexer) processes were caught in an `uncaughtException` feedback loop: a periodic IPC send via `process.send` would throw `ERR_IPC_CHANNEL_CLOSED` once the parent closed the channel, which re-entered the same handler that itself called `process.send`, scheduled via `setImmediate` and amplified by source-map-support's `prepareStackTrace`. Fixed by (1) silently dropping packets in `ZodIpcConnection` when the channel is disconnected, (2) adding a `process.on(\"disconnect\", ...)` handler in dev workers so they exit cleanly when the CLI closes the IPC channel, and (3) wrapping all `uncaughtException`-path `process.send` calls in a `safeSend` guard that checks `process.connected` and swallows synchronous throws. ([#3491](https://github.com/triggerdotdev/trigger.dev/pull/3491))\n\n## All packages: v4.4.6\n\n@trigger.dev/build, @trigger.dev/core, @trigger.dev/python, @trigger.dev/react-hooks, @trigger.dev/redis-worker, @trigger.dev/rsc, @trigger.dev/schema-to-json, @trigger.dev/sdk, trigger.dev\n\n## Contributors\n\nEric Allam, @nicktrn, James Ritchie, @isshaddad, @d-cs, github-actions[bot], Matt Aitken, Saadi Myftija, Oskar Otwinowski\n\n**Full changelog**: https://github.com/triggerdotdev/trigger.dev/compare/v4.4.5...v4.4.6\n","publishedAt":"2026-05-12T10:38:39.000Z","fetchedAt":"2026-05-12T11:00:25.766Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/v4.4.6","media":[],"coverageCount":0},{"id":"rel_-zMotCe14zFHZ8S02o_gy","version":"v4.4.5","type":"feature","title":"trigger.dev v4.4.5","summary":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbun...","titleGenerated":null,"titleShort":null,"content":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbunx trigger.dev@latest update  # bun\r\n```\r\n\r\nSelf-hosted Docker image: [`ghcr.io/triggerdotdev/trigger.dev:v4.4.5`](https://github.com/triggerdotdev/trigger.dev/pkgs/container/trigger.dev/834767454?tag=v4.4.5)\r\n\r\n## Release notes\r\n\r\nRead the full release notes: https://trigger.dev/changelog/v4-4-5\r\n\r\n## What's changed\r\n\r\n## Breaking changes\r\n- Add server-side deprecation gate for deploys from v3 CLI versions (gated by `DEPRECATE_V3_CLI_DEPLOYS_ENABLED`). v4 CLI deploys are unaffected. ([#3415](https://github.com/triggerdotdev/trigger.dev/pull/3415))\r\n\r\n## Improvements\r\n- Add `--no-browser` flag to `init` and `login` to skip auto-opening the browser during authentication. Also error loudly when `init` is run without `--yes` under non-TTY stdin (previously default-and-exited silently, leaving the project half-initialized). Both commands now show an `Examples` section in `--help`. ([#3483](https://github.com/triggerdotdev/trigger.dev/pull/3483))\r\n- Add `isReplay` boolean to the run context (`ctx.run.isReplay`), derived from the existing `replayedFromTaskRunFriendlyId` database field. Defaults to `false` for backwards compatibility. ([#3454](https://github.com/triggerdotdev/trigger.dev/pull/3454))\r\n- Redact the `resolveWaitpoint` runtime log so it only emits `id` and `type` instead of the full completed waitpoint. Previously the log printed the entire waitpoint (including `output`) to stdout in production runs, which could leak sensitive payloads. The value returned by `wait.forToken()` is unchanged. ([#3490](https://github.com/triggerdotdev/trigger.dev/pull/3490))\r\n- Add `SessionId` friendly ID generator and schemas for the new durable Session primitive. Exported from `@trigger.dev/core/v3/isomorphic` alongside `RunId`, `BatchId`, etc. Ships the `CreateSessionStreamWaitpoint` request/response schemas alongside the main Session CRUD. ([#3417](https://github.com/triggerdotdev/trigger.dev/pull/3417))\r\n- Truncate large error stacks and messages to prevent OOM crashes. Stack traces are capped at 50 frames (keeping top 5 + bottom 45 with an omission notice), individual stack lines at 1024 chars, and error messages at 1000 chars. Applied in parseError, sanitizeError, and OTel span recording. ([#3405](https://github.com/triggerdotdev/trigger.dev/pull/3405))\r\n\r\n## Server changes\r\n\r\nThese changes affect the self-hosted Docker image and Trigger.dev Cloud:\r\n\r\n- Add a \"Back office\" tab to `/admin` and a per-organization detail page at `/admin/back-office/orgs/:orgId`. The first action available on that page is editing the org's API rate limit: admins can save a `tokenBucket` override (refill rate, interval, max tokens) and see a plain-English preview of the resulting sustained rate and burst allowance. Writes are audit-logged via the server logger. ([#3434](https://github.com/triggerdotdev/trigger.dev/pull/3434))\r\n- Optional `DEPLOY_REGISTRY_ECR_DEFAULT_REPOSITORY_POLICY` env var to apply a default repository policy when the webapp creates new ECR repos ([#3467](https://github.com/triggerdotdev/trigger.dev/pull/3467))\r\n- Ship the Errors page to all users, with a polish + bug-fix pass: pinned \"No channel\" item in the Slack alert channel picker, viewer-timezone alert timestamps via Slack's `<!date^>` token, Activity sparkline peak tooltip, centered loading spinner and bug-icon empty state on the error detail page, ellipsis on the Configure alerts trigger. ([#3477](https://github.com/triggerdotdev/trigger.dev/pull/3477))\r\n- Configure the set of machine presets to build boot snapshots for at deploy time via `COMPUTE_TEMPLATE_MACHINE_PRESETS` (CSV of preset names, default `small-1x`). Use `COMPUTE_TEMPLATE_MACHINE_PRESETS_REQUIRED` (CSV, default = full PRESETS list) to scope which preset failures fail a required-mode deploy. Optional preset failures are logged and don't block the deploy. ([#3492](https://github.com/triggerdotdev/trigger.dev/pull/3492))\r\n- Regenerating a RuntimeEnvironment API key no longer invalidates the previous key immediately. The old key is recorded in a new `RevokedApiKey` table with a 24 hour grace window, and `findEnvironmentByApiKey` falls back to it when the submitted key doesn't match any live environment. The grace window can be ended early (or extended) by updating `expiresAt` on the row. ([#3420](https://github.com/triggerdotdev/trigger.dev/pull/3420))\r\n- Add the `Session` primitive — a durable, task-bound, bidirectional I/O channel that outlives a single run and acts as the run manager for `chat.agent`. Ships the Postgres `Session` + `SessionRun` tables, ClickHouse `sessions_v1` + replication service, the `sessions` JWT scope, and the public CRUD + realtime routes (`/api/v1/sessions`, `/realtime/v1/sessions/:session/:io`) including `end-and-continue` for server-orchestrated run handoffs and session-stream waitpoints. ([#3417](https://github.com/triggerdotdev/trigger.dev/pull/3417))\r\n- Add `KUBERNETES_POD_DNS_NDOTS_OVERRIDE_ENABLED` flag (off by default) that overrides the cluster default and sets `dnsConfig.options.ndots` on runner pods (defaulting to 2, configurable via `KUBERNETES_POD_DNS_NDOTS`). Kubernetes defaults pods to `ndots: 5`, so any name with fewer than 5 dots — including typical external domains like `api.example.com` — is first walked through every entry in the cluster search list (`<ns>.svc.cluster.local`, `svc.cluster.local`, `cluster.local`) before being tried as-is, turning one resolution into 4+ CoreDNS queries (×2 with A+AAAA). Using a lower `ndots` value reduces DNS query amplification in the `cluster.local` zone.\r\n  \r\n  Note: before enabling, make sure no code path relies on search-list expansion for names with dots ≥ the configured value — those names will hit their as-is form first and could resolve externally before falling back to the cluster search path. ([#3441](https://github.com/triggerdotdev/trigger.dev/pull/3441))\r\n- Vercel integration option to disable auto promotions ([#3376](https://github.com/triggerdotdev/trigger.dev/pull/3376))\r\n- Make it clear in the admin that feature flags are global and should rarely be changed. ([#3408](https://github.com/triggerdotdev/trigger.dev/pull/3408))\r\n- Admin worker groups API: add GET loader and expose more fields on POST. ([#3390](https://github.com/triggerdotdev/trigger.dev/pull/3390))\r\n- Add 60s fresh / 60s stale SWR cache to `getEntitlement` in `platform.v3.server.ts`. Eliminates a synchronous billing-service HTTP round trip on every trigger. Reuses the existing `platformCache` (LRU memory + Redis) pattern already used for `limits` and `usage`. Cache key is `${orgId}`. Errors return a permissive `{ hasAccess: true }` fallback (existing behavior) and are also cached to prevent thundering-herd on billing outages. ([#3388](https://github.com/triggerdotdev/trigger.dev/pull/3388))\r\n- Show a `MicroVM` badge next to the region name on the regions page. ([#3407](https://github.com/triggerdotdev/trigger.dev/pull/3407))\r\n- Increase default maximum project count per organization from 10 to 25 ([#3409](https://github.com/triggerdotdev/trigger.dev/pull/3409))\r\n- Merge execution snapshot creation into the dequeue taskRun.update transaction, reducing 2 DB commits to 1 per dequeue operation ([#3395](https://github.com/triggerdotdev/trigger.dev/pull/3395))\r\n- Add per-worker Node.js heap metrics to the OTel meter — `nodejs.memory.heap.used`, `nodejs.memory.heap.total`, `nodejs.memory.heap.limit`, `nodejs.memory.external`, `nodejs.memory.array_buffers`, `nodejs.memory.rss`. Host-metrics only publishes RSS, which overstates V8 heap by the external + native footprint; these give direct heap visibility per cluster worker so `NODE_MAX_OLD_SPACE_SIZE` can be sized against observed heap peaks rather than RSS. ([#3437](https://github.com/triggerdotdev/trigger.dev/pull/3437))\r\n- Tag Prisma spans with `db.datasource: \"writer\" | \"replica\"` so monitors and trace queries can distinguish the writer pool from the replica pool. Applies to all `prisma:engine:*` spans (including `prisma:engine:connection` used by the connection-pool monitors) and the outer `prisma:client:operation` span. ([#3422](https://github.com/triggerdotdev/trigger.dev/pull/3422))\r\n- Clarify the cross-region intent in the Terraform and AI-prompt helpers on the Add Private Connection page. Both already default `supported_regions` to `[\"us-east-1\", \"eu-central-1\"]`; added an inline comment / parenthetical so the user understands why both regions are listed (Trigger.dev runs in both, so the service must be consumable from either). ([#3465](https://github.com/triggerdotdev/trigger.dev/pull/3465))\r\n- Add `RUN_ENGINE_READ_REPLICA_SNAPSHOTS_SINCE_ENABLED` flag (default off) to route the Prisma reads inside `RunEngine.getSnapshotsSince` through the read-only replica client. Offloads the snapshot polling queries (fired by every running task runner) from the primary. When disabled, behavior is unchanged. ([#3423](https://github.com/triggerdotdev/trigger.dev/pull/3423))\r\n- Stop creating TaskRunTag records and _TaskRunToTaskRunTag join table entries during task triggering. The denormalized runTags string array on TaskRun already stores tag names, making the M2M relation redundant write overhead. ([#3369](https://github.com/triggerdotdev/trigger.dev/pull/3369))\r\n- Stop writing per-tick state (`lastScheduledTimestamp`, `nextScheduledTimestamp`, `lastRunTriggeredAt`) on `TaskSchedule` and `TaskScheduleInstance`. The schedule engine now carries the previous fire time forward via the worker queue payload, eliminating ~270K dead-tuple-driven autovacuums per year on these hot tables and the associated `IO:XactSync` mini-spikes on the writer. Customer-facing `payload.lastTimestamp` semantics are unchanged. ([#3476](https://github.com/triggerdotdev/trigger.dev/pull/3476))\r\n- Replace the expensive DISTINCT query for task filter dropdowns with a dedicated TaskIdentifier registry table backed by Redis. Environments migrate automatically on their next deploy, with a transparent fallback to the legacy query for unmigrated environments. Also fixes duplicate dropdown entries when a task changes trigger source, and adds active/archived grouping for removed tasks. Moves BackgroundWorkerTask reads in the trigger hot path to the read replica. ([#3368](https://github.com/triggerdotdev/trigger.dev/pull/3368))\r\n- Public Access Tokens (PATs) minted before an API key rotation now keep working during the 24h grace window. `validatePublicJwtKey` falls back to any non-expired `RevokedApiKey` rows for the signing environment when the primary signature check against the env's current `apiKey` fails. The fallback query only runs on the failure path, so the hot success path is unchanged. ([#3464](https://github.com/triggerdotdev/trigger.dev/pull/3464))\r\n- Batch items that hit the environment queue size limit now fast-fail without\r\n  retries and without creating pre-failed TaskRuns. ([#3352](https://github.com/triggerdotdev/trigger.dev/pull/3352))\r\n- Show the cancel button in the runs list for runs in `DEQUEUED` status. `DEQUEUED` was missing from `NON_FINAL_RUN_STATUSES` so the list hid the button even though the single run page allowed it. ([#3421](https://github.com/triggerdotdev/trigger.dev/pull/3421))\r\n- Reduce 5xx feedback loops on hot debounce keys by quantizing `delayUntil`,\r\n  adding an unlocked fast-path skip, and gracefully handling redlock\r\n  contention in `handleDebounce` so the SDK no longer retries into a herd. ([#3453](https://github.com/triggerdotdev/trigger.dev/pull/3453))\r\n- Fix RSS memory leak in the realtime proxy routes. `/realtime/v1/runs`, `/realtime/v1/runs/:id`, and `/realtime/v1/batches/:id` called `fetch()` into Electric with no abort signal, so when a client disconnected mid long-poll, undici kept the upstream socket open and buffered response chunks that would never be consumed — retained only in RSS, invisible to V8 heap tooling. Thread `getRequestAbortSignal()` through `RealtimeClient.streamRun/streamRuns/streamBatch` to `longPollingFetch` and cancel the upstream body in the error path. Isolated reproducer showed ~44 KB retained per leaked request; signal propagation releases it cleanly. ([#3442](https://github.com/triggerdotdev/trigger.dev/pull/3442))\r\n- Fix memory leak where every aborted SSE connection pinned the full request/response graph on Node 20, caused by `AbortSignal.any()` in `sse.ts` retaining its source signals indefinitely (see nodejs/node#54614, nodejs/node#55351). Also clear the `setTimeout(abort)` timer in `entry.server.tsx` so successful HTML renders don't pin the React tree for 30s per request. ([#3430](https://github.com/triggerdotdev/trigger.dev/pull/3430))\r\n- Preserve filters on the queues page when submitting modal actions. ([#3471](https://github.com/triggerdotdev/trigger.dev/pull/3471))\r\n- Fix Redis connection leak in realtime streams and broken abort signal propagation.\r\n  \r\n  **Redis connections**: Non-blocking methods (ingestData, appendPart, getLastChunkIndex) now share a single Redis connection instead of creating one per request. streamResponse still uses dedicated connections (required for XREAD BLOCK) but now tears them down immediately via disconnect() instead of graceful quit(), with a 15s inactivity fallback.\r\n  \r\n  **Abort signal**: request.signal is broken in Remix/Express due to a Node.js undici GC bug (nodejs/node#55428) that severs the signal chain when Remix clones the Request internally. Added getRequestAbortSignal() wired to Express res.on(\"close\") via httpAsyncStorage, which fires reliably on client disconnect. All SSE/streaming routes updated to use it. ([#3399](https://github.com/triggerdotdev/trigger.dev/pull/3399))\r\n- Prevent dashboard crash (React error #31) when span accessory item text is not a string. Filters out malformed accessory items in SpanCodePathAccessory instead of passing objects to React as children. ([#3400](https://github.com/triggerdotdev/trigger.dev/pull/3400))\r\n- Upgrade Remix packages from 2.1.0 to 2.17.4 to address security vulnerabilities in React Router ([#3372](https://github.com/triggerdotdev/trigger.dev/pull/3372))\r\n- Fix Vercel integration settings page (remove redundant section toggles) and improve the Vercel onboarding flow so the modal closes after connecting a GitHub repo and the marketplace `next` URL is preserved across the GitHub app install redirect. ([#3424](https://github.com/triggerdotdev/trigger.dev/pull/3424))\r\n\r\n## All packages: v4.4.5\r\n\r\n@trigger.dev/build, @trigger.dev/core, @trigger.dev/python, @trigger.dev/react-hooks, @trigger.dev/redis-worker, @trigger.dev/rsc, @trigger.dev/schema-to-json, @trigger.dev/sdk, trigger.dev\r\n\r\n## Contributors\r\n\r\nEric Allam, @nicktrn, @isshaddad, devin-ai-integration[bot], Matt Aitken, Oskar Otwinowski, @D-K-P, @ThullyoCunha, github-actions[bot], Saadi Myftija\r\n\r\n**Full changelog**: https://github.com/triggerdotdev/trigger.dev/compare/v4.4.4...v4.4.5\n","publishedAt":"2026-05-01T14:44:57.000Z","fetchedAt":"2026-05-01T18:00:59.265Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/v4.4.5","media":[],"coverageCount":0},{"id":"rel_HIhxKHyv2M1O9ENF2s3Oo","version":"v4.4.4","type":"feature","title":"trigger.dev v4.4.4","summary":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbun...","titleGenerated":null,"titleShort":null,"content":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbunx trigger.dev@latest update  # bun\r\n```\r\n\r\nSelf-hosted Docker image: [`ghcr.io/triggerdotdev/trigger.dev:v4.4.4`](https://github.com/triggerdotdev/trigger.dev/pkgs/container/trigger.dev/793991665?tag=v4.4.4)\r\n\r\n## Release notes\r\n\r\nRead the full release notes: https://trigger.dev/changelog/v4-4-4\r\n\r\n## What's changed\r\n\r\n## Highlights\r\n\r\n- Add support for setting TTL (time-to-live) defaults at the task level and globally in trigger.config.ts, with per-trigger overrides still taking precedence ([#3196](https://github.com/triggerdotdev/trigger.dev/pull/3196))\r\n- Large run outputs can use the new API which allows switching object storage providers. ([#3275](https://github.com/triggerdotdev/trigger.dev/pull/3275))\r\n\r\n## CLI Improvements\r\n\r\n- Add platform notifications support to the CLI. The `trigger dev` and `trigger login` commands now fetch and display platform notifications (info, warn, error, success) from the server. Includes discovery-based filtering to conditionally show notifications based on project file patterns, color markup rendering for styled terminal output, and a non-blocking display flow with a spinner fallback for slow fetches. Use `--skip-platform-notifications` flag with `trigger dev` to disable the notification check. ([#3254](https://github.com/triggerdotdev/trigger.dev/pull/3254))\r\n\r\n## MCP Server improvements\r\n\r\n- Add `get_span_details` MCP tool for inspecting individual spans within a run trace. ([#3255](https://github.com/triggerdotdev/trigger.dev/pull/3255))\r\n- Span IDs now shown in `get_run_details` trace output for easy discovery\r\n- New API endpoint `GET /api/v1/runs/:runId/spans/:spanId`\r\n- `get_query_schema` — discover available TRQL tables and columns\r\n- `query` — execute TRQL queries against your data\r\n- `list_dashboards` — list built-in dashboards and their widgets\r\n- `run_dashboard_query` — execute a single dashboard widget query\r\n- `whoami` — show current profile, user, and API URL\r\n- `list_profiles` — list all configured CLI profiles\r\n- `switch_profile` — switch active profile for the MCP session\r\n- `start_dev_server` — start `trigger dev` in the background and stream output\r\n- `stop_dev_server` — stop the running dev server\r\n- `dev_server_status` — check dev server status and view recent logs\r\n- `GET /api/v1/query/schema` — query table schema discovery\r\n- `GET /api/v1/query/dashboards` — list built-in dashboards\r\n- `--readonly` flag hides write tools (`deploy`, `trigger_task`, `cancel_run`) so the AI cannot make changes\r\n- `read:query` JWT scope for query endpoint authorization\r\n- `get_run_details` trace output is now paginated with cursor support\r\n- MCP tool annotations (`readOnlyHint`, `destructiveHint`) for all tools\r\n- `get_query_schema` now requires a table name and returns only one table's schema (was returning all tables)\r\n- `get_current_worker` no longer inlines payload schemas; use new `get_task_schema` tool instead\r\n- Query results formatted as text tables instead of JSON (~50% fewer tokens)\r\n- `cancel_run`, `list_deploys`, `list_preview_branches` formatted as text instead of raw JSON\r\n- Schema and dashboard API responses cached to avoid redundant fetches\r\n- Adapted the CLI API client to propagate the trigger source via http headers. ([#3241](https://github.com/triggerdotdev/trigger.dev/pull/3241))\r\n- `--readonly` flag hides write tools (`deploy`, `trigger_task`, `cancel_run`) so the AI cannot make changes\r\n- `get_run_details` trace output is now paginated with cursor support\r\n- MCP tool annotations (`readOnlyHint`, `destructiveHint`) for all tools\r\n- `get_query_schema` now requires a table name and returns only one table's schema (was returning all tables)\r\n- `get_current_worker` no longer inlines payload schemas; use new `get_task_schema` tool instead\r\n- Query results formatted as text tables instead of JSON (~50% fewer tokens)\r\n- `cancel_run`, `list_deploys`, `list_preview_branches` formatted as text instead of raw JSON\r\n- Schema and dashboard API responses cached to avoid redundant fetches\r\n\r\n## Bug fixes\r\n\r\n- Fix dev CLI leaking build directories on rebuild, causing disk space accumulation. Deprecated workers are now pruned (capped at 2 retained) when no active runs reference them. The watchdog process also cleans up `.trigger/tmp/` when the dev CLI is killed ungracefully (e.g. SIGKILL from pnpm). ([#3224](https://github.com/triggerdotdev/trigger.dev/pull/3224))\r\n- Fix `--load` flag being silently ignored on local/self-hosted builds. ([#3114](https://github.com/triggerdotdev/trigger.dev/pull/3114))\r\n- Fixed `search_docs` tool failing due to renamed upstream Mintlify tool (`SearchTriggerDev` → `search_trigger_dev`)\r\n- Fixed `list_deploys` failing when deployments have null `runtime`/`runtimeVersion` fields (#3139)\r\n- Fixed `list_preview_branches` crashing due to incorrect response shape access\r\n- Fixed `metrics` table column documented as `value` instead of `metric_value` in query docs\r\n- Fixed dev CLI leaking build directories on rebuild — deprecated workers now clean up their build dirs when their last run completes\r\n- Fixed `search_docs` tool failing due to renamed upstream Mintlify tool (`SearchTriggerDev` → `search_trigger_dev`)\r\n- Fixed `list_deploys` failing when deployments have null `runtime`/`runtimeVersion` fields (#3139)\r\n- Fixed `list_preview_branches` crashing due to incorrect response shape access\r\n- Fixed `metrics` table column documented as `value` instead of `metric_value` in query docs\r\n- Fixed dev CLI leaking build directories on rebuild — deprecated workers now clean up their build dirs when their last run completes\r\n\r\n## Server changes\r\n\r\nThese changes affect the self-hosted Docker image and Trigger.dev Cloud:\r\n\r\n- Add admin UI for viewing and editing feature flags (org-level overrides and global defaults). ([#3291](https://github.com/triggerdotdev/trigger.dev/pull/3291))\r\n  \r\n**Other improvements:**\r\n\r\n- Add allowRollbacks query param to the promote deployment API to enable version downgrades ([#3214](https://github.com/triggerdotdev/trigger.dev/pull/3214))\r\n- Add automatic LLM cost calculation for spans with GenAI semantic conventions. When a span arrives with `gen_ai.response.model` and token usage data, costs are calculated from an in-memory pricing registry backed by Postgres and dual-written to both span attributes (`trigger.llm.*`) and a new `llm_metrics_v1` ClickHouse table that captures usage, cost, performance (TTFC, tokens/sec), and behavioral (finish reason, operation type) metrics. ([#3213](https://github.com/triggerdotdev/trigger.dev/pull/3213))\r\n- Add API endpoint `GET /api/v1/runs/:runId/spans/:spanId` that returns detailed span information including properties, events, AI enrichment (model, tokens, cost), and triggered child runs. ([#3255](https://github.com/triggerdotdev/trigger.dev/pull/3255))\r\n- Multi-provider object storage with protocol-based routing for zero-downtime migration ([#3275](https://github.com/triggerdotdev/trigger.dev/pull/3275))\r\n- Add IAM role-based auth support for object stores (no access keys required). ([#3275](https://github.com/triggerdotdev/trigger.dev/pull/3275))\r\n- Add platform notifications to inform users about new features, changelogs, and platform events directly in the dashboard. ([#3254](https://github.com/triggerdotdev/trigger.dev/pull/3254))\r\n- Add private networking support via AWS PrivateLink. Includes BillingClient methods for managing private connections, org settings UI pages for connection management, and supervisor changes to apply `privatelink` pod labels for CiliumNetworkPolicy matching. ([#3264](https://github.com/triggerdotdev/trigger.dev/pull/3264))\r\n- Reduce run start latency by skipping the intermediate queue when concurrency is available. This optimization is rolled out per-region and enabled automatically for development environments. ([#3299](https://github.com/triggerdotdev/trigger.dev/pull/3299))\r\n- Extended the search filter on the environment variables page to match on environment type (production, staging, development, preview) and branch name, not just variable name and value. ([#3302](https://github.com/triggerdotdev/trigger.dev/pull/3302))\r\n- Set `application_name` on Prisma connections from SERVICE_NAME so DB load can be attributed by service ([#3348](https://github.com/triggerdotdev/trigger.dev/pull/3348))\r\n- Fix transient R2/object store upload failures during batchTrigger() item streaming.\r\n  \r\n  - Added p-retry (3 attempts, 500ms–2s exponential backoff) around `uploadPacketToObjectStore` in `BatchPayloadProcessor.process()` so transient network errors self-heal server-side rather than aborting the entire batch stream.\r\n  - Removed `x-should-retry: false` from the 500 response on the batch items route so the SDK's existing 5xx retry path can recover if server-side retries are exhausted. Item deduplication by index makes full-stream retries safe. ([#3331](https://github.com/triggerdotdev/trigger.dev/pull/3331))\r\n- Concurrency-keyed queues now use a single master queue entry per base queue instead of one entry per key. Prevents high-CK-count tenants from consuming the entire parentQueueLimit window and starving other tenants on the same shard. ([#3219](https://github.com/triggerdotdev/trigger.dev/pull/3219))\r\n- Reduce lock contention when processing large `batchTriggerAndWait` batches. Previously, each batch item acquired a Redis lock on the parent run to insert a `TaskRunWaitpoint` row, causing `LockAcquisitionTimeoutError` with high concurrency (880 errors/24h in prod). Since `blockRunWithCreatedBatch` already transitions the parent to `EXECUTING_WITH_WAITPOINTS` before items are processed, the per-item lock is unnecessary. The new `blockRunWithWaitpointLockless` method performs only the idempotent CTE insert without acquiring the lock. ([#3232](https://github.com/triggerdotdev/trigger.dev/pull/3232))\r\n- Strip `secure` query parameter from QUERY_CLICKHOUSE_URL before passing to ClickHouse client. This was already done for the main and logs ClickHouse clients but was missing for the query client, causing a startup crash with `Error: Unknown URL parameters: secure`. ([#3204](https://github.com/triggerdotdev/trigger.dev/pull/3204))\r\n- Fix `OrganizationsPresenter.#getEnvironment` matching the wrong development environment on teams with multiple members. All dev environments share the slug `\"dev\"`, so the previous `find` by slug alone could return another member's environment. Now filters DEVELOPMENT environments by `orgMember.userId` to ensure the logged-in user's dev environment is selected. ([#3273](https://github.com/triggerdotdev/trigger.dev/pull/3273))\r\n\r\n## All packages: v4.4.4\r\n\r\n@trigger.dev/build, @trigger.dev/core, @trigger.dev/python, @trigger.dev/react-hooks, @trigger.dev/redis-worker, @trigger.dev/rsc, @trigger.dev/schema-to-json, @trigger.dev/sdk, trigger.dev\r\n\r\n## Contributors\r\n\r\nEric Allam, Oskar Otwinowski, Matt Aitken, James Ritchie, @nicktrn, Saadi Myftija, @D-K-P, @isshaddad, github-actions[bot], @chengzp, Dinko Osrecki\r\n\r\n**Full changelog**: https://github.com/triggerdotdev/trigger.dev/compare/v4.4.3...v4.4.4\r\n","publishedAt":"2026-04-13T13:17:10.000Z","fetchedAt":"2026-04-13T14:02:18.644Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/v4.4.4","media":[],"coverageCount":0},{"id":"rel_meVz2tATIdRHDVfW7jcGq","version":"v4.4.3","type":"feature","title":"trigger.dev v4.4.3","summary":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbun...","titleGenerated":null,"titleShort":null,"content":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update  # npm\r\npnpm dlx trigger.dev@latest update  # pnpm\r\nyarn dlx trigger.dev@latest update  # yarn\r\nbunx trigger.dev@latest update  # bun\r\n```\r\n\r\nSelf-hosted Docker image: [`ghcr.io/triggerdotdev/trigger.dev:v4.4.3`](https://github.com/triggerdotdev/trigger.dev/pkgs/container/trigger.dev/727492473?tag=v4.4.3)\r\n\r\n## Release notes\r\n\r\nRead the full release notes: https://trigger.dev/changelog/v4-4-3\r\n\r\n## What's changed\r\n\r\n## Improvements\r\n- Add syncSupabaseEnvVars to pull database connection strings and save them as trigger.dev environment variables ([#3152](https://github.com/triggerdotdev/trigger.dev/pull/3152))\r\n- Auto-cancel in-flight dev runs when the CLI exits, using a detached watchdog process that survives pnpm SIGKILL ([#3191](https://github.com/triggerdotdev/trigger.dev/pull/3191))\r\n\r\n## Server changes\r\n\r\nThese changes affect the self-hosted Docker image and Trigger.dev Cloud:\r\n\r\n- A new Errors page for viewing and tracking errors that cause runs to fail\r\n  \r\n  - Errors are grouped using error fingerprinting\r\n  - View top errors for a time period, filter by task, or search the text\r\n  - View occurrences over time\r\n  - View all the runs for an error and bulk replay them ([#3172](https://github.com/triggerdotdev/trigger.dev/pull/3172))\r\n- Add sidebar tabs (Options, AI, Schema) to the Test page for schemaTask payload generation and schema viewing. ([#3188](https://github.com/triggerdotdev/trigger.dev/pull/3188))\r\n\r\n## All packages: v4.4.3\r\n\r\n@trigger.dev/build, @trigger.dev/core, @trigger.dev/python, @trigger.dev/react-hooks, @trigger.dev/redis-worker, @trigger.dev/rsc, @trigger.dev/schema-to-json, @trigger.dev/sdk, trigger.dev\r\n\r\n## Contributors\r\n\r\nEric Allam, Matt Aitken, James Ritchie, Oskar Otwinowski\r\n\r\n**Full changelog**: https://github.com/triggerdotdev/trigger.dev/compare/v4.4.2...v4.4.3\r\n","publishedAt":"2026-03-10T10:21:58.000Z","fetchedAt":"2026-04-11T14:01:41.445Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/v4.4.3","media":[],"coverageCount":0},{"id":"rel_fGIkqvU97bMEclTkEvv8k","version":"v4.4.2","type":"feature","title":"trigger.dev v4.4.2","summary":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update\r\npnpm dlx trigger.dev@latest update\r\nyarn dlx trigger.dev@latest update\r\nbunx trigger.dev@latest up...","titleGenerated":null,"titleShort":null,"content":"## Upgrade\r\n\r\n```sh\r\nnpx trigger.dev@latest update\r\npnpm dlx trigger.dev@latest update\r\nyarn dlx trigger.dev@latest update\r\nbunx trigger.dev@latest update \r\n```\r\n\r\nSelf-hosted Docker image: [`ghcr.io/triggerdotdev/trigger.dev:v4.4.2`](https://github.com/triggerdotdev/trigger.dev/pkgs/container/trigger.dev/716803036?tag=v4.4.2)\r\n\r\n## Release notes\r\n\r\nRead the full release notes: https://trigger.dev/changelog/v4-4-2\r\n\r\n## What's changed\r\n\r\n## Improvements\r\n- Add input streams for bidirectional communication with running tasks. Define typed input streams with `streams.input<T>({ id })`, then consume inside tasks via `.wait()` (suspends the process), `.once()` (waits for next message), or `.on()` (subscribes to a continuous stream). Send data from backends with `.send(runId, data)` or from frontends with the new `useInputStreamSend` React hook. ([#3146](https://github.com/triggerdotdev/trigger.dev/pull/3146))\r\n- Add PAYLOAD_TOO_LARGE error to handle graceful recovery of sending batch trigger items with payloads that exceed the maximum payload size ([#3137](https://github.com/triggerdotdev/trigger.dev/pull/3137))\r\n\r\n## Bug fixes\r\n- Fix slow batch queue processing by removing spurious cooloff on concurrency blocks and fixing a race condition where retry attempt counts were not atomically updated during message re-queue. ([#3079](https://github.com/triggerdotdev/trigger.dev/pull/3079))\r\n- fix(sdk): batch triggerAndWait variants now return correct run.taskIdentifier instead of unknown ([#3080](https://github.com/triggerdotdev/trigger.dev/pull/3080))\r\n\r\n## Server changes\r\n\r\nThese changes affect the self-hosted Docker image and Trigger.dev Cloud:\r\n\r\n- Two-level tenant dispatch architecture for batch queue processing. Replaces the\r\n  single master queue with a two-level index: a dispatch index (tenant → shard)\r\n  and per-tenant queue indexes (tenant → queues). This enables O(1) tenant\r\n  selection and fair scheduling across tenants regardless of queue count. Improves batch queue processing performance. ([#3133](https://github.com/triggerdotdev/trigger.dev/pull/3133))\r\n- Add input streams with API routes for sending data to running tasks, SSE reading, and waitpoint creation. Includes Redis cache for fast `.send()` to `.wait()` bridging, dashboard span support for input stream operations, and s2-lite support with configurable S2 endpoint, access token skipping, and S2-Basin headers for self-hosted deployments. Adds s2-lite to Docker Compose for local development. ([#3146](https://github.com/triggerdotdev/trigger.dev/pull/3146))\r\n- Speed up batch queue processing by disabling cooloff and increasing the batch queue processing concurrency limits on the cloud:\r\n  \r\n  - Pro plan: increase to 50 from 10.\r\n  - Hobby plan: increase to 10 from 5.\r\n  - Free plan: increase to 5 from 1. ([#3079](https://github.com/triggerdotdev/trigger.dev/pull/3079))\r\n- Move batch queue global rate limiter from FairQueue claim phase to BatchQueue worker queue consumer for accurate per-item rate limiting. Add worker queue depth cap to prevent unbounded growth that could cause visibility timeouts. ([#3166](https://github.com/triggerdotdev/trigger.dev/pull/3166))\r\n- Fix a race condition in the waitpoint system where a run could be blocked by a completed waitpoint but never be resumed because of a PostgreSQL MVCC issue. This was most likely to occur when creating a waitpoint via `wait.forToken()` at the same moment as completing the token with `wait.completeToken()`. Other types of waitpoints (timed, child runs) were not affected. ([#3075](https://github.com/triggerdotdev/trigger.dev/pull/3075))\r\n- Fix metrics dashboard chart series colors going out of sync and widgets not reloading stale data when scrolled back into view ([#3126](https://github.com/triggerdotdev/trigger.dev/pull/3126))\r\n- Gracefully handle oversized batch items instead of aborting the stream.\r\n  \r\n  When an NDJSON batch item exceeds the maximum size, the parser now emits an error marker instead of throwing, allowing the batch to seal normally. The oversized item becomes a pre-failed run with `PAYLOAD_TOO_LARGE` error code, while other items in the batch process successfully. This prevents `batchTriggerAndWait` from seeing connection errors and retrying with exponential backoff.\r\n  \r\n  Also fixes the NDJSON parser not consuming the remainder of an oversized line split across multiple chunks, which caused \"Invalid JSON\" errors on subsequent lines. ([#3137](https://github.com/triggerdotdev/trigger.dev/pull/3137))\r\n- Require the user is an admin during an impersonation session. Previously only the impersonation cookie was checked; now the real user's admin flag is verified on every request. If admin has been revoked, the session falls back to the real user's ID. ([#3078](https://github.com/triggerdotdev/trigger.dev/pull/3078))\r\n\r\n## All packages: v4.4.2\r\n\r\n@trigger.dev/build, @trigger.dev/core, @trigger.dev/python, @trigger.dev/react-hooks, @trigger.dev/redis-worker, @trigger.dev/rsc, @trigger.dev/schema-to-json, @trigger.dev/sdk, trigger.dev\r\n\r\n**Full changelog**: https://github.com/triggerdotdev/trigger.dev/compare/v4.4.1...v4.4.2","publishedAt":"2026-03-04T09:52:32.000Z","fetchedAt":"2026-04-11T14:01:41.445Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/v4.4.2","media":[],"coverageCount":0},{"id":"rel_NZnWippgezuGMzWNQFsDy","version":"@trigger.dev/core@4.4.1","type":"feature","title":"@trigger.dev/core@4.4.1","summary":"\n","titleGenerated":null,"titleShort":null,"content":"\n","publishedAt":"2026-02-20T16:45:38.000Z","fetchedAt":"2026-04-11T14:01:41.484Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/core%404.4.1","media":[],"coverageCount":0},{"id":"rel_sbayEPbNisEkTVVshR9XE","version":"@trigger.dev/python@4.4.1","type":"feature","title":"@trigger.dev/python@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/sdk@4.4.1`\n    -   `@trigger.dev/build@4.4.1`\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/sdk@4.4.1`\n    -   `@trigger.dev/build@4.4.1`\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:35.000Z","fetchedAt":"2026-04-11T14:01:41.484Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/python%404.4.1","media":[],"coverageCount":0},{"id":"rel_C7r2TEnu7JwJ8l5qdOjaD","version":"@trigger.dev/sdk@4.4.1","type":"feature","title":"@trigger.dev/sdk@4.4.1","summary":"### Patch Changes\n\n-   Add OTEL metrics pipeline for task workers. Workers collect process CPU/memory, Node.js runtime metrics (event loop utilization...","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Add OTEL metrics pipeline for task workers. Workers collect process CPU/memory, Node.js runtime metrics (event loop utilization, event loop delay, heap usage), and user-defined custom metrics via `otel.metrics.getMeter()`. Metrics are exported to ClickHouse with 10-second aggregation buckets and 1m/5m rollups, and are queryable through the dashboard query engine with typed attribute columns, `prettyFormat()` for human-readable values, and AI query support. ([#3061](https://github.com/triggerdotdev/trigger.dev/pull/3061))\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:32.000Z","fetchedAt":"2026-04-11T14:01:41.445Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/sdk%404.4.1","media":[],"coverageCount":0},{"id":"rel_fd1ktYrsnk3onNWdC-be3","version":"@trigger.dev/rsc@4.4.1","type":"feature","title":"@trigger.dev/rsc@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:29.000Z","fetchedAt":"2026-04-11T14:01:41.484Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/rsc%404.4.1","media":[],"coverageCount":0},{"id":"rel_UM2DUx7P5TIL6nluXqD3e","version":"@trigger.dev/build@4.4.1","type":"feature","title":"@trigger.dev/build@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:26.000Z","fetchedAt":"2026-04-11T14:01:41.533Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/build%404.4.1","media":[],"coverageCount":0},{"id":"rel_oFcm-ehwrLsoNVkELd2JL","version":"trigger.dev@4.4.1","type":"feature","title":"trigger.dev@4.4.1","summary":"### Patch Changes\n\n-   Add OTEL metrics pipeline for task workers. Workers collect process CPU/memory, Node.js runtime metrics (event loop utilization...","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Add OTEL metrics pipeline for task workers. Workers collect process CPU/memory, Node.js runtime metrics (event loop utilization, event loop delay, heap usage), and user-defined custom metrics via `otel.metrics.getMeter()`. Metrics are exported to ClickHouse with 10-second aggregation buckets and 1m/5m rollups, and are queryable through the dashboard query engine with typed attribute columns, `prettyFormat()` for human-readable values, and AI query support. ([#3061](https://github.com/triggerdotdev/trigger.dev/pull/3061))\n-   Updated dependencies:\n    -   `@trigger.dev/build@4.4.1`\n    -   `@trigger.dev/core@4.4.1`\n    -   `@trigger.dev/schema-to-json@4.4.1`\n","publishedAt":"2026-02-20T16:45:23.000Z","fetchedAt":"2026-04-11T14:01:41.445Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/trigger.dev%404.4.1","media":[],"coverageCount":0},{"id":"rel__d1hx6fvMB5JoJZ_PWYH9","version":"@trigger.dev/schema-to-json@4.4.1","type":"feature","title":"@trigger.dev/schema-to-json@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:20.000Z","fetchedAt":"2026-04-11T14:01:41.445Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/schema-to-json%404.4.1","media":[],"coverageCount":0},{"id":"rel_v_N0-AVWZf7au_DojLEz8","version":"@trigger.dev/react-hooks@4.4.1","type":"feature","title":"@trigger.dev/react-hooks@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:17.000Z","fetchedAt":"2026-04-11T14:01:41.484Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/react-hooks%404.4.1","media":[],"coverageCount":0},{"id":"rel_1prxCybvTxjS9wakLHnqx","version":"@trigger.dev/redis-worker@4.4.1","type":"feature","title":"@trigger.dev/redis-worker@4.4.1","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.1`\n","publishedAt":"2026-02-20T16:45:14.000Z","fetchedAt":"2026-04-11T14:01:41.484Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/redis-worker%404.4.1","media":[],"coverageCount":0},{"id":"rel_USvEYv7UchbyUqWZAXDk-","version":"@trigger.dev/sdk@4.4.0","type":"feature","title":"@trigger.dev/sdk@4.4.0","summary":"### Minor Changes\n\n-   Added `query.execute()` which lets you query your Trigger.dev data using TRQL (Trigger Query Language) and returns results as t...","titleGenerated":null,"titleShort":null,"content":"### Minor Changes\n\n-   Added `query.execute()` which lets you query your Trigger.dev data using TRQL (Trigger Query Language) and returns results as typed JSON rows or CSV. It supports configurable scope (environment, project, or organization), time filtering via `period` or `from`/`to` ranges, and a `format` option for JSON or CSV output. ([#3060](https://github.com/triggerdotdev/trigger.dev/pull/3060))\n\n    ```typescript\n    import { query } from \"@trigger.dev/sdk\";\n    import type { QueryTable } from \"@trigger.dev/sdk\";\n\n    // Basic untyped query\n    const result = await query.execute(\"SELECT run_id, status FROM runs LIMIT 10\");\n\n    // Type-safe query using QueryTable to pick specific columns\n    const typedResult = await query.execute<QueryTable<\"runs\", \"run_id\" | \"status\" | \"triggered_at\">>(\n      \"SELECT run_id, status, triggered_at FROM runs LIMIT 10\"\n    );\n    typedResult.results.forEach((row) => {\n      console.log(row.run_id, row.status); // Fully typed\n    });\n\n    // Aggregation query with inline types\n    const stats = await query.execute<{ status: string; count: number }>(\n      \"SELECT status, COUNT(*) as count FROM runs GROUP BY status\",\n      { scope: \"project\", period: \"30d\" }\n    );\n\n    // CSV export\n    const csv = await query.execute(\"SELECT run_id, status FROM runs\", {\n      format: \"csv\",\n      period: \"7d\",\n    });\n    console.log(csv.results); // Raw CSV string\n    ```\n\n### Patch Changes\n\n-   Add `maxDelay` option to debounce feature. This allows setting a maximum time limit for how long a debounced run can be delayed, ensuring execution happens within a specified window even with continuous triggers. ([#2984](https://github.com/triggerdotdev/trigger.dev/pull/2984))\n\n    ```typescript\n    await myTask.trigger(payload, {\n      debounce: {\n        key: \"my-key\",\n        delay: \"5s\",\n        maxDelay: \"30m\", // Execute within 30 minutes regardless of continuous triggers\n      },\n    });\n    ```\n\n-   Aligned the SDK's `getRunIdForOptions` logic with the Core package to handle semantic targets (`root`, `parent`) in root tasks. ([#2874](https://github.com/triggerdotdev/trigger.dev/pull/2874))\n\n-   Export `AnyOnStartAttemptHookFunction` type to allow defining `onStartAttempt` hooks for individual tasks. ([#2966](https://github.com/triggerdotdev/trigger.dev/pull/2966))\n\n-   Fixed a minor issue in the deployment command on distinguishing between local builds for the cloud vs local builds for self-hosting setups. ([#3070](https://github.com/triggerdotdev/trigger.dev/pull/3070))\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","publishedAt":"2026-02-19T13:44:21.000Z","fetchedAt":"2026-04-11T14:01:41.533Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/sdk%404.4.0","media":[],"coverageCount":0},{"id":"rel_-WDNcUhmFbwoitv3KRoD2","version":"@trigger.dev/redis-worker@4.4.0","type":"feature","title":"@trigger.dev/redis-worker@4.4.0","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","publishedAt":"2026-02-19T13:44:18.000Z","fetchedAt":"2026-04-11T14:01:41.528Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/redis-worker%404.4.0","media":[],"coverageCount":0},{"id":"rel_CWU-H2HAbcjycByAveOGR","version":"@trigger.dev/python@4.4.0","type":"feature","title":"@trigger.dev/python@4.4.0","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n    -   `@trigger.dev/sdk@4.4.0`\n    -   `@trigger.dev/build@4.4.0`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n    -   `@trigger.dev/sdk@4.4.0`\n    -   `@trigger.dev/build@4.4.0`\n","publishedAt":"2026-02-19T13:44:15.000Z","fetchedAt":"2026-04-11T14:01:41.528Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/python%404.4.0","media":[],"coverageCount":0},{"id":"rel_R5fQy1dc1c7Wza9OC2XQ2","version":"@trigger.dev/schema-to-json@4.4.0","type":"feature","title":"@trigger.dev/schema-to-json@4.4.0","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","publishedAt":"2026-02-19T13:44:12.000Z","fetchedAt":"2026-04-11T14:01:41.533Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/schema-to-json%404.4.0","media":[],"coverageCount":0},{"id":"rel_LeqBF6U1ixeFDzce9-H-2","version":"trigger.dev@4.4.0","type":"feature","title":"trigger.dev@4.4.0","summary":"### Patch Changes\n\n-   Fix runner getting stuck indefinitely when `execute()` is called on a dead child process. ([#2978](https://github.com/triggerdo...","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Fix runner getting stuck indefinitely when `execute()` is called on a dead child process. ([#2978](https://github.com/triggerdotdev/trigger.dev/pull/2978))\n-   Add optional `timeoutInSeconds` parameter to the `wait_for_run_to_complete` MCP tool. Defaults to 60 seconds. If the run doesn't complete within the timeout, the current state of the run is returned instead of waiting indefinitely. ([#3035](https://github.com/triggerdotdev/trigger.dev/pull/3035))\n-   Fixed a minor issue in the deployment command on distinguishing between local builds for the cloud vs local builds for self-hosting setups. ([#3070](https://github.com/triggerdotdev/trigger.dev/pull/3070))\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n    -   `@trigger.dev/build@4.4.0`\n    -   `@trigger.dev/schema-to-json@4.4.0`\n","publishedAt":"2026-02-19T13:44:09.000Z","fetchedAt":"2026-04-11T14:01:41.533Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/trigger.dev%404.4.0","media":[],"coverageCount":0},{"id":"rel_O-XCFRk8ksu9n3tKTHhEH","version":"@trigger.dev/build@4.4.0","type":"feature","title":"@trigger.dev/build@4.4.0","summary":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","titleGenerated":null,"titleShort":null,"content":"### Patch Changes\n\n-   Updated dependencies:\n    -   `@trigger.dev/core@4.4.0`\n","publishedAt":"2026-02-19T13:44:06.000Z","fetchedAt":"2026-04-11T14:01:41.528Z","url":"https://github.com/triggerdotdev/trigger.dev/releases/tag/%40trigger.dev/build%404.4.0","media":[],"coverageCount":0}],"pagination":{"nextCursor":"2026-02-19T13:44:06.000Z|2026-04-11T14:01:41.528Z|rel_O-XCFRk8ksu9n3tKTHhEH","limit":20},"summaries":{"rolling":{"windowDays":90,"summary":"Trigger.dev shipped observability and runtime communication primitives across three minor releases. The 4.4.0 wave added a SQL query engine (`query.execute()` with TRQL support for typed data access) and OTEL metrics collection from task workers (CPU, memory, event loop metrics, and custom metrics exported to ClickHouse with dashboard queryability). 4.4.2 introduced bidirectional input streams for tasks—developers define typed streams with `streams.input<T>()`, then suspend execution with `.wait()`, listen with `.once()`, or subscribe with `.on()`, while backends and React frontends send data via `.send()` and `useInputStreamSend`. 4.4.3 added Supabase environment variable syncing to pull database connection strings directly into Trigger.dev's env management, an errors page for self-hosted and cloud deployments, and fixed dev run cleanup by auto-canceling in-flight runs when the CLI exits.","releaseCount":29,"generatedAt":"2026-04-11T14:01:47.237Z"},"monthly":[{"year":2026,"month":3,"summary":"Focused on real-time task communication and developer experience. Added input streams for bidirectional messaging with running tasks, letting you suspend execution with `.wait()`, consume messages with `.once()` or `.on()`, and send data from backends or React frontends. Also shipped automatic cleanup of dev runs when the CLI exits and a new Errors page for tracking issues across self-hosted and Cloud deployments.","releaseCount":2,"generatedAt":"2026-04-11T14:01:48.974Z"}]}}