Skip to main content

HeyGen MCP Server for AI Video Creation (Community Fork)

Project description

HeyGen MCP Server

VS Code Marketplace Installs PyPI Downloads GitHub Downloads

CI Release PyPI Version

License: MIT Python Built with Copilot

HeyGen Logo

⚠️ Disclaimer: This is a community fork of the original HeyGen MCP server, which appears to be abandoned. This is not an official HeyGen repository. Use at your own discretion.

Generate AI Videos with Natural Language - A Model Context Protocol (MCP) server for HeyGen API integration with AI assistants.

The HeyGen MCP server enables AI assistants (GitHub Copilot, Claude, ChatGPT) to generate AI avatar videos, manage templates, and work with assets through natural language commands.

🚀 Quick Start (1 Minute)

Requirements: Python 3.10+ | HeyGen API Key (get one here - 10 free credits/month)

⭐ Recommended: VS Code Extension (One-Click Setup)

Fastest way to get started - everything configured automatically:

Install from VS Code Marketplace →

The extension handles server registration and API key configuration automatically!


Installation

Prerequisites

  • Python 3.10 or higher
  • A Heygen API key (get one from Heygen). Includes 10 Free Credits per Month

Install from PyPI

Install the package directly using pip or uv:

# Using pip
pip install heygen-mcp-sbroenne

# Using uv (recommended)
uv pip install heygen-mcp-sbroenne

# Or run directly without installing (uvx)
uvx heygen-mcp-sbroenne

Install from GitHub Releases

Download pre-built packages from GitHub Releases:

  1. Download the .whl or .tar.gz file from the latest release
  2. Install with pip:
    pip install heygen_mcp_sbroenne-*.whl
    

For the VS Code extension, download the .vsix file and install via:

  • VS Code → Extensions → ... menu → "Install from VSIX..."

Usage

VS Code Extension (Recommended)

The easiest way to use HeyGen MCP with VS Code is through the community VS Code extension:

  1. Install the extension:

  2. Configure your API key:

    • Use Command Palette (Ctrl+Shift+P)
    • Search for "HeyGen: Configure API Key"
    • Enter your API key
  3. Start using it:

    • The HeyGen MCP server will automatically be available to your AI assistant
    • Ask your AI assistant to generate videos, manage templates, etc.

See vscode-extension/README.md for more details.

Quickstart with Claude Desktop

  1. Get your API key from HeyGen.
  2. Install uv package manager (see Installing uv section above).
  3. Go to Claude > Settings > Developer > Edit Config > claude_desktop_config.json to include the following:
{
  "inputs": [
    {
      "id": "heygen-api-key",
      "type": "promptString",
      "description": "HeyGen API Key",
      "password": true
    }
  ],
  "mcpServers": {
    "HeyGen": {
      "command": "uvx",
      "args": ["heygen-mcp-sbroenne"],
      "env": {
        "HEYGEN_API_KEY": "${input:heygen-api-key}"
      }
    }
  }
}

If you're using Windows, you'll need to enable "Developer Mode" in Claude Desktop to use the MCP server. Click "Help" in the hamburger menu at the top left and select "Enable Developer Mode".

Using with VS Code (Manual Configuration)

Add the following to your VS Code settings (.vscode/mcp.json):

{
  "inputs": [
    {
      "id": "heygen-api-key",
      "type": "promptString",
      "description": "HeyGen API Key",
      "password": true
    }
  ],
  "servers": {
    "HeyGen": {
      "type": "stdio",
      "command": "uvx",
      "args": ["heygen-mcp-sbroenne"],
      "env": {
        "HEYGEN_API_KEY": "${input:heygen-api-key}"
      }
    }
  }
}

Using a Local Development Version

If you want to run from a local clone (for development or testing), use uv run instead of uvx:

{
  "inputs": [
    {
      "id": "heygen-api-key",
      "type": "promptString",
      "description": "HeyGen API Key",
      "password": true
    },
    {
      "id": "heygen-mcp-path",
      "type": "promptString",
      "description": "Path to local heygen-mcp repository"
    }
  ],
  "mcpServers": {
    "HeyGen": {
      "type": "stdio",
      "command": "uv",
      "args": [
        "run",
        "--directory",
        "${input:heygen-mcp-path}",
        "python",
        "-m",
        "heygen_mcp.server"
      ],
      "env": {
        "HEYGEN_API_KEY": "${input:heygen-api-key}"
      }
    }
  }
}

For VS Code, use servers instead of mcpServers.

Available MCP Tools

The server provides 7 resource-based tools, each with multiple actions:

user - User Account Management

Action Description
info Get user profile information
credits Get remaining credits/quota

voices - Voice Management

Action Description
list Get available voices (max 100, private voices first)

avatars - Avatar Management

Action Parameters Description
list - Get all avatars and talking photos
get avatar_id Get details for a specific avatar
list_groups include_public (optional) Get avatar groups
list_in_group group_id Get avatars in a specific group

