R2-D2

R2-D2

An MCP server for Star Wars Unlimited that provides card search, deck building, format validation, meta analysis, and two-player game simulation through Claude or any MCP-compatible client.

Category
Visit Server

README

R2-D2

A Star Wars Unlimited MCP server built with FastMCP. Search cards, build decks, validate formats, analyze the meta, and simulate two-player games — all through Claude Code, Claude Desktop, or any MCP-compatible client.

Card data comes from the live SWU DB API first and automatically falls back to the bundled local catalog when the API is unavailable.

Capabilities

Card Database

Tool What it does
swu_search_cards Natural text search with typed structured filters (aspect/type/arena/rarity/set as enums; cost/power/hp as {op, value} comparators). Returns a typed SearchResult.
swu_lookup_card Exact lookup by name or set/number. Returns a typed CardDetail.
swu_random_card Random card from a filtered pool. Returns a typed CardSummary.
swu_get_image Front or back art URL for any card.

Typed search filters (v0.3.0)

swu_search_cards, swu_lookup_card, and swu_random_card now return Pydantic models instead of opaque dicts. FastMCP serializes them as both content (human-readable text) and structuredContent (typed JSON) — agents can read .cards[0].cost directly without parsing string keys.

Filters are typed too. Aspect/type/arena/rarity/set are Literal[...] enums, so the agent sees the valid options in the tool schema and typos like aspect="Cunninng" are rejected before the API call. Numeric stats use a structured {op, value} instead of magic strings:

swu_search_cards(
    query="Vader",
    filters={"aspect": "Villainy", "type": "Leader",
             "cost": {"op": ">=", "value": 5}},
)

Deck and game tools still return dict — that refactor is staged for a follow-up.

Deck Building

Tool What it does
swu_upload_deck Parse a decklist into a stateful session
swu_validate_deck Check legality for Premier or Twin Suns (leaders, base, copy limits, aspect penalties)
swu_analyze_deck Resource curve, aspect breakdown, synergy score, role analysis
swu_suggest_cards Targeted card suggestions for a stated goal or matchup
swu_generate_deck First-pass brew from a theme, leaders, and format
swu_export_deck Export a session to a shareable decklist

Game Simulation

Tool What it does
swu_start_game Two-player setup with deck loading
swu_get_game_state Current board state, hand, resources, damage
swu_get_legal_actions Available actions with targeting options
swu_take_game_action Execute an action (play, attack, pass, etc.)
swu_take_ai_turn Let the AI pilot take a full turn
swu_draw_card / swu_view_hand / swu_view_board Card management
swu_play_card / swu_move_card / swu_defeat_card / swu_set_card_state Direct board manipulation
swu_mulligan / swu_resource_phase / swu_sideboard Phase management

Quick Start

uv sync
uv run python scripts/start_stdio.py

Claude Code / Claude Desktop Config

Add to ~/.mcp.json:

{
  "mcpServers": {
    "r2-d2": {
      "command": "uv",
      "args": [
        "--directory",
        "/path/to/r2-d2",
        "run",
        "python",
        "scripts/start_stdio.py"
      ]
    }
  }
}

Offline Catalog

A bundled card catalog (data/catalog/cards.json) is auto-discovered at startup. The server uses it as a fallback whenever the live API is unavailable — no configuration needed.

To rebuild the catalog from the latest API data:

uv run python scripts/build_catalog.py

Environment Variables

All optional — sensible defaults are built in.

Variable Default Purpose
SWU_MCP_API_BASE_URL https://api.swu-db.com Live card data API
SWU_MCP_CARD_CATALOG_PATH Auto-discovered from data/catalog/ Local JSON fallback
SWU_MCP_CACHE_DIR .swu-mcp-cache Per-card response cache
SWU_MCP_DEFAULT_LIMIT 10 Default search result limit

Format Support

Premier — 1 leader, 1 base, 50+ main deck (3x copy limit), 10-card sideboard, off-aspect penalty reporting.

Twin Suns — 2 leaders sharing Heroism or Villainy, 1 base, 80+ singleton main deck, no sideboard.

Game Engine

The simulator supports two-player games with:

  • Resource turns, unit/event play, leader deployment, combat, base damage
  • Stack/priority loop with targeting and responses
  • Ambush, Sentinel, Saboteur, Overwhelm, Shielded, Restore, Raid, Hidden
  • When Played / On Attack / When Defeated trigger patterns
  • Upgrade attachment with static buffs and keyword grants
  • Basic AI pilot for sparring

This is a pragmatic rules engine for playtesting and AI sparring, not a comprehensive rules simulator. Edge cases around complex upgrade conditions, nested optional triggers, and deep timing interactions are not fully covered.

Example Prompts

  • "Search for all Cunning leaders from Legends of the Force"
  • "Generate a Twin Suns deck with Cad Bane and Jabba the Hutt"
  • "Upload this decklist, analyze it, and suggest swaps for an aggro-heavy meta"
  • "Start a game with my Qui-Gon deck against a generated Villainy aggro deck"
  • "Take my action to play Boba Fett, then let the AI respond"

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured