LinkedIn Buddy
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 Buddysearch for data scientists in San Francisco"
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.
You've been doing LinkedIn wrong.
Scraping with Python scripts that break every Tuesday. Rate-limited by APIs that don't actually exist. Copy-pasting from the web UI like it's 2015. Running Chrome extensions that sell your session cookies to whoever's buying.
Stop.
LinkedIn Buddy is a local-first Playwright runtime that operates LinkedIn the way you would — just faster, safer, and without the RSI. Anti-bot evasion, persistent browser profiles, and a two-phase commit system that previews every single write before it fires. Nothing touches LinkedIn until you say so.
Three surfaces. One runtime. CLI for operators, MCP server for AI agents, TypeScript API for builders. Same services, same safety guarantees, zero duplication.
Every write previews first. Two-phase commit. Prepare, inspect, confirm. No accidental DMs. No "oops, wrong connection request."
The chameleon blends in. Human-like typing, Poisson-distributed pauses, Bézier mouse paths. LinkedIn sees a person, not a bot.
Your machine. Your data. SQLite state, persistent profiles, structured logs, screenshots. Nothing leaves your laptop. No cloud. No telemetry. No accounts.
100+ MCP tools. Claude Desktop, Cursor, Cline — your agent gets full LinkedIn access through structured tool calls, not brittle prompt hacks.
Get running in 60 seconds.
You're a developer. You've done this before.
git clone https://github.com/sigvardt/linkedin-buddy.git
cd linkedin-buddy
npm install
npx playwright install chromium
npm run buildAuthenticate and verify:
npm exec -w @linkedin-buddy/cli -- linkedin login --profile default
npm exec -w @linkedin-buddy/cli -- linkedin status --profile defaultRun your first search:
npm exec -w @linkedin-buddy/cli -- linkedin search "developer relations" --category people --limit 5That's it. You're in.
Tip: The CLI installs three equivalent binaries —
lbud, andlinkedin-buddy. After a global install (once published), drop thenpm execprefix entirely:lbud search "developer relations" --category people --limit 5
Prefer manual encrypted session capture over browser-based login?
npm exec -w @linkedin-buddy/cli -- linkedin auth session --session defaultPlug into your AI.
Paste this into your MCP client config. Done.
{
"mcpServers": {
"linkedin": {
"command": "npm",
"args": ["exec", "-w", "@linkedin-buddy/mcp", "--", "linkedin-mcp"]
}
}
}Works with Claude Desktop, Cursor, Cline, and every MCP-compatible client. 100+ tools. Zero boilerplate. Your AI agent interacts with LinkedIn through structured tool calls — not screen-scraping, not prompt engineering, not prayer.
Tools to start with:
linkedin.session.status · linkedin.search · linkedin.inbox.list_threads · linkedin.feed.list · linkedin.jobs.search · linkedin.notifications.list · linkedin.actions.confirm · linkedin.activity_poller.run_once
Go deeper.
🔍 Search everything.
People, companies, posts, jobs, groups, events. One unified surface, structured results.
npm exec -w @linkedin-buddy/cli -- linkedin search "staff engineer" --category people --limit 5
npm exec -w @linkedin-buddy/cli -- linkedin search "open source ai" --category posts --limit 5
npm exec -w @linkedin-buddy/cli -- linkedin jobs search "product manager" --location Copenhagen --limit 10💬 Inbox. Read it. Reply safely.
List threads, read messages, stage replies. Every outbound message goes through two-phase commit — you see exactly what will send before it sends.
npm exec -w @linkedin-buddy/cli -- linkedin inbox list --limit 10
npm exec -w @linkedin-buddy/cli -- linkedin inbox show --thread <thread-url-or-id> --limit 20
npm exec -w @linkedin-buddy/cli -- linkedin inbox prepare-reply --thread <thread-url-or-id> --text "Thanks for reaching out."
npm exec -w @linkedin-buddy/cli -- linkedin actions confirm --token ct_...📝 Feed and posts. Comment without regret.
Browse the feed, view posts, stage comments. The confirm flow means you see exactly what will post before it posts. Create text posts, media posts, and polls through the same two-phase pipeline.
npm exec -w @linkedin-buddy/cli -- linkedin feed list --limit 5
npm exec -w @linkedin-buddy/cli -- linkedin feed view <post-url>
npm exec -w @linkedin-buddy/cli -- linkedin feed comment <post-url> --text "Insightful breakdown. Thanks for sharing."
npm exec -w @linkedin-buddy/cli -- linkedin actions confirm --token ct_...💼 Jobs. Search, save, apply.
Full job search with location filters and Easy Apply support. Save jobs, manage alerts, track everything locally in SQLite.
npm exec -w @linkedin-buddy/cli -- linkedin jobs search "product manager" --location Copenhagen --limit 10👤 Profiles, companies, and notifications.
Inspect any profile, browse company pages, manage your notification feed.
npm exec -w @linkedin-buddy/cli -- linkedin profile view me
npm exec -w @linkedin-buddy/cli -- linkedin company view openai
npm exec -w @linkedin-buddy/cli -- linkedin notifications list --limit 20☕ Activity polling. Webhooks that actually work.
Set up watches on LinkedIn activity. Get notified when things change. Fan out webhooks with HMAC-signed payloads and automatic retry logic.
npm exec -w @linkedin-buddy/cli -- linkedin activity watch add --profile default --kind notifications --interval-seconds 600
npm exec -w @linkedin-buddy/cli -- linkedin activity webhook add --watch <watch-id> --url https://example.com/hooks/linkedin
npm exec -w @linkedin-buddy/cli -- linkedin activity run-once --profile defaultEvery write previews before it executes. No accidents.
This isn't a YOLO automation tool. Every outbound action — messages, connection requests, comments, profile edits, posts — goes through two-phase commit:
Prepare → Action stored in SQLite, preview returned, confirm token generated.
Review → You (or your AI agent) inspect exactly what will happen.
Confirm → Token validated, action executed, result recorded.
Tokens expire in 30 minutes. HMAC-SHA256 sealed with entropy. No confirmation, no execution. Period.
The chameleon blends in.
LinkedIn's bot detection is aggressive. LinkedIn Buddy doesn't fight it — it disappears.
Human-like typing with configurable typo rates and correction pauses
Poisson-distributed delays between actions — not fixed sleeps, real statistical distributions
Bézier curve mouse paths — smooth, natural movement with overshoot and correction
Fingerprint hardening — WebGL, canvas, timezone, locale, all consistent per profile
Four evasion levels —
off·light·moderate(default) ·aggressive
Configure via --evasion-level, LINKEDIN_BUDDY_EVASION_LEVEL env var, or runtime options. See docs/evasion.md for the full breakdown.
Use the TypeScript API.
Skip the CLI. Embed the full runtime in your own apps.
import { createCoreRuntime } from "@linkedin-buddy/core";
const runtime = createCoreRuntime();
try {
const result = await runtime.search.search({
profileName: "default",
category: "people",
query: "developer relations",
limit: 5,
});
console.log(result.results.map((person) => person.name));
} finally {
runtime.close();
}Same services, same two-phase commit safety, same evasion layer. Everything the CLI and MCP server use, exposed as clean TypeScript APIs with full type definitions.
Architecture.
Local-first. No cloud. No third-party servers. Everything runs on your machine.
Architecture | Workflow |
The runtime wires 25+ services through constructor injection. No circular dependencies.
Infrastructure: DB → Logger → Artifacts → ProfileManager → Auth → RateLimiter → TwoPhaseCommit
↓
LinkedIn: Inbox, Feed, Connections, Profile, Search, Jobs, Notifications,
Posts, Publishing, Followups, Groups, Events, CompanyPages,
Members, PrivacySettings, Analytics
↓
Activity: Watches → Poller → Webhooks → SchedulerHow it compares.
Tool | CLI | MCP | Dev API | Confirm-before-write | Best fit |
LinkedIn Buddy | ✅ | ✅ | ✅ | ✅ | Local-first workflows for operators and AI agents |
— | ✅ | — | — | MCP-focused LinkedIn scraping and job search | |
✅ | — | — | — | Terminal-oriented LinkedIn usage | |
— | — | ✅ | — | Library-style LinkedIn integrations |
See docs/repository-seo.md for keyword targets and the GitHub-search baseline.
Terminal snapshots.
Install and build | MCP quick connect | Confirm before write |
Docs.
Need | Doc |
Activity polling and webhooks | |
Anti-bot evasion profiles | |
E2E and replay testing | |
Live validation and account safety | |
Selector auditing | |
Draft quality evaluation | |
Brand and social preview assets | |
README media research | |
Media asset inventory | |
Articles and newsletters | |
Notifications | |
Rate limiting | |
Jobs, alerts, and Easy Apply | |
SEO targets and metadata |
Contributing.
Start with CONTRIBUTING.md. Be decent (CODE_OF_CONDUCT.md). Report security issues through SECURITY.md.
If you change CLI commands, MCP tools, or write flows — update the README and the relevant docs so new users discover the feature.
Star history.
Author's note.
LinkedIn's API is locked behind partner programs most developers will never access. The web UI is designed for humans clicking buttons one at a time. Every existing tool is either a fragile Python scraper, a Chrome extension with questionable permissions, or a wrapper around endpoints that don't actually exist publicly.
I built LinkedIn Buddy because I needed LinkedIn automation that worked. Not a demo. Not a proof-of-concept that impresses on Twitter and breaks in production. A real tool that handles authentication, evades detection, previews every action before executing, and runs entirely on my own machine.
The two-phase commit system isn't a nice-to-have — it's the thing that lets AI agents use LinkedIn without accidentally messaging your CEO. The evasion layer isn't paranoia — it's the difference between a tool that works for a week and one that works for months.
100% open source. No telemetry. No cloud. No accounts. Your data stays on your machine.
Find it useful? Star the repo. Find a bug? Open an issue. Have a better approach? PRs are welcome.
License
License: pending repository selection.
Built with Playwright, Commander, better-sqlite3, and the Model Context Protocol SDK.
Release notes in CHANGELOG.md.
This server cannot be installed
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
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/sigvardt/linkedin-buddy'
If you have feedback or need assistance with the MCP directory API, please join our Discord server