mcp-reddit-ads
Provides tools for managing Reddit Ads campaigns, ad groups, ads, performance reporting, and audience targeting via the Reddit Ads API.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-reddit-adsshow me my active campaigns"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-reddit-ads
MCP server for Reddit Ads API v3 -- campaign management, ad creation, performance reporting, and audience targeting via Claude.
Features
18 tools covering full CRUD for campaigns, ad groups, and ads
Performance reports with daily breakdowns
Subreddit, interest, and geographic targeting
Bulk pause/enable operations
Safe by default: all new entities created in PAUSED status
Budget inputs in dollars (auto-converts to Reddit's microcurrency format)
Related MCP server: synter-mcp-server
Installation
npm install mcp-reddit-adsOr clone the repository:
git clone https://github.com/mharnett/mcp-reddit-ads.git
cd mcp-reddit-ads
npm install
npm run buildConfiguration
Security: Never share your .mcp.json file or commit it to git -- it may contain API credentials. Add .mcp.json to your .gitignore.
1. Reddit OAuth App
Create a Reddit OAuth app at reddit.com/prefs/apps:
Select "script" type
Note the client ID and client secret
Obtain a refresh token with
adsread adsedit readscopes
2. Environment Variables
Set credentials via environment variables:
Variable | Description |
| OAuth app client ID |
| OAuth app client secret |
| OAuth refresh token with ads scopes |
| Set to |
Read-only by 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.
3. Config File
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.
Usage
Claude Code (.mcp.json)
{
"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).
Tools
Context
Tool | Description |
| Get account info and verify API connectivity |
| List all ad accounts accessible to the authenticated user |
Read
Tool | Description |
| List campaigns with optional status filter |
| List ad groups for a campaign |
| List ads for an ad group |
| Aggregated performance metrics for campaigns/ad groups/ads |
| Day-by-day performance breakdown |
Write: Campaigns
Tool | Description |
| Create a new campaign (PAUSED by default) |
| Update campaign name, budget, objective, or status |
Write: Ad Groups
Tool | Description |
| Create a new ad group with targeting (PAUSED by default) |
| Update ad group bid, targeting, or status |
Write: Ads
Tool | Description |
| Create a new ad with headline, body, URL, and media (PAUSED by default) |
| Update ad creative or status |
Bulk Operations
Tool | Description |
| Pause multiple campaigns, ad groups, or ads at once |
| Enable multiple campaigns, ad groups, or ads at once |
Targeting
Tool | Description |
| Search for subreddits by keyword for targeting |
| List available interest categories for targeting |
| Search for geographic targeting options (countries, regions, metros) |
Key Conventions
Spend values are returned from the API in microcurrency (1 dollar = 1,000,000 microcurrency units). Divide by 1,000,000 to get dollar amounts. Budget inputs accept dollars and auto-convert.
Dates and times use ISO 8601 format (
YYYY-MM-DDTHH:MM:SSZ).New entities default to PAUSED status. Explicitly set status to
ACTIVEto go live.Report metrics default to the set configured in
config.jsonbut can be overridden per request.
Architecture
Resilience: Uses cockatiel for retry policies and circuit breaking on API calls
Logging: Structured logging via pino
Response truncation: Large API responses are truncated at 200KB to stay within MCP message limits
Auth: OAuth 2.0 refresh token flow with automatic access token renewal
License
MIT -- see LICENSE.
Author
Built by Mark Harnett / drak-marketing.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/mharnett/mcp-reddit-ads'
If you have feedback or need assistance with the MCP directory API, please join our Discord server