Sponsored by Deepsite.site

Instagram Mcp Server

Created By
drashrafsaiyed-cyber18 days ago
Control your Instagram from Claude — publish photos, reels, carousels, read insights, manage comments and DMs. 14 tools via Instagram Login API. One-click free Render deploy for Claude Web and mobile.
Overview

📸 Instagram MCP Server

Control your Instagram from Claude — post, analyze, reply to DMs, manage comments. All by chatting.

License: MIT Python 3.11+ MCP Deploy to Render


🎬 Demo GIF coming soon — Claude posting a reel, reading insights, replying to comments live on screen.


What You Can Do

Ask Claude in plain English. It handles the API.

"Show my last 10 posts and which got the most reach"
"Post this image with caption: Monday motivation 💪 #AI #Health"
"Read my DMs from today and draft replies for the questions"
"Hide all spam comments on my latest reel"
"What are my account insights for this week?"
"Which of my reels got the best watch time?"

Use Cases

📊 Content Creator

  • Morning briefing: "Show yesterday's post performance — reach, saves, shares"
  • Strategy: "Compare my last 5 reels by reach and tell me what worked"
  • Scheduling prep: "Draft 3 caption options for this fitness post"

🏥 Doctor / Professional

  • Engagement: "Reply to all comments on my last post professionally"
  • Growth tracking: "How many followers did I gain this week?"
  • Content audit: "List all posts from this month with their engagement rates"

🛍️ Small Business

  • Customer service: "Show DMs from the last 24 hours and reply to order questions"
  • Publishing: "Post this product photo with this caption and these hashtags"
  • Analytics: "Which post type (reel/carousel/photo) gets me the most reach?"

Tools (14 total)

CategoryToolWhat it does
Accountget_account_infoFollowers, bio, post count
update_profileUpdate bio text and/or website URL
list_recent_mediaLast N posts with engagement stats
get_account_insightsReach, profile views, follower growth
Insightsget_media_insightsPer-post reach, saves, views, interactions
Publishingpublish_photoPost a photo with caption + hashtags
publish_reelPost a Reel (video)
publish_carouselPost 2–10 images as carousel
Commentsget_commentsRead all comments on a post
reply_to_commentReply to a comment
hide_commentHide spam/unwanted comments
delete_commentPermanently delete a comment
Engagementlike_mediaLike a post or reel
unlike_mediaUnlike a post or reel
like_commentLike a comment
Contentdelete_postPermanently delete a post
Hashtagssearch_hashtagSearch public posts by hashtag
Eventslist_eventsList upcoming events
create_eventCreate a new event (health camps, workshops)
Adsget_ad_accountsList linked ad accounts
get_ad_insightsGet ad spend, reach, CTR
DMslist_conversationsList active DM threads
get_messagesRead messages in a thread
send_dmReply to a DM (24h window)
send_human_agent_dmReply within 7-day Human Agent window

Quick Start

1. Deploy your server (free, 2 min):

Deploy to Render

Fill in META_ACCESS_TOKEN and IG_USER_ID when prompted. (How to get these ↓)

2. Connect to Claude web:

  • claude.ai → Settings → Integrations → Add Integration
  • Paste: https://your-app-name.onrender.com/mcp

3. Done. Open a new chat and try: "Show my recent Instagram posts"


Option B — Claude Desktop (Local)

git clone https://github.com/drashrafsaiyed-cyber/instagram-mcp
cd instagram-mcp
uv sync
cp .env.example .env
# Fill .env with your token and user ID
uv run server.py

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "instagram": {
      "command": "uv",
      "args": ["--directory", "/path/to/instagram-mcp", "run", "server.py"],
      "env": {
        "META_ACCESS_TOKEN": "your_token",
        "IG_USER_ID": "your_ig_user_id",
        "ACCOUNT_NAME": "My Instagram"
      }
    }
  }
}

Option C — Multiple Instagram Accounts (Claude Desktop)

Run the same server folder multiple times with different env vars. Claude sees each as a separate named MCP and never confuses them.

{
  "mcpServers": {
    "instagram-personal": {
      "command": "uv",
      "args": ["--directory", "/path/to/instagram-mcp", "run", "server.py"],
      "env": {
        "META_ACCESS_TOKEN": "TOKEN_FOR_ACCOUNT_1",
        "IG_USER_ID": "IG_USER_ID_1",
        "ACCOUNT_NAME": "Personal"
      }
    },
    "instagram-business": {
      "command": "uv",
      "args": ["--directory", "/path/to/instagram-mcp", "run", "server.py"],
      "env": {
        "META_ACCESS_TOKEN": "TOKEN_FOR_ACCOUNT_2",
        "IG_USER_ID": "IG_USER_ID_2",
        "ACCOUNT_NAME": "My Business"
      }
    }
  }
}

Claude will show separate tools per account — "Post this to My Business" picks the right one automatically.

Each account must be a Business or Creator Instagram account, and must be added as a tester in your Meta app → Use cases → Step 2: Generate access tokens → Add account.


Getting Your Token

This server uses the Instagram Login API (graph.instagram.com) — the modern Meta approach for Instagram Business/Creator accounts.

Step 1 — Create or open your Meta app

  1. Go to developers.facebook.com → My Apps
  2. Create a new app or open an existing one
  3. Add use case: "Manage messaging & content on Instagram"

