Skip to main content

Product Hunt MCP Server - A FastMCP implementation for the Product Hunt API

Project description

๐Ÿš€ Product Hunt MCP Server

PyPI version License: MIT Python 3.10+ Docker Ready MCP Compatible

A plug-and-play MCP server for Product Hunt


๐Ÿ“ฆ Quick Install

pip install product-hunt-mcp

๐Ÿƒโ€โ™‚๏ธ Quick Start Example

# Run the MCP server (requires PRODUCT_HUNT_TOKEN environment variable)
export PRODUCT_HUNT_TOKEN=your_token_here
product-hunt-mcp

โœจ What is this?

Product Hunt MCP Server connects Product Hunt's API to any LLM or agent that speaks the Model Context Protocol (MCP). Perfect for AI assistants, chatbots, or your own automations!

  • ๐Ÿ” Get posts, collections, topics, users
  • ๐Ÿ—ณ๏ธ Get votes, comments, and more
  • ๐Ÿ› ๏ธ Use with Claude Desktop, Cursor, or any MCP client

๐Ÿ› ๏ธ Features

  • Get detailed info on posts, comments, collections, topics, users
  • Search/filter by topic, date, votes, etc.
  • Paginated comments, user upvotes, and more
  • Built with FastMCP for speed and compatibility

๐Ÿง‘โ€๐Ÿ’ป Who is this for?

  • AI/LLM users: Plug into Claude Desktop, Cursor, or your own agent
  • Developers: Build bots, dashboards, or automations with Product Hunt data
  • Tinkerers: Explore the MCP ecosystem and build your own tools

๐Ÿ Setup

Prerequisites

  • Python 3.10+
  • Product Hunt API token (get one here)
    • You'll need to create an account on Product Hunt
    • Navigate to the API Dashboard and create a new application
    • Use the Developer Token for the token

Note: When creating a new application on Product Hunt, you will be asked for a redirect_uri. While the MCP server does not use the redirect URI, it is a required field. You can enter any valid URL, such as https://localhost:8424/callback.

Installation

Preferred: uv (fast, modern Python installer)

# Install uv if you don't have it
pip install uv

Install from PyPI (recommended)

uv pip install product-hunt-mcp
# or
pip install product-hunt-mcp

Install from GitHub (latest main branch)

uv pip install 'git+https://github.com/jaipandya/producthunt-mcp-server.git'
# or
pip install 'git+https://github.com/jaipandya/producthunt-mcp-server.git'

Install locally from source

uv pip install .
# or
pip install .

๐Ÿš€ Usage with Claude Desktop & Cursor

Once installed, the product-hunt-mcp command will be available. Add it to your Claude Desktop or Cursor configuration:

{
  "mcpServers": {
    "product-hunt": {
      "command": "product-hunt-mcp",
      "env": {
        "PRODUCT_HUNT_TOKEN": "your_token_here"
      }
    }
  }
}
  • Replace your_token_here with your actual Product Hunt API token.
  • The token must be set as an environment variable in your Claude Desktop or Cursor config for the server to authenticate.
  • Always restart your client (Claude Desktop/Cursor) after editing the config file.

Tip: On macOS, Claude Desktop may not always find the product-hunt-mcp command if it's not in the default PATH. If you encounter issues, you can provide the full path to the executable. After installing, run:

which product-hunt-mcp

Use the output path in your Claude Desktop config, replacing "command": "product-hunt-mcp" with the full path (e.g., "command": "/Users/youruser/.local/bin/product-hunt-mcp").

Finding your configuration file

  • Claude Desktop:

    • Windows: %APPDATA%\claude-desktop\config.json
    • macOS: ~/Library/Application Support/claude-desktop/config.json
    • Linux: ~/.config/claude-desktop/config.json
  • Cursor:

    • Windows: %APPDATA%\Cursor\User\settings.json
    • macOS: ~/Library/Application Support/Cursor/User/settings.json
    • Linux: ~/.config/Cursor/User/settings.json

Docker

You can also run the server using Docker:

# Build the Docker image
docker build -t product-hunt-mcp .

# Run the Docker container (interactive for MCP)
docker run -i --rm -e PRODUCT_HUNT_TOKEN=your_token_here product-hunt-mcp

