MCP server and Python client for Perplexity AI using your existing subscription — no API costs.
Project description
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.ai - Copy 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-mcp
Verify: 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-mcp
Verify: 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 |
|---|---|---|
auto |
Quick answers using Perplexity's default model | No |
pro |
Enhanced search with model selection | Yes |
reasoning |
Deep reasoning with thinking models | Yes |
deep_research |
Comprehensive multi-step research | Yes |
Available Models
| Mode | Available Models |
|---|---|
auto |
Default (turbo) |
pro |
Default, sonar, gpt-4.5, gpt-4o, claude 3.7 sonnet, gemini 2.0 flash, grok-2 |
reasoning |
Default, r1, o3-mini, claude 3.7 sonnet |
deep_research |
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 size - Follow-up conversations: Continue discussions using
backend_uuidfrom previous responses - Thread 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 |
Search Perplexity AI | query (required), mode, model, sources, answer_only, language, incognito |
follow_up |
Continue a previous conversation | query (required), backend_uuid (required), mode, model, answer_only |
list_threads |
List conversation threads | limit, search_term |
get_thread |
Get thread details by slug | slug (required) |
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 guides
| Agent | Instructions File |
|---|---|
| Claude Code | ~/.claude/CLAUDE.md |
| Auggie | ~/.augment/rules/perplexity.md |
| Cursor | ~/.cursor/CURSOR_INSTRUCTIONS.md |
| Codex CLI | ~/.codex/AGENTS.md |
Python Library Usage
Install the package if using as a Python library:
pip install perplexity-subscription-mcp
from 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 8000
| Endpoint | Method | Description |
|---|---|---|
/api/query_sync |
GET | Synchronous search |
/api/query_async |
GET | SSE streaming response |
/api/threads |
GET | List conversation threads |
/api/threads/{slug} |
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.json - Check 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!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file perplexity_subscription_mcp-0.1.1.tar.gz.
File metadata
- Download URL: perplexity_subscription_mcp-0.1.1.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fcf5d538c21fbbd8e355e199d1e6882396fc424af3e252e94e6fbdc4bce7dbb1
|
|
| MD5 |
590bb5ccd733f8a2a77c804f0b7ab9ea
|
|
| BLAKE2b-256 |
7ccf244a0ae8c3b99b4d44925af01455d1817e6d8496fc22bd1cec3a9d57b019
|
File details
Details for the file perplexity_subscription_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: perplexity_subscription_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 14.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7bb117930f7b729d2e0366ec75a9d9c878b01eb6b326b7f5643644f8d0718ae2
|
|
| MD5 |
716b42cc84e1bf271b57f8f62196f7bb
|
|
| BLAKE2b-256 |
1a2f42ebc272c3d4907c22b8ec40b273524b97f89f46eac2a2a58044bcdd9baf
|