MCP Bridge for Claude Code with Multi-Model Support. Install globally: claude mcp add --scope user stravinsky -- uvx stravinsky. Add to CLAUDE.md: See https://pypi.org/project/stravinsky/
Project description
Stravinsky
The Avant-Garde MCP Bridge for Claude Code
Movement โข Rhythm โข Precision
What is Stravinsky?
Multi-model AI orchestration with OAuth authentication for Claude Code.
Features
- ๐ OAuth Authentication - Secure browser-based auth for Google (Gemini) and OpenAI (ChatGPT)
- ๐ค Multi-Model Support - Seamlessly invoke Gemini and GPT models from Claude
- ๐ฏ Native Subagent Orchestration - Auto-delegating orchestrator with parallel execution (zero CLI overhead)
- ๐ ๏ธ 31 MCP Tools - Model invocation, code search, LSP integrations, session management, and more
- ๐ง 7 Specialized Native Agents - Stravinsky (orchestrator), Delphi (GPT-5.2 advisor), Dewey (documentation), Explore (code search), Frontend (Gemini 3 Pro High UI/UX), Code Reviewer, Debugger
- ๐ Hook-Based Delegation - PreToolUse hooks enforce delegation patterns with hard boundaries (exit code 2)
- ๐ LSP Integration - Full Language Server Protocol support for Python (jedi)
- ๐ AST-Aware Search - Structural code search and refactoring with ast-grep
- โก Cost-Optimized Routing - Free/cheap agents (explore, dewey) always async, expensive (delphi) only when needed
Quick Start
Installation
From PyPI (Recommended):
# One-shot with uvx - no installation needed!
claude mcp add stravinsky -- uvx stravinsky
# Or install globally first:
uv tool install stravinsky
claude mcp add stravinsky -- stravinsky
From Source (for development):
uv tool install --editable /path/to/stravinsky
claude mcp add stravinsky -- stravinsky
Authentication
# Login to Google (Gemini)
stravinsky-auth login gemini
# Login to OpenAI (ChatGPT Plus/Pro required)
stravinsky-auth login openai
# Check status
stravinsky-auth status
# Logout
stravinsky-auth logout gemini
Slash Commands
Slash commands are discovered from:
- Project-local:
.claude/commands/**/*.md(recursive) - User-global:
~/.claude/commands/**/*.md(recursive)
Commands can be organized in subdirectories (e.g., .claude/commands/strav/stravinsky.md).
Native Subagent Architecture
Stravinsky uses native Claude Code subagents (.claude/agents/) with automatic delegation:
How It Works
- Auto-Delegation: Claude Code automatically delegates complex tasks to the Stravinsky orchestrator
- Hook-Based Control: PreToolUse hooks intercept direct tool calls and enforce delegation patterns
- Parallel Execution: Task tool enables true parallel execution of specialist agents
- Multi-Model Routing: Specialists use invoke_gemini/openai MCP tools for multi-model access
Agent Types
| Agent | Model | Cost | Use For |
|---|---|---|---|
| stravinsky | Claude Sonnet 4.5 (32k thinking) | Moderate | Auto-delegating orchestrator (primary) |
| explore | Gemini 3 Flash (via MCP) | Free | Code search, always async |
| dewey | Gemini 3 Flash + WebSearch | Cheap | Documentation research, always async |
| code-reviewer | Claude Sonnet (native) | Cheap | Quality analysis, always async |
| debugger | Claude Sonnet (native) | Medium | Root cause (after 2+ failures) |
| frontend | Gemini 3 Pro High (via MCP) | Medium | ALL visual changes (blocking) |
| delphi | GPT-5.2 Medium (via MCP) | Expensive | Architecture (after 3+ failures) |
Delegation Rules (oh-my-opencode Pattern)
- Always Async: explore, dewey, code-reviewer (free/cheap)
- Blocking: debugger (2+ failures), frontend (ALL visual), delphi (3+ failures or architecture)
- Never Work Alone: Orchestrator blocks Read/Grep/Bash via PreToolUse hooks
ULTRATHINK / ULTRAWORK
- ULTRATHINK: Engage exhaustive deep reasoning with extended thinking budget (32k tokens)
- ULTRAWORK: Maximum parallel execution - spawn all async agents immediately
## Tools (31)
| Category | Tools |
| ---------------- | ---------------------------------------------------------------------------------- |
| **Model Invoke** | `invoke_gemini`, `invoke_openai`, `get_system_health` |
| **Environment** | `get_project_context`, `task_spawn`, `task_status`, `task_list` |
| **Agents** | `agent_spawn`, `agent_output`, `agent_cancel`, `agent_list`, `agent_progress` |
| **Code Search** | `ast_grep_search`, `ast_grep_replace`, `grep_search`, `glob_files` |
| **LSP** | `lsp_diagnostics`, `lsp_hover`, `lsp_goto_definition`, `lsp_find_references`, etc. |
| **Sessions** | `session_list`, `session_read`, `session_search` |
| **Skills** | `skill_list`, `skill_get` |
## Native Subagents (7)
Configured in `.claude/agents/*.md`:
| Agent | Purpose | Location |
| ---------------- | --------------------------------------------------------------------- | -------- |
| `stravinsky` | Task orchestration with 32k extended thinking (Sonnet 4.5) | .claude/agents/stravinsky.md |
| `explore` | Codebase search and structural analysis (Gemini 3 Flash) | .claude/agents/explore.md |
| `dewey` | Documentation research and web search (Gemini 3 Flash) | .claude/agents/dewey.md |
| `code-reviewer` | Security, quality, and best practice analysis (Claude Sonnet) | .claude/agents/code-reviewer.md |
| `debugger` | Root cause analysis and fix strategies (Claude Sonnet) | .claude/agents/debugger.md |
| `frontend` | UI/UX implementation with creative generation (Gemini 3 Pro High) | .claude/agents/frontend.md |
| `delphi` | Strategic architecture advisor with 32k thinking (GPT-5.2 Medium) | .claude/agents/delphi.md |
## Development
```bash
# Install in development mode
uv pip install -e .
# Run server
stravinsky
```
## Project Structure
```
stravinsky/
โโโ .claude/ # Claude Code configuration
โ โโโ agents/ # Native subagent configurations (7 agents)
โ โ โโโ stravinsky.md # Orchestrator (auto-delegated)
โ โ โโโ explore.md # Code search specialist
โ โ โโโ dewey.md # Documentation research
โ โ โโโ code-reviewer.md # Quality analysis
โ โ โโโ debugger.md # Root cause analysis
โ โ โโโ frontend.md # UI/UX specialist
โ โ โโโ delphi.md # Strategic advisor (GPT-5.2)
โ โ โโโ HOOKS.md # Hook architecture guide
โ โโโ commands/ # Slash commands (skills)
โ โ โโโ stravinsky.md # /stravinsky orchestrator
โ โ โโโ delphi.md # /delphi strategic advisor
โ โ โโโ dewey.md # /dewey documentation research
โ โ โโโ publish.md # /publish PyPI release
โ โ โโโ review.md # /review code review
โ โ โโโ verify.md # /verify post-implementation
โ โ โโโ version.md # /version diagnostic info
โ โโโ hooks/ # Native Claude Code hooks (11 hooks)
โ โ โโโ stravinsky_mode.py # PreToolUse delegation enforcer
โ โ โโโ context.py # UserPromptSubmit context injection
โ โ โโโ todo_continuation.py # UserPromptSubmit todo continuation
โ โ โโโ truncator.py # PostToolUse output truncation
โ โ โโโ tool_messaging.py # PostToolUse user messaging
โ โ โโโ edit_recovery.py # PostToolUse edit backup
โ โ โโโ todo_delegation.py # PostToolUse parallel reminder
โ โ โโโ parallel_execution.py # PostToolUse parallel enforcement
โ โ โโโ notification_hook.py # PreToolUse agent spawn notifications
โ โ โโโ subagent_stop.py # PostToolUse agent completion handling
โ โ โโโ pre_compact.py # PreCompact context preservation
โ โโโ skills/ # Skill library (empty, skills in commands/)
โ โโโ settings.json # Hook configuration
โ โโโ HOOKS_INTEGRATION.md # Hook integration guide
โโโ mcp_bridge/ # Python MCP server
โ โโโ server.py # MCP server entry point
โ โโโ server_tools.py # Tool definitions
โ โโโ auth/ # OAuth authentication
โ โ โโโ oauth.py # Google OAuth (Gemini)
โ โ โโโ openai_oauth.py # OpenAI OAuth (ChatGPT)
โ โ โโโ token_store.py # Keyring storage
โ โ โโโ token_refresh.py # Auto-refresh tokens
โ โ โโโ cli.py # stravinsky-auth CLI
โ โโโ tools/ # MCP tool implementations
โ โ โโโ model_invoke.py # invoke_gemini, invoke_openai
โ โ โโโ agent_manager.py # agent_spawn, agent_output, etc.
โ โ โโโ code_search.py # ast_grep, grep, glob
โ โ โโโ session_manager.py # session_list, session_read, etc.
โ โ โโโ skill_loader.py # skill_list, skill_get
โ โ โโโ project_context.py # get_project_context
โ โ โโโ lsp/ # LSP tool implementations
โ โ โโโ templates.py # Project templates
โ โโโ prompts/ # Agent system prompts (legacy CLI)
โ โ โโโ stravinsky.py # Legacy orchestrator prompt
โ โ โโโ delphi.py # Legacy advisor prompt
โ โ โโโ dewey.py # Legacy research prompt
โ โ โโโ explore.py # Legacy search prompt
โ โ โโโ frontend.py # Legacy UI/UX prompt
โ โ โโโ multimodal.py # Multimodal analysis prompt
โ โโโ hooks/ # MCP internal hooks (17+ hooks)
โ โ โโโ manager.py # Hook orchestration
โ โ โโโ truncator.py # Output truncation
โ โ โโโ parallel_enforcer.py # Parallel execution
โ โ โโโ todo_enforcer.py # Todo continuation
โ โ โโโ ... # 13+ more optimization hooks
โ โโโ native_hooks/ # Native Claude Code hooks
โ โ โโโ stravinsky_mode.py # PreToolUse delegation enforcer
โ โ โโโ tool_messaging.py # PostToolUse user messaging
โ โ โโโ todo_delegation.py # TodoWrite parallel reminder
โ โ โโโ todo_continuation.py # UserPromptSubmit todo injection
โ โ โโโ context.py # UserPromptSubmit context
โ โ โโโ truncator.py # PostToolUse truncation
โ โ โโโ edit_recovery.py # PostToolUse backup
โ โโโ cli/ # CLI utilities
โ โ โโโ session_report.py # Session analysis
โ โโโ config/ # Configuration
โ โ โโโ hooks.py # Hook configuration
โ โโโ utils/ # Utility functions
โโโ .stravinsky/ # Agent execution logs (gitignored)
โโโ assets/ # Logo, images
โโโ docs/ # Additional documentation
โโโ logs/ # Application logs
โโโ tests/ # Test suite
โโโ pyproject.toml # Build configuration
โโโ uv.lock # Dependency lock
โโโ ARCHITECTURE.md # Architecture guide (oh-my-opencode comparison)
โโโ CLAUDE.md # Project instructions
โโโ INSTALL.md # Installation guide
โโโ README.md # This file
```
## Troubleshooting
### OpenAI "Port 1455 in use"
The Codex CLI uses the same port. Stop it with: `killall codex`
### OpenAI Authentication Failed
- Ensure you have a ChatGPT Plus/Pro subscription
- Tokens expire occasionally; run `stravinsky-auth login openai` to refresh
## License
MIT
---
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file stravinsky-0.2.66.tar.gz.
File metadata
- Download URL: stravinsky-0.2.66.tar.gz
- Upload date:
- Size: 1.2 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2dc6010396fe56fccfffc8dbe96f4f1d6da1fa8261fceb97ceab707a8fffb04b
|
|
| MD5 |
9950e7e1c05aab6d7d78ba595a0c7dcb
|
|
| BLAKE2b-256 |
c0276acfe296f4f671befdb1f3948e828a4b2204e5dccf6b4353807870550f9b
|
File details
Details for the file stravinsky-0.2.66-py3-none-any.whl.
File metadata
- Download URL: stravinsky-0.2.66-py3-none-any.whl
- Upload date:
- Size: 177.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e9e77aeafec48fecfec9f70b5166978549648f624a3c008dd97c7d23d0b5586
|
|
| MD5 |
51109c2f0121c6ecd544557a05ef0194
|
|
| BLAKE2b-256 |
9d6dd8553c70d5fb08ec4e9ae56ac0a5cd819aea13c48b6fe05865d7f7d42c57
|