
instagram-mcp
โ 5from AleemHaider
Instagram Graph API server for Business/Creator accounts โ 24 tools for posting, comments, DMs, and insights.
instagram-mcp
A Model Context Protocol server that wraps the Instagram Graph API so Claude (or any MCP client) can read, publish, comment, DM, and pull insights from an Instagram Business or Creator account.
24 tools across five capability areas โ profile/media, publishing, comments, DMs, and insights โ built on FastMCP + httpx.
Connect to Claude Desktop
Edit ~/.config/Claude/claude_desktop_config.json (Linux) or
~/Library/Application Support/Claude/claude_desktop_config.json (macOS):
{
"mcpServers": {
"instagram": {
"command": "instagram-mcp",
"env": {
"IG_USER_ID": "17841446575432302",
"IG_ACCESS_TOKEN": "EAAxxxxxxxxxxxxxxxxxxx"
}
}
}
}
Restart Claude Desktop. You should see 24 tools under the instagram server.
Available tools
Profile & media
Tool What it does
get_my_profile Profile info: bio, followers, media count, etc.
list_my_media One page of recent posts
list_all_media Auto-paginate through all media
get_media Fetch a single media item
list_tagged_media Posts the account is tagged in
list_stories Currently-live stories (24h window)
Hashtags
Tool What it does
search_hashtag Resolve a #tag to its ID
hashtag_top_media Top-ranked posts for a hashtag
hashtag_recent_media Recent posts for a hashtag (24h window)
Publishing
Tool What it does
publish_image Single image post from a public URL
publish_reel Reel (waits for container processing)
publish_story Image or video story
publish_carousel 2-10 item carousel
get_publish_limit Show 24h publish quota usage
Comments
Tool What it does
list_comments Top-level comments + nested replies
get_comment_replies Replies under a specific comment
reply_to_comment Post a reply
hide_comment Hide / unhide
delete_comment Delete a comment you own
Direct messages
Tool What it does
list_conversations DM conversations
get_conversation Messages in a conversation
send_dm Send a DM (optionally with a message_tag)
Insights
Tool What it does
get_account_insights Account-level metrics with optional metric_type
get_media_insights Per-media insights
Notes & gotchas
-
Publishing requires public HTTPS URLs. Meta fetches media server-side. Host your images/videos on a publicly accessible URL first.
-
Publish quota is 100 posts per 24h rolling window on most Business accounts.
-
send_dmis response-only by default โ it only works inside the 24h user-initiated window. Pass amessage_tag(e.g.HUMAN_AGENT) to send outside that window. Tags require Meta approval. -
Some insight metrics need
metric_type='total_value'(Meta tightened this in 2024):views,accounts_engaged,total_interactions,profile_views,likes,comments,shares,saves.reachandfollower_countdon't. -
Errors return a structured dict, not exceptions. Look for
error: truealong withstatus,message,code,subcode, andfbtrace_idin the response โ that's the Graph API error, not a Python traceback.
Development
git clone https://github.com/AleemHaider/instagram-mcp
cd instagram-mcp
python -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]"
pytest
License
MIT โ see LICENSE.
pip install instagram-mcpBefore it works, you'll need: IG_USER_IDIG_ACCESS_TOKEN
Quick install
pip install instagram-mcp
Or with uv:
uv tool install instagram-mcp
Setup
1. Create a Meta App
-
Go to https://developers.facebook.com/apps โ Create app โ use case Other โ type Business.
-
In the app dashboard, add the Instagram product (Add Product โ Instagram โ Set up).
2. Link an Instagram Business/Creator account
You need an Instagram account switched to Business or Creator, linked to a Facebook Page. In the app dashboard, walk through Instagram โ API setup with Facebook login โ Step 1: Generate access tokens and link your account.
3. Get the required permissions
Generate a token with these scopes (in Graph API Explorer or the Instagram API setup page):
-
instagram_basic -
instagram_content_publish -
instagram_manage_comments -
instagram_manage_messages -
instagram_manage_insights -
pages_show_list -
pages_read_engagement -
business_management
While your app is in Development mode, only accounts in your app's Roles list (admins/developers/testers) can authenticate. That's fine for personal use. For other users, you need App Review with Advanced Access.
4. Mint a long-lived Page token
The fastest way: run the bundled helper.
instagram-mcp-get-token
It will ask for your short-lived user token + app ID/secret, exchange it for a
long-lived user token, list your linked IG accounts, and write .env for you.
Manual alternative:
# Exchange short-lived user token โ long-lived (~60 days)
curl -G "https://graph.facebook.com/v21.0/oauth/access_token" \
--data-urlencode "grant_type=fb_exchange_token" \
--data-urlencode "client_id=YOUR_APP_ID" \
--data-urlencode "client_secret=YOUR_APP_SECRET" \
--data-urlencode "fb_exchange_token=SHORT_LIVED_TOKEN"
# Find your Pages and their IG accounts
curl -G "https://graph.facebook.com/v21.0/me/accounts" \
--data-urlencode "fields=name,instagram_business_account,access_token" \
--data-urlencode "access_token=LONG_LIVED_USER_TOKEN"
Use the Page's access_token (never expires) and the
instagram_business_account.id of the linked IG account.
5. Configure .env
IG_USER_ID=17841446575432302
IG_ACCESS_TOKEN=EAAxxxxxxxxxxxxxxxxxxx
IG_GRAPH_VERSION=v21.0
IG_GRAPH_HOST=graph.facebook.com
Set IG_GRAPH_HOST=graph.instagram.com if your token came from the Instagram
Login path instead of Facebook Login.
No common issues documented yet. If you hit a problem, the repository's GitHub Issues page is the best place to look.