videos - Video Generation

Action Parameters Description
list token (optional) List all videos with pagination
generate video_inputs_json (JSON array of scenes), title (optional) Create a new avatar video
generate_iv image_key, script, voice_id, video_title, motion options Create Avatar IV video from photo
status video_id Check video processing status

✨ Video Background Support - Generate videos with color, image, or video backgrounds. See Video Backgrounds Guide for details.

templates - Template Management

Action Parameters Description
list - Get all templates in your account
get template_id Get template details including variables
generate template_id, variables (optional), title, test, caption Create video from template

assets - Asset Management

Action Parameters Description
list - Get all assets (images, videos, audios)
upload file_path Upload a media file, returns asset_id
delete asset_id Remove an asset

folders - Folder Management

Action Parameters Description
list - Get all folders
create name Create a new folder
delete folder_id Delete a folder

Example Usage:

# Get remaining credits
user(action="credits")

# List all avatars
avatars(action="list")

# Get specific avatar details
avatars(action="get", avatar_id="avatar_123")

# Generate a video (single scene)
videos(action="generate", video_inputs_json='[{"character": {"avatar_id": "..."}, "voice": {"voice_id": "...", "input_text": "Hello!"}}]')

Development

Setup

# Clone the repository
git clone https://github.com/sbroenne/heygen-mcp.git
cd heygen-mcp

# Install dependencies
uv sync --dev

# Install pre-commit hooks
uv run pre-commit install

Pre-commit Hooks

This project uses pre-commit to run checks before each commit:

  • ruff - Linting and auto-fixing
  • ruff-format - Code formatting
  • pyright - Type checking
  • trailing-whitespace - Remove trailing whitespace
  • end-of-file-fixer - Ensure files end with newline
  • check-yaml - Validate YAML files

Run hooks manually on all files:

uv run pre-commit run --all-files

Running with MCP Inspector

To run the server locally with the MCP Inspector for testing and debugging:

uv run mcp dev heygen_mcp/server.py

This will start the server in development mode and allow you to use the MCP Inspector to test the available tools and functionality.

Running Tests

# Run all tests (requires HEYGEN_API_KEY in .env)
uv run pytest tests/ -v

# Skip video generation tests (uses credits)
uv run pytest tests/ -v -k "not video_generation"

LLM Integration Tests

This project includes LLM-based tests using agent-benchmark to validate that AI assistants can correctly understand and use the MCP tools.

cd tests/heygen_mcp_llm_tests

# List available test scenarios
python run_llm_tests.py --list

# Run safe tests (read-only, no credits consumed)
python run_llm_tests.py

# Run a specific scenario
python run_llm_tests.py -s user-credits-test

Requirements: Azure OpenAI endpoint (AZURE_OPENAI_ENDPOINT) and HeyGen API key (HEYGEN_API_KEY).

See tests/heygen_mcp_llm_tests/README.md for full documentation.

Roadmap

  • Tests (integration tests + MCP server smoke tests)
  • Template API Support
  • CI/CD (GitHub Actions + PyPI release)
  • Photo Avatar APIs Support
  • SSE And Remote MCP Server with OAuth Flow
  • Translation API Support
  • Interactive Avatar API Support

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

For maintainers: see the Publishing Guide for release instructions.

Related Projects

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

heygen_mcp_sbroenne-0.3.1.tar.gz (36.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

heygen_mcp_sbroenne-0.3.1-py3-none-any.whl (27.1 kB view details)

Uploaded Python 3

File details

Details for the file heygen_mcp_sbroenne-0.3.1.tar.gz.

File metadata

  • Download URL: heygen_mcp_sbroenne-0.3.1.tar.gz
  • Upload date:
  • Size: 36.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for heygen_mcp_sbroenne-0.3.1.tar.gz
Algorithm Hash digest
SHA256 2d8bd8c80b8555e24d67bdce49e4661b6be3d22e1748654b9374de2064034dbe
MD5 6b085e483cb1e5502a958bfcbfc1d459
BLAKE2b-256 6822d45f9bc210736b878b079704f797c5ed23b58b175c4c395b9b041714896f

See more details on using hashes here.

Provenance

The following attestation bundles were made for heygen_mcp_sbroenne-0.3.1.tar.gz:

Publisher: release.yml on sbroenne/heygen-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file heygen_mcp_sbroenne-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for heygen_mcp_sbroenne-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8c7ee67998145792184f040aab2099213ab619ece08785c632df3eb809eeee60
MD5 b9fde4e6af9a7af1e4c5f7d6fd037b66
BLAKE2b-256 cc39d67235091b992fa331950ec10b0bb9fe3751bf543f7a598af440c2b788b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for heygen_mcp_sbroenne-0.3.1-py3-none-any.whl:

Publisher: release.yml on sbroenne/heygen-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page