meta-ads-manager-mcp
Allows creating and managing Facebook ad campaigns, including creating full campaigns with ad sets, creatives, and ads, checking status, pausing, activating, and deleting campaigns.
Allows creating and managing Instagram ad campaigns, utilizing the same tools for campaign, ad set, creative, and ad management.
Provides tools for creating and managing Meta (Facebook/Instagram) ad campaigns, including campaign creation, status checking, pausing, activating, and deleting.
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., "@meta-ads-manager-mcpCreate a campaign targeting US women 25-40 with daily budget $30."
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.
meta-ads-manager-mcp
MCP server for creating and managing Meta (Facebook/Instagram) ad campaigns directly from Claude. Tell Claude what you want. It deploys.
Built by Attainment Labs.
Status in the Meta Ads ecosystem
This is an early independent open source Meta Ads MCP server, first published in February 2026 before Meta later introduced its official Ads AI Connectors and hosted Ads MCP endpoint.
Use Meta's official connector if you want Meta-hosted OAuth and first-party support. Use this project if you want a lightweight, self-managed MCP server that you can inspect, fork, and run with your own Meta app credentials.
Related:
Related MCP server: Meta Ads MCP
What it does
Add this server to your Claude config. You get campaign creation, reporting, bulk operations, budget control, and safety tools:
Tool | What it does |
| Create a full campaign: campaign, ad set, creatives, and ads |
| Confirm connected ad account, currency, timezone, spend, balance, and status |
| List recent campaigns in the configured ad account |
| List recent ad sets in the configured ad account |
| List recent ads in the configured ad account |
| Check status of a campaign, its ad sets, and ads |
| Pull account, campaign, ad set, or ad performance insights |
| Upload an image and return the image hash for creatives |
| Update campaign or ad set daily budget |
| Bulk pause, activate, or delete campaigns |
| Pause a live campaign |
| Activate a paused campaign |
| Permanently delete a campaign |
All campaigns are created as PAUSED by default. You review before spending.
Safety controls:
dry_run=Trueby default on campaign creation, media upload, budget updates, and bulk status changes.confirm=Trueis required for live campaign creation, uploads, budget updates, activation, deletion, and bulk status changes.META_ADS_MAX_DAILY_BUDGET_CENTScan cap campaign and ad set daily budgets.META_ADS_AUDIT_LOG_PATHcan set a JSONL audit log path. Default is~/.meta-ads-mcp/audit.jsonl.
Install
Option 1: Let Claude set it up for you (easiest)
If you use Claude Code, paste this prompt:
"Set up meta-ads-mcp for me: https://github.com/attainmentlabs/meta-ads-mcp"
Claude will check your environment, walk you through getting your Meta credentials step by step, edit your ~/.mcp.json, and confirm when it's done. No docs to read.
Option 2: uvx (recommended, no install needed)
# No setup required. uvx runs it directlyAdd to ~/.mcp.json:
{
"mcpServers": {
"meta-ads": {
"command": "uvx",
"args": ["meta-ads-manager-mcp"],
"env": {
"META_ACCESS_TOKEN": "your-token-here",
"META_AD_ACCOUNT_ID": "your-account-id",
"META_PAGE_ID": "your-page-id",
"META_ADS_MAX_DAILY_BUDGET_CENTS": "5000"
}
}
}
}Option 2: pip install
pip install meta-ads-manager-mcpThen in ~/.mcp.json:
{
"mcpServers": {
"meta-ads": {
"command": "meta-ads-manager-mcp",
"env": {
"META_ACCESS_TOKEN": "your-token-here",
"META_AD_ACCOUNT_ID": "your-account-id",
"META_PAGE_ID": "your-page-id",
"META_ADS_MAX_DAILY_BUDGET_CENTS": "5000"
}
}
}
}Credentials
You need three values from Meta. Full step-by-step walkthrough: SETUP.md
Variable | Where to find it |
| Graph API Explorer. Long-lived token with |
| Business Manager: Ad Accounts. Numbers only, no |
| Facebook Page: About → Page transparency → Page ID |
| Optional daily budget guardrail |
| Optional JSONL audit log path |
The access token expires after 60 days. See SETUP.md for the exchange flow.
Usage examples
Once the server is connected, just describe what you want:
Create a campaign:
"Create a Meta campaign targeting US fitness enthusiasts aged 25-40. Daily budget $30. Use the image at /Users/me/ads/hero.jpg. Copy: 'Track every rep. Hit every goal.' Headline: 'FitCommit AI'. CTA: Learn More. Link to fitcommit.ai."
Check status:
"What's the status of campaign 120243616427570285?"
List campaigns:
"List my recent Meta campaigns."
Pull insights:
"Show Meta ad account insights for the last 7 days by campaign."
Update budget safely:
"Dry run a budget update to set ad set 120243616427570285 to $30 per day."
Bulk pause:
"Dry run pausing these three campaigns: 111, 222, 333."
Pause:
"Pause campaign 120243616427570285."
Activate:
"Go live with campaign 120243616427570285."
Delete:
"Delete campaign 120243616427570285."
dry_run mode
create_meta_campaign, upload_ad_image, update_daily_budget, and bulk_update_campaign_status default to dry_run=True. This simulates API calls and returns fake IDs or planned changes without making requests or spending money.
For live changes, set dry_run=False and confirm=True.
activate_campaign and delete_campaign also require confirm=True.
YAML workflow
Prefer writing campaigns as config files? Use meta-ads-cli, the companion CLI tool.
Requirements
Python 3.10+
uvfor the uvx install pathA Meta Business Manager account with an ad account and Facebook Page
License
MIT
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/attainmentlabs/meta-ads-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server