LinkedIn MCP Server
Enables drafting, formatting, analyzing, and publishing LinkedIn posts directly from MCP-compatible clients like Claude.
README
LinkedIn MCP Server
A Model Context Protocol server that lets Claude — and any MCP-compatible client — draft, format, analyze, and publish LinkedIn posts straight from a chat.
Stop context-switching between your editor, a "best time to post" blog, and LinkedIn's composer. This server exposes five focused tools so the model can take a raw idea, shape it into a polished post, score it, generate hashtags, and (optionally) publish it to your profile — all without leaving the conversation.
Features
- ✍️ Draft full posts from a topic, tone, and a few key points
- 🎨 Format raw text with clean line breaks, spacing, emojis, and hashtags
- 🏷️ Generate relevant, topic-aware hashtags
- 📊 Analyze a post and get a score plus concrete improvement suggestions
- 🚀 Publish to LinkedIn (or save as a draft) with configurable visibility
- 🧩 Works with Claude Desktop and any other MCP host over stdio
- ⚡ Bundled with esbuild for fast, low-memory builds
Note: Four of the five tools (
draft_post,format_post,generate_hashtags,analyze_post) run fully offline and need no credentials. Onlycreate_posttalks to the LinkedIn API and requires an access token.
Available Tools
draft_post
Generate a LinkedIn post template from a topic and tone.
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
topic |
string |
✅ | — | Topic or subject of the post |
tone |
string (enum) |
— | professional |
One of professional, casual, inspirational, educational, storytelling, promotional |
key_points |
string[] |
— | — | Key points to weave into the post |
target_audience |
string |
— | — | Who the post is aimed at |
cta |
string |
— | — | Custom call-to-action |
include_hashtags |
boolean |
— | true |
Whether to append hashtags |
hashtag_count |
number |
— | 5 |
Number of hashtags (0–10) |
format_post
Format raw content with proper LinkedIn structure and hashtags.
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
content |
string |
✅ | — | Raw post text to format |
add_line_breaks |
boolean |
— | true |
Insert readable spacing and line breaks |
add_emojis |
boolean |
— | false |
Sprinkle in relevant emojis |
hashtags |
string[] |
— | [] |
Hashtags to append |
generate_hashtags
Generate relevant LinkedIn hashtags for a topic.
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
topic |
string |
✅ | — | Topic to generate hashtags for |
count |
number |
— | 5 |
Number of hashtags (1–10) |
custom_keywords |
string[] |
— | — | Seed keywords to bias generation |
analyze_post
Score a LinkedIn post and return improvement suggestions.
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
content |
string |
✅ | — | The post text to score and critique |
create_post
Format and publish a LinkedIn post, or save it as a draft. Requires LinkedIn API credentials.
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
content |
string |
✅ | — | Post text (max 3000 characters) |
hashtags |
string[] |
— | [] |
Hashtags to include |
visibility |
string (enum) |
— | PUBLIC |
One of PUBLIC, CONNECTIONS, LOGGED_IN |
save_as_draft |
boolean |
— | false |
Save as a draft instead of publishing |
Prerequisites
- Node.js 18+ and npm (pnpm or yarn work too)
- An MCP-compatible client — e.g. Claude Desktop
- (Only for publishing) A LinkedIn developer app and an access token with the
w_member_socialscope
Installation
git clone https://github.com/<your-username>/linkedin-mcp-server.git
cd linkedin-mcp-server
npm install
npm run build
The build step bundles src/ into a single executable file at dist/index.js.
Configuration
1. LinkedIn API credentials (for create_post)
- Create an app in the LinkedIn Developer Portal.
- Request the Share on LinkedIn product to unlock the
w_member_socialscope. - Complete the OAuth 2.0 flow to obtain an access token.
Create a .env file in the project root:
LINKEDIN_ACCESS_TOKEN=your_access_token_here
# Optional — many setups resolve this from the token via /userinfo.
# Provide it only if your implementation expects it:
LINKEDIN_AUTHOR_URN=urn:li:person:XXXXXXXXXX
⚠️ Never commit your
.envfile or share your access token. Add.envto.gitignore.
2. Connect to Claude Desktop
Add the server to your Claude Desktop config:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"linkedin": {
"command": "node",
"args": ["/absolute/path/to/linkedin-mcp-server/dist/index.js"],
"env": {
"LINKEDIN_ACCESS_TOKEN": "your_access_token_here",
"LINKEDIN_AUTHOR_URN": "urn:li:person:XXXXXXXXXX"
}
}
}
}
Use an absolute path to dist/index.js, then fully restart Claude Desktop. The LinkedIn tools should now appear in the tools menu.
Usage
Once connected, just talk to the model naturally — it will pick the right tool:
- "Draft a LinkedIn post about shipping my first MCP server. Educational tone, aimed at junior devs, and include a CTA to star the repo."
- "Format this draft, add line breaks and a couple of emojis: …"
- "Generate 8 hashtags for a post about AI compliance for fintech."
- "Analyze this post and tell me how to make it stronger: …"
- "Publish this to LinkedIn, connections-only."
Development
Why esbuild?
This project bundles with esbuild rather than tsc. Beyond being dramatically faster, it sidesteps the JavaScript heap out of memory errors that tsc can hit when bundling the MCP SDK and its dependencies. tsc is still used for type-checking only.
Scripts
npm run build # Bundle src/ -> dist/index.js with esbuild
npm run typecheck # Type-check with tsc (no emit)
npm start # Run the built server directly (stdio)
Example esbuild.config.js
import { build } from "esbuild";
build({
entryPoints: ["src/index.ts"],
outfile: "dist/index.js",
bundle: true,
platform: "node",
format: "esm",
target: "node18",
banner: { js: "#!/usr/bin/env node" },
}).catch(() => process.exit(1));
Project structure
linkedin-mcp-server/
├── src/
│ ├── index.ts # MCP server entry — stdio transport + tool registration
│ ├── tools/ # One module per tool
│ │ ├── draftPost.ts
│ │ ├── formatPost.ts
│ │ ├── generateHashtags.ts
│ │ ├── analyzePost.ts
│ │ └── createPost.ts
│ └── linkedin/ # LinkedIn API client (auth + posts)
├── dist/ # Bundled output (esbuild)
├── esbuild.config.js
├── package.json
├── tsconfig.json
└── README.md
Built on top of @modelcontextprotocol/sdk.
Troubleshooting
Tools don't appear in Claude Desktop.
Double-check that the path in args is absolute, that npm run build succeeded, and fully quit and reopen Claude Desktop. On macOS, logs live at ~/Library/Logs/Claude/.
JavaScript heap out of memory during build.
Use the bundled esbuild build (npm run build). If you reintroduce tsc for emitting, raise the heap limit with NODE_OPTIONS=--max-old-space-size=4096.
401 Unauthorized from create_post.
Your access token is missing, expired, or lacks the w_member_social scope. Regenerate it and update your .env / config.
License
Built with the Model Context Protocol. Contributions and issues welcome.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.