MCP Marketplace
BrowseHow It WorksFor CreatorsDocs
Sign inSign up
MCP Marketplace

The curated, security-first marketplace for AI tools.

Product

Browse ToolsSubmit a ToolDocumentationHow It WorksBlogFAQChangelog

Legal

Terms of ServicePrivacy PolicyCommunity Guidelines

Connect

support@mcp-marketplace.ioTwitter / XDiscord

MCP Marketplace © 2026. All rights reserved.

Back to Browse

Linkedctl MCP Server

by Alexey Pelykh
Developer ToolsLow Risk10.0MCP RegistryLocal
Free

Server data from the Official MCP Registry

CLI and MCP server for the LinkedIn API

About

CLI and MCP server for the LinkedIn API

Security Report

10.0
Low Risk10.0Low Risk

Valid MCP server (1 strong, 1 medium validity signals). No known CVEs in dependencies. Package registry verified. Imported from the Official MCP Registry.

10 files analyzed · 1 issue found

Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.

Permissions Required

This plugin requests these system permissions. Most are normal for its category.

file_system

Check that this permission is expected for this type of plugin.

What You'll Need

Set these up before or after installing:

LinkedIn OAuth2 access tokenRequired

Environment variable: LINKEDCTL_ACCESS_TOKEN

LinkedIn OAuth2 client IDOptional

Environment variable: LINKEDCTL_CLIENT_ID

LinkedIn OAuth2 client secretRequired

Environment variable: LINKEDCTL_CLIENT_SECRET

How to Install

Add this to your MCP configuration file:

{
  "mcpServers": {
    "io-github-alexey-pelykh-linkedctl": {
      "env": {
        "LINKEDCTL_CLIENT_ID": "your-linkedctl-client-id-here",
        "LINKEDCTL_ACCESS_TOKEN": "your-linkedctl-access-token-here",
        "LINKEDCTL_CLIENT_SECRET": "your-linkedctl-client-secret-here"
      },
      "args": [
        "-y",
        "linkedctl"
      ],
      "command": "npx"
    }
  }
}

Documentation

View on GitHub

From the project's GitHub README.

LinkedCtl: The Complete CLI & MCP for LinkedIn

CI CodeQL License

OAuth2 CLI and MCP server for the LinkedIn API.

What It Does

  • Post content — text, images, video, documents, articles, multi-image carousels, and polls
  • Comments & reactions — create, list, and delete comments and reactions on posts
  • Organization support — post, comment, react, and view analytics as an organization
  • Analytics — per-post, per-member, and per-organization statistics
  • Media uploads — upload images, video, and documents to LinkedIn
  • Draft posts — save posts as drafts before publishing
  • OAuth 2.0 authentication with your own LinkedIn app
  • Direct token passing for tokens obtained from other applications
  • MCP server for AI assistant integration (Claude, Cursor, etc.)
  • CLI for scriptable LinkedIn operations

Prerequisites

  • Node.js >= 24
  • A LinkedIn Developer App with appropriate permissions

Installation

npm install -g linkedctl

Or run directly:

npx linkedctl --help

Quick Start

  1. Create a LinkedIn app at linkedin.com/developers
  2. Configure OAuth 2.0 credentials
  3. Authenticate:
    linkedctl auth login --client-id YOUR_CLIENT_ID --client-secret YOUR_CLIENT_SECRET
    
  4. Start using:
    linkedctl post "Hello from LinkedCtl!"
    

See the OAuth Setup Guide for detailed step-by-step instructions.

MCP Integration

MCP Client Configuration

Add to your Claude Desktop configuration (claude_desktop_config.json):

{
    "mcpServers": {
        "linkedctl": {
            "command": "npx",
            "args": ["linkedctl", "mcp"]
        }
    }
}
claude mcp add linkedctl -- npx linkedctl mcp

Add to .cursor/mcp.json in your project root:

{
    "mcpServers": {
        "linkedctl": {
            "command": "npx",
            "args": ["linkedctl", "mcp"]
        }
    }
}

Add to ~/.codeium/windsurf/mcp_config.json:

{
    "mcpServers": {
        "linkedctl": {
            "command": "npx",
            "args": ["linkedctl", "mcp"]
        }
    }
}

