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
Related Servers
Bright Data
sponsorDiscover, extract, and interact with the web - one interface powering automated access across the public internet.
Oxylabs
Scrape websites with Oxylabs Web API, supporting dynamic rendering and parsing for structured data extraction.
Claimify
Extracts factual claims from text using the Claimify methodology. Requires an OpenAI API key.
Xiaohongshu Search & Comment
An automated tool to search notes, retrieve content, and post comments on Xiaohongshu (RedBook) using Playwright.
MCP Deep Web Research Server
An advanced web research server with intelligent search queuing, enhanced content extraction, and deep research capabilities.
MCP Orlen Wholesale Price
Model Context Protocol Servers for Orlen Wholesale Price.
PlayMCP Browser Automation Server
A server for browser automation using Playwright, providing powerful tools for web scraping, testing, and automation.
MCP RSS Crawler
Fetches and caches RSS feeds using a SQLite database for use with LLMs via the MCP protocol.
GeekNews MCP Server
Fetches and caches daily articles from GeekNews using web scraping.
TradingView Chart Image Scraper
Fetches TradingView chart images for a given ticker and interval.
Hacker News
Fetches and parses stories from Hacker News, providing structured data for top, new, ask, show, and job posts.