op3-mcp
op3-mcp
Podcast analytics for AI agents through OP3: downloads over time, listener geography, apps, and per-episode breakdowns. Read-only.
An MCP server for OP3, the Open Podcast Prefix Project. It gives AI assistants podcast analytics that most hosting APIs do not expose: downloads over time, listener geography, the apps people listen in, and per-episode breakdowns.
Read-only by design. OP3 is an analytics service. This server only reads data. It cannot change anything, so it is safe to give an agent.
Why this exists. Most podcast hosts expose almost nothing through their API. Transistor's API, for example, returns download counts and not much else: no geography, no app share, no per-episode recency curve. OP3 has all of that, because it logs each download at the redirect. This server puts that data in front of an agent.
What is OP3?
OP3 is a free, open analytics prefix for podcasts. You add https://op3.dev/e/ in front of your enclosure URLs, and OP3 logs each download before redirecting to your real audio file. It then reports downloads, geography, and app share. Stats pages are public; the API needs a token. See https://op3.dev for details.
If your feed does not use the OP3 prefix yet, OP3 has no data for it. See "Adding the OP3 prefix" below.
Related MCP server: Umami MCP Server
Tools
Tool | What it returns | OP3 endpoint |
| Show UUID, title, podcast GUID, stats page URL, optional episode list |
|
| Monthly downloads, weekly breakdown, weekly average |
|
| Per-episode downloads at 1/3/7/30 days and all-time |
|
| Top apps/players by download share, last 3 calendar months |
|
| Top listener countries or regions (computed from raw records) |
|
| Raw download events over a date range (time, country, app, device) |
|
Most tools need a show UUID. Start with op3_get_show to turn a feed URL or podcast GUID into a UUID.
Every list tool takes a limit and defaults it low (10) to keep responses small. Agents pay tokens per response.
Setup
1. Get a token
Go to https://op3.dev and sign in.
Open your API token page and copy the token.
For trying things out, OP3 also publishes a shared preview token,
preview07ce, which works against public shows.
2. Find your show UUID
If you know your feed URL or podcast GUID, ask the assistant to run op3_get_show with it and it will return your UUID. You can also read the UUID from your show's OP3 stats page URL: https://op3.dev/show/{showUuid}.
3. Configure your MCP client
Claude Code
Add to your .mcp.json:
{
"mcpServers": {
"op3": {
"command": "npx",
"args": ["-y", "@conorbronsdon/op3-mcp"],
"env": {
"OP3_API_TOKEN": "your-op3-token"
}
}
}
}Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"op3": {
"command": "npx",
"args": ["-y", "@conorbronsdon/op3-mcp"],
"env": {
"OP3_API_TOKEN": "your-op3-token"
}
}
}
}4. Verify
Ask your assistant: "Look up my show on OP3" with your feed URL, then "How many downloads did it get last month?"
Adding the OP3 prefix (if you are not on OP3 yet)
OP3 only has data once downloads route through its prefix. To start:
In your podcast host, prepend
https://op3.dev/e/to your episode audio URLs. Many hosts (Transistor, Buzzsprout, and others) have a one-click OP3 toggle. Check your host's settings for an "OP3" or "analytics prefix" option.New downloads will start being logged. Historical downloads from before you added the prefix are not backfilled.
Find your show on https://op3.dev and note its stats page URL, which contains your show UUID.
Limitations
Read these so you know what the numbers mean.
Geography is a computed sample, not an exact total. OP3 has no country-level aggregate endpoint.
op3_top_countriespulls raw download records and counts them by country on the client side. The result is representative, not a precise lifetime figure. OP3 returns raw records oldest-first, so the tool defaults to the last 90 days (window_days) when you do not pass an explicitstart— otherwise the sample would be the show's oldest downloads, not recent listeners. Within the window, records are still sampled oldest-first, so on a high-volume show amax_recordssample skews toward the start of the window; the response includessampleHitCapso you can tell when the window held more records than were sampled. Raisemax_records(cap 20000) for a larger, more representative sample at the cost of speed and rate-limit headroom.No device breakdown tool. OP3's raw records include a
deviceTypeanddeviceName, but there is no aggregate device query. You can see per-record device info viaop3_downloads_timeseries. App share is available and exposed throughop3_top_apps.Top apps covers the last three calendar months only. That window is fixed by OP3, not configurable.
Data starts when the prefix was added. OP3 cannot report on downloads that never went through its redirect.
Bots are excluded by default in OP3's download queries, which is usually what you want.
Rate limits are not publicly documented. Keep
limitandmax_recordsmodest. The server surfaces a clear error on HTTP 429.
Development
git clone https://github.com/conorbronsdon/op3-mcp.git
cd op3-mcp
npm install
npm run build
npm testRun locally:
OP3_API_TOKEN=your-token npm startTests mock fetch and make no network calls.
Contributing
Issues and pull requests are welcome. If an OP3 endpoint changes shape, or there is an aggregate query worth wrapping as a tool, open an issue describing what you want and the OP3 endpoint it maps to. Keep the read-only contract: this server reports analytics, it does not change anything.
About
Built and maintained by Conor Bronsdon. I host the Chain of Thought podcast, which covers AI infrastructure, developer tools, and how practitioners actually use this stuff. I built this to pull honest listener analytics into the agent workflows that run the show.
Companion tools:
podcast-benchmark: benchmark your show against peers on public signals. The public-data complement to your own private OP3 analytics here.
Transistor-MCP: the Transistor.fm MCP server. Episodes, transcripts, and the download counts that OP3 fills out with geography and apps.
substack-mcp: read posts and manage drafts on Substack, safe for agent workflows.
podcastindex-mcp: the Podcast Index MCP server, search by person or topic, trending shows, feed health.
ai-tools-for-creators: a curated list of AI skills and MCP servers for people who ship ideas for a living.
More at chainofthought.show and on X.
Disclaimer
All views, opinions, and statements expressed on this account are solely my own and are made in my personal capacity. They do not reflect, and should not be construed as reflecting, the views, positions, or policies of Modular. This account is not affiliated with, authorized by, or endorsed by Modular in any way.
License
MIT
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/conorbronsdon/op3-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server