Instagram DMs

Send Instagram DMs via your LLM

{{ message }}

trypeggy / instagram_dm_mcp Public

  • Notifications
  • Fork16
  • Star 87

Instagram Direct messages MCP

tally.so/r/mR18zl

MIT license

87 stars16 forksBranches Tags Activity

Star

Notifications

main

BranchesTags

Go to file

Code

NameNameLast commit messageLast commit date
27 Commits
srcsrc
.gitignore.gitignore
.python-version.python-version
LICENSELICENSE
env.exampleenv.example
pyproject.tomlpyproject.toml
readme.mdreadme.md
requirements.txtrequirements.txt
setup_env.pysetup_env.py
uv.lockuv.lock
View all files

Repository files navigation

Instagram DM MCP server

This is a Model Context Protocol (MCP) server for sending instagram Direct Messages.

With this you can send Instagram Direct Messages from your account (more capabilities coming soon).

Here's an example of what you can do when it's connected to Claude.

Instagram_DM_MCP_Demo-2.mp4

To get updates on this and other projects we work on enter your email here

PS: Join our Twitter community for all things MCP


Hackathon Submission

Build anything using this Instagram DM MCP (can be technical, no-code or low-code) and submit!

No restrictions, open to anyone/anywhere to join.

Submit now

Note: submisions due by Friday 27 June 11:59PM PST

Three cash prizes up for grabs

  1. $5k USD - Breaking the internet (go viral AF)
  2. $2.5k USD - Technical Sorcery (coolest technical implementation)
  3. $2.5k USD - Holy Sh*t Award (make our jaws drop)

Installation

Prerequisites

  • Python 3.11+
  • Anthropic Claude Desktop app (or Cursor)
  • Pip (Python package manager), install with python -m pip install
  • An instagram account

Steps

  1. Clone this repository
    git clone https://github.com/trypeggy/instagram_dm_mcp.git
    cd instagram_dm_mcp
  2. Install dependencies
  • Using uv (recommended):
    uv sync
  • Using Pip:
    pip install -r requirements.txt
  1. Configure Instagram credentials
    You have two options for providing your Instagram credentials:
    Option A: Environment Variables (Recommended)
    Quick Setup (Recommended):
    Run the helper script:
    python setup_env.py
    This will interactively prompt you for your credentials and create the .env file securely.
    Manual Setup:
    Create a .env file in the project root:
    cp env.example .env
    Then edit .env with your actual credentials:
INSTAGRAM_USERNAME=your_instagram_username  
INSTAGRAM_PASSWORD=your_instagram_password  

Option B: Command Line Arguments
You can still pass credentials as command line arguments (less secure). 2. Connect to the MCP server
For Claude Desktop:
Save this as claude_desktop_config.json in your Claude Desktop configuration directory at:

~/Library/Application Support/Claude/claude_desktop_config.json  

For Cursor:
Save this as mcp.json in your Cursor configuration directory at:

~/.cursor/mcp.json  

Configuration with Environment Variables (Recommended):

  • Using uv
    {
    "mcpServers": {
    "instagram_dms": {
    "command": "uv",
    "args": [
    "run",
    "--directory",
    "PATH/TO/instagram_dm_mcp",
    "python",
    "src/mcp_server.py"
    ]
    }
    }
    }
  • Using Python
    {
    "mcpServers": {
    "instagram_dms": {
    "command": "python",
    "args": [
    "{{PATH_TO_SRC}}/instagram_dm_mcp/src/ mcp_server.py"
    ]
    }
    }
    }
    Configuration with Command Line Arguments:
    {
    "mcpServers": {
    "instagram_dms": {
    "command": "python",
    "args": [
    "{{PATH_TO_SRC}}/instagram_dm_mcp/src/mcp_server.py",
    "--username",
    "{{YOUR_INSTAGRAM_USERNAME}}",
    "--password",
    "{{YOUR_INSTAGRAM_PASSWORD}}"
    ]
    }
    }
    }
  1. Restart Claude Desktop / Cursor
    Open Claude Desktop and you should now see the Instagram DM MCP as an available integration.
    Or restart Cursor.

Usage

Below is a list of all available tools and what they do:

Tool NameDescription
send_messageSend an Instagram direct message to a user by username.
send_photo_messageSend a photo as an Instagram direct message to a user by username.
send_video_messageSend a video as an Instagram direct message to a user by username.
list_chatsGet Instagram Direct Message threads (chats) from your account, with optional filters/limits.
list_messagesGet messages from a specific Instagram Direct Message thread by thread ID. Now exposes item_type and shared post/reel info for each message. Use this to determine which download tool to use.
download_media_from_messageDownload a direct-uploaded photo or video from a DM message (not for shared posts/reels/clips).
download_shared_post_from_messageDownload media from a shared post, reel, or clip in a DM message (not for direct uploads).
list_media_messagesList all messages containing direct-uploaded media (photo/video) in a DM thread.
mark_message_seenMark a specific message in an Instagram Direct Message thread as seen.
list_pending_chatsGet Instagram Direct Message threads from your pending inbox.
search_threadsSearch Instagram Direct Message threads by username or keyword.
get_thread_by_participantsGet an Instagram Direct Message thread by participant user IDs.
get_thread_detailsGet details and messages for a specific Instagram Direct Message thread by thread ID.
get_user_id_from_usernameGet the Instagram user ID for a given username.
get_username_from_user_idGet the Instagram username for a given user ID.
get_user_infoGet information about a specific Instagram user by username.
search_usersSearch for Instagram users by username
get_user_storiesGet recent stories from a specific Instagram user by username.
like_mediaLike or unlike a specific media post by media ID.
get_user_followersGet a list of followers for a specific Instagram user by username.
get_user_followingGet a list of users that a specific Instagram user is following by username.
get_user_postsGet recent posts from a specific Instagram user by username.

Troubleshooting

Instagram Login Hanging: The server now includes automatic session management to prevent login hangs. Session files (e.g., username_session.json) are automatically created and reused to maintain authentication state between runs.

For additional Claude Desktop integration troubleshooting, see the MCP documentation. The documentation includes helpful tips for checking logs and resolving common issues.


Feedback

Your feedback will be massively appreciated. Please tell us which features on that list you like to see next or request entirely new ones.


License

This project is licensed under the MIT License.

License Python

About

github python instagram marketing facebook ai mcp python3 llm instagram-message-bot instagram-message-sender mcp-server instagram-messenger

Readme

MIT license

Activity

Custom properties

87 stars

1 watching

16 forks

Report repository

Releases

No releases published

Packages

No packages published

Contributors4

  • @tanmayjain-bit tanmayjain-bit tanmay
  • @jakebloom jakebloom Jake Bloom
  • @HeetVekariya HeetVekariya Heet Vekariya
  • @theailifestyle theailifestyle The AI Lifestyle

Languages

  • Python 100.0%

Related Servers