A read-only STDIO server that wires 1.13M threat intelligence indicators into Claude Desktop, Cursor, or any MCP client. You get three tools: full-text search across 17.9M documents spanning IOCs, CISA KEV, adversary profiles, and 40+ threat indexes; IP enrichment with geolocation, ASN, and cross-index correlation; and STIX feed metadata. No filesystem writes, no exec calls, no third-party SDK dependencies. The same two-person Minnesota outfit that named TeamPCP 45 days before CISA and called NGINX-UI exploitation 20 days early. Built for CI pipelines that need to fail on known-bad indicators before deployment, now accessible as conversational tooling. Optional local policy gate if you need stricter controls than the default allow-all stance.
1.08M+ IOCs. 17.9M+ documents. Two binaries. One install. The MCP we'd audit.
# Scanner — block bad IOCs in your stack
npx dugganusa-cli 185.39.19.176
# MCP server — wire DugganUSA into Claude Desktop / Cursor / Claude Code
npx -y -p dugganusa-cli dugganusa-mcp
A two-person Minnesota LLC. A Bloom filter for novelty checks. Meilisearch cross-index correlation. A github-hunt cron that runs at 08:15 UTC every day.
That's the stack that named TeamPCP 45 days before CISA added LiteLLM CVE-2026-42208 to KEV. That named Handala 28 days before they exfiltrated 6 petabytes from Dubai. That named NGINX-UI as actively exploited 20 days before the same agency caught up.
This is the CLI that puts the same corpus in your terminal.
v1.3.0 rename: the scanner bin was
dugganusa-lookupin v1.2.0. It is nowdugganusa-cli. The MCP bin (dugganusa-mcp) is unchanged. Update any pinned scripts.
# Run without installing
npx dugganusa-cli 185.39.19.176
npx -y -p dugganusa-cli dugganusa-mcp --help
# Or install globally — both bins on PATH
npm install -g dugganusa-cli
# Single lookup
dugganusa-cli 185.39.19.176
dugganusa-cli welcome.supp0v3.com
dugganusa-cli CVE-2026-21643
# Multiple indicators
dugganusa-cli 185.39.19.176 welcome.supp0v3.com CVE-2026-21643
# Scan a file for IOCs
dugganusa-cli --file config.js
dugganusa-cli --file terraform/main.tf
# Pipe stdin (works with any tool)
cat firewall.log | dugganusa-cli --stdin
grep -r "http" src/ | dugganusa-cli --stdin
# Batch lookup (one IOC per line)
dugganusa-cli --batch iocs.txt
# AIPM audit (AI presence + brand exposure)
dugganusa-cli --aipm crowdstrike.com
# Output formats
dugganusa-cli --format json 185.39.19.176
dugganusa-cli --format markdown --file report.md
dugganusa-cli --format table 185.39.19.176 # default
# Only show matches (suppress clean results)
dugganusa-cli --file app.js --quiet
# With API key (higher rate limits)
dugganusa-cli --key dugusa_YOUR_KEY 185.39.19.176
# Or set env var
export DUGGANUSA_API_KEY=dugusa_YOUR_KEY
!! 12 185.39.19.176 IOC: Cobalt Strike C2 (via SSLBL) | Blocked 47x | 3 OTX pulse(s)
OK 0 8.8.8.8 clean
1 threat indicator(s) found in 2 checked.
Full enrichment: https://analytics.dugganusa.com/api/v1/search/correlate?q=<indicator>
Free API key: https://analytics.dugganusa.com/stix/register
| Code | Meaning |
|---|---|
| 0 | All clean — no threat indicators found |
| 1 | Threat indicator(s) found — use in CI to fail builds |
| 2 | Error (network, invalid input, etc.) |
Exit 1 on match is the whole point. Block deployments containing known-bad indicators before they ship.
# GitHub Actions — block deploys containing live IOCs
- name: Scan for threat indicators
run: npx dugganusa-cli --file config/production.json --quiet
# Shell pipeline
if npx dugganusa-cli --file deploy.conf --quiet; then
echo "Clean — deploying"
./deploy.sh
else
echo "BLOCKED — threat indicators found"
exit 1
fi
Free tier: 500 queries/day. Anonymous lookups work for casual use.
Free key for higher limits: analytics.dugganusa.com/stix/register
Set via --key flag or DUGGANUSA_API_KEY env var.
1.08M+ indicators sourced from OTX, abuse.ch SSLBL, URLhaus, Spamhaus, CISA KEV, DugganUSA original research, our exploit harvester, and our edge honeypots. Cross-correlated across 44 indexes covering 17.9M+ documents. The same feed pulled daily by 275+ organizations in 46 countries — including Microsoft, AT&T, and Starlink.
You are getting the receipts the big platforms get. Same corpus, your terminal.
Local STDIO MCP server. Wire it into any MCP client, your AI assistant gets the DugganUSA threat-intel corpus as read-only tools.
This is the MCP we wrote because the ones we audited were dangerous.
No tools that write. No tools that touch your filesystem. No tools that exec. Read-only, all the way down.
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS):
{
"mcpServers": {
"dugganusa": {
"command": "npx",
"args": ["-y", "-p", "dugganusa-cli", "dugganusa-mcp"],
"env": {
"DUGGANUSA_API_KEY": "your-key-or-leave-blank-for-anonymous"
}
}
}
}
Restart Claude Desktop. Three tools appear in the picker. Same pattern works for Cursor, Windsurf, Claude Code, or any MCP client that speaks STDIO.
--dredd-gatedugganusa-mcp --dredd-gate
Pre-flights every tool call: validates tool name, required arguments, logs allowed calls to stderr. Read the verdict function in mcp/lib/serve.js (function dreddVerdict). This is the hook where you wire stricter policy: deny lists, IP allow-lists, per-tool rate limits, or a remote dredd verdict endpoint.
Default is off. Turn it on if your environment is anything more than your laptop.
On April 20, 2026 we published "Anthropic's MCP Has a Critical RCE Vulnerability. We Don't Use MCP. Here's Why." (dugganusa.com)
We named the affected vendors three weeks before they hit the headlines: MCP Inspector, LibreChat, Windsurf, LiteLLM, Langchain-Chatchat, NGINX-UI. The architectural problem was that MCP trusts the transport — STDIO gives an AI model a pipe to execute commands on the host, and the path from "tool definition" to "command execution" had no gate.
We meant it. We still don't trust other people's MCPs without auditing them first. The coherent answer is to ship the MCP we'd audit:
--dredd-gate local policy hookThis is that MCP.
Read the bytes you're running:
# install
npm install -g dugganusa-cli
# audit
grep -rnE 'child_process|require\(.*shell|require\(.*child|exec\(|spawn\(|eval\(' "$(npm root -g)/dugganusa-cli"
Should return nothing.
Source layout under mcp/:
mcp/serve.js — bin entry, argv parser (~45 LOC)mcp/lib/serve.js — JSON-RPC 2.0 over STDIO (~125 LOC)mcp/lib/tools.js — three tool schemas + handlers (~80 LOC)mcp/lib/upstream.js — HTTPS request to analytics.dugganusa.com (~40 LOC)Tests:
npm run test:mcp
10 tests covering the dispatch surface and live network calls. Every release runs them in CI before publishing.
Releases ≥ v1.3.0 are published via npm Trusted Publishing (GitHub Actions OIDC) with --provenance. Verify:
npm audit signatures dugganusa-cli
You get signed attestation that the published bytes came from a specific commit in a specific GitHub workflow run. No long-lived tokens involved.
The platform behind this CLI runs left-of-boom on adversary infrastructure:
| Adversary | We named them | Vendor / agency caught up | Days early |
|---|---|---|---|
| TeamPCP (Trivy / LiteLLM / Telnyx supply chain) | Mar 24, 2026 | CISA KEV adds CVE-2026-42208 May 8 | 45 days |
| NGINX-UI (actively exploited MCP) | Apr 20, 2026 | CISA KEV adds May 8 | 20 days |
| Lynx ransomware vs ACN Healthcare | indexed | Microsoft published | 43 days |
| Handala (Iran/MOIS-aligned) vs Dubai | indexed | Disclosure | 28 days |
| Medtronic vish chain | flagged | Microsoft published | 39 days |
Five entries in the quantified ledger as of May 10, 2026. The pattern is not luck. The pattern is the methodology.
Read the math: dugganusa.com/post/45-days-early-on-litellm-20-days-early-on-nginx-ui-cisa-caught-up-today-1
MIT — DugganUSA LLC, Minneapolis, MN.
Free tier means free. Audit it. Fork it. Tell us when we got something wrong.
Same threat corpus, surfaced wherever you live. Open source, MIT licensed, receipts on every repo.
| Plugin | Surface |
|---|---|
| dugganusa-scanner-core | Core IOC scanning engine |
| dugganusa-vscode | VS Code extension |
| dugganusa-splunk | Splunk Technology Add-on |
| dugganusa-slack | Slack bot |
| dugganusa-raycast | Raycast extension |
| dugganusa-sentinel | Microsoft Sentinel TAXII connector |
| dugganusa-obsidian | Obsidian plugin |
| dugganusa-nvim | Neovim plugin |
| dugganusa-elastic | Elastic / OpenSearch integration |
| dugganusa-edge-shield | Cloudflare Worker |
| dugganusa-cli (this repo) | CLI scanner + local STDIO MCP server |
| dugganusa-chrome | Chrome extension |
| dugganusa-action | GitHub Action |
| dredd-mcp | Pre-flight MCP security judge |
Backed by the live DugganUSA threat intel platform: analytics.dugganusa.com.
Jeevesus saves. Dredd judges.
DUGGANUSA_API_KEYsecretOptional API key for higher rate limits. Anonymous tier works.