A Model Context Protocol (MCP) server that automates generating professional LinkedIn post drafts from YouTube videos. This tool streamlines content repurposing by extracting transcripts from YouTube videos, summarizing the content, and generating engaging LinkedIn posts tailored to your preferences.
- YouTube Transcript Extraction: Automatically extract transcripts from any YouTube video
- Content Summarization: Generate concise summaries with customizable tone and target audience
- LinkedIn Post Generation: Create professional LinkedIn posts with customizable style and tone
- All-in-One Workflow: Go from YouTube URL to LinkedIn post in a single operation
- Customization Options: Adjust tone, audience, word count, and more to match your personal brand
- MCP Integration: Works seamlessly with AI assistants that support the Model Context Protocol
-
Clone the repository:
git clone https://github.com/NvkAnirudh/LinkedIn-Post-Generator.git cd LinkedIn-Post-Generator -
Install dependencies:
npm install
-
Create a
.envfile based on the example:cp .env.example .env
-
Add your API keys to the
.envfile:OPENAI_API_KEY=your_openai_api_key YOUTUBE_API_KEY=your_youtube_api_key -
Run the server:
npm run dev
-
Test with MCP Inspector:
npm run inspect
This MCP server is designed to work with Claude Desktop and other AI assistants that support the Model Context Protocol. To use it with Claude Desktop:
-
Configure Claude Desktop by editing the configuration file at
~/Library/Application Support/Claude/claude_desktop_config.json(Mac) or%APPDATA%\Claude\claude_desktop_config.json(Windows):{ "mcpServers": { "linkedin-post-generator": { "command": "npx", "args": [ "-y", "@smithery/cli@latest", "run", "@NvkAnirudh/linkedin-post-generator", "--key", "YOUR_SMITHERY_API_KEY", "--config", "{\"OPENAI_API_KEY\":\"YOUR_OPENAI_API_KEY\",\"YOUTUBE_API_KEY\":\"YOUR_YOUTUBE_API_KEY\"}", "--transport", "stdio" ] } } }Replace:
YOUR_SMITHERY_API_KEYwith your Smithery API keyYOUR_OPENAI_API_KEYwith your OpenAI API keyYOUR_YOUTUBE_API_KEYwith your YouTube API key (optional)
-
Restart Claude Desktop
-
In Claude Desktop, you can now access the LinkedIn Post Generator tools without needing to set API keys again
The application requires API keys to function properly:
- OpenAI API Key (required): Used for content summarization and post generation
- YouTube API Key (optional): Enhances YouTube metadata retrieval
You can provide these keys in three ways:
When using with Claude Desktop and Smithery, the best approach is to include your API keys in the Claude Desktop configuration file as shown in the Using with Claude Desktop section. This way, the keys are automatically passed to the MCP server, and you don't need to set them again.
When running locally, you can set API keys as environment variables in a .env file:
OPENAI_API_KEY=your_openai_api_key
YOUTUBE_API_KEY=your_youtube_api_key
If you haven't provided API keys through the configuration or environment variables, you can set them directly through the MCP interface using the set_api_keys tool.
- Tool:
set_api_keys - Purpose: Configure your API keys
- Parameters:
openaiApiKey: Your OpenAI API key (required)youtubeApiKey: Your YouTube API key (optional)
- Tool:
check_api_keys - Purpose: Verify your API key configuration status
- Tool:
extract_transcript - Purpose: Get the transcript from a YouTube video
- Parameters:
youtubeUrl: URL of the YouTube video
- Tool:
summarize_transcript - Purpose: Create a concise summary of the video content
- Parameters:
transcript: The video transcript texttone: Educational, inspirational, professional, or conversationalaudience: General, technical, business, or academicwordCount: Approximate word count for the summary (100-300)
- Tool:
generate_linkedin_post - Purpose: Create a LinkedIn post from a summary
- Parameters:
summary: Summary of the video contentvideoTitle: Title of the YouTube videospeakerName: Name of the speaker (optional)hashtags: Relevant hashtags (optional)tone: First-person, third-person, or thought-leaderincludeCallToAction: Whether to include a call to action
- Tool:
youtube_to_linkedin_post - Purpose: Complete workflow from YouTube URL to LinkedIn post
- Parameters:
youtubeUrl: YouTube video URLtone: Desired tone for the post- Plus additional customization options
- Set your API keys using the
set_api_keystool - Use the
youtube_to_linkedin_posttool with a YouTube URL - Receive a complete LinkedIn post draft ready to publish
This server is deployed on Smithery, a platform for hosting and sharing MCP servers. The deployment configuration is defined in the smithery.yaml file.
To deploy your own instance:
- Create an account on Smithery
- Install the Smithery CLI:
npm install -g @smithery/cli
- Deploy the server:
smithery deploy
Contributions are welcome and appreciated! Here's how you can contribute to the LinkedIn Post Generator:
- Use the GitHub issue tracker to report bugs or suggest features
- Please provide detailed information about the issue, including steps to reproduce, expected behavior, and actual behavior
- Include your environment details (OS, Node.js version, etc.) when reporting bugs
- Fork the repository
- Create a new branch (
git checkout -b feature/your-feature-name) - Make your changes
- Run tests to ensure your changes don't break existing functionality
- Commit your changes (
git commit -m 'Add some feature') - Push to the branch (
git push origin feature/your-feature-name) - Open a Pull Request
- Follow the existing code style and conventions
- Write clear, commented code
- Include tests for new features
- Update documentation to reflect your changes
If you have ideas for new features or improvements:
- Check existing issues to see if your suggestion has already been proposed
- If not, open a new issue with the label 'enhancement'
- Clearly describe the feature and its potential benefits
Improvements to documentation are always welcome:
- Fix typos or clarify existing documentation
- Add examples or use cases
- Improve the structure or organization of the documentation
By contributing to this project, you agree that your contributions will be licensed under the project's MIT License.