wg21-wiki-mcp
Provides read access to the WG21 (ISO C++) committee wiki, allowing AI agents to search and retrieve pages, list namespaces, access meeting materials, and get recent changes with verifiable provenance.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@wg21-wiki-mcpget the page for P2300R5"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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
oldidURL,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.
Related MCP server: WikiMCP
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-mcpOr 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 |
| Full-text search; returns titles, API snippets (non-verbatim), and URLs. |
| Verbatim wikitext for a page or section, with provenance; chunked if large. |
| Enumerate page titles in a namespace. |
| List content namespaces and their numeric ids. |
| List discovered meetings (newest first); flags the active one. |
| A meeting's landing page plus its subpage index. |
| Raw materials (agenda time slots + relevant pages) to compose a schedule. |
| Recent edits/new pages, optionally by namespace or since a time. |
| 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 wikitextDependencies
mcp- the MCP/FastMCP server framework.requests+mwclient- MediaWiki API access (re-login, batched fetch).beautifulsoup4+lxml- parse the SSO login form for headless user auth.pydantic- structured tool outputs.python-dotenv- optional.envloading for local dev.filelock- cross-process single-flight page locking.
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.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/cppalliance/wg21-wiki-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server