Instant MCP Server for Claude Desktop to Make Images and Videos using FAL

FAL Image/Video MCP Server ๐ŸŽจ๐ŸŽฌ

High-performance MCP server for FAL AI image and video generation with automatic downloads

VersionPlatform SupportLicenseTypeScriptMCP Compatible

Seamless bridge between FAL AI's powerful image and video generation capabilities and MCP-compatible clients like Claude. All generated content is automatically downloaded to your local machine while providing public URLs, data URLs, and local file paths.

Make ImagesExample of MCP

Make VideosExample of MCP

๐Ÿš€ Claude Desktop Setup

Quick Setup

  1. Get your FAL API key from fal.ai
  2. Add to Claude Desktop configuration:
{
  "mcpServers": {
    "fal-image-video": {
      "command": "npx",
      "args": ["-y", "fal-image-video-mcp"],
      "env": {
        "FAL_KEY": "YOUR-FAL-AI-API-KEY"
      }
    }
  }
}

Configuration File Locations

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%/Claude/claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json

Optimized for Claude Desktop

{
  "mcpServers": {
    "fal-image-video": {
      "command": "npx",
      "args": ["-y", "fal-image-video-mcp"],
      "env": {
        "FAL_KEY": "YOUR-FAL-AI-API-KEY",
        "DOWNLOAD_PATH": "/custom/download/path",
        "ENABLE_DATA_URLS": "true",
        "MAX_DATA_URL_SIZE": "1048576",
        "AUTOOPEN": "false"
      }
    }
  }
}

Environment Variables:

  • FAL_KEY (required): Your FAL AI API key
  • DOWNLOAD_PATH (optional): Custom download directory (defaults to ~/Downloads)
  • ENABLE_DATA_URLS (optional): Enable/disable data URLs (default: false, optimized for Claude Desktop)
  • MAX_DATA_URL_SIZE (optional): Max file size for data URLs in bytes (default: 2MB)
  • AUTOOPEN (optional): Automatically open generated files with default application (default: true, cross-platform)

Getting Your FAL API Key

  1. Visit fal.ai and create an account
  2. Navigate to your API keys section
  3. Generate a new API key
  4. Replace YOUR-FAL-AI-API-KEY with your actual key
  5. Restart Claude Desktop

๐Ÿ“ฅ Automatic Downloads

All generated content is automatically saved to your local machine!

Default Behavior:

  • Images: Downloaded as .jpg files
  • Videos: Downloaded as .mp4 files
  • Location: ~/Downloads folder (or custom DOWNLOAD_PATH)
  • Naming: fal_{model}_{timestamp}_{index}.{ext}

๐ŸŽฏ Claude Desktop Optimized Response:

{
  "images": [
    {
      "url": "https://fal-storage.../image.jpg",
      "localPath": "/Users/you/Downloads/fal_imagen4_2025-01-06T12-30-45-123Z.jpg",
      "width": 1024,
      "height": 1024
    }
  ],
  "download_path": "/Users/you/Downloads",
  "data_url_settings": {
    "enabled": false,
    "max_size_mb": 2,
    "note": "Data URLs disabled by default for Claude Desktop optimization"
  },
  "autoopen_settings": {
    "enabled": true,
    "note": "Files automatically opened with default application"
  }
}

Why this works better for Claude Desktop:

  • โœ… Local file paths allow Claude to directly access downloaded images
  • โœ… No large data URLs that overwhelm the context
  • โœ… Auto-open files instantly display generated content in default applications
  • โœ… Public URLs available for sharing if needed
  • โœ… Size limits prevent context overflow

โœจ Features

Category Features
๐ŸŽจ Image Generation 8 curated models including Imagen 4, FLUX Kontext Pro, Ideogram V3
๐ŸŽฌ Video Generation 7 text-to-video models including Veo 3, Kling 2.1 Master, Pixverse V4.5
๐Ÿ”„ Image-to-Video 6 image-to-video models for animating static images
๐Ÿ“ฅ Auto Downloads All content automatically saved locally with custom path support
๐Ÿ”— Triple URL Support Public URLs, Data URLs, and Local file paths
๐Ÿš€ Universal Execution Run any FAL model beyond the curated registry
๐ŸŒ Multi-Transport stdio (Claude Desktop) + HTTP/SSE (Smithery/Web)
๐Ÿ” Lazy Authentication Discover tools without API key, authenticate on use
โšก Performance TypeScript implementation, async operations, error handling

๐Ÿš€ Version History

Version 1.0.0

  • โœ… Initial release with FAL AI integration
  • โœ… Image generation with Flux models
  • โœ… Video generation with Minimax
  • โœ… Data URL conversion for MCP compatibility
  • โœ… TypeScript support
  • โœ… NPX deployment ready