Step 2 — Generate your access token

  1. Use cases → Customize → API Setup with Instagram Login
  2. Step 2: Generate access tokens → click Generate next to your account
  3. Copy the token → this is your META_ACCESS_TOKEN
  4. Your numeric IG User ID is shown below your username on the same page

Step 3 — Refresh before expiry (60 days)

curl "https://graph.instagram.com/refresh_access_token?grant_type=ig_refresh_token&access_token=YOUR_TOKEN"

Or just run this in your project folder:

uv run python -c "
import httpx, re
from pathlib import Path
env = Path('.env').read_text()
token = re.search(r'META_ACCESS_TOKEN=(.+)', env).group(1).strip()
r = httpx.get('https://graph.instagram.com/refresh_access_token', params={'grant_type':'ig_refresh_token','access_token':token})
new = r.json()['access_token']
Path('.env').write_text(env.replace(token, new))
print('Refreshed. Expires in:', r.json()['expires_in']//86400, 'days')
"

Requirements

  • Instagram Business or Creator account
  • Meta Developer app with "Manage messaging & content on Instagram" use case
  • Python 3.11+

Publishing note: Images and videos must be at a public HTTPS URL — Instagram fetches from your URL. Use Cloudinary (free), S3, or a public GitHub raw URL. Local file paths won't work.


Architecture

Claude (Web/Desktop)
      │  MCP protocol
instagram-mcp server  (FastMCP 3.x, streamable-http or stdio)
      │  HTTPS REST
graph.instagram.com   (Instagram Login API v21.0)
Your Instagram account

Why graph.instagram.com and not graph.facebook.com? This server uses the newer Instagram Login API which issues IGAA... tokens and routes through graph.instagram.com. The older Facebook Graph API approach required a linked Facebook Page and EAA... tokens. The new flow is simpler — just your Instagram account, no Facebook Page needed.


Troubleshooting

ErrorFix
Cannot parse access tokenToken expired or wrong type. Regenerate via the steps above.
code 100 on insightsInvalid metric name. Metrics differ between account vs media endpoints.
code 190Token expired. Run the refresh command.
Container processing failedVideo too long (>90s), wrong codec, or URL returns 404 after first fetch.
Empty DM listNo active 24h messaging window. Someone needs to DM you first.
Claude doesn't see toolsRestart Claude Desktop fully (tray icon → Quit). Check logs at %APPDATA%\Claude\logs\.

Contributing

PRs welcome. If you add a new tool or fix a metric name mismatch, please:

  1. Test against a real Instagram account
  2. Update the tool table in this README
  3. Note which API permission the new tool requires

License

MIT — free to use, fork, and deploy commercially.


Built with FastMCP · Powered by Instagram Graph API

Server Config

{
  "mcpServers": {
    "instagram": {
      "type": "streamable-http",
      "url": "https://your-app.onrender.com/mcp"
    }
  }
}
Recommend Servers
TraeBuild with Free GPT-4.1 & Claude 3.7. Fully MCP-Ready.
AiimagemultistyleA Model Context Protocol (MCP) server for image generation and manipulation using fal.ai's Stable Diffusion model.
Baidu Map百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
WindsurfThe new purpose-built IDE to harness magic
ChatWiseThe second fastest AI chatbot™
DeepChatYour AI Partner on Desktop
EdgeOne Pages MCPAn MCP service designed for deploying HTML content to EdgeOne Pages and obtaining an accessible public URL.
Serper MCP ServerA Serper MCP Server
Jina AI MCP ToolsA Model Context Protocol (MCP) server that integrates with Jina AI Search Foundation APIs.
MCP AdvisorMCP Advisor & Installation - Use the right MCP server for your needs
RedisA Model Context Protocol server that provides access to Redis databases. This server enables LLMs to interact with Redis key-value stores through a set of standardized tools.
Zhipu Web SearchZhipu Web Search MCP Server is a search engine specifically designed for large models. It integrates four search engines, allowing users to flexibly compare and switch between them. Building upon the web crawling and ranking capabilities of traditional search engines, it enhances intent recognition capabilities, returning results more suitable for large model processing (such as webpage titles, URLs, summaries, site names, site icons, etc.). This helps AI applications achieve "dynamic knowledge acquisition" and "precise scenario adaptation" capabilities.
CursorThe AI Code Editor
Visual Studio Code - Open Source ("Code - OSS")Visual Studio Code
MiniMax MCPOfficial MiniMax Model Context Protocol (MCP) server that enables interaction with powerful Text to Speech, image generation and video generation APIs.
Tavily Mcp
Y GuiA web-based graphical interface for AI chat interactions with support for multiple AI models and MCP (Model Context Protocol) servers.
Amap Maps高德地图官方 MCP Server
Howtocook Mcp基于Anduin2017 / HowToCook (程序员在家做饭指南)的mcp server,帮你推荐菜谱、规划膳食,解决“今天吃什么“的世纪难题; Based on Anduin2017/HowToCook (Programmer's Guide to Cooking at Home), MCP Server helps you recommend recipes, plan meals, and solve the century old problem of "what to eat today"
Playwright McpPlaywright MCP server
BlenderBlenderMCP connects Blender to Claude AI through the Model Context Protocol (MCP), allowing Claude to directly interact with and control Blender. This integration enables prompt assisted 3D modeling, scene creation, and manipulation.