Skip to main content

MCP Server for the Perplexity API.

Project description

Perplexity MCP Server

The Perplexity MCP Server provides a Python-based interface to the Perplexity API, offering tools for querying responses, maintaining chat history, and managing conversations. It supports model configuration via environment variables and stores chat data locally. Built with Hatch, it's designed for integration with development environments.

The MCP Server is desined to mimick how users interact with the Perplexity Chat on their browser by allowing your models to ask questions, continue conversations, and list all your chats.

smithery badge PyPI Publish

Components

Tools

  • ask_perplexity: Request expert programming assistance through Perplexity. Focuses on coding solutions, error debugging, and technical explanations. Returns responses with source citations and alternative suggestions.
  • chat_perplexity: Maintains ongoing conversations with Perplexity AI. Creates new chats or continues existing ones with full history context. Returns chat ID for future continuation.
  • list_chats_perplexity: Lists all available chat conversations with Perplexity AI. Returns chat IDs, titles, and creation dates (displayed in relative time format, e.g., "5 minutes ago", "2 days ago"). Results are paginated with 50 chats per page.
  • read_chat_perplexity: Retrieves the complete conversation history for a specific chat. Returns the full chat history with all messages and their timestamps. No API calls are made to Perplexity - this only reads from local storage.

Key Features

  • Model Configuration via Environment Variable: Allows you to specify the Perplexity model using the PERPLEXITY_MODEL environment variable for flexible model selection.

    You can also specify PERPLEXITY_MODEL_ASK and PERPLEXITY_MODEL_CHAT to use different models for the ask_perplexity and chat_perplexity tools, respectively.

    These will override PERPLEXITY_MODEL. You can check which models are available on the Perplexity documentation.

  • Persistent Chat History: The chat_perplexity tool maintains ongoing conversations with Perplexity AI. Creates new chats or continues existing ones with full history context. Returns chat ID for future continuation.

  • Streaming Responses with Progress Reporting: Uses progress reporting to prevent timeouts on slow responses.

Quickstart

Prerequisites

Before using this MCP server, ensure you have:

  • Python 3.10 or higher
  • uvx package manager installed

Note: Installation instructions for uvx are available here.

Configuration for All Clients

To use this MCP server, configure your client with these settings (configuration method varies by client):

"mcpServers": {
  "mcp-perplexity": {
    "command": "uvx",
    "args": ["mcp-perplexity"],
    "env": {
      "PERPLEXITY_API_KEY": "your-api-key",
      "PERPLEXITY_MODEL": "sonar-pro",
      "DB_PATH": "chats.db"
    }
  }
}

Key Configuration Notes:

  • Replace "your-api-key" with your Perplexity API key
  • Environment variables can specify different models for ask/chat tools
  • DB_PATH sets custom chat history location (default: chats.db)

Cursor IDE Installation Helpers

For Cursor users, we provide automated scripts that:

  1. Install uvx (Python package manager) if missing
  2. Set up the mcp-starter helper tool
  3. Generate appropriate Cursor command to be added to the MCP settings.
Windows Installation
  1. Download the install.ps1 script
  2. Open PowerShell as Administrator
  3. Allow script execution and run:
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser -Force
.\install.ps1

The script will:

  • Check for required dependencies (curl, PowerShell)
  • Install uvx if not present
  • Install mcp-starter to %USERPROFILE%\.local\bin
  • Create a configuration file at %USERPROFILE%\.config\mcp-starter\config.json
  • Prompt for your Perplexity API key and model preferences
Unix Installation (Linux/MacOS)
  1. Download the install.sh script
  2. Open Terminal
  3. Navigate to the directory containing the script
  4. Make the script executable and run it:
chmod +x install.sh  # Only needed if downloaded directly from browser
./install.sh

The script will:

  • Check for required dependencies (curl)
  • Install uvx if not present
  • Install mcp-starter to $HOME/.local/bin
  • Create a configuration file at $HOME/.config/mcp-starter/config.json
  • Prompt for your Perplexity API key and model preferences

Using Smithery CLI (Cursor Only)

npx -y @smithery/cli@latest run @daniel-lxs/mcp-perplexity --config "{\"perplexityApiKey\":\"abc\"}"

Usage

ask_perplexity

The ask_perplexity tool is used for specific questions, this tool doesn't maintain a chat history, every request is a new chat.

The tool will return a response from Perplexity AI using the PERPLEXITY_MODEL_ASK model if specified, otherwise it will use the PERPLEXITY_MODEL model.

chat_perplexity

The chat_perplexity tool is used for ongoing conversations, this tool maintains a chat history. A chat is identified by a chat ID, this ID is returned by the tool when a new chat is created. Chat IDs look like this: wild-horse-12.

This tool is useful for debugging, research, and any other task that requires a chat history.

The tool will return a response from Perplexity AI using the PERPLEXITY_MODEL_CHAT model if specified, otherwise it will use the PERPLEXITY_MODEL model.

list_chats_perplexity

Lists all available chat conversations. It returns a paginated list of chats, showing the chat ID, title, and creation time (in relative format). You can specify the page number using the page argument (defaults to 1, with 50 chats per page).

read_chat_perplexity

Retrieves the complete conversation history for a given chat_id. This tool returns all messages in the chat, including timestamps and roles (user or assistant). This tool does not make any API calls to Perplexity; it only reads from the local database.

Development

This project uses Hatch for development and builds. To get started:

  1. Install Hatch (if not already installed):

    pip install hatch
    
  2. Create and activate the Hatch environment:

    hatch env create
    hatch shell
    
  3. Build the project:

    hatch build
    

The Hatch environment will automatically install all required dependencies.

Contributing

This project is open to contributions. Please see the CONTRIBUTING.md file for more information.

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

mcp_perplexity-0.4.1.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

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

mcp_perplexity-0.4.1-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file mcp_perplexity-0.4.1.tar.gz.

File metadata

  • Download URL: mcp_perplexity-0.4.1.tar.gz
  • Upload date:
  • Size: 14.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mcp_perplexity-0.4.1.tar.gz
Algorithm Hash digest
SHA256 4462e08ce10a32514806d087ec69939462ea82f5f5a91de0702fe315a65f94bf
MD5 0233446e39efeda9610b312a51c1fa3e
BLAKE2b-256 ef1d93cd2ba312975d2e80766d76b8aae2571ab4e6e27d2633c3ed99a910d09d

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_perplexity-0.4.1.tar.gz:

Publisher: release.yml on daniel-lxs/mcp-perplexity

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

File details

Details for the file mcp_perplexity-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: mcp_perplexity-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mcp_perplexity-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0197933a2bb7cb04eaedc7ec4f3229c6516749d6ea4ac8e17913effbc67edeaf
MD5 ba93c8190bf6af595d4c087a67f3379e
BLAKE2b-256 079a96d2cae21b994632568a04844d155782be4a9a7ca84ccca138c324870cb0

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_perplexity-0.4.1-py3-none-any.whl:

Publisher: release.yml on daniel-lxs/mcp-perplexity

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