The Perplexity MCP Server enables web searches using Perplexity AI with intelligent query handling and filtering options:
Web Search: Perform searches using the Perplexity API
Intelligent Model Selection: Automatically chooses the optimal model based on query intent (research, reasoning, general search)
Manual Model Control: Set or view information about available Perplexity AI models
Domain Filtering: Allow or block up to 3 specific domains in search results
Recency Filtering: Limit results to a specific time window (hour, day, week, month)
Filter Management: View active filters or clear all filters
Integration: Works seamlessly with Claude Desktop App for interactive search
Provides web search capabilities using Perplexity's API with automatic model selection based on query intent, supporting various Perplexity models like sonar, sonar-pro, sonar-reasoning, sonar-reasoning-pro, and sonar-deep-research
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 MCP Serverwhat are the latest developments in quantum computing?"
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 MCP Server
An MCP server that provides Perplexity AI web search capabilities to Claude, with automatic model selection, stateful filters, and 7 purpose-built tools.
Prerequisites
Node.js v20 or higher
A Perplexity API key — get one at https://www.perplexity.ai/settings/api
Claude Desktop (or any MCP-compatible client)
Related MCP server: Perplexity AI MCP Server
Installation
Clone this repository:
git clone https://github.com/RossH121/perplexity-mcp.git cd perplexity-mcpInstall dependencies:
npm installBuild the server:
npm run build
Configuration
Add the server to Claude's config file at ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"perplexity-server": {
"command": "node",
"args": ["/absolute/path/to/perplexity-mcp/build/index.js"],
"env": {
"PERPLEXITY_API_KEY": "your-api-key-here",
"PERPLEXITY_MODEL": "sonar-pro"
}
}
}
}Replace /absolute/path/to with the actual path to where you cloned the repository.
Available Models
The server automatically selects the best model based on your query, but you can also set a default via PERPLEXITY_MODEL:
Model | Best for |
| Comprehensive reports, exhaustive multi-source research |
| Complex logic, math, chain-of-thought analysis |
| General search, factual queries (default) |
| Quick, simple lookups |
For pricing and availability: https://docs.perplexity.ai/guides/pricing
Tools
search — AI-powered web search
The main search tool. Automatically selects the right model based on your query. Returns a synthesized answer with cited sources.
Parameter | Options | Description |
| string | Your search query |
|
| How much web context to retrieve. |
|
| Depth of reasoning for |
| boolean | Remove |
|
|
|
| boolean | Enable streaming responses |
Examples:
"What's the latest on fusion energy?" → auto-selects
sonar-pro"Deep research analysis of CRISPR gene editing advances" → auto-selects
sonar-deep-research"Solve this logic puzzle step by step" → auto-selects
sonar-reasoning-pro
raw_search — Raw ranked results (no LLM)
Returns ranked web results directly without AI synthesis. Faster and cheaper — useful for URL discovery, building source lists, or fact-checking pipelines.
Parameter | Options | Description |
| string | Search query |
| 1–20 | Number of results (default: 10) |
|
| Search type |
|
| Time window filter |
|
| Only results after this date |
|
| Only results before this date |
| ISO 3166 code | Localize results (e.g. |
domain_filter — Allowlist/blocklist domains
Restrict or exclude specific domains from search results. Filters persist across all subsequent searches until cleared.
action: "allow"— restrict results to this domain (allowlist mode)action: "block"— exclude this domain from results (denylist mode)Maximum 20 domains; cannot mix allow and block in the same filter set
"Allow results only from arxiv.org and nature.com"
"Block pinterest.com and reddit.com from search results"recency_filter — Time window filter
Limit search results to a specific time period. Persists until changed.
Options: hour, day, week, month, year, none
"Set recency filter to week"
"Remove the recency filter"clear_filters — Reset all filters
Clears all domain and recency filters in one call.
list_filters — View active filters
Shows currently active domain allowlist/blocklist and recency setting.
model_info — View or override model selection
View available models and current selection, or manually force a specific model.
"Show model info"
"Set model to sonar-deep-research"Intelligent Model Selection
The server scores your query against keyword lists to automatically pick the right model:
Research keywords (
deep research,comprehensive,in-depth) →sonar-deep-researchReasoning keywords (
solve,logic,mathematical,figure out) →sonar-reasoning-proSimple keywords (
quick,brief,basic) →sonarEverything else →
sonar-pro
Each response shows which model was used and why. If a query strongly matches a model (score ≥ 2), it will override a manually set model.
Example Workflows
Time-sensitive research with domain filtering:
recency_filter→weekdomain_filter→ allownature.com, allowarxiv.orgsearch→ "Recent breakthroughs in quantum error correction"
Financial document research:
raw_searchwithsearch_mode: "sec"→ find relevant filingssearchwithsearch_mode: "sec"→ synthesized analysis
Academic literature review:
searchwithsearch_mode: "academic",search_context_size: "high"→ comprehensive results from peer-reviewed sources
Deep research with reasoning control:
searchwithreasoning_effort: "high",strip_thinking: true→ thorough analysis without<think>blocks in the output
Development
npm run build # Compile TypeScript to build/
npm start # Run the built serverSource is in src/ — after editing, rebuild and restart Claude to load changes.
License
MIT