Coming Soon

  • ๐Ÿ”œ Additional FAL models
  • ๐Ÿ”œ Batch processing
  • ๐Ÿ”œ Enhanced error handling
  • ๐Ÿ”œ Performance optimizations

๐Ÿ—๏ธ Technical Architecture

Component Technology Purpose
Backend TypeScript + Node.js Core server implementation
AI Client @fal-ai/client FAL API integration
MCP SDK @modelcontextprotocol/sdk MCP protocol compliance
Transport stdio / HTTP + SSE Multi-transport communication
Build System TypeScript Compiler Production builds
Deployment npm / Docker / Smithery Multiple deployment options

๐Ÿ“– Usage

Available Tools

๐ŸŽจ Image Generation Models (8 Available)

The server dynamically loads the latest available models from FAL AI. Current models include:

imagen4 - Imagen 4

Google's latest text-to-image model with superior quality.

{
  "tool": "imagen4",
  "arguments": {
    "prompt": "A photorealistic mountain landscape at golden hour",
    "image_size": "landscape_16_9"
  }
}
flux_kontext - FLUX Kontext Pro

State-of-the-art prompt adherence and typography generation.

{
  "tool": "flux_kontext",
  "arguments": {
    "prompt": "Modern logo design with the text 'AI Studio'",
    "num_inference_steps": 25
  }
}
ideogram_v3 - Ideogram V3

Advanced typography and realistic outputs.

{
  "tool": "ideogram_v3",
  "arguments": {
    "prompt": "Vintage poster with text 'Retro Cafรฉ'",
    "negative_prompt": "blurry, low quality"
  }
}
recraft_v3 - Recraft V3

Professional design and illustration capabilities.

{
  "tool": "recraft_v3",
  "arguments": {
    "prompt": "Minimalist icon design for a mobile app",
    "image_size": "square_hd"
  }
}
Other Available Models:
  • stable_diffusion_35 - Stable Diffusion 3.5 Large
  • flux_dev - FLUX Dev (High-quality 12B parameter model)
  • hidream - HiDream I1 (High-resolution generation)
  • janus - Janus (Multimodal understanding)

๐ŸŽฌ Image-to-Video Models (6 Available)

kling_master_image - Kling 2.1 Master I2V

Premium image-to-video conversion with motion fluidity.

{
  "tool": "kling_master_image",
  "arguments": {
    "image_url": "https://example.com/landscape.jpg",
    "prompt": "Gentle wind blowing through the trees",
    "duration": 5
  }
}
pixverse_image - Pixverse V4.5 I2V

Advanced image-to-video with high quality output.

{
  "tool": "pixverse_image",
  "arguments": {
    "image_url": "https://example.com/portrait.jpg",
    "prompt": "Person looking around and smiling",
    "aspect_ratio": "16:9"
  }
}
wan_pro_image - Wan Pro I2V

Professional image animation with effects.

{
  "tool": "wan_pro_image",
  "arguments": {
    "image_url": "https://example.com/scene.jpg",
    "prompt": "Camera slowly panning across the scene"
  }
}
Other Available Models:
  • hunyuan_image - Hunyuan I2V (Open-source)
  • vidu_image - Vidu I2V (High-quality animation)
  • luma_ray2_image - Luma Ray 2 I2V (Latest Luma)

๐Ÿ“น Text-to-Video Models (7 Available)

veo3 - Veo 3

Google DeepMind's latest with speech and audio capabilities.

{
  "tool": "veo3",
  "arguments": {
    "prompt": "A serene mountain lake with gentle ripples at sunrise",
    "duration": 10,
    "aspect_ratio": "16:9"
  }
}
kling_master_text - Kling 2.1 Master

Premium text-to-video with motion fluidity and cinematic quality.

{
  "tool": "kling_master_text",
  "arguments": {
    "prompt": "A cat playing with a ball of yarn in slow motion",
    "duration": 6,
    "aspect_ratio": "16:9"
  }
}
pixverse_text - Pixverse V4.5

Advanced text-to-video generation with precise control.

{
  "tool": "pixverse_text",
  "arguments": {
    "prompt": "Ocean waves crashing on a rocky shore at sunset",
    "duration": 8
  }
}
luma_ray2 - Luma Ray 2

Latest Luma Dream Machine with enhanced capabilities.

{
  "tool": "luma_ray2",
  "arguments": {
    "prompt": "A field of flowers swaying in the breeze",
    "aspect_ratio": "16:9"
  }
}
Other Available Models:
  • magi - Magi (Creative video generation)
  • wan_pro_text - Wan Pro (Professional video effects)
  • vidu_text - Vidu Q1 (High-quality text-to-video)

๐Ÿ”„ Image-to-Video Workflow