Available Tools

All tools accept an optional profile parameter to select a configuration profile.

Authentication
ToolDescription
whoamiShow the current user's name, email, and profile picture URL
auth_statusShow authentication status for a profile
auth_revokeRevoke the access token server-side and clear local credentials
Posts
ToolDescription
post_createCreate a post on LinkedIn with optional media, poll, or article attachment
post_getFetch a single post by URN
post_listList posts with pagination (supports as_org for organization posts)
post_updateUpdate the commentary text of an existing post
post_deleteDelete a post by URN

post_create supports rich content types:

ParameterDescription
textPost text content (required)
visibilityPUBLIC or CONNECTIONS (default PUBLIC)
draftSave as draft instead of publishing
image / image_fileAttach a single image (URN or local file path)
video / video_fileAttach a video (URN or local file path)
document / document_fileAttach a document (URN or local file path)
images / image_filesAttach multiple images (minimum 2)
article_urlAttach an article link
pollPoll question text
poll_optionsPoll answer options (2–4 required when poll is set)
poll_durationONE_DAY, THREE_DAYS, ONE_WEEK, or TWO_WEEKS
as_orgPost as an organization (numeric ID)
Comments
ToolDescription
comment_createCreate a comment on a post (supports as_org)
comment_listList comments on a post
comment_getGet a specific comment by URN
comment_deleteDelete a comment by URN
Reactions
ToolDescription
reaction_createAdd a reaction to a post (supports as_org). Types: LIKE, PRAISE, EMPATHY, INTEREST, APPRECIATION, ENTERTAINMENT
reaction_listList reactions on a post
reaction_deleteRemove a reaction from a post (supports as_org)
Organizations
ToolDescription
org_listList organizations the authenticated user administers
org_getFetch a single organization by ID
org_followersGet the follower count for an organization
Analytics
ToolDescription
stats_postGet analytics for a single post (impressions, reach, reactions, comments, reshares)
stats_meGet aggregated analytics across all your posts
stats_orgGet share statistics for an organization (lifetime or time-bucketed)
Media
ToolDescription
document_uploadUpload a document to LinkedIn (PDF, DOCX, PPTX, DOC, PPT; max 100 MB)

Configuration

Config File Format

LinkedCtl stores configuration in YAML files. Each file represents a single profile:

api-version: "202601"
oauth:
    client-id: "YOUR_CLIENT_ID"
    client-secret: "YOUR_CLIENT_SECRET"
    access-token: "YOUR_ACCESS_TOKEN"
    refresh-token: "YOUR_REFRESH_TOKEN"
    token-expires-at: "2026-05-03T12:00:00.000Z"

Available keys:

KeyDescription
api-versionLinkedIn API version (e.g. 202601)
oauth.client-idOAuth 2.0 client ID
oauth.client-secretOAuth 2.0 client secret
oauth.access-tokenOAuth 2.0 access token
oauth.refresh-tokenOAuth 2.0 refresh token
oauth.token-expires-atToken expiration timestamp (ISO 8601)

Config files are written with 0600 permissions (owner read/write only).

File Location and Precedence

Without a profile, LinkedCtl searches for config files in this order:

  1. .linkedctl.yaml in the current working directory
  2. ~/.linkedctl.yaml in the home directory

The first file found is used. When writing (e.g. after auth login), LinkedCtl writes to the CWD file if it exists, otherwise to the home directory file.

Profiles

Profiles let you manage multiple LinkedIn accounts or configurations. Each profile is stored as a separate YAML file under ~/.linkedctl/:

ProfileConfig file path
(default)~/.linkedctl.yaml
work~/.linkedctl/work.yaml
personal~/.linkedctl/personal.yaml

Use the --profile flag with any command:

linkedctl --profile work auth login --client-id ID --client-secret SECRET
linkedctl --profile work post "Hello from my work account!"

Manage profiles with the profile command:

linkedctl profile create work --access-token YOUR_TOKEN --api-version 202601
linkedctl profile list
linkedctl profile show work
linkedctl profile delete work

Authentication Methods

OAuth 2.0 (Recommended)

LinkedCtl supports OAuth 2.0 with your own LinkedIn Developer App:

