
WOL MCP Server
Provides read-only access to the Watchtower Online Library (WOL) with advanced search capabilities, document retrieval, and multilingual support. Enables users to search and browse Jehovah's Witnesses publications through natural language interactions.
README
WOL MCP Server
An MCP server that gives LLMs read-only access to the Watchtower Online Library (WOL).
Features
- Advanced search with operators
- Document retrieval (always Markdown)
- Browse publication types
- Multilingual support (dynamic WOL language config)
- Robust error handling and retry logic
Installation
# Clone and install dependencies
git clone https://github.com/LeomaiaJr/wol-mcp-server.git
cd wol-mcp
npm install
# Build the server
npm run build
Available Tools
wol_search
Search the Watchtower Online Library with operators and pagination.
Parameters:
- query (string, required)
- useOperators (boolean, default: true)
- scope ("sen" | "par" | "art", default: "par")
- publications (array; see list below)
- language (string, default: "en")
- sort ("occ" | "newest" | "oldest", default: "occ")
- page (integer, default: 1)
- limit (integer, 1-100, default: 10) — applies only to document results
Search operators:
- & or + (AND), | or / (OR), ! (NOT), && or ++ (adjacent), "..." (phrase), * (wildcard), ? (single char), (...) (group)
wol_get_document
Retrieve full content of a specific document (always Markdown).
Parameters:
- url (string, required) — full WOL document URL
Output includes: title, publication, URL, optional date/volume/issue, subheadings, similar materials, followed by the article content. Bible citation links (/wol/bc) are inlined as plain text.
wol_browse_publications
Browse available publications by type.
Parameters:
- type (string) — optional filter
- language (string, default: "en")
- year (integer) — optional year filter
Publication types (common):
w
, g
, bk
, bi
, it
, dx
, yb
, syr
, sgbk
, mwb
, km
, brch
, bklt
, es
, trct
, kn
, pgm
, ca-copgm
, ca-brpgm
, co-pgm
, manual
, gloss
, web
Available Resources
wol://publications
Lists all available publication types with descriptions.
wol://operators
Details on search operators and examples.
wol://languages
Supported languages for multilingual access.
Development (Cloudflare Workers)
# Install dependencies
npm install
# Run locally (wrangler dev)
npm start
# Local MCP endpoint: http://localhost:8787/sse
# Optional: open MCP Inspector in another terminal and connect to the local endpoint
npx @modelcontextprotocol/inspector@latest
# Type check
npm run type-check
# Deploy to Cloudflare
npx wrangler deploy
Deploy to Cloudflare Workers (Remote MCP)
Cloudflare Workers let you run a remote MCP server reachable over HTTP/SSE. This repo’s server currently starts via stdio
(subprocess) using StdioServerTransport
. To expose it remotely, deploy a Workers-based MCP server that implements the HTTP/SSE transport and wires the same tools. Below are two practical paths.
Option A — Quick deploy (authless template)
- Create a new Workers project from Cloudflare’s authless remote MCP template:
npm create cloudflare@latest -- wol-mcp-worker --template=cloudflare/ai/demos/remote-mcp-authless
cd wol-mcp-worker
- Develop locally:
npm start
# Server runs at http://localhost:8787/sse
- Deploy (Wrangler is already authenticated on your machine):
npx wrangler@latest deploy
- Connect using the MCP Inspector:
npx @modelcontextprotocol/inspector@latest
open http://localhost:5173
# Enter your server URL, e.g. http://localhost:8787/sse or https://<worker>.<account>.workers.dev/sse
- Use with a local proxy:
{
"mcpServers": {
"wol-remote": {
"command": "npx",
"args": ["mcp-remote", "https://<worker>.<account>.workers.dev/sse"]
}
}
}
Option B — Add authentication (OAuth)
Start from Cloudflare’s GitHub OAuth example and deploy:
npm create cloudflare@latest -- wol-mcp-github-auth --template=cloudflare/ai/demos/remote-mcp-github-oauth
cd wol-mcp-github-auth
npx wrangler@latest deploy
Follow the guide to register OAuth apps and set secrets (GITHUB_CLIENT_ID
, GITHUB_CLIENT_SECRET
). See: Cloudflare “Build a Remote MCP server” guide.
Porting this server’s tools
- This repo is
stdio
-only. Workers cannot runstdio
subprocesses, so you do not deploydist/index.js
directly. - Reuse logic by moving the WOL tool handlers (e.g.,
WOLService
) into the Workers project and registering equivalent tools there. - Cloudflare Workers support the MCP HTTP/SSE transport out of the box in their templates. Implement tools that call the same methods you see in this repo’s
wol_search
,wol_get_document
, andwol_browse_publications
handlers.
Notes:
- Spec reference: MCP transports (stdio and Streamable HTTP). Workers templates expose an
/sse
endpoint compatible with MCP clients. - For clients that don’t yet support remote MCP natively, use
mcp-remote
as shown above.
Configuration
Environment Variables
NODE_ENV
- Environment (development/production)LOG_LEVEL
- Logging level (error/warn/info/debug)
Service Availability
Currently, no server-side rate limiting is enforced. Upstream availability from WOL may occasionally result in temporary outages (e.g., 502/503), which are surfaced as SERVICE_UNAVAILABLE
errors.
Examples
Basic Search
Query: "Jesus Christ"
Result: Exact phrase search across all publications
Advanced Search with Operators
Query: (Jesus | Christ) & Jehovah & !Trinity
Result: Documents containing (Jesus OR Christ) AND Jehovah but NOT Trinity
Publication-Specific Search
Query: prayer
Publications: ["w", "g"] // Watchtower and Awake! only
Result: Prayer-related articles from these magazines
Multilingual Search
Query: "reino de Dios"
Language: "es"
Result: Spanish content about God's Kingdom
Contributing
- Fork the repository
- Create a feature branch:
git checkout -b feature/new-feature
- Make changes and add tests
- Commit:
git commit -am 'Add new feature'
- Push:
git push origin feature/new-feature
- Submit a Pull Request
License
MIT License - see LICENSE file for details.
Disclaimer
This is an unofficial MCP server for accessing the Watchtower Online Library. It is not affiliated with or endorsed by Jehovah's Witnesses or the Watchtower Bible and Tract Society.
Recommended Servers
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.
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.
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.

VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.

E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.