mcpzim
The mcpzim server provides local LLM agents with offline access to ZIM archives (Wikipedia, medical wikis, maps) for knowledge retrieval and, optionally, routing.
list_libraries— Inventory all loaded ZIM archives, their types (wikipedia, mdwiki, streetzim, generic), metadata, and aggregate capabilities. Call this first to understand what sources are active.search— Full-text search across all loaded ZIMs, with optional kind filter and configurable result limit. Returns source ZIM, path, title, and snippet per hit.get_article— Fetch a specific article by its ZIM entry path as clean plain text (HTML cruft stripped). Optionally target a specific ZIM file.get_main_page— Retrieve the main/home page of a specific ZIM, or all loaded ZIMs if none is specified.
Conditional (requires a streetzim archive with routing data):
geocode— Resolve a place name or address string to geographic coordinates.plan_driving_route— Compute an A* driving route between two lat/lon pairs, returning distance, duration, polyline, and road segments.route_from_places— Convenience tool that geocodes an origin and destination, then plans a driving route between them.
Everything runs fully offline; no data leaves the device.
Supports running on Android devices via Termux, allowing the MCP server to operate directly on Android with offline ZIM content access and routing capabilities.
Discusses potential integration approaches for iOS, including running as a LAN bridge or creating a Swift MCP module that leverages libzim bindings for in-app content access.
Integrates with Kiwix's ZIM file format and mentions potential future integration with Kiwix mobile apps' local HTTP server for serving content through the MCP server.
Provides access to offline Wikipedia content through ZIM files, enabling search and article retrieval for general knowledge queries without internet connectivity.
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., "@mcpzimsearch for information about the history of the Eiffel Tower"
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.
Zimfo
Zimfo is an offline, on-device chat app (iOS + macOS) that answers questions from locally-loaded ZIM archives — Wikipedia, OpenStreetMap street data (streetzim), and medical (mdwiki) — using a local fine-tuned LLM that drives a tool loop over those archives. Nothing leaves the device.
Ask "tell me about the Duchy of Lithuania", "how do solar panels work?", "what's near me?", "how far is it to the cathedral?", or "compare Musk and Bezos" — Zimfo searches the ZIMs, reads the right article, and answers. Follow-ups ("tell me more", "yes", "what's near there?", "the second one") resolve against a deterministic on-device conversation focus rather than the small model's own memory, and a "let's discuss X" mode grounds multi-turn Q&A in retrieved article passages — so a walking conversation actually holds together.
The shipping model is a LoRA-fine-tuned
LFM2.5-8B-A1B
(8.3B-total / 1.5B-active hybrid MoE) quantized to IQ3_XS with an
importance matrix calibrated on the app's own tool-call transcripts:
12/13 on the tool-calling eval grid at ~3.6 GB peak RSS and ~136 t/s
decode (M2 Max), running through llama.cpp with a 32k context and
cross-turn KV prefix reuse (follow-up turns prefill ~23 tokens instead of
the whole transcript). How we got here — the full stock-model sweep
(Gemma 3/4, Qwen 3/3.5, Phi, …), the fine-tuning pivot, the Gemma 4 QAT/MTP
investigation, and the quantization frontier — is written up in
MODEL_EVALUATION_HISTORY.md.
This repo has three layers, smallest-dependency first:
The shared engine —
swift/MCPZimKit: a transport-agnostic, Foundation-only Swift package. ZIM tool adapter, A* routing-graph parser + router, prefix geocoder, and the conversation-state machine (focus, reference resolution, drift threads). Exercised byswift test.The app —
ios/: the SwiftUI Zimfo app (on-device Gemma 4 / fine-tuned LFM2.5 via MLX + llama.cpp). Architecture and the pieces that took the most iteration are indocs/ARCHITECTURE.md.The reusable kernel — the
mcpzimMCP server (Python): the original backend, documented below. It exposes the same ZIM tools to any agent host over MCP, so the engine isn't locked to the app.
The mcpzim MCP server (Python)
An MCP server that makes a group of offline ZIM files available to local LLM agents. Point it at a directory of ZIMs and the server will:
Inventory what's there (
list_libraries) and advertise aggregate capabilities (general knowledge, medical knowledge, maps/routing) based on what's loaded.Expose search and article retrieval across every ZIM (
search,get_article,get_main_page).When it detects a streetzim ZIM built with
--routing, it additionally exposesplan_driving_route,geocode, androute_from_placesso a local agent can ask "give me a driving route from A to B" and get street-by-street directions, distance, and an estimated time.
The design principle is opportunistic capability: start with one Wikipedia
ZIM and you get a Wikipedia server. Drop in mdwiki_en_all_*.zim and it also
answers medical questions. Drop in a streetzim ZIM and it can also plan driving
routes for the area the ZIM covers. Tools appear only when the underlying data
is present, so the agent's tool list never lies about what the server can do.
Related MCP server: mcp-web-calc
Install
Requires Python 3.10+.
pip install mcpzim # once published
# or, from a checkout:
pip install -e .libzim is a native wheel; prebuilt wheels exist for macOS (x86_64/arm64),
Linux (x86_64/aarch64, glibc and musl) and Windows x64. On other platforms pip
will build from source and you'll need a C++ toolchain.
Run
Drop your ZIM files into one directory and run:
export ZIM_DIR=~/zims
mcpzim # stdio transport (Claude Desktop / Code)
mcpzim ~/zims/wikipedia.zim ~/zims/streetzim_ma.zim # explicit paths
mcpzim --transport streamable-http --host 0.0.0.0 --port 8765 # LANAdd to ~/.config/claude-desktop/claude_desktop_config.json (or the
equivalent for your MCP client):
{
"mcpServers": {
"mcpzim": {
"command": "mcpzim",
"env": { "ZIM_DIR": "/Users/me/zims" }
}
}
}Tools
Always available:
Tool | What it does |
| Inventory: list every ZIM with kind, title, language, and the aggregate capabilities ( |
| Full-text search across every ZIM (uses libzim's Xapian index when present, falls back to title-prefix suggestions). Accepts an optional |
| Fetch an entry by path; HTML is stripped of navbox / infobox / script cruft so the LLM sees clean text. |
| Main page of one ZIM, or of every loaded ZIM. |
Only present when a streetzim ZIM with routing data is loaded:
Tool | What it does |
| A* over the streetzim routing graph. Input: two |
| Resolve a place/address string to coordinates using streetzim's prefix-chunked search index. |
| Convenience: geocode both endpoints then plan a route. |
Cost/heuristic in the router match streetzim's JS viewer exactly:
edge_cost = distance_m / (speed_kmh / 3.6) and heuristic = haversine / (100/3.6), so results are identical to what the in-browser
viewer would produce.
Supported ZIMs
Type detection runs at scan time and uses a combination of filename prefix, the
ZIM's Name / Tags / Creator / Publisher metadata, and signature entries
inside the archive. Out of the box:
Wikipedia — any
wikipedia_*.zim(Creator: Wikipedia, taggedwikipedia).mdwiki —
mdwiki_*.zimfrom the WikiProjectMed Foundation (taggedmdwiki/medical).streetzim — detected by the presence of
routing-data/graph.binormap-config.jsoninside the archive.generic — anything else (a
*.zimstill gets served; only theZimKind.GENERICdefault toolset applies).
Example session
> list_libraries
{"zims": [
{"path": ".../wikipedia_en_all_nopic_2026-03.zim", "kind": "wikipedia", ...},
{"path": ".../mdwiki_en_all_2026-03.zim", "kind": "mdwiki", ...},
{"path": ".../streetzim_ma.zim", "kind": "streetzim", "has_routing": true, ...}
],
"by_kind": {"wikipedia": 1, "mdwiki": 1, "streetzim": 1},
"capabilities": ["encyclopedia", "general_knowledge", "geocode",
"get_article", "list_libraries", "maps", "medical",
"plan_route", "search"]}
> route_from_places {"origin": "Boston Common", "destination": "Fenway Park"}
{"origin_resolved": {"name": "Boston Common", "lat": 42.3554, "lon": -71.0655, ...},
"destination_resolved": {"name": "Fenway Park", "lat": 42.3467, "lon": -71.0972, ...},
"distance_km": 3.27, "duration_min": 9.4,
"roads": [
{"name": "Beacon Street", "distance_m": 412.3, "duration_s": 44.0},
...
],
"turn_by_turn": ["Beacon Street for 0.41 km (~0.7 min)", ...],
"polyline": [[42.3554, -71.0655], ...]}Mobile
Concrete paths that actually work, matched to the on-device LLM hosts people are shipping in 2026:
Platform | LLM host | Path | Status |
Desktop | Claude Desktop / Code, any MCP client | This Python server via | Works today |
Android | Google AI Edge Gallery (Gemma 4 + LiteRT-LM, Apache 2.0) | Small Kotlin fork — add a | See |
Android (fully offline) | same | Run | Works; Termux has to build |
iOS | The Zimfo app in this repo ( | Links | Works today — see |
iOS | Google AI Edge Gallery (closed-source app) | Available on the App Store since 2026-04 with Gemma 4 support — fine for trying models, but no tool-calling hook into this server. | Demo-only |
The short version: on Android the open-source Agent Chat host already knows how
to call a tool, so a short Kotlin patch makes it speak to this Python server.
On iOS, the LLM host has no tool-calling layer yet, so the companion Swift
package ships (a) the same algorithms in pure Swift for in-process use, and (b)
a transport-agnostic MCP adapter you can plug into the official
modelcontextprotocol/swift-sdk
when you want the model to call tools over LAN.
swift/MCPZimKit's SZRG v2 parser, A* router, and prefix geocoder are
line-for-line ports of the Python implementations; the Python test suite and
the Swift test suite in swift/Tests/MCPZimKitTests/ cover the same cases, so
if both green, you know the two agree.
Development
pip install -e '.[dev]'
pytestTests do not require any real ZIM files; the routing tests build a tiny SZRG v2
graph in-memory using mcpzim.routing.encode_graph_v2, and the library tests
exercise the classifier directly.
License
MIT.
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/jasontitus/mcpzim'
If you have feedback or need assistance with the MCP directory API, please join our Discord server