linkedctl auth login --client-id YOUR_CLIENT_ID --client-secret YOUR_CLIENT_SECRET
Direct Token

If you already have an access token from another application:

linkedctl auth token --access-token YOUR_TOKEN

Environment Variables

VariableDescription
LINKEDCTL_CLIENT_IDLinkedIn OAuth 2.0 client ID
LINKEDCTL_CLIENT_SECRETLinkedIn OAuth 2.0 client secret
LINKEDCTL_ACCESS_TOKENDirect access token (bypasses OAuth flow)
LINKEDCTL_API_VERSIONLinkedIn API version string (e.g. 202601) required

Environment variables take precedence over config file values.

Profile-Prefixed Environment Variables

When using a named profile, LinkedCtl also reads profile-prefixed environment variables. The profile name is uppercased with hyphens converted to underscores:

ProfileVariable
(default)LINKEDCTL_ACCESS_TOKEN
workLINKEDCTL_WORK_ACCESS_TOKEN
my-brandLINKEDCTL_MY_BRAND_ACCESS_TOKEN

The same pattern applies to CLIENT_ID, CLIENT_SECRET, and API_VERSION.

Precedence Order

Configuration values are resolved in this order (highest priority first):

  1. Environment variables (profile-prefixed if a profile is active)
  2. Config file (profile-specific file, or CWD/home fallback)

CLI Reference

Global Options

OptionDescription
--profile <name>Use a specific configuration profile
--jsonForce JSON output
-q, --quietSuppress informational output
--no-colorDisable color output

auth — Manage Authentication

CommandDescription
auth setupConfigure OAuth client credentials interactively
auth loginAuthenticate via OAuth 2.0 (opens browser)
auth tokenStore a direct access token
auth statusShow authentication status and token expiry
auth logoutClear stored credentials from the active profile
auth refreshRefresh the access token using a stored refresh token
auth revokeRevoke the access token server-side and clear local tokens

auth login options:

OptionDescriptionDefault
--client-id <id>OAuth 2.0 client IDfrom config
--client-secret <secret>OAuth 2.0 client secretfrom config
--scope <scopes>OAuth 2.0 scopes (space-separated)openid profile w_member_social

auth token options:

OptionDescription
--access-token <token>Access token to store (required)

post — Manage LinkedIn Posts

# Shorthand: pass text as an argument
linkedctl post "Hello from LinkedCtl!"

# Explicit subcommand
linkedctl post create --text "Hello from LinkedCtl!"

# Pipe content from stdin
echo "Hello from LinkedCtl!" | linkedctl post create
CommandDescription
post createCreate a post on LinkedIn
post get <urn>Fetch a post by URN
post listList posts with pagination
post update <urn>Update a post's commentary text
post delete <urn>Delete a post (with confirmation)

post create options:

OptionDescriptionDefault
--text <text>Text content (also accepts --text-file, positional, or stdin)
--visibility <visibility>PUBLIC or CONNECTIONSPUBLIC
--draftSave as draft instead of publishing
--image <urn>Image URN to attach
--image-file <path>Local image file to upload and attach
--video <urn>Video URN to attach
--video-file <path>Local video file to upload and attach
--document <urn>Document URN to attach
--document-file <path>Local document file to upload and attach
--images <urns>Multiple image URNs (comma-separated, minimum 2)
--image-files <paths>Multiple local image files (comma-separated, minimum 2)
--article-url <url>Article URL to attach
--poll <question>Poll question text
--option <text>Poll option (repeat 2–4 times)
--poll-duration <duration>ONE_DAY, THREE_DAYS, ONE_WEEK, or TWO_WEEKSTHREE_DAYS
--as-org <id>Post as an organization (numeric ID)
--format <format>Output format (json, table)auto

post list options:

OptionDescriptionDefault
--count <n>Number of posts to return (max 100)10
--start <n>Starting index for pagination0
--as-org <id>List posts of an organization (numeric ID)

comment — Manage Comments

CommandDescription
comment create <post-urn>Create a comment on a post
comment list <post-urn>List comments on a post
comment get <comment-urn>Get a specific comment by URN
comment delete <comment-urn>Delete a comment (with confirmation)

comment create options:

OptionDescription
--text <text>Comment text (required)
--as-org <id>Comment as an organization (numeric ID)

