wg21-wiki-mcp

wg21-wiki-mcp

A local MCP server that gives an LLM agent read access to the WG21 (ISO C++) committee wiki as a verifiable source of truth, requiring authentication and providing exact wikitext with provenance.

Category
Visit Server

README

wg21-wiki-mcp

A local Model Context Protocol (stdio) server that gives an LLM agent read access to the WG21 (ISO C++) committee wiki at wiki.isocpp.org as a verifiable source of truth.

The committee wiki requires a login even to read, and its agendas, straw polls, documents, and subgroup pages are otherwise hard to reach from an agent. This server authenticates with your credentials, fetches pages live over the MediaWiki API, and caches them - returning the exact wiki text with a clickable URL and revision id so every answer can be verified.

Access requires WG21 membership. This tool stores nothing confidential in its source and never logs page content. See SECURITY.md.

What it does

  • Verifiable content. Tools return wikitext byte-for-byte with provenance (canonical URL, permanent oldid URL, revid, last-edit time). Nothing is summarized or reformatted by the server.
  • Authentication, no browser. Prefers a MediaWiki bot password; falls back to your normal account via headless SSO (SimpleSAMLphp) if no bot password is set. The working path is pinned and reused; sessions that drop are transparently re-established.
  • Shared, meeting-aware cache. A cross-process SQLite cache in ~/.isocpp.wiki/ is shared by all your local agents. Pages are cached for a week normally and re-checked hourly during the three-times-a-year meetings (detected from the public meetings calendar).
  • Token-lean tools with opaque-cursor pagination and UTF-8-safe chunking of long pages.

Install

This package is not published to PyPI yet; install it from the GitHub source. Pin a released version (recommended for reproducibility) with @v0.1.0, or track the latest release with @master (the release branch). The simplest option is uv, which can run it without a manual install:

# pinned release (reproducible)
uvx --from git+https://github.com/cppalliance/wg21-wiki-mcp.git@v0.1.0 wg21-wiki-mcp

# or always the latest release (master tracks releases; --refresh bypasses uv's cache)
uvx --refresh --from git+https://github.com/cppalliance/wg21-wiki-mcp.git@master wg21-wiki-mcp

Or install from git with pip/pipx:

pipx install "git+https://github.com/cppalliance/wg21-wiki-mcp.git@v0.1.0"
# or, into a venv:
pip install "git+https://github.com/cppalliance/wg21-wiki-mcp.git@v0.1.0"

Or from a local clone (for development):

git clone https://github.com/cppalliance/wg21-wiki-mcp
cd wg21-wiki-mcp
pip install -e ".[dev]"

Requires Python 3.10+. Works on Windows, macOS, and Linux.

Configure

The wiki base URL is fixed (https://wiki.isocpp.org), so only credentials are needed. With an MCP host, pass them in the server's launch env block. Since the package is not on PyPI, run it from GitHub with uvx:

{
  "mcpServers": {
    "wg21-wiki": {
      "command": "uvx",
      "args": [
        "--from",
        "git+https://github.com/cppalliance/wg21-wiki-mcp.git@v0.1.0",
        "wg21-wiki-mcp"
      ],
      "env": {
        "WIKI_BOT_USERNAME": "YourAccount@yourbot",
        "WIKI_BOT_PASSWORD": "the-bot-password"
      }
    }
  }
}

To always run the newest release instead of a pinned one, replace @v0.1.0 with @master and add "--refresh" as the first entry in args (so uv re-resolves the branch rather than reusing its cache). Pinning a tag is recommended for a source-of-truth tool so behavior is reproducible.

If you installed the console script (via pipx/pip), use "command": "wg21-wiki-mcp" with no args instead. To use your normal account instead of a bot password, supply WIKI_USER_USERNAME / WIKI_USER_PASSWORD (requires that MFA is not enabled). If both are present, the bot password is used by default. See .env.example for optional tuning (cache directory, TTLs, meeting overrides). A bot password is created at Special:BotPasswords with the Read grant and is the recommended, revocable option.

Tools

Tool Purpose
search_wiki Full-text search; returns titles, API snippets (non-verbatim), and URLs.
get_page Verbatim wikitext for a page or section, with provenance; chunked if large.
list_pages Enumerate page titles in a namespace.
list_namespaces List content namespaces and their numeric ids.
list_meetings List discovered meetings (newest first); flags the active one.
get_meeting_overview A meeting's landing page plus its subpage index.
get_meeting_sessions Raw materials (agenda time slots + relevant pages) to compose a schedule.
get_recent_changes Recent edits/new pages, optionally by namespace or since a time.
wiki_status Auth path, meeting-aware TTL state, cache stats (no wiki content).

Quickstart (programmatic)

from wg21_wiki_mcp.config import Config
from wg21_wiki_mcp.context import ServerContext
from wg21_wiki_mcp import tools

ctx = ServerContext.create(Config.from_env())

# Search, then read a page verbatim with a verifiable URL.
hits = tools.search_wiki(ctx, "some topic", limit=5)
page = tools.get_page(ctx, hits.hits[0].title)
print(page.provenance.url, page.provenance.revid)
print(page.content)  # exact wikitext

Dependencies

Documentation

  • ARCHITECTURE.md - design, data flow, parse-vs-offload policy, what may break, future work.
  • CONTRIBUTING.md - dev setup, tests, confidentiality rules, where to start reading.
  • SECURITY.md - credential handling and confidentiality.

License

Boost Software License 1.0 - see LICENSE.

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