linkedin-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@linkedin-mcpPost this image to LinkedIn with caption 'Happy Monday!'"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
linkedin-mcp
A local MCP (Model Context Protocol) server that lets Claude log in to LinkedIn and publish image posts to your personal profile feed, backed by LinkedIn's REST Images API and Posts API.
Scope: two tools, linkedin_login and create_image_post. No org/company
page posting, no scheduling, no carousels.
1. Create a LinkedIn Developer App
Go to https://www.linkedin.com/developers/apps and click Create app. LinkedIn requires every app to be linked to a LinkedIn Page, even for personal-profile posting -- create a minimal Page first if you don't have one.
Fill in the app name, select the Page, upload a logo (required), accept the agreement, and click Create app.
In the Products tab, add:
Sign In with LinkedIn using OpenID Connect (grants
openid,profile,email) -- self-serve, instant.Share on LinkedIn (grants
w_member_social) -- self-serve, instant.
In the Auth tab, under OAuth 2.0 settings, add an Authorized redirect URL that exactly matches
LINKEDIN_REDIRECT_URIbelow (defaulthttp://localhost:3000/callback, including the path -- must match byte-for-byte).Copy the Client ID and Client Secret from the Auth tab.
Known risk to watch for: the Microsoft Learn docs for /rest/images and
/rest/posts live under "Community Management API," which normally needs a
separate LinkedIn approval. Posting to your own profile with w_member_social
OpenID scopes has historically worked without that approval, but if your first
create_image_postcall comes back with a 403, that's the signal your app needs the Community Management API product added in the developer portal (approval-gated, outside this code's control).
Related MCP server: LinkedIn Ads MCP Server
2. Install and build
npm install
npm run build3. Configure your MCP client
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"linkedin": {
"command": "node",
"args": ["/absolute/path/to/linkedin-mcp/dist/index.js"],
"env": {
"LINKEDIN_CLIENT_ID": "xxxx",
"LINKEDIN_CLIENT_SECRET": "xxxx",
"LINKEDIN_REDIRECT_URI": "http://localhost:3000/callback"
}
}
}
}Claude Code
Add the same shape to your project or user .mcp.json, or run:
claude mcp add linkedin node /absolute/path/to/linkedin-mcp/dist/index.js \
--env LINKEDIN_CLIENT_ID=xxxx \
--env LINKEDIN_CLIENT_SECRET=xxxx \
--env LINKEDIN_REDIRECT_URI=http://localhost:3000/callbackRestart the client after editing config. You should see the server connected
with two tools: linkedin_login and create_image_post.
4. Environment variables
See .env.example for the full list. Only LINKEDIN_CLIENT_ID
and LINKEDIN_CLIENT_SECRET are required; everything else has a sane default.
Tokens are persisted to ~/.linkedin-mcp/tokens.json (mode 600) so you only
need to log in once per ~60-day LinkedIn access token lifetime.
5. Usage
In a Claude conversation:
"Log in to LinkedIn" -> calls
linkedin_login, opens your browser, and completes the OAuth flow. Calling it again when already logged in is a no-op unless you passforce: true."Post this image to LinkedIn with caption ..." -> calls
create_image_postwithimagePathorimageUrl,text, and optionallyaltText/visibility.
Development
npm run dev # run directly via tsx, without buildingAll logging goes to stderr (console.error) -- stdout is reserved for the
MCP JSON-RPC protocol stream over stdio.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/egig/linkedin-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server