SkillAgentSearch skills...

10xer

No description available

Install / Use

/learn @fortytwode/10xer
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

Facebook Ads MCP Server

A Model Context Protocol (MCP) server that provides Facebook Ads functionality for Claude and other MCP clients. Access your Facebook advertising data, insights, and account information directly through natural language conversations.

npm version License: MIT

🚀 Quick Start for Claude Desktop Users

1. Install the Server

npm install -g facebook-ads-mcp-server

2. Create Facebook Developer App

  1. Go to Facebook Developers
  2. Create a new app or use existing one
  3. Add "Facebook Login" product
  4. Configure OAuth settings:
    • Client OAuth Login: ON
    • Web OAuth Login: ON
    • Valid OAuth Redirect URIs: http://localhost:3002/auth/callback

3. Configure Claude Desktop

Add this to your Claude Desktop MCP settings:

{
  "mcpServers": {
    "facebook-ads": {
      "command": "facebook-ads-mcp",
      "env": {
        "FACEBOOK_APP_ID": "your_facebook_app_id",
        "FACEBOOK_APP_SECRET": "your_facebook_app_secret",
        "FACEBOOK_REDIRECT_URI": "http://localhost:3002/auth/callback"
      }
    }
  }
}

4. Restart Claude Desktop

After adding the configuration, restart Claude Desktop and start asking about your Facebook ads!

💬 Example Conversations with Claude

Once configured, you can ask Claude things like:

  • "Login to Facebook" (OAuth flow will open in browser)
  • "Check my Facebook authentication status"
  • "Show me all my Facebook ad accounts"
  • "What's the current balance and status of my main ad account?"
  • "Get performance insights for my ad account for the last 30 days"
  • "Show me recent activities on account act_123456"
  • "Logout from Facebook"

✨ Features

Authentication

  • OAuth Login: Secure browser-based Facebook authentication
  • Token Management: Automatic secure token storage and retrieval
  • Session Management: Login, logout, and authentication status checking
  • Production Security: Hardcoded tokens only allowed in test mode (NODE_ENV=test)

Facebook Ads Data

  • List Ad Accounts: Get all accessible Facebook ad accounts
  • Account Details: Get detailed information about specific ad accounts
  • Account Insights: Retrieve performance metrics and analytics data
  • Account Activities: Get activity logs for ad accounts
  • Pagination Support: Handle large datasets with automatic pagination

Installation

  1. Clone and install dependencies:

    cd facebook-ads-mcp
    npm install
    
  2. Configure environment:

    cp .env.example .env
    # Edit .env with your Facebook access token
    
  3. Get Facebook Access Token:

    • Visit Facebook Graph API Explorer
    • Select your app and generate a token with required permissions:
      • ads_read
      • ads_management
      • business_management

Usage

Running the Server

# Development mode with auto-restart
npm run dev

# Production mode
npm start

MCP Integration

Add to your MCP client configuration:

{
  "mcpServers": {
    "facebook-ads-mcp": {
      "command": "node",
      "args": ["src/index.js"],
      "cwd": "/path/to/facebook-ads-mcp",
      "env": {
        "FACEBOOK_ACCESS_TOKEN": "your_facebook_access_token"
      }
    }
  }
}

Available Tools

1. facebook_list_ad_accounts

Lists all Facebook ad accounts accessible with the provided credentials.

Parameters: None

Example:

// No parameters required
{}

Response:

{
  "adaccounts": {
    "data": [
      {
        "name": "My Ad Account",
        "id": "act_1234567890"
      }
    ]
  },
  "id": "user_id"
}

2. facebook_fetch_pagination_url

Fetches data from a Facebook Graph API pagination URL.

Parameters:

  • url (string, required): The complete pagination URL

Example:

{
  "url": "https://graph.facebook.com/v18.0/act_123/insights?after=cursor_string&access_token=..."
}

3. facebook_get_details_of_ad_account

Gets details of a specific ad account based on requested fields.

Parameters:

  • act_id (string, required): The ad account ID (e.g., "act_1234567890")
  • fields (array, optional): Fields to retrieve

Available Fields:

  • name, business_name, age, account_status, balance, amount_spent
  • attribution_spec, account_id, business, business_city
  • brand_safety_content_filter_levels, currency, created_time, id

Example:

{
  "act_id": "act_1234567890",
  "fields": ["name", "account_status", "balance", "currency"]
}

4. facebook_get_adaccount_insights

Retrieves performance insights for a specified Facebook ad account.

