Add support for thinking blocks and redacted thinking blocks in Anthropic v1/messages API#15501
Merged
Sameerlite merged 1 commit intolitellm_staging_octfrom Oct 13, 2025
Conversation
|
The latest updates on your projects. Learn more about Vercel for GitHub.
|
Closed
4 tasks
1 task
2 tasks
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Title
Add support for thinking blocks and redacted thinking blocks in Anthropic v1/messages API
Relevant issues
Fixes LIT-1260
Pre-Submission checklist
Please complete all items before asking a LiteLLM maintainer to review your PR
tests/litellm/directory, Adding at least 1 test is a hard requirement - see detailsmake test-unitType
🆕 New Feature
Changes
This PR adds support for both regular thinking blocks and redacted thinking blocks in the Anthropic v1/messages API experimental pass-through adapter.
What was added:
Type Definitions (
litellm/types/llms/anthropic.py):AnthropicResponseContentBlockThinkingfor regular thinking blocksAnthropicResponseContentBlockRedactedThinkingfor redacted thinking blocksTransformation Logic (
litellm/llms/anthropic/experimental_pass_through/adapters/transformation.py):translate_anthropic_messages_to_openai()to detect and convert thinking blocks from Anthropic's content array format to OpenAI'sthinking_blocksfieldtranslate_openai_response_to_anthropic()to convert thinking blocks back to Anthropic's content array formatthinkingandredacted_thinkingcontent typesChatCompletionThinkingBlockandChatCompletionRedactedThinkingBlockTest Coverage (
tests/test_litellm/llms/anthropic/experimental_pass_through/adapters/test_anthropic_experimental_pass_through_adapters_transformation.py):test_translate_anthropic_messages_with_thinking_blocks_to_openai()for regular thinking blockstest_translate_anthropic_messages_with_redacted_thinking_blocks_to_openai()for redacted thinking blocksHow it works:
Anthropic → OpenAI:
OpenAI → Anthropic:
thinking_blocksback to Anthropic's content array formatthinkingandredacted_thinkingtypesthinking/data,signature, etc.)This ensures that the v1/messages API properly retains thinking blocks as required in the OpenAI format while maintaining compatibility with Anthropic's native format.
Before:

After:
