claude-meta-mcp

claude-meta-mcp

Self-hosted Meta Ads (Facebook & Instagram) connector for Claude.

Category
Visit Server

README

claude-meta-mcp

Self-hosted Meta Ads (Facebook & Instagram) connector for Claude. Bring your campaign data into Claude conversations — no SaaS middleman, no per-seat pricing, your tokens stay on your server.

CI License: MIT MCP Status

Status — v0.4.0 (single-tenant alpha). One Meta System User token, one shared Bearer secret, no database. Perfect for personal use or a single agency account. Multi-tenant + OAuth 2.1 + DCR are on the roadmap (see Roadmap).

v0.4 adds read-only Product Catalog tools (catalog discovery, feeds, products, diagnostics) on top of v0.3's full Ads CRUD and Instagram Business publishing. 47 tools across four surfaces — Ads, Pages, Instagram, Catalogs.


Why?

Existing options for connecting Meta Ads to Claude are either:

  • SaaS-only (Windsor.ai, Pipeboard) — your ad data flows through a third-party platform, monthly fees, vendor lock-in.
  • Local-only (most community MCP servers) — stdio transport, only works in Claude Desktop, can't be installed as a remote connector in claude.ai web.

claude-meta-mcp is a small, self-hostable Node service that:

  • Speaks MCP Streamable HTTP, so it works with claude.ai web and Claude Desktop alike.
  • Reads & writes Meta Ads (campaigns, ad sets, ads, creatives + image/video uploads), publishes & manages Facebook Page posts, publishes & moderates Instagram Business posts/reels/stories/carousels, and inspects Product Catalogs (feeds, products, diagnostics) for Dynamic Product Ads.
  • Is MIT licensed — fork it, sell it, embed it.

Quick start

Prerequisites

  • Node.js ≥ 20
  • A Meta Developer App with a System User token. For the full v0.4 toolset that's ads_read, ads_management, business_management, pages_*, instagram_* and catalog_management scopes → see docs/META_APP_SETUP.md for the full step-by-step
  • A public HTTPS URL (Claude requires HTTPS for custom connectors)

Install

git clone https://github.com/maxx3250/claude-meta-mcp.git
cd claude-meta-mcp
npm install
cp .env.example .env
# fill in META_ACCESS_TOKEN and generate AUTH_TOKEN:
echo "AUTH_TOKEN=$(openssl rand -hex 32)" >> .env
npm run build
node --env-file=.env dist/index.js

The server listens on PORT (default 3210) and exposes:

  • GET /health — liveness probe (no auth)
  • POST /mcp — MCP Streamable HTTP transport (Bearer auth)

Connect to Claude

  1. Put the service behind a reverse proxy that terminates TLS — see docs/DEPLOYMENT.md.
  2. In Claude → Settings → Connectors → Add custom connector.
  3. URL: https://your-domain.example.com/mcp
  4. Add header Authorization: Bearer <your AUTH_TOKEN> in the connector's advanced settings.
  5. Save. Tools should appear in the connector list.

Available tools

47 tools in v0.4 across four surfaces — Ads (read + write), Facebook Pages (read + write), Instagram Business (read + write), Product Catalogs (read).

Safety: every write tool that creates campaigns / ad sets / ads defaults to status: PAUSED. To go live you must explicitly pass status: "ACTIVE". This prevents an LLM from accidentally spending money.

Meta Ads — read

Tool What it does
list_ad_accounts List ad accounts the token has access to
get_ad_account Fetch one ad account's details (balance, currency, spend cap, …)
list_campaigns List campaigns inside an ad account, optionally filtered by status
get_campaign Fetch one campaign's full configuration
list_adsets List ad sets under a campaign or an ad account
list_ads List ads under a campaign, ad set, or ad account
get_insights Performance metrics (impressions, clicks, spend, CTR, CPC, CPM, reach, conversions) at any level, with date presets / custom ranges and breakdowns
list_creatives List ad creatives inside an ad account

Meta Ads — write & assets

Tool What it does
upload_ad_image Upload an image (URL or base64) to an ad account's library; returns image hash
list_ad_images List images in an ad account's library
upload_ad_video Upload a video (URL or base64) to an ad account; returns video id
get_video_processing_status Poll Meta's async transcoding status for an uploaded video
list_ad_videos List videos uploaded to an ad account
create_ad_creative Create an ad creative from a Page post or object_story_spec (link_data / video_data)
delete_ad_creative Delete an ad creative
create_campaign ⚠️ Create a campaign (default PAUSED, requires objective + special_ad_categories)
update_campaign ⚠️ Update name / status / budget / bid strategy on a campaign
delete_campaign ⚠️ Destructive — delete a campaign
create_adset ⚠️ Create an ad set with full targeting (geo, age, gender, interests, placements)
update_adset ⚠️ Update an ad set (status, budget, schedule, targeting)
delete_adset ⚠️ Destructive — delete an ad set
create_ad ⚠️ Create an ad bound to an ad set + creative (default PAUSED)
update_ad ⚠️ Update an ad's name, status, or bound creative
delete_ad ⚠️ Destructive — delete an ad
preview_ad Render a preview HTML iframe for any placement (DESKTOP_FEED_STANDARD, INSTAGRAM_STANDARD, …)

Facebook Pages (read & write)

Tool What it does
list_pages List Facebook Pages the System User manages
list_page_posts List recent posts on a Page (newest first)
get_page_insights Page-level metrics (impressions, engagement, follows, page views)
create_page_post ⚠️ Write — publishes a new post on a Page (text + optional link)
delete_page_post ⚠️ Destructive — deletes a post from a Page

Instagram Business (read & write)

Tool What it does
list_instagram_accounts List IG Business accounts linked to the managed Pages
list_instagram_posts List recent media on an IG account
get_instagram_insights Account-level metrics (reach, impressions, profile_views, …)
get_instagram_post_insights Per-post metrics (likes, saves, reach, plays for video/reels)
create_instagram_post ⚠️ Publish IMAGE / VIDEO / REELS / STORIES (2-phase: container + publish, with FINISHED-polling)
create_instagram_carousel ⚠️ Publish a 2–10-item carousel post
delete_instagram_media ⚠️ Destructive — delete an IG post / reel / story
list_instagram_comments List comments on an IG media
reply_instagram_comment ⚠️ Reply to a comment
delete_instagram_comment ⚠️ Destructive — delete a comment
hide_instagram_comment Hide / unhide a comment

Product Catalogs (read)

Tool What it does
list_businesses Discover Business Manager accounts via dedup over /me/adaccounts + /me/accounts (System User tokens get empty /me/businesses)
list_product_catalogs List catalogs owned by a Business (id, name, vertical, product_count, feed_count)
get_product_catalog Single catalog details with business edge
list_product_feeds Feeds attached to a catalog with latest_upload error/warning counts
list_catalog_products Paginated product listing with availability/condition filters (max 100/call, pass after cursor for next page)
get_catalog_diagnostics Aggregated catalog issues from /{catalog_id}/diagnostics; falls back to latest feed-upload error report when empty

get_insights is the workhorse. Examples (in plain English from Claude):

  • "What did we spend in the last 7 days, broken down by campaign?"
  • "Compare CTR across publisher_platform breakdown for campaign 12345 last month."
  • "Which ad sets had the worst CPM yesterday?"

Configuration

Variable Required Default Description
META_ACCESS_TOKEN yes Meta System User token (recommended, never expires) or long-lived user access token. Full v0.4 scopes: ads_read, ads_management, business_management, pages_show_list, pages_read_engagement, pages_manage_posts, pages_manage_metadata, instagram_basic, instagram_content_publish, instagram_manage_comments, instagram_manage_insights, catalog_management. Subsets are allowed — missing scopes simply make the matching tools return 403.
META_API_VERSION no v22.0 Graph API version
AUTH_TOKEN yes Shared bearer secret for POST /mcp. Generate with openssl rand -hex 32
PUBLIC_URL no http://localhost:3210 Public URL (currently informational; v0.2 will use it for OAuth callbacks)
PORT no 3210 TCP port to bind
LOG_LEVEL no info debug / info / warn / error

See .env.example.


How is this different from … ?

claude-meta-mcp Windsor.ai Pipeboard hashcott/meta-ads-mcp-server
Self-hosted
Remote claude.ai web partial
License MIT proprietary BSL 1.1 MIT
Your data leaves your server
Monthly fee $0 from $19 from $29 $0

<sub>As of May 2026, based on each project's public README and pricing page. Names and trademarks belong to their respective owners; comparison is informational only.</sub>


Architecture (v0.4)

┌─────────────────────┐     POST /mcp        ┌──────────────────────────┐
│  Claude.ai / Desktop│ ──────────────────►  │  Express + MCP server    │
│                     │  Bearer AUTH_TOKEN   │  StreamableHTTPTransport │
└─────────────────────┘                      │           │              │
                                             │           ▼              │
                                             │  Meta Graph API client   │
                                             │  (axios, v22.0)          │
                                             └─────────────┬────────────┘
                                                           │
                                                           ▼
                                             https://graph.facebook.com

No database. No state between requests. One Meta System User token, one Bearer token, 47 tools.

For sequence diagrams and the planned v1.0 multi-tenant architecture, see docs/ARCHITECTURE.md.


Roadmap

v0.2 — Pages support ✓ shipped

  • [x] list_pages, list_page_posts, get_page_insights, create_page_post, delete_page_post

v0.3 — Ads write + Instagram ✓ shipped

  • [x] Ads CRUD (campaigns, ad sets, ads, creatives)
  • [x] Image + video upload
  • [x] Instagram Business publishing (image / video / reel / story / carousel)
  • [x] Instagram comments (read / reply / delete / hide)

v0.4 — Product Catalogs (read) ✓ shipped (current)

  • [x] Business discovery via adaccount + page dedup
  • [x] Catalog + feed listing, single-catalog detail
  • [x] Product listing with availability/condition filters
  • [x] get_catalog_diagnostics (/{catalog_id}/diagnostics + feed-upload fallback)

v0.5 — Catalog writes + Signal Diagnostics

  • [ ] create_product_catalog, create_product_feed, update_product_feed_schedule
  • [ ] Pixel + CAPI health (list_pixels, get_pixel_stats, get_pixel_event_match_quality, get_capi_status)

v0.6 — proper auth

  • [ ] OAuth 2.1 with Dynamic Client Registration on the Claude side
  • [ ] .well-known/oauth-authorization-server discovery endpoint
  • [ ] Token issuance + refresh

v0.7 — multi-tenant

  • [ ] Meta OAuth user flow + 60-day token refresh
  • [ ] SQLite (then Postgres) for user → meta-token mapping
  • [ ] AES-256-GCM encryption at rest for stored tokens

v0.8 — performance

  • [ ] Insights pre-aggregation cache with smart invalidation
  • [ ] Background refresh for "yesterday and earlier" data

v1.0 — production-ready

  • [ ] Audit log, rate limiting per tenant
  • [ ] Prometheus /metrics endpoint
  • [ ] Health checks for downstream Meta API

Stretch

  • [ ] Google Ads connector under the same umbrella
  • [ ] TikTok Ads connector
  • [ ] LinkedIn Ads connector

Project layout

src/
├── index.ts             Express + MCP bootstrap, Bearer middleware
├── config.ts            Env validation
├── meta-client.ts       Graph API axios wrapper + pagination + multipart helpers
├── tools.ts             Read tools (Ads + Pages)
├── tools-write.ts       Ads write tools (campaigns/ad sets/ads/creatives + asset uploads)
├── tools-instagram.ts   Instagram Business tools (publish + comments + insights)
└── tools-catalogs.ts    Product Catalog read tools (businesses, catalogs, feeds, products, diagnostics)

docs/
├── ARCHITECTURE.md
├── DEPLOYMENT.md
└── META_APP_SETUP.md

ecosystem.config.cjs  pm2 example
.env.example          Configuration template

Development

npm run dev       # tsx watch mode
npm run build     # tsc → dist/
npm start         # node dist/index.js

Security notes

  • The Bearer token in AUTH_TOKEN is a single shared secret. Anyone with it can mutate ad campaigns, publish/delete posts on your Facebook Pages and Instagram Business accounts, and read your product catalogs via the connector. Treat it like a database password.
  • All write tools that create campaigns/ad sets/ads default to status: PAUSED. Activating an ad still costs nothing until you set status: "ACTIVE".
  • The connector's scopes are additive. If you only want a read-only Ads experience, omit ads_management and the IG/Pages write scopes from your System User token — the matching tools will then fail with 403 at runtime.
  • Always run behind HTTPS. Claude refuses to connect to non-TLS connectors anyway.
  • Rotate AUTH_TOKEN by editing .env and restarting the process.
  • Rotate META_ACCESS_TOKEN by revoking the System User token in Meta Business and minting a new one.

If you find a security issue, please email security@markusstoeger.com instead of opening a public issue.


Contributing

PRs welcome. See CONTRIBUTING.md for ground rules and CODE_OF_CONDUCT.md. Security issues should follow SECURITY.md, not the public issue tracker.


License

MIT © 2026 Markus Stöger


Acknowledgements

Inspired by the open MCP ecosystem and prior art in hashcott/meta-ads-mcp-server, pipeboard-co/meta-ads-mcp, and the Model Context Protocol team.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured