🚀 DAY 5 OF LAUNCH WEEK: Introducing Socket Firewall Enterprise.Learn more →
Socket
Book a DemoInstallSign in
Socket

@raydeck/gamma-app-mcp

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@raydeck/gamma-app-mcp

MCP server for Gamma.app API - Generate AI-powered presentations, documents, and social media posts

latest
Source
npmnpm
Version
1.0.1
Version published
Maintainers
1
Created
Source

Gamma MCP Server

An MCP (Model Context Protocol) server that enables AI assistants to generate Gamma presentations, documents, and social media posts using the Gamma.app API.

What is MCP?

The Model Context Protocol (MCP) allows AI assistants like Claude to interact with external tools and data sources. This server exposes Gamma's AI generation capabilities to any MCP-compatible client.

Features

  • 🎨 Generate presentations, documents, and social media posts
  • 🤖 AI-powered content generation with customizable options
  • 🎭 Theme support for consistent branding
  • 📝 Multiple text modes: generate, condense, or preserve
  • 🖼️ Image generation options (AI-generated or Unsplash)
  • 📊 Export as PDF or PPTX
  • 🌍 Multi-language support

Prerequisites

  • Node.js 18 or higher
  • A Gamma.app account with API access
  • Gamma API key (get one from Gamma.app API settings)

Installation & Usage

Production Mode (via NPM)

Once published to NPM, you can use the server directly with npx:

  • Configure your MCP client (e.g., Claude Desktop) by adding to your config file:

    macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

    Windows: %APPDATA%\Claude\claude_desktop_config.json

    {
      "mcpServers": {
        "gamma": {
          "command": "npx",
          "args": ["-y", "@raydeck/gamma-app-mcp"],
          "env": {
            "GAMMA_API_KEY": "your-gamma-api-key-here"
          }
        }
      }
    }
    
  • Restart your MCP client to load the server

Local Development / Testing Mode

For testing and development before publishing:

  • Clone/navigate to the repository:

    cd /path/to/gamma-mcp
    
  • Install dependencies:

    npm install
    
  • Build the project:

    npm run build
    
  • Configure your MCP client with the local path:

    macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

    Windows: %APPDATA%\Claude\claude_desktop_config.json

    {
      "mcpServers": {
        "gamma": {
          "command": "node",
          "args": ["/absolute/path/to/gamma-mcp/dist/index.js"],
          "env": {
            "GAMMA_API_KEY": "your-gamma-api-key-here"
          }
        }
      }
    }
    

    Alternative using npm link:

    # In the gamma-mcp directory
    npm link
    
    # Then in your MCP config:
    {
      "mcpServers": {
        "gamma": {
          "command": "gamma-mcp",
          "env": {
            "GAMMA_API_KEY": "your-gamma-api-key-here"
          }
        }
      }
    }
    
  • Restart your MCP client

Development Mode (with auto-reload)

For active development with TypeScript hot-reloading:

npm run dev

This runs the server directly from TypeScript source using tsx.

Configuration

Environment Variables

  • GAMMA_API_KEY (required): Your Gamma API key

Available Tools

generate_gamma

Generate AI-powered Gamma content (presentations, documents, or social posts).

Note: This tool returns a generation ID. Use the get_gamma_generation tool to automatically wait for completion and retrieve the final URLs.

Parameters

ParameterTypeRequiredDescription
inputTextstringâś…The text content to generate from (1-400,000 characters). Can be a short prompt, messy notes, or polished content.
textModestring❌How to process input: generate, condense, or preserve (default: generate)
formatstring❌Output format: presentation, document, or social (default: presentation)
themeNamestring❌Name of a specific theme to use. Only use if the user explicitly requests a custom theme by name. Theme must exist in your Gamma workspace. Omit this parameter to use Gamma's default theme selection.
numCardsnumber❌Number of cards/slides to generate (1-60 for Pro, 1-75 for Ultra, default: 10)
cardSplitstring❌How to split content: auto or inputTextBreaks (default: auto)
additionalInstructionsstring❌Additional instructions for content and layout (1-500 characters)
exportAsstring❌Export format: pdf or pptx

Text Options

ParameterTypeDescription
textOptions.amountstringAmount of text per card: brief, medium, detailed, or extensive
textOptions.tonestringTone of voice for the content
textOptions.audiencestringIntended audience
textOptions.languagestringOutput language code (e.g., 'en', 'es', 'fr')

Image Options

ParameterTypeDescription
imageOptions.sourcestringImage source: aiGenerated or unsplash
imageOptions.modelstringAI model to use for image generation
imageOptions.stylestringArtistic style for generated images

Card Options

ParameterTypeDescription
cardOptions.dimensionsstringCard dimensions: fluid, 16x9, or 4x3

Sharing Options

ParameterTypeDescription
sharingOptions.workspaceAccessstringWorkspace access level

Example Usage

When using with Claude or another MCP client:

Create a 10-slide presentation about "The Future of AI" with a professional tone, 
targeted at business executives, using medium text amount and AI-generated images.

The AI will use the tool like this:

{
  "inputText": "The Future of AI - covering trends, opportunities, and challenges",
  "format": "presentation",
  "numCards": 10,
  "textOptions": {
    "amount": "medium",
    "tone": "professional",
    "audience": "business executives"
  },
  "imageOptions": {
    "source": "aiGenerated"
  }
}

get_gamma_generation

Retrieve the status and URLs of a Gamma generation. Automatically polls every 5 seconds until generation is complete (recommended by Gamma API).

Parameters

ParameterTypeRequiredDescription
generationIdstringâś…The generation ID returned from generate_gamma
pollUntilCompleteboolean❌Whether to automatically poll until complete (default: true)
maxWaitSecondsnumber❌Maximum wait time in seconds when polling (default: 300 = 5 minutes)

Automatic Polling (Default Behavior)

By default, the tool automatically polls every 5 seconds until the generation is complete or fails:

  • âś… Follows Gamma API recommendation (5-second intervals)
  • âś… Returns final URLs when ready
  • âś… Times out after 5 minutes (configurable)
  • âś… Simple single tool call - no manual polling needed

Response

The tool returns a JSON response containing:

  • Status: pending, processing, completed, or failed
  • URL: Link to the generated Gamma (editable in Gamma app)
  • Export URLs: PDF or PPTX download links (if requested during generation)

Example Usage

Automatic polling (recommended):

{
  "generationId": "abc123"
}

Waits until complete and returns final URLs

Custom timeout:

{
  "generationId": "abc123",
  "maxWaitSeconds": 600
}

Waits up to 10 minutes

Single status check (no polling):

{
  "generationId": "abc123",
  "pollUntilComplete": false
}

Returns current status immediately without waiting

Response Format

generate_gamma Response

Returns a JSON response from the Gamma API containing:

  • Generation ID (use with get_gamma_generation)
  • Initial status

get_gamma_generation Response

Returns:

  • Current status (pending, processing, completed, failed)
  • Gamma URL (when completed)
  • Export links for PDF/PPTX (if requested)

Development Workflow

Project Structure

gamma-mcp/
├── src/
│   └── index.ts          # Main server implementation
├── dist/                 # Compiled JavaScript output
├── package.json          # NPM package configuration (includes mcpName for registry validation)
├── server.json           # MCP registry metadata
├── tsconfig.json
└── README.md

Note: The server.json file is required for publishing to the MCP Registry. It contains metadata about your server including its namespace (io.github.statechangelabs/gamma-app-mcp), package information, and deployment configuration.

Building

npm run build

This compiles TypeScript to JavaScript in the dist/ directory.

Validating server.json

Before publishing to the MCP registry, you can validate your server.json:

npm run validate

This checks that your server.json has all required fields and is properly structured for the MCP registry.

Testing Locally

  • Make changes to src/index.ts
  • Run npm run build to compile
  • Restart your MCP client to reload the server
  • Test with your AI assistant

Publishing to NPM

When ready to publish:

  • Update version in package.json and server.json:

    npm version patch  # or minor, or major
    

    Then update the version field in server.json to match.

  • Build the project:

    npm run build
    
  • Publish to NPM:

    npm publish --access public
    
  • Users can then install via:

    npx @raydeck/gamma-app-mcp
    

Publishing to the MCP Registry

After publishing to NPM, you can publish to the official MCP registry to make your server discoverable:

  • Install the MCP Publisher CLI:

    # macOS/Linux with Homebrew
    brew install mcp-publisher
    
    # Or download pre-built binaries from:
    # https://github.com/modelcontextprotocol/registry/releases
    
  • Authenticate with GitHub (for io.github.* namespaces):

    mcp-publisher login github
    
  • Publish to the registry:

    mcp-publisher publish
    
  • Verify publication:

    curl "https://registry.modelcontextprotocol.io/v0/servers?search=io.github.statechangelabs/gamma-app-mcp"
    

For detailed instructions, see the official publishing guide.

Troubleshooting

Server not starting

  • Verify GAMMA_API_KEY is set correctly in your MCP config
  • Check that Node.js version is 18 or higher
  • Ensure the path in your config is absolute and correct

API Errors

  • Verify your Gamma API key is valid
  • Check that you have sufficient API credits
  • Review Gamma API documentation for parameter requirements

MCP Client Not Detecting Server

  • Ensure the config JSON is valid (use a JSON validator)
  • Restart your MCP client after config changes
  • Check client logs for error messages

Resources

License

ISC

Author

Ray Deck

Support

For issues and questions:

Keywords

mcp

FAQs

Package last updated on 13 Oct 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts