BulkPublish
Publish, schedule, and manage social media across 11 platforms with media uploads and analytics tracking.
BulkPublish MCP Server
A Model Context Protocol server that lets Claude and other AI assistants interact with the BulkPublish social media publishing API.
What it does
This MCP server exposes BulkPublish API operations as tools that AI assistants can call directly. You can ask Claude to schedule posts, check analytics, upload media, manage labels, and more — all through natural conversation.
Installation
Option 1: npx (recommended)
npx @bulkpublish/mcp-server
Option 2: Global install
npm install -g @bulkpublish/mcp-server
bulkpublish-mcp
Option 3: From source
git clone https://github.com/azeemkafridi/bulkpublish-api.git
cd bulkpublish-api/mcp-server
npm install
npm run build
node dist/index.js
Configuration
Set your API key as an environment variable:
export BULKPUBLISH_API_KEY=bp_your_api_key_here
Get your API key at app.bulkpublish.com/developer.
Claude Desktop
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"bulkpublish": {
"command": "npx",
"args": ["-y", "@bulkpublish/mcp-server"],
"env": {
"BULKPUBLISH_API_KEY": "bp_your_api_key_here"
}
}
}
}
If you installed from source:
{
"mcpServers": {
"bulkpublish": {
"command": "node",
"args": ["/absolute/path/to/bulkpublish-api/mcp-server/dist/index.js"],
"env": {
"BULKPUBLISH_API_KEY": "bp_your_api_key_here"
}
}
}
}
Claude Code
Add the MCP server to your Claude Code configuration:
claude mcp add bulkpublish -- npx -y @bulkpublish/mcp-server
Set the environment variable in your shell profile or .env file:
export BULKPUBLISH_API_KEY=bp_your_api_key_here
Available Tools
| Tool | Description |
|---|---|
| Posts | |
create_post | Create and optionally schedule a post (supports reels, stories, carousels, threads via postTypeOverrides) |
update_post | Update a draft or scheduled post |
get_post | Get a single post with full details |
list_posts | List posts with filters (status, search, date range) |
delete_post | Delete a post |
publish_post | Publish a draft post immediately |
retry_post | Retry a failed post |
get_post_metrics | Get engagement metrics (impressions, likes, comments, shares) |
publish_story | Publish as a story to Facebook or Instagram |
bulk_posts | Bulk delete or retry multiple posts |
get_queue_slot | Get the next optimal time slot for a channel |
| Channels | |
list_channels | List all connected social media channels |
get_channel_health | Check channel token health |
get_channel_options | Get platform-specific options (boards, playlists, orgs) |
search_mentions | Search users for @mention (X, Bluesky) |
| Media | |
upload_media | Upload a media file from a URL |
get_media | Get a media file by ID |
list_media | List uploaded media files |
delete_media | Delete a media file |
| Labels | |
create_label | Create a new label |
list_labels | List all labels |
update_label | Update a label name or color |
delete_label | Delete a label |
| Analytics | |
get_analytics | Get analytics summary for a date range |
| Schedules | |
list_schedules | List recurring schedules |
create_schedule | Create a recurring schedule |
update_schedule | Update a schedule |
delete_schedule | Delete a schedule |
| Quota | |
get_quota_usage | Check current plan quota usage |
Example Conversation
Here is an example of using the BulkPublish tools in Claude:
You: Schedule a post for tomorrow at 9am EST saying "Excited to announce our new feature! Check it out at example.com" to all my connected channels.
Claude: Let me check your connected channels first.
[Calls list_channels]
You have 3 active channels:
- X/Twitter: @yourcompany (ID: 1)
- LinkedIn: Your Company Page (ID: 2)
- Instagram: @yourcompany (ID: 3)
Now I'll schedule the post for tomorrow at 9:00 AM Eastern.
[Calls create_post with content, channels, scheduledAt: "2025-01-16T14:00:00Z", timezone: "America/New_York", status: "scheduled"]
Done! Your post has been scheduled:
- Post ID: 42
- Status: scheduled
- Scheduled for: January 16, 2025 at 9:00 AM EST
- Channels: X/Twitter, LinkedIn, Instagram
You: How did my posts perform this month?
Claude: [Calls get_analytics with from: "2025-01-01", to: "2025-01-31"]
Here is your January analytics summary:
- Total posts: 28
- Published: 25
- Failed: 1
- Scheduled (pending): 2
- By platform: X/Twitter (25 posts, 24 published), LinkedIn (20 posts, 19 published), Instagram (15 posts, all published)
- Best day: January 12 with 5 posts
You: Upload this image and create a draft post with it: https://example.com/product-launch.png
Claude: [Calls upload_media with url]
Image uploaded successfully (ID: 15, 1200x630px, 245KB).
[Calls create_post with content and mediaFileIds]
Draft post created (ID: 43) with the product launch image attached. You can review and publish it when ready.
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
BULKPUBLISH_API_KEY | Yes | — | Your API key (starts with bp_) |
BULKPUBLISH_BASE_URL | No | https://app.bulkpublish.com | API base URL (for self-hosted instances) |
License
MIT
Related Servers
PostCopilot MCP
Threads tools for AI agents — generate viral posts, download videos, and export profile data from Meta Threads.
VOICEROID Daemon
A text-to-speech server for VOICEROID2 via the voiceroid_daemon.
MCP Server Whisper
Advanced audio transcription and processing using OpenAI's Whisper and GPT-4o models.
Ntfy MCP Server
Send push notifications via the ntfy service, enabling LLMs and AI agents to notify your devices.
FeedMansion Social Media MCP
Schedule and queue text, image, and video posts to many social networks, including LinkedIn, X, Bluesky, Instagram, Facebook, Threads, Tiktok.
Reddit Outreach
The only AI tool that connects directly to a proprietary Reddit outreach network — find your prospects, personalize your pitch, and send thousands of DMs per day.
AivisSpeech
A server for text-to-speech generation using the AivisSpeech engine.
Webhooks MCP
Send HTTP requests to webhooks with dynamic parameters.
Telegram Notifier (Botfather)
Use botfather bot to notify yourself on Telegram.
MCP反馈收集器
An MCP server for collecting interactive user feedback through a graphical user interface.