ThreatWatch MCP

ThreatWatch MCP

AI-powered threat intelligence server with real-time alert monitoring and multi-source IOC analysis, enabling security investigations directly in Claude Desktop.

Category
Visit Server

README

๐Ÿ›ก๏ธ ThreatWatch MCP

AI-Powered Threat Intelligence with Real-Time Alert Monitoring

A Model Context Protocol (MCP) server that brings multi-source threat intelligence directly into Claude Desktop and any MCP-compatible AI assistant.

Python 3.11+ License: Apache-2.0 MCP


โœจ What Makes ThreatWatch Different

Feature ThreatWatch fastmcp-threatintel
Real-time watch-list & alerts โœ… โŒ
Persistent alert history โœ… โŒ
Shodan InternetDB (free, no key needed) โœ… โŒ
Status-change detection โœ… โŒ
IOC extraction from freeform text โœ… โŒ
Works with zero API keys โœ… โŒ

๐Ÿ”Œ Available MCP Tools

Tool Description
analyze_ioc Analyse a single IP / domain / URL / hash
bulk_analyze Analyse up to 50 IOCs concurrently
detect_iocs_in_text Extract IOCs from log files, reports, pastes
add_watch Add an IOC to the real-time watch-list
remove_watch Remove an IOC from the watch-list
list_watches Show all monitored IOCs and their status
get_alerts Retrieve alerts from monitored IOCs
run_monitor_cycle Manually trigger a re-scan of all watches
server_status Show configured sources and monitor state

๐Ÿš€ Installation

Prerequisites

  • Python 3.11 or higher
  • Claude Desktop
  • API keys (see below โ€” all free tier)

Step 1 โ€” Clone the repo

git clone https://github.com/YOUR_USERNAME/threatwatch-mcp.git
cd threatwatch-mcp

Step 2 โ€” Install

pip3 install fastmcp httpx python-dotenv
pip3 install -e .

Step 3 โ€” Verify installation

which threatwatch

You should see a path like /usr/local/bin/threatwatch or /Library/Frameworks/Python.framework/Versions/3.x/bin/threatwatch. Copy this path โ€” you'll need it in Step 5.


๐Ÿ”‘ API Keys (All Free)

Source Required Free Limit Sign Up
VirusTotal Recommended 1,000 req/day virustotal.com
AlienVault OTX Recommended Unlimited otx.alienvault.com
AbuseIPDB Optional 1,000 req/day abuseipdb.com
IPinfo Optional 50,000 req/month ipinfo.io
Shodan InternetDB None needed Always free Built-in

ThreatWatch works with zero API keys โ€” Shodan InternetDB is always available and returns open ports, CVEs, and hostnames for any IP for free.


โš™๏ธ Connect to Claude Desktop

Step 4 โ€” Open the Claude Desktop config

macOS:

open -e ~/Library/Application\ Support/Claude/claude_desktop_config.json

Windows:

%APPDATA%\Claude\claude_desktop_config.json

Step 5 โ€” Add ThreatWatch

Add the threatwatch entry to your mcpServers block. Replace the command path with the output of which threatwatch from Step 3, and fill in your API keys:

{
  "mcpServers": {
    "threatwatch": {
      "command": "/Library/Frameworks/Python.framework/Versions/3.13/bin/threatwatch",
      "env": {
        "VIRUSTOTAL_API_KEY": "your_virustotal_key_here",
        "OTX_API_KEY": "your_otx_key_here",
        "ABUSEIPDB_API_KEY": "your_abuseipdb_key_here",
        "IPINFO_API_KEY": "your_ipinfo_key_here"
      }
    }
  }
}

If you already have other MCP servers configured, just add the threatwatch block inside your existing mcpServers object โ€” don't replace the whole file.

Step 6 โ€” Restart Claude Desktop

Fully quit Claude Desktop (Cmd + Q on Mac, system tray โ†’ Exit on Windows) and reopen it.

Step 7 โ€” Verify

Click the "+" button at the bottom of the Claude chat โ†’ Connectors. You should see ThreatWatch listed with all 9 tools.

Then test it:

Run server_status

๐Ÿ’ฌ Example Prompts

Analyse IP 185.220.101.1 for threats

Check if domain update-adobe-flash.ru is malicious

Is this hash dangerous: d41d8cd98f00b204e9800998ecf8427e

Extract all IOCs from this log and analyse them:
[paste your firewall log, SIEM alert, or email header]

Add a watch on 185.220.101.1 and alert me if it becomes malicious

Get all alerts from the last hour

Run a full monitor cycle now

๐Ÿ”” How Real-Time Monitoring Works

add_watch("185.220.101.1", alert_on=["malicious", "suspicious"])
         โ”‚
         โ–ผ
   Watch-list saved to ~/.threatwatch/watchlist.json
         โ”‚
         โ–ผ
run_monitor_cycle()   โ† trigger manually or on a schedule
         โ”‚
         โ–ผ
   Re-queries all sources for each watched IOC
         โ”‚
         โ–ผ
   Status changed or threshold crossed?
         โ”‚
    Yes  โ”‚  No
    โ–ผ    โ–ผ
  Alert  (no-op)
    โ”‚
    โ–ผ
get_alerts(since_minutes=60)

๐Ÿ—๏ธ Project Structure

threatwatch-mcp/
โ”œโ”€โ”€ src/
โ”‚   โ””โ”€โ”€ threatwatch/
โ”‚       โ”œโ”€โ”€ __init__.py        โ† package definition
โ”‚       โ”œโ”€โ”€ server.py          โ† FastMCP server + all 9 MCP tools
โ”‚       โ”œโ”€โ”€ config.py          โ† settings from environment variables
โ”‚       โ”œโ”€โ”€ ioc_detector.py    โ† IOC type detection (IP/domain/URL/hash)
โ”‚       โ”œโ”€โ”€ intel_sources.py   โ† API adapters (VT, OTX, AbuseIPDB, IPinfo, Shodan)
โ”‚       โ”œโ”€โ”€ alert_monitor.py   โ† real-time watch-list + alert engine
โ”‚       โ””โ”€โ”€ reporter.py        โ† Markdown report builder
โ”œโ”€โ”€ tests/
โ”‚   โ””โ”€โ”€ test_core.py           โ† unit tests
โ”œโ”€โ”€ pyproject.toml             โ† package config + dependencies
โ”œโ”€โ”€ .env.example               โ† environment variable template
โ””โ”€โ”€ README.md

๐Ÿ”’ Security Notes

  • Never commit your .env file โ€” it is in .gitignore by default
  • Restrict config file permissions on your machine:
    chmod 600 ~/Library/Application\ Support/Claude/claude_desktop_config.json
    
  • All API keys used are read-only โ€” they can query data but cannot modify anything
  • If a key is ever leaked, regenerate it instantly from each service's dashboard

๐Ÿงช Running Tests

pip3 install pytest pytest-asyncio
pytest tests/ -v

๐Ÿ“œ License

Apache 2.0 โ€” see LICENSE for details.


๐Ÿ™ Acknowledgments

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured