Joelclaw ahrefs
Query Ahrefs SEO data via their MCP server — keyword research, site explorer, SERP analysis, competitor research, backlink analysis, and Brand Radar AI visibility. Use when researching keywords, analyzing competitors, checking backlinks, auditing sites, or any SEO data task. Triggers on 'keyword research', 'check backlinks', 'competitor analysis', 'ahrefs', 'search volume', 'keyword difficulty', 'domain rating', 'SERP analysis', 'SEO data', 'brand radar', or any request needing search engine optimization data.
git clone https://github.com/joelhooks/joelclaw
T=$(mktemp -d) && git clone --depth=1 https://github.com/joelhooks/joelclaw "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/ahrefs" ~/.claude/skills/joelhooks-joelclaw-ahrefs && rm -rf "$T"
skills/ahrefs/SKILL.mdAhrefs SEO Tools
Query Ahrefs via their remote MCP server (Streamable HTTP transport). Joel has a Standard plan ($249/mo).
Connection
Endpoint:
https://api.ahrefs.com/mcp/mcp
Auth: Bearer token via agent-secrets lease ahrefs_api_key
Transport: Streamable HTTP (JSON-RPC over POST, NOT SSE)
Config: ~/.pi/agent/mcp.json under ahrefs key
Raw curl pattern (when MCP bridge isn't available)
AHREFS_KEY=$(agent-secrets lease ahrefs_api_key --ttl 4h --json 2>&1 | python3 -c "import sys,json; print(json.load(sys.stdin)['result']['value'])") curl -s -X POST "https://api.ahrefs.com/mcp/mcp" \ -H "Authorization: Bearer $AHREFS_KEY" \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{ "jsonrpc":"2.0","id":1,"method":"tools/call", "params":{"name":"TOOL_NAME","arguments":{...}} }'
MCP initialization handshake (required once per session)
{"jsonrpc":"2.0","id":0,"method":"initialize","params":{ "protocolVersion":"2025-03-26", "capabilities":{}, "clientInfo":{"name":"pi","version":"1.0"} }}
Critical: Use doc
tool first
docBefore calling any data tool for the first time, call the
doc tool to get the real input schema:
{"name":"doc","arguments":{"tool":"keywords-explorer-overview"}}
This returns the full schema with field names, types, filter syntax, and output columns. The tool list schemas are summaries —
gives the real contract.doc
API Units
Every call costs API units. The response includes cost info:
{"apiUsageCosts":{"rows":10,"units-cost-row":21,"units-cost-total":210}}
- Monetary values (CPC, traffic_value, etc.) are in USD cents, not dollars. Divide by 100.
costs 10 extra units per row when selecteddifficulty- Standard plan has monthly unit limits — check with
subscription-info-limits-and-usage
Tool Categories
Keywords Explorer (keyword research)
| Tool | Use for | Key required params |
|---|---|---|
| Volume, KD, CPC for specific keywords | , , (array) |
| Find keyword ideas matching seed terms | , , , , |
| "Also rank for" and "also talk about" | , , |
| Autocomplete suggestions with metrics | , , |
| Historical volume trends | , (singular) |
| Volume broken down by country | (singular) |
Common
fields: select
keyword, volume, difficulty, cpc, traffic_potential, global_volume, parent_topic, intents, clicks, cps, serp_features
Gotcha:
keywords-explorer-overview requires keywords as an array BUT returns empty results for broad terms — it only returns data for exact keyword matches in their DB. Use matching-terms or search-suggestions for discovery.
Site Explorer (domain/URL analysis)
| Tool | Use for | Key required params |
|---|---|---|
| DR, traffic, keywords count | , |
| What keywords a site ranks for | , , , |
| Who competes in organic search | , , , |
| Best pages by traffic | , , |
| Inbound link details | , |
| Domains linking to target | , |
| DR score | , |
| DR over time | , |
| Backlink summary stats | , |
| Anchor text analysis | , |
| Broken inbound links | , |
| Traffic by country | , |
| Historical traffic/keywords | , |
= domain (target
example.com), URL (https://example.com/page), or path (example.com/blog/*)
mode = exact | domain | subdomains | prefix
date = YYYY-MM-DD (use recent date like today)
SERP Analysis
| Tool | Use for | Key required params |
|---|---|---|
| Top results for a keyword | , , |
Batch Analysis
| Tool | Use for | Key required params |
|---|---|---|
| Analyze multiple URLs/domains at once | , (array) |
Rank Tracker (requires project setup in Ahrefs UI)
Tools:
rank-tracker-overview, rank-tracker-competitors-*, rank-tracker-serp-overview
All require project_id — get via management-projects.
Site Audit (requires project setup in Ahrefs UI)
Tools:
site-audit-issues, site-audit-page-explorer, site-audit-page-content, site-audit-projects
Brand Radar (AI visibility monitoring)
Tools:
brand-radar-mentions-*, brand-radar-impressions-*, brand-radar-sov-*, brand-radar-ai-responses, brand-radar-cited-*
Requires brand monitoring setup in Ahrefs UI.
Web Analytics (requires Ahrefs analytics snippet)
All
web-analytics-* tools require project_id from a Web Analytics project.
Management
| Tool | Use for |
|---|---|
| List all projects |
| Keywords in a project |
| Competitors in a project |
| Location IDs for targeting |
| Keywords from a saved list (free, no units) |
| Check remaining API units |
Common Recipes
Keyword research for a local service
# 1. Discover keywords {"name":"keywords-explorer-matching-terms","arguments":{ "keywords":["water damage restoration"], "select":"keyword,volume,difficulty,cpc,traffic_potential", "country":"us", "limit":20, "order_by":"volume:desc" }} # 2. Check specific local terms {"name":"keywords-explorer-overview","arguments":{ "keywords":["water damage restoration vancouver wa","water damage portland or"], "select":"keyword,volume,difficulty,cpc", "country":"us" }}
Competitor analysis
# 1. Get domain metrics {"name":"site-explorer-metrics","arguments":{ "target":"competitor.com", "date":"2026-03-11" }} # 2. See what they rank for {"name":"site-explorer-organic-keywords","arguments":{ "select":"keyword,position,volume,traffic,url", "target":"competitor.com", "date":"2026-03-11", "country":"us", "limit":20, "order_by":"traffic:desc" }} # 3. Find their competitors {"name":"site-explorer-organic-competitors","arguments":{ "select":"domain,common_keywords,keywords_unique_to_target", "target":"competitor.com", "country":"us", "date":"2026-03-11", "limit":10 }}
Batch compare multiple domains
{"name":"batch-analysis","arguments":{ "select":"target,domain_rating,organic_traffic,organic_keywords", "targets":["site1.com","site2.com","site3.com"], "country":"us" }}
Check API budget
{"name":"subscription-info-limits-and-usage","arguments":{}}
Filter Syntax
The
where parameter uses a JSON filter expression:
{"field":"volume","is":["gte",100]}
Operators:
eq, neq, gt, gte, lt, lte, substring, isubstring, prefix, suffix, regex
Boolean combinators:
and, or, not
{"and":[ {"field":"volume","is":["gte",100]}, {"field":"difficulty","is":["lte",30]} ]}
MCP Config (correct)
The
~/.pi/agent/mcp.json entry should use the remote URL, not the npm package:
{ "ahrefs": { "url": "https://api.ahrefs.com/mcp/mcp", "headers": { "Authorization": "Bearer <from agent-secrets>" }, "lifecycle": "lazy" } }
NOT the npx command — that was the wrong setup. The npm
@ahrefs/mcp package does NOT work with Standard plan auth. The remote endpoint does.
Gotchas
- Empty results from
: This tool returns data only for keywords that exist exactly in Ahrefs' DB. Usekeywords-explorer-overview
for discovery,matching-terms
for metrics on known keywords.overview - CPC is in cents: A CPC of
= $1.90190
costs extra units: 10 units per row when included indifficultyselect- Date format: Always
YYYY-MM-DD - Country codes: Use ISO 2-letter codes (
,us
,gb
, etc.)au - The
tool is your friend: Always call it before using a new tool to get the real schemadoc
: The server explicitly rejects SSE. Use POST-based Streamable HTTP only.http+sse is not supported