feat(observer): support Anthropic OAuth for Claude Max/Pro subscriptions#230
Merged
kunickiaj merged 1 commit intoMar 15, 2026
Conversation
7 tasks
Owner
Author
This stack of pull requests is managed by Graphite. Learn more about stacking. |
7 tasks
There was a problem hiding this comment.
💡 Codex Review
Here are some automated review suggestions for this pull request.
Reviewed commit: a000341de1
ℹ️ About Codex in GitHub
Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you
- Open a pull request for review
- Mark a draft as ready
- Comment "@codex review".
If Codex has suggestions, it will comment; otherwise it will react with 👍.
Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".
7 tasks
Add a direct API path for Anthropic OAuth tokens from OpenCode's auth cache, mirroring the existing Codex path for OpenAI subscriptions. When OpenCode has cached Anthropic OAuth credentials (Claude Max/Pro), the observer now hits api.anthropic.com/v1/messages with Bearer auth and the oauth-2025-04-20 beta header instead of requiring an API key or claude_sidecar runtime. New module: observer_anthropic.py (headers, payload, SSE stream parser) Updated: observer.py (detection, routing, consumer call method) Closes: codemem-gz9
a000341 to
6a2f81e
Compare
Owner
Author
Merge activity
|
kunickiaj
added a commit
that referenced
this pull request
Mar 15, 2026
## Summary - Add `/api/observer-status` GET endpoint returning the resolved observer runtime state (provider, model, auth method, token presence) - Add `probe_available_credentials()` to check OpenCode OAuth cache and env vars for each provider - Add `ObserverClient.get_status()` for introspecting the active observer's resolved auth path ## Type of Change - [x] New feature ## Testing - 9 new tests in `test_observer_status.py` covering credential probing (OAuth, env vars, expired tokens, both providers) and status reporting - 768 tests pass ## Checklist - [x] Tests added/updated - [x] Lint clean - [x] No secrets or private references Closes: codemem-yny Stack: 2/3 (depends on #230)
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.

Description
Add a direct API path for Anthropic OAuth tokens from OpenCode's auth cache, mirroring the existing Codex path for OpenAI subscriptions. When OpenCode has cached Anthropic OAuth credentials (Claude Max/Pro), the observer now hits
api.anthropic.com/v1/messageswith Bearer auth and theoauth-2025-04-20beta header instead of requiring an API key orclaude_sidecarruntime.New module
observer_anthropic.pywith headers, payload builder, and SSE stream parser. URL composition usesurllib.parsefor safe query parameter handling with custom endpoints.Type of Change
Testing
pytest)Checklist
ruff checkandruff formatpass)Closes: codemem-gz9