Server data from the Official MCP Registry
Reddit Ads MCP: campaigns, ad groups, ads, reporting, and audience targeting.
Reddit Ads MCP: campaigns, ad groups, ads, reporting, and audience targeting.
Valid MCP server (3 strong, 4 medium validity signals). 2 known CVEs in dependencies (0 critical, 2 high severity) Imported from the Official MCP Registry. 1 finding(s) downgraded by scanner intelligence.
4 files analyzed · 3 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: REDDIT_CLIENT_ID
Environment variable: REDDIT_CLIENT_SECRET
Environment variable: REDDIT_REFRESH_TOKEN
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-mharnett-reddit-ads": {
"env": {
"REDDIT_CLIENT_ID": "your-reddit-client-id-here",
"REDDIT_CLIENT_SECRET": "your-reddit-client-secret-here",
"REDDIT_REFRESH_TOKEN": "your-reddit-refresh-token-here"
},
"args": [
"-y",
"mcp-reddit-ads"
],
"command": "npx"
}
}
}From the project's GitHub README.
MCP server for Reddit Ads API v3 -- campaign management, ad creation, performance reporting, and audience targeting via Claude.
npm install mcp-reddit-ads
Or clone the repository:
git clone https://github.com/mharnett/mcp-reddit-ads.git
cd mcp-reddit-ads
npm install
npm run build
Security: Never share your .mcp.json file or commit it to git -- it may contain API credentials. Add .mcp.json to your .gitignore.
Create a Reddit OAuth app at reddit.com/prefs/apps:
adsread adsedit read scopesSet credentials via environment variables:
| Variable | Description |
|---|---|
REDDIT_CLIENT_ID | OAuth app client ID |
REDDIT_CLIENT_SECRET | OAuth app client secret |
REDDIT_REFRESH_TOKEN | OAuth refresh token with ads scopes |
REDDIT_ADS_MCP_WRITE | Set to true to enable mutating tools (create/update/pause/enable). Unset = read-only (default). |
As of v1.1.0 the MCP starts in read-only mode. The 10 read/report/targeting tools are always exposed, but the 8 mutating tools (create/update campaigns, ad groups, ads, and bulk pause/enable) are hidden from the tool list and refused at call time unless REDDIT_ADS_MCP_WRITE=true is set in the server's environment. This guards against a casual chat message accidentally mutating live ad spend. Enable writes deliberately, for the sessions where you actually intend to ship changes.
Copy config.example.json to config.json and fill in defaults:
{
"reddit_api": {
"base_url": "https://ads-api.reddit.com/api/v3",
"auth": {
"client_id": "",
"client_secret": "",
"refresh_token": "",
"user_agent": "reddit-ad-mcp/1.0"
}
},
"defaults": {
"account_id": "",
"business_id": "",
"report_metrics": ["impressions", "clicks", "spend", "ctr", "cpc", "ecpm"],
"date_range_days": 7
}
}
Environment variables take precedence over config file values.
{
"mcpServers": {
"reddit-ads": {
"command": "node",
"args": ["/path/to/mcp-reddit-ads/dist/index.js"],
"env": {
"REDDIT_CLIENT_ID": "$(security find-generic-password -a reddit-ads-mcp -s REDDIT_CLIENT_ID -w)",
"REDDIT_CLIENT_SECRET": "$(security find-generic-password -a reddit-ads-mcp -s REDDIT_CLIENT_SECRET -w)",
"REDDIT_REFRESH_TOKEN": "$(security find-generic-password -a reddit-ads-mcp -s REDDIT_REFRESH_TOKEN -w)"
}
}
}
}
Claude Desktop: Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows).
| Tool | Description |
|---|---|
reddit_ads_get_client_context | Get account info and verify API connectivity |
reddit_ads_get_accounts | List all ad accounts accessible to the authenticated user |
| Tool | Description |
|---|---|
reddit_ads_get_campaigns | List campaigns with optional status filter |
reddit_ads_get_ad_groups | List ad groups for a campaign |
reddit_ads_get_ads | List ads for an ad group |
reddit_ads_get_performance_report | Aggregated performance metrics for campaigns/ad groups/ads |
reddit_ads_get_daily_performance | Day-by-day performance breakdown |
| Tool | Description |
|---|---|
reddit_ads_create_campaign | Create a new campaign (PAUSED by default) |
reddit_ads_update_campaign | Update campaign name, budget, objective, or status |
| Tool | Description |
|---|---|
reddit_ads_create_ad_group | Create a new ad group with targeting (PAUSED by default) |
reddit_ads_update_ad_group | Update ad group bid, targeting, or status |
| Tool | Description |
|---|---|
reddit_ads_create_ad | Create a new ad with headline, body, URL, and media (PAUSED by default) |
reddit_ads_update_ad | Update ad creative or status |
| Tool | Description |
|---|---|
reddit_ads_pause_items | Pause multiple campaigns, ad groups, or ads at once |
reddit_ads_enable_items | Enable multiple campaigns, ad groups, or ads at once |
| Tool | Description |
|---|---|
reddit_ads_search_subreddits | Search for subreddits by keyword for targeting |
reddit_ads_get_interest_categories | List available interest categories for targeting |
reddit_ads_search_geo_targets | Search for geographic targeting options (countries, regions, metros) |
YYYY-MM-DDTHH:MM:SSZ).ACTIVE to go live.config.json but can be overridden per request.MIT -- see LICENSE.
Built by Mark Harnett / drak-marketing.
Be the first to review this server!
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace · Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm — conversationally
by mcp-marketplace · Finance
Free stock data and market news for any MCP-compatible AI assistant.
by Taylorwilsdon · Productivity
Control Gmail, Calendar, Docs, Sheets, Drive, and more from your AI