Perplexity MCP
Provides search capabilities using Perplexity AI's web interface, enabling AI agents to query Perplexity with various modes (auto, pro, reasoning, deep_research) and models, using the user's existing Perplexity Pro subscription.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Perplexity MCPsearch the web for latest AI breakthroughs in 2024"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Perplexity Subscription MCP
Unofficial Python wrapper for Perplexity AI's web interface, providing an MCP (Model Context Protocol) server and Python client for integration with coding agents.
Use your existing Perplexity subscription — no API costs. This wrapper uses your Perplexity web session cookies, so all queries use your existing Pro subscription instead of the paid Perplexity API.
Why This Wrapper?
Approach | Cost | Rate Limits |
This wrapper (web session) | $0 (uses your existing subscription) | Your subscription limits |
Perplexity API | $5/1000 requests (sonar), $200/month (pro tier) | API tier limits |
If you already have a Perplexity Pro subscription ($20/month), this wrapper lets you integrate Perplexity into your coding workflow without additional API costs.
Quick Start
No install needed — your MCP config runs the server via uvx automatically.
Prerequisites: uv and Python 3.10+
1. Get Your Perplexity Cookies
The MCP server authenticates using your browser's Perplexity session cookies. You need to export them once (and re-export when they expire).
Option A: Cookie-Editor Extension (Recommended)
Install the Cookie-Editor browser extension (Chrome, Firefox)
Go to perplexity.ai and log in to your account
Click the Cookie-Editor extension icon
Click Export (bottom-left) → copies JSON to clipboard
Save the clipboard content to a file:
# Create the config directory mkdir -p ~/.config/perplexity # Paste your clipboard into this file # macOS: pbpaste > ~/.config/perplexity/cookies.json # Linux: xclip -selection clipboard -o > ~/.config/perplexity/cookies.json # Windows (PowerShell): Get-Clipboard | Out-File -Encoding utf8 ~/.config/perplexity/cookies.json # Or just create the file manually and paste the JSON content
This gives you an array format like:
[
{"domain": ".perplexity.ai", "name": "__Secure-next-auth.session-token", "value": "eyJ...", ...},
{"domain": ".perplexity.ai", "name": "pplx.visitor-id", "value": "...", ...}
]Option B: Browser DevTools (Manual)
Go to perplexity.ai and log in
Open DevTools (
F12orCmd+Opt+I/Ctrl+Shift+I)Go to Application tab (Chrome) or Storage tab (Firefox)
Click Cookies →
https://www.perplexity.aiCopy cookie names and values into a JSON file:
{
"__Secure-next-auth.session-token": "eyJ...",
"pplx.visitor-id": "...",
"__cf_bm": "..."
}Save as ~/.config/perplexity/cookies.json.
Tip: Export all cookies from perplexity.ai for best results. The essential one is
__Secure-next-auth.session-token, but exporting everything avoids issues with missing tokens.
Both formats (array from Cookie-Editor and flat object from manual export) are supported automatically.
2. Add to Your Coding Agent
Pick your agent below. Each config uses uvx to run the server directly from PyPI — no install step needed. Replace YOUR_ABSOLUTE_PATH with your actual home directory path (e.g., /home/user or /Users/yourname).
Claude Code CLI
claude mcp add --transport stdio perplexity --scope user \
-e PERPLEXITY_COOKIES_PATH=$HOME/.config/perplexity/cookies.json \
-- uvx --from perplexity-subscription-mcp perplexity-mcpVerify: claude mcp list · Remove: claude mcp remove perplexity -s user
Augment CLI (Auggie)
auggie mcp add perplexity \
-e PERPLEXITY_COOKIES_PATH=$HOME/.config/perplexity/cookies.json \
-- uvx --from perplexity-subscription-mcp perplexity-mcpVerify: auggie mcp list · Remove: auggie mcp remove perplexity
Cursor IDE
File: ~/.cursor/mcp.json
{
"mcpServers": {
"perplexity": {
"command": "uvx",
"args": ["--from", "perplexity-subscription-mcp", "perplexity-mcp"],
"env": {
"PERPLEXITY_COOKIES_PATH": "YOUR_ABSOLUTE_PATH/.config/perplexity/cookies.json"
}
}
}
}Windsurf IDE
File: ~/.codeium/windsurf/mcp_config.json
{
"mcpServers": {
"perplexity": {
"command": "uvx",
"args": ["--from", "perplexity-subscription-mcp", "perplexity-mcp"],
"env": {
"PERPLEXITY_COOKIES_PATH": "YOUR_ABSOLUTE_PATH/.config/perplexity/cookies.json"
}
}
}
}OpenAI Codex CLI
File: ~/.codex/config.toml
[mcp_servers.perplexity]
command = "uvx"
args = ["--from", "perplexity-subscription-mcp", "perplexity-mcp"]
[mcp_servers.perplexity.env]
PERPLEXITY_COOKIES_PATH = "YOUR_ABSOLUTE_PATH/.config/perplexity/cookies.json"VS Code with Continue Extension
File: .continue/config.json
{
"experimental": {
"modelContextProtocolServers": [
{
"transport": {
"type": "stdio",
"command": "uvx",
"args": ["--from", "perplexity-subscription-mcp", "perplexity-mcp"],
"env": {
"PERPLEXITY_COOKIES_PATH": "YOUR_ABSOLUTE_PATH/.config/perplexity/cookies.json"
}
}
}
]
}
}VS Code with Cline Extension
{
"cline.mcpServers": {
"perplexity": {
"command": "uvx",
"args": ["--from", "perplexity-subscription-mcp", "perplexity-mcp"],
"env": {
"PERPLEXITY_COOKIES_PATH": "YOUR_ABSOLUTE_PATH/.config/perplexity/cookies.json"
}
}
}
}Cookie Location Resolution
If PERPLEXITY_COOKIES_PATH is not set, the server checks these locations in order:
PERPLEXITY_COOKIES_PATHenv var — explicit file pathPERPLEXITY_COOKIESenv var — inline JSON string (useful for CI/Docker)~/.config/perplexity/cookies.json— default user config location./perplexity_cookies.json— current working directory
Features
Search Modes
Mode | Description | Pro Subscription Required |
| Quick answers using Perplexity's default model | No |
| Enhanced search with model selection | Yes |
| Deep reasoning with thinking models | Yes |
| Comprehensive multi-step research | Yes |
Available Models
Mode | Available Models |
| Default (turbo) |
| Default, |
| Default, |
| Default (alpha) |
Sources
web— General web search (default)scholar— Academic papers and researchsocial— Social media content
Additional Features
Token-efficient
answer_onlymode: Returns only the answer andbackend_uuid, reducing response sizeFollow-up conversations: Continue discussions using
backend_uuidfrom previous responsesThread management: List and retrieve past conversation threads
Incognito mode: Search without saving to history
File uploads: Attach files to queries (Pro subscription)
MCP Tools Reference
Tool | Description | Key Parameters |
| Search Perplexity AI |
|
| Continue a previous conversation |
|
| List conversation threads |
|
| Get thread details by slug |
|
Tool Details
search
# Example response with answer_only=True (default)
{
"answer": "Perplexity AI is an AI-powered search engine...",
"backend_uuid": "abc-123-def-456"
}
# Example response with answer_only=False
{
"answer": "Perplexity AI is an AI-powered search engine...",
"backend_uuid": "abc-123-def-456",
"sources": ["https://example.com/article1", "https://example.com/article2"],
"related_queries": ["How does Perplexity AI work?", "Perplexity AI vs ChatGPT"]
}follow_up
Continue a conversation using the backend_uuid from a previous response.
follow_up(query="Can you elaborate on that?", backend_uuid="abc-123-def-456")list_threads / get_thread
list_threads(limit=10, search_term="python")
get_thread(slug="thread-slug-here")Agent Instructions (Optional)
To help coding agents use Perplexity MCP efficiently, add these instructions to your agent's rules file:
# Perplexity MCP - Web Research
**Use Perplexity MCP instead of web search. Use fetch/WebFetch only when you need full page content.**
| Tool | Use For |
|------|---------|
| `perplexity.search` | ALL web research - replaces web search |
| `fetch` | Reading full page content in detail when needed |
## Mode Selection
| Research Type | Mode | Use Case |
|--------------|------|----------|
| Quick lookup | `auto` | Simple facts, definitions, quick answers |
| Standard research | `pro` | API docs, library usage, best practices, debugging |
| Deep research | `deep_research` | PRDs, design docs, comprehensive analysis |
## When to Use Each Mode
- **auto**: "What is X?", simple lookups, quick facts
- **pro**: Technical questions, debugging, API research, implementation guidance
- **deep_research**: Creating PRDs, design documents, competitive analysis, comprehensive guidesAgent | Instructions File |
Claude Code |
|
Auggie |
|
Cursor |
|
Codex CLI |
|
Python Library Usage
Install the package if using as a Python library:
pip install perplexity-subscription-mcpfrom perplexity_subscription_mcp import Client
from pathlib import Path
import json
# Load cookies
with open(Path.home() / ".config/perplexity/cookies.json") as f:
cookies = json.load(f)
# Initialize client
client = Client(cookies)
# Basic search
result = client.search("What is quantum computing?", mode="auto")
print(result)
# Pro search with specific model
result = client.search(
"Explain transformer architecture",
mode="pro",
model="claude 3.7 sonnet",
sources=["web", "scholar"]
)
# Follow-up query
follow_up_result = client.search(
"Can you provide code examples?",
follow_up={
"backend_uuid": result["backend_uuid"],
"attachments": []
}
)
# List threads
threads = client.get_threads(limit=10)
# Get thread details
thread_details = client.get_thread_details_by_slug("thread-slug")REST API (Optional — for development)
The REST API is not included in the PyPI package. To use it, clone the repo and install with the api extra:
git clone https://github.com/balakumardev/perplexity-web-wrapper.git
cd perplexity-web-wrapper
uv sync --extra api
uvicorn api.main:app --reload --host 0.0.0.0 --port 8000Endpoint | Method | Description |
| GET | Synchronous search |
| GET | SSE streaming response |
| GET | List conversation threads |
| GET | Get thread details by slug |
Troubleshooting
"No cookies file found"
Export cookies following the setup guide above
Verify the file exists:
cat ~/.config/perplexity/cookies.jsonCheck your MCP config has
PERPLEXITY_COOKIES_PATHset correctly
"No remaining pro queries"
Your Pro subscription may have hit its limit. Use
mode="auto"for free searches.
"Invalid model for the selected mode"
Check the model compatibility table. Some models only work in specific modes.
Connection or authentication errors
Cookies expire periodically. Re-export from your browser and replace the file.
Make sure you're logged in to Perplexity when exporting cookies.
Notes
This is an unofficial project and not affiliated with Perplexity AI
Respect Perplexity AI's terms of service and rate limits
Cookie sessions expire periodically — re-export when you get auth errors
License
MIT License. Contributions welcome!
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/balakumardev/perplexity-web-wrapper'
If you have feedback or need assistance with the MCP directory API, please join our Discord server