Pulls your LinkedIn professional profile directly into Claude or Copilot using LinkedIn's official Member Data Portability API. You get read-only access to positions, education, skills, certifications, projects, and activity data without scraping or manual copy-paste. Five tools cover the basics: fetch full profile, get activity feed, pull specific sections by name, poll recent changes via changelog API, and diagnose authorization issues. Currently EEA and Switzerland only, thanks to the Digital Markets Act. Setup is straightforward if you can generate a member access token from a LinkedIn Developer app. Useful when you want AI assistants to have accurate professional context about you for resume writing, job applications, or career planning conversations.
Bring your LinkedIn professional profile into AI assistants — without copy-pasting, scraping, or guessing.
Unlinked is a TypeScript MCP server that connects your LinkedIn professional profile and experience to any Model Context Protocol client — Claude Desktop, GitHub Copilot, and others. It reads your data directly from LinkedIn's official Member Data Portability API, so your assistant always has accurate, up-to-date context about who you are professionally.
:eu: EEA / Switzerland only. LinkedIn's Member Data Portability API is currently available exclusively to members located in the European Economic Area and Switzerland. Thank you, Digital Markets Act (DMA)!
Once connected, your AI assistant can:
All data access is read-only. Your access token is used only to talk to LinkedIn and is never stored, logged, or echoed back.
Add to your claude_desktop_config.json:
{
"mcpServers": {
"unlinked": {
"command": "npx",
"args": ["-y", "@larsbaunwall/unlinked"],
"env": {
"LINKEDIN_TOKEN": "<your_access_token>"
}
}
}
}
The config file is typically at:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.jsonAdd to your user-level MCP config (File → Preferences → MCP Servers) or a workspace .vscode/mcp.json:
{
"servers": {
"unlinked": {
"command": "npx",
"args": ["-y", "@larsbaunwall/unlinked"],
"env": {
"LINKEDIN_TOKEN": "<your_access_token>"
}
}
}
}
| Tool | Description |
|---|---|
linkedin_get_profile | Get the user's LinkedIn résumé: bio, work history, education, skills, certifications, projects, etc. |
linkedin_get_activity | Get the user's LinkedIn activity: connections, posts, articles, comments, likes, job applications |
linkedin_get_section | Get raw data for one specific LinkedIn section by exact name |
linkedin_get_recent_changes | Get recent changes to the user's LinkedIn data (past 28 days), with cursor-based polling |
linkedin_check_access | Check whether the user has granted LinkedIn data access — useful for diagnosing missing data |
| Environment variable | Required | Description |
|---|---|---|
LINKEDIN_TOKEN | Yes | LinkedIn access token. Accepts Bearer <token> or a bare token. |
LINKEDIN_API_VERSION | No | API version in YYYYMM format. Defaults to 202312. |
npm install
npm run build
npm run dev # run directly from source with .env
npm run inspect # test with MCP Inspector
See AGENTS.md for implementation guidance.
MIT
LINKEDIN_TOKEN*secretLinkedIn access token from the OAuth Token Generator. Accepts a bare token or 'Bearer <token>'. Required for EEA/Switzerland members only.
LINKEDIN_API_VERSIONLinkedIn API version in YYYYMM format (e.g. 202312). Defaults to 202312 when unset.