For Claude Desktop/Cursor integration with Docker, use this configuration:

{
  "mcpServers": {
    "product-hunt": {
      "command": "docker",
      "args": ["run", "-i", "--rm", "-e", "PRODUCT_HUNT_TOKEN=your_token_here", "product-hunt-mcp"],
      "env": {}
    }
  }
}

Security Note: Your PRODUCT_HUNT_TOKEN is sensitive. Do not share it or commit it to version control.


๐Ÿ› ๏ธ MCP Tools

Tool Description Key Parameters
get_post_details Get info about a specific post id or slug, comments_count, comments_after
get_posts Get posts with filters topic, order, count, featured, posted_before, posted_after
get_comment Get info about a specific comment id (required)
get_post_comments Get comments for a post post_id or slug, order, count, after
get_collection Get info about a collection id or slug
get_collections Get collections with filters featured, user_id, post_id, order, count
get_topic Get info about a topic id or slug
search_topics Search topics query, followed_by_user_id, order, count
get_user Get info about a user id or username, posts_type, posts_count
get_viewer Get info about the authenticated user None
check_server_status Check server/API status & authentication None

๐Ÿ—๏ธ Project Structure

product-hunt-mcp/
โ”œโ”€โ”€ src/
โ”‚   โ””โ”€โ”€ product_hunt_mcp/ # Main package directory
โ”‚       โ”œโ”€โ”€ __init__.py
โ”‚       โ”œโ”€โ”€ cli.py        # Command-line entry point
โ”‚       โ”œโ”€โ”€ api/          # API clients & queries
โ”‚       โ”œโ”€โ”€ schemas/      # Data validation schemas
โ”‚       โ”œโ”€โ”€ tools/        # MCP tool definitions
โ”‚       โ””โ”€โ”€ utils/        # Utility functions
โ”œโ”€โ”€ pyproject.toml      # Project metadata, dependencies, build config
โ”œโ”€โ”€ README.md
โ”œโ”€โ”€ CONTRIBUTING.md
โ”œโ”€โ”€ CHANGELOG.md
โ”œโ”€โ”€ Dockerfile
โ””โ”€โ”€ ... (config files, etc.)

๐Ÿ”„ Rate Limiting

The Product Hunt API has rate limits that this client respects. If you encounter rate limit errors, the client will inform you when the rate limit resets. You can check your current rate limit status using the get_api_rate_limits or check_server_status tools.


๐Ÿ› Troubleshooting

  • Missing token: Ensure your PRODUCT_HUNT_TOKEN is correctly set as an environment variable.
  • Connection issues: Verify your internet connection and that the Product Hunt API is accessible.
  • Rate limiting: If you hit rate limits, wait until the reset time or reduce your query frequency.
  • Claude Desktop/Cursor not finding the server: Verify the path to your Python executable and restart the client.

๐Ÿค Contributing

  • PRs and issues welcome!
  • Please follow PEP8 and use ruff for linting.
  • See pyproject.toml for dev dependencies.

๐ŸŒ Links


๐Ÿ“ Notes

  • This project is not affiliated with Product Hunt.
  • The Product Hunt API is subject to change.

๐Ÿ“œ License

MIT

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

iflow_mcp_jaipandya_product_hunt_mcp-0.1.0.tar.gz (19.7 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file iflow_mcp_jaipandya_product_hunt_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: iflow_mcp_jaipandya_product_hunt_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 19.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_jaipandya_product_hunt_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 24e2d0986d4324de3ff0335222915a567701ffe066326d06872f79c0f798c7cd
MD5 8e7d1a67e1c362cfbc339280ebffba7f
BLAKE2b-256 a13c97520c59a86d9c74aedf9044ae02f68b0a1ff5494e0de1b6644a071f965f

See more details on using hashes here.

File details

Details for the file iflow_mcp_jaipandya_product_hunt_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_jaipandya_product_hunt_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 28.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_jaipandya_product_hunt_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2852a46c7214d7a94a6f3390ab9ca1bf5b4684edbb0459944cbe8cf3b81fd3d
MD5 279df2d9f1f162532e6ef2e6b680f2e7
BLAKE2b-256 c296ad3f41946d7eed08ff0cbbc31a9a4c034b21f46cf6527692cf6b41ba4502

See more details on using hashes here.

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