claude-code - 💡(How to fix) Fix [BUG] 400 "thinking/redacted_thinking blocks cannot be modified" bricks session after large multi-tool turns

Official PRs (…)
ON THIS PAGE

Recommended Tools

×6

Utilities matched from this issue’s tags and category — try them while you read without losing context.

GitHub issue graph ai analysis

Paste a GitHub issue URL. We fetch that issue, discover linked issues from bodies/comments/timeline, collect linked pull requests, and produce a structured English report.

The report is written in English Markdown for sharing and archival.

Helpful · Quick feedback

Loading…

Error Message

API Error: 400 messages.5.content.33: thinking or redacted_thinking blocks in the latest assistant message cannot be modified. These blocks must remain as they were in the original response. API Error: 400 messages.3.content.13: thinking or redacted_thinking blocks in the latest assistant message cannot be modified.

Fix Action

Fix / Workaround

The malformed assistant message stays in conversation history, so every following request re-throws the same 400. The only workaround is starting a new session, which loses in-context state. This has recurred across multiple sessions running the same deploy-and-verify workflow. The offending block indices observed were content.33 and content.13 (i.e. large assistant messages).

Code Example

API Error: 400 messages.5.content.33: thinking or redacted_thinking blocks in the latest assistant message cannot be modified. These blocks must remain as they were in the original response.
API Error: 400 messages.3.content.13: thinking or redacted_thinking blocks in the latest assistant message cannot be modified.
RAW_BUFFERClick to expand / collapse

Preflight Checklist

  • I have searched existing issues and this hasn't been reported yet
  • This is a single bug report (please file separate reports for different bugs)
  • I am using the latest version of Claude Code

What's Wrong?

After an assistant turn with many content blocks (interleaved thinking + many tool_use blocks — e.g. 10+ Bash calls and/or a sub-agent spawn in one turn), the NEXT request fails with a 400 and the session becomes unrecoverable.

The malformed assistant message stays in conversation history, so every following request re-throws the same 400. The only workaround is starting a new session, which loses in-context state. This has recurred across multiple sessions running the same deploy-and-verify workflow. The offending block indices observed were content.33 and content.13 (i.e. large assistant messages).

What Should Happen?

Claude Code should resend the prior thinking / redacted_thinking blocks verbatim (or safely drop and regenerate them) so the follow-up request validates and the session continues instead of getting permanently stuck. The API's 400 looks correct — it is rejecting modified signed thinking blocks — so the fix appears to be on the client side (Claude Code's message handling on large turns).

Error Messages/Logs

API Error: 400 messages.5.content.33: thinking or redacted_thinking blocks in the latest assistant message cannot be modified. These blocks must remain as they were in the original response.
API Error: 400 messages.3.content.13: thinking or redacted_thinking blocks in the latest assistant message cannot be modified.

Steps to Reproduce

  1. Use Claude Code with extended thinking enabled (model: Opus 4.8, 1M context).
  2. In a single turn, trigger a heavy batch of tool calls — e.g. 10+ Bash commands and/or spawn a sub-agent — so the assistant message contains many interleaved thinking + tool_use blocks.
  3. Send the next message to continue the conversation.
  4. The request fails with: 400 ... thinking or redacted_thinking blocks ... cannot be modified.
  5. Every subsequent message re-throws the same 400 — the session is stuck until a new session is started.

Note: strongly correlated with large turns. Likely cause is client-side message management (context compaction, large tool-result truncation, or block reordering) mutating the signed thinking blocks before resend.

Claude Model

Opus

Is this a regression?

I don't know

Last Working Version

No response

Claude Code Version

2.1.158 (Claude Code)

Platform

Anthropic API

Operating System

macOS

Terminal/Shell

Terminal.app (macOS)

Additional Information

No response

Vote matrix · Quick signals

Works
Did the solution work? Tap to confirm.
Easy Fix
Was it a quick fix?
Time Saver
Did it save you time?
Blocking
Was it severely blocking?
Common Issue
Are others likely hitting this too?
Flaky / Intermittent
Is it intermittent?
Verified / Reproducible
Can you reproduce it reliably?
Loading…

Still need to ship something?

×6

Another batch ranked right after the header list — different links, same matching logic.

Back to top recommendations

TRENDING

claude-code - 💡(How to fix) Fix [BUG] 400 "thinking/redacted_thinking blocks cannot be modified" bricks session after large multi-tool turns