惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
人人都是产品经理
人人都是产品经理
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
V2EX
博客园 - 三生石上(FineUI控件)
Martin Fowler
Martin Fowler
WordPress大学
WordPress大学
D
Docker
S
SegmentFault 最新的问题
博客园 - 聂微东
美团技术团队
Apple Machine Learning Research
Apple Machine Learning Research
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Last Week in AI
Last Week in AI
M
MIT News - Artificial intelligence
F
Fortinet All Blogs
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
GbyAI
GbyAI
L
LangChain Blog
Vercel News
Vercel News
博客园 - 叶小钗
MongoDB | Blog
MongoDB | Blog
Stack Overflow Blog
Stack Overflow Blog
H
Help Net Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
The Cloudflare Blog
Engineering at Meta
Engineering at Meta
T
Threat Research - Cisco Blogs
T
Threatpost
Scott Helme
Scott Helme
T
Tailwind CSS Blog
Latest news
Latest news
Stack Overflow Blog
Stack Overflow Blog
Blog — PlanetScale
Blog — PlanetScale
The Register - Security
The Register - Security
罗磊的独立博客
P
Proofpoint News Feed
腾讯CDC
S
Schneier on Security
雷峰网
雷峰网
A
About on SuperTechFans
T
Tenable Blog
F
Full Disclosure
Cyberwarzone
Cyberwarzone
博客园_首页
有赞技术团队
有赞技术团队
K
Kaspersky official blog

Workflow SDK Documentation

Upgrading Workflows Versioning Serializable AbortController and AbortSignal Internal How Cancellation Works Cancellation abort-signal-timeout-in-workflow Eager Processing of Steps & Incremental Event Replay TanStack Start Workflow Composition Timeouts Sequential & Parallel Execution Agent Cancellation Distributed Abort Controller Child Workflows Distributed Abort Controller Python Resumable Streams Publishing Libraries start-invalid-workflow-function Vercel World Postgres World Local World Migration Guides Migrating from AWS Step Functions Migrating from Inngest Migrating from Temporal Migrating from trigger.dev Cookbook API Reference Changelog Resilient run start Building a World Deploying Astro Express Fastify Hono Getting Started NestJS Next.js Nitro Nuxt SvelteKit Vite Common Patterns Errors & Retrying Hooks & Webhooks Idempotency Foundations Serialization Starting Workflows Streaming Workflows and Steps corrupted-event-log fetch-in-workflow hook-conflict Errors node-js-module-in-workflow serialization-failed step-not-registered timeout-in-workflow webhook-invalid-respond-with-value webhook-response-not-sent workflow-not-registered How the Directives Work Encryption Event Sourcing Framework Integrations Understanding Directives Observability Testing Server-Based Testing @workflow/vitest DurableAgent @workflow/ai WorkflowChatTransport createHook createWebhook Fan-Out & Parallel Delivery WORKFLOW_DESERIALIZE WORKFLOW_SERIALIZE Custom Serialization Durable Objects Isomorphic Packages Serializable Steps Durable Agent Human-in-the-Loop Stop Workflow Tool Orchestration Tool Streaming Batching & Parallel Processing Child Workflows Conditional Routing Queue Sandbox World SDK Observability Utilities Chat SDK Storage
runtime-decryption-failed
2026-05-30 · via Workflow SDK Documentation

The SDK's built-in AES-GCM encryption layer failed to encrypt or decrypt a workflow payload.

This error occurs when the Workflow SDK's built-in AES-GCM encryption layer fails while encrypting or decrypting a workflow payload. The SDK encrypts step inputs, step outputs, hook payloads, and other event-log data with a per-run AES-256 key whenever encryption is configured for the deployment.

This is an internal SDK failure — your workflow code never invokes the encryption primitives directly. When this surfaces, it means the ciphertext, nonce, or auth tag the SDK tried to verify is not the bytes that were originally produced. The run is failed with the RUNTIME_ERROR classification.

AES-256-GCM decryption failed: The operation failed for an operation-specific reason

The underlying cause is a native Web Crypto OperationError — most commonly raised by AESCipherJob.onDone in Node's node:internal/crypto/util module when the GCM authentication tag does not verify.

The thrown RuntimeDecryptionError carries a small context object with diagnostic fields to help triangulate the source:

  • operation'encrypt' or 'decrypt'
  • byteLength — total byte length of the payload at the failure site
  • formatPrefix — the first 4 bytes of the input ('encr' for a well-formed encrypted envelope, otherwise a hex dump)

Common causes, in rough order of likelihood:

  1. Ciphertext mutation or truncation in transit. The encrypted payload reached the SDK with bytes that differ from what storage holds. Possible sources include a truncated HTTP response from a workflow-server ref endpoint, an edge-cache miss returning a partial 200, or a proxy drop during streaming. A truncated body whose first 4 bytes happen to still spell encr produces the exact "auth tag mismatch" symptom.
  2. Key resolution mismatch. The key used to decrypt is not the key that was used to encrypt — e.g. the run's deploymentId was not threaded through key resolution and the SDK fell back to the wrong deployment's key material.
  3. Malformed encrypted envelope. The envelope is too short to contain the GCM nonce (12 bytes) and auth tag (16 bytes), so decryption is rejected before it begins.

This error indicates an SDK or infrastructure problem — not a bug in your workflow code. Your workflow code does not need to change.

1. Upgrade to the latest workflow package

The underlying issue may have already been identified and fixed:

npm install workflow@latest

2. Retry the failed run

Since this is a fatal error, the run is automatically marked as failed. You can re-run it using the Re-run button in the Workflow Dashboard.

3. Report the issue

If the error persists after upgrading, please open an issue on GitHub so we can investigate. Include:

  • The version of the workflow package you are using
  • The run ID(s) of the affected workflow run(s)
  • The full error message, including the context fields (operation, byteLength, formatPrefix)
  • Whether the affected workflows make heavy use of large step inputs/outputs (which may indicate the failure is on the lazy-loaded ref read path)

Like other WorkflowRuntimeError subclasses, a runtime decryption failure is not catchable inside your workflow function. The runtime cannot safely continue executing user code when an event-log payload can't be verified, so the entire run fails immediately and is marked as failed.

To handle this programmatically from outside the workflow, check the run status:

import { getRun } from "workflow/api";

const run = getRun("wrun_abc123");
const status = await run.status;
if (status === "failed") {
  console.error("Run failed");
}