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
Máy chủ liên quan
Speech MCP Server
A text-to-speech server using the Kokoro TTS model, configurable via environment variables.
Voidly MCP Server
3 tools for global censorship intelligence (119 countries) + E2E encrypted agent-to-agent messaging with Double Ratchet and post-quantum crypto
Apple Notifier
Send native macOS notifications and interact with system dialogs.
MyMCPSpace
Access and interact with MyMCPSpace posts, replies, likes, and feeds.
AgentRPC
Connect to any function, any language, across network boundaries using AgentRPC.
YAGMS
An MCP server for interacting with the Gmail API, enabling email management.
Phone-a-Friend MCP Server
An AI-to-AI consultation system for complex problem-solving and reasoning, using OpenRouter for model access.
Email Processing
An email processing server that uses MongoDB for semantic search and SQLite for efficient storage and retrieval.
MCP Relay
A Discord relay server to send messages and prompts to a channel and receive responses.
LigueLead
Send SMS, SMS Flash, and voice calls in Brazil via LigueLead API. Brazilian CPaaS with BRL pricing and PIX payments.