reaction — Manage Reactions

CommandDescription
reaction create <urn>Add a reaction to a post
reaction list <urn>List reactions on a post
reaction delete <urn>Remove a reaction from a post

reaction create options:

OptionDescription
--type <type>LIKE, PRAISE, EMPATHY, INTEREST, APPRECIATION, or ENTERTAINMENT (default LIKE)
--as-org <id>React as an organization (numeric ID)

org — Manage Organizations

CommandDescription
org listList organizations the authenticated user administers
org get <id>Get organization details
org followers <id>Get organization follower count

media — Upload Media

CommandDescription
media upload-image <file>Upload an image (JPG, PNG, GIF)
media upload-video <file>Upload a video
media upload-document <file>Upload a document (PDF, DOCX, PPTX, DOC, PPT; max 100 MB)

All media commands accept --as-org <id> and --format json|table.

stats — View Analytics

CommandDescription
stats post <urn>Get post analytics (impressions, reach, engagement)
stats meGet aggregated analytics across all your posts
stats org <id>Get organization share statistics

Common options:

OptionDescription
--from <date> / --start <date>Start of date range (YYYY-MM-DD)
--to <date> / --end <date>End of date range (YYYY-MM-DD)
--time-granularity <granularity>DAY or MONTH (org stats only)

profile — Manage Configuration Profiles

CommandDescription
profile create <name>Create a new profile
profile listList all profiles
profile show [<name>]Show profile details (redacted)
profile delete <name>Delete a profile (with confirmation)

profile create options:

OptionDescription
--access-token <token>OAuth 2.0 access token (required)
--api-version <version>LinkedIn API version, e.g. 202601 (required)

whoami — Show Current User

linkedctl whoami
linkedctl whoami --format json
OptionDescriptionDefault
--format <format>Output format (json, table)auto

completion — Shell Completions

linkedctl completion bash
linkedctl completion zsh

Security

  • Dependabot keeps dependencies up to date with automated pull requests
  • CodeQL analysis runs on every push and pull request for automated vulnerability detection
  • Path traversal validation on profile names prevents directory escape attacks
  • Unified auth error handling across all MCP tools provides consistent authentication failure messages
  • Destructive operations (delete post, delete comment, delete profile) require interactive confirmation unless --force is passed

Disclaimer

This is an independent project and is not affiliated with, endorsed by, or associated with LinkedIn Corporation. LinkedIn is a trademark of LinkedIn Corporation.

License

AGPL-3.0-only

Using LinkedCtl as a CLI tool or MCP server: No license obligations — use freely.

Using @linkedctl/core as a library in your project: Your combined work must be licensed under AGPL-3.0 (or a compatible license).

Reviews

No reviews yet

Be the first to review this server!

0

installs

New

no ratings yet

Is this your server?

Claim ownership to manage your listing, respond to reviews, and track installs from your dashboard.

Claim with GitHub

Sign up with the GitHub account that owns this repo

Links

Source Codenpm Package

Details

Published March 10, 2026
Version 0.5.0
0 installs
Local Plugin

More Developer Tools MCP Servers

Git

Free

by Modelcontextprotocol · Developer Tools

Read, search, and manipulate Git repositories programmatically

80.0K
Stars
4
Installs
6.5
Security
No ratings yet
Local

Toleno

Free

by Toleno · Developer Tools

Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.

114
Stars
411
Installs
8.0
Security
4.8
Local

mcp-creator-python

Free

by mcp-marketplace · Developer Tools

Create, build, and publish Python MCP servers to PyPI — conversationally.

-
Stars
56
Installs
10.0
Security
5.0
Local

MarkItDown

Free

by Microsoft · Content & Media

Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption

116.1K
Stars
16
Installs
6.0
Security
5.0
Local

mcp-creator-typescript

Free

by mcp-marketplace · Developer Tools

Scaffold, build, and publish TypeScript MCP servers to npm — conversationally

-
Stars
14
Installs
10.0
Security
5.0
Local

FinAgent

Free

by mcp-marketplace · Finance

Free stock data and market news for any MCP-compatible AI assistant.

-
Stars
13
Installs
10.0
Security
No ratings yet
Local