Yes! You can absolutely pass generated images back to Claude and use them for video generation. Here's how:

  1. Generate an image using any image model:
{
  "tool": "imagen4",
  "arguments": {
    "prompt": "A majestic mountain landscape at sunset"
  }
}
  1. Use the returned image URL in any image-to-video model:
{
  "tool": "kling_master_image",
  "arguments": {
    "image_url": "<URL_FROM_PREVIOUS_GENERATION>",
    "prompt": "Gentle clouds moving across the sky",
    "duration": 5
  }
}

๐Ÿ”ง Advanced Model System

This MCP server features comprehensive model access:

๐Ÿ“‹ Model Discovery

Use list_available_models to see all models in the registry:

{
  "tool": "list_available_models",
  "arguments": {
    "category": "imageGeneration"
  }
}

๐Ÿš€ Universal Model Execution

Use execute_custom_model to run ANY FAL endpoint beyond our registry:

{
  "tool": "execute_custom_model",
  "arguments": {
    "endpoint": "fal-ai/custom-model-name",
    "input_params": {
      "prompt": "Your custom prompt",
      "custom_param": "value"
    },
    "category_hint": "image"
  }
}

โœจ Smart Features:

  • โœ… 21 curated models from actual FAL AI platform
  • โœ… Universal execution for any FAL endpoint
  • โœ… Automatic downloading to ~/Downloads (configurable)
  • โœ… Triple URL support (public + data + local file URLs)
  • โœ… Automatic categorization by type
  • โœ… Dynamic tool generation for each model
  • โœ… Model-specific parameter handling

๐ŸŽฏ No Limitations:

  • Want to use a model not in our registry? Use execute_custom_model
  • Need to see all available models? Use list_available_models
  • Want both curated experience AND full flexibility? You got it!

The MCP server provides both public URLs and data URLs for maximum compatibility with Claude and other clients.

Response Format

Both tools return structured JSON with:

  • Public URL: Direct link to the generated content
  • Data URL: Base64-encoded data URL for direct embedding
  • Metadata: Generation parameters and dimensions
  • Claude-compatible format: Ready for immediate use in conversations

Example Response:

{
  "model": "fal-ai/flux/schnell",
  "prompt": "A majestic dragon...",
  "images": [
    {
      "url": "https://storage.googleapis.com/fal-flux-storage/...",
      "dataUrl": "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQ...",
      "width": 1024,
      "height": 768
    }
  ],
  "metadata": {
    "image_size": "landscape_4_3",
    "num_inference_steps": 4,
    "guidance_scale": 3.5
  }
}

๐Ÿ”ง Alternative Installation Methods

๐ŸŒ HTTP Server Mode (Standalone Testing)

Start HTTP server for testing or integration:

# Start on auto-detected port (default: 3000)
npx -y fal-image-video-mcp --http

# Or specify port via environment
PORT=8080 npx -y fal-image-video-mcp --http

# With custom transport flag
MCP_TRANSPORT=http npx -y fal-image-video-mcp

HTTP Endpoints:

  • GET /health - Server health check
  • GET /mcp - SSE endpoint for MCP communication
  • POST /mcp - JSON-RPC message handling

Test the server:

# Health check
curl http://localhost:3000/health

# List available tools
curl -X POST http://localhost:3000/mcp \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc": "2.0", "id": 1, "method": "tools/list", "params": {}}'

๐ŸŽฏ Authentication in HTTP Mode

Lazy Loading Support:

  • โœ… Server starts without FAL_KEY (for tool discovery)
  • โœ… API key validated only when tools are invoked
  • โœ… Clear error messages for missing authentication

Set your FAL_KEY:

# Via environment variable
FAL_KEY=your-api-key npx fal-image-video-mcp --http

# Or configure in your deployment platform
export FAL_KEY=your-api-key
npx fal-image-video-mcp --http

Production deployment example:

# Dockerfile
FROM node:18-slim
ENV FAL_KEY=your-api-key
ENV PORT=3000
RUN npx -y fal-image-video-mcp --http
EXPOSE 3000

๐Ÿ“ฑ NPX (One-time use)

# Stdio mode (Claude Desktop)
npx -y fal-image-video-mcp

# HTTP mode (Testing/Smithery)
npx -y fal-image-video-mcp --http

๐Ÿ”ง Global Installation

npm install -g fal-image-video-mcp

# Run in different modes
fal-image-video-mcp              # Stdio mode
fal-image-video-mcp --http       # HTTP mode

๐Ÿ’ป From Source

git clone https://github.com/RamboRogers/fal-image-video-mcp.git
cd fal-image-video-mcp
npm install
npm run build

# Choose your transport
npm start                    # Stdio mode
npm start -- --http         # HTTP mode

๐Ÿ“„ License

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

GPLv3 License

๐ŸŒ Connect

GitHubWebsiteEmail

Created by Matthew Rogers - Bringing AI creativity to MCP clients everywhere! ๐Ÿš€

MCP Server ยท Populars

MCP Server ยท New