WebWatch MCP
Website change monitoring with URL watching, snapshot comparison, and intelligent content extraction for AI assistants
š WebWatch MCP
A Model Context Protocol (MCP) server for monitoring website changes. Track URLs, detect content changes, compare snapshots, and extract content with CSS selectors ā all from your AI assistant.
Features
- Watch URLs ā Monitor any webpage for content changes
- CSS Selectors ā Track specific elements (prices, headlines, stock info)
- Snapshot History ā SQLite-backed storage of every page state
- Diff Detection ā See exactly what changed, line by line
- Content Extraction ā Pull structured data from any page on demand
Tools
| Tool | Description |
|---|---|
watch_url | Add a URL to the watch list with optional CSS selector and label |
list_watches | List all monitored URLs with status and statistics |
check_now | Fetch a URL now, compare to previous snapshot, return diff |
get_changes | Browse change history for one or all watched URLs |
compare_snapshots | Compare any two snapshots side-by-side |
extract_content | One-off content extraction with CSS selectors |
Installation
# Clone and build
git clone https://github.com/leviai-tools/webwatch-mcp.git
cd webwatch-mcp
npm install
npm run build
# Or install globally
npm install -g @leviai/webwatch-mcp
Usage with Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"webwatch": {
"command": "node",
"args": ["/path/to/webwatch-mcp/build/index.js"],
"env": {
"WEBWATCH_DATA_DIR": "/path/to/data/dir"
}
}
}
}
Or if installed globally:
{
"mcpServers": {
"webwatch": {
"command": "webwatch-mcp"
}
}
}
Environment Variables
| Variable | Default | Description |
|---|---|---|
WEBWATCH_DATA_DIR | ~/.webwatch-mcp | Directory for SQLite database |
Example Workflows
Monitor a pricing page
You: "Watch https://example.com/pricing ā track the .pricing-table element"
ā watch_url(url, selector=".pricing-table", label="Example pricing")
You: "Check if pricing changed"
ā check_now("https://example.com/pricing")
Track competitor changes
You: "Add these competitor pages to my watchlist"
ā watch_url for each URL
You: "Show me all recent changes"
ā get_changes(limit=20)
Extract data on demand
You: "What are the headlines on HN right now?"
ā extract_content("https://news.ycombinator.com", ".titleline > a")
Data Storage
All data is stored locally in SQLite at ~/.webwatch-mcp/webwatch.db (configurable via WEBWATCH_DATA_DIR).
Tables:
watchesā Monitored URLs with selectors and labelssnapshotsā Page content captured at each checkchangesā Detected diffs between consecutive snapshots
Requirements
- Node.js ā„ 18.0.0
License
MIT
Server Terkait
Bright Data
sponsorDiscover, extract, and interact with the web - one interface powering automated access across the public internet.
Stepstone
Fetches job listings from Stepstone.de based on keywords and location parameters.
WebforAI Text Extractor
Extracts plain text from web pages using WebforAI.
AgentQL
Enable AI agents to get structured data from unstructured web with AgentQL.
Riksdag & Regering MCP
MCP-server that provides LLMs with easy access to open data from the Swedish Government Offices and Parliament.
Weibo
Scrape Weibo user information, feeds, and perform searches.
YouTube Transcript MCP
Download transcripts directly from YouTube videos.
Urlbox Full Page Screenshots
An MCP server for the Urlbox Screenshot API. It enables your client to take screenshots, generate PDFs, extract HTML/markdown, and more from websites.
WebScraping.AI
Interact with WebScraping.AI for web data extraction and scraping.
Primp MCP Server
An MCP server for the Primp HTTP client, enabling browser impersonation for requests and file uploads.
Douyin MCP Server
Extract watermark-free video links and copy from Douyin.