Parameters:

  • act_id (string, required): The ad account ID
  • fields (array, required): Performance metrics to retrieve
  • date_preset (string, optional): Predefined time range (last_7d, last_30d, etc.)
  • level (string, optional): Aggregation level (account, campaign, adset, ad)
  • breakdowns (array, optional): Result breakdown dimensions (placement, age, gender, country, etc.)
  • action_breakdowns (array, optional): Breakdown dimensions for actions/conversions
  • time_range (object, optional): Custom time range with since/until dates
  • time_increment (string/number, optional): Time aggregation period (1=daily, 7=weekly, "monthly"=monthly)
  • limit (number, optional): Maximum results per page
  • after/before (string, optional): Pagination cursors

Examples:

Basic Performance Data:

{
  "act_id": "act_1234567890",
  "fields": ["impressions", "clicks", "spend", "ctr"],
  "date_preset": "last_30d",
  "level": "campaign"
}

Performance by Placement with Conversions:

{
  "act_id": "act_1234567890", 
  "fields": ["spend", "actions", "conversions", "cost_per_action_type"],
  "breakdowns": ["placement"],
  "action_breakdowns": ["action_type"],
  "date_preset": "last_7d"
}

Demographic Analysis (Age/Gender):

{
  "act_id": "act_1234567890",
  "fields": ["spend", "actions", "conversions"],
  "breakdowns": ["age", "gender"], 
  "action_breakdowns": ["action_type"],
  "date_preset": "last_7d"
}

Daily Performance Breakdown:

{
  "act_id": "act_1234567890",
  "fields": ["spend", "actions", "conversions", "date_start", "date_stop"],
  "time_increment": 1,  // 1 = daily breakdown
  "date_preset": "last_30d"
}

🎯 Enhanced Conversion Tracking

This tool automatically enhances conversion tracking by:

Problem Solved: Custom events like start_trial often don't appear in the Facebook API's actions field but are available in the conversions field. Previously, requests for only actions would miss conversion events, leading to incomplete data.

Solution: When you request the actions field, the system automatically includes conversions as well, then uses a priority system:

  1. Priority 1: Checks conversions field (higher fidelity data)
  2. Priority 2: Falls back to actions field if conversion data unavailable
  3. Priority 3: Reports no match found

Example with Auto-Enhancement:

// Your request:
{
  "fields": ["spend", "actions"]
}

// Automatically becomes:
{
  "fields": ["spend", "actions", "conversions"]  // conversions auto-added
}

This ensures you capture conversion events like start_trial, purchase, and custom events that might only exist in the conversions field.

5. facebook_get_activities_by_adaccount

Retrieves activities for a Facebook ad account.

Parameters:

  • act_id (string, required): The ad account ID
  • fields (array, optional): Activity fields to retrieve
  • since/until (string, optional): Date range in YYYY-MM-DD format
  • time_range (object, optional): Custom time range object
  • limit (number, optional): Maximum activities per page

Example:

{
  "act_id": "act_1234567890",
  "fields": ["event_type", "event_time", "actor_name"],
  "since": "2024-01-01",
  "until": "2024-01-31"
}

Error Handling

The server provides detailed error responses with appropriate error codes:

  • FACEBOOK_API_ERROR: Facebook Graph API errors
  • VALIDATION_ERROR: Parameter validation failures
  • TIMEOUT_ERROR: Request timeout errors
  • INTERNAL_ERROR: Server-side errors

Environment Variables

# Required
FACEBOOK_ACCESS_TOKEN=your_facebook_access_token

# Optional
FACEBOOK_API_VERSION=v18.0
FACEBOOK_BASE_URL=https://graph.facebook.com
MCP_SERVER_NAME=facebook-ads-mcp
MCP_SERVER_VERSION=1.0.0
DEBUG=true
LOG_LEVEL=info

Testing

# Run test script
npm test

Facebook API Permissions

Ensure your access token has the following permissions:

  • ads_read: Read ad account data
  • ads_management: Manage ad accounts (if needed)
  • business_management: Access business information

Troubleshooting

Common Issues

  1. Invalid Access Token

    • Verify token in Graph API Explorer
    • Check token expiration
    • Ensure required permissions are granted
  2. API Rate Limiting

    • Facebook enforces rate limits on API calls
    • Implement appropriate delays between requests
  3. Permission Errors

    • Verify ad account access permissions
    • Check business manager roles

Debug Mode

Enable debug logging:

DEBUG=true npm start

Architecture

facebook-ads-mcp/
├── src/
│   ├── index.js                 # Main MCP server
│   ├── tools/                   # Tool implementations
│   │   ├── list-ad-accounts.js
│   │   ├── fetch-pagination.js
│   │   ├── get-account-details.js
│   │   ├── get-account-insights.js
│   │   └── get-
View on GitHub
GitHub Stars4
CategoryDevelopment
Updated15d ago
Forks0

Languages

JavaScript

Security Score

65/100

Audited on Mar 19, 2026

No findings