Pearl

Pearl

Pearl

Category
Visit Server

README

Pearl MCP Server

A Model Context Protocol (MCP) server implementation that exposes Pearl's AI and Expert services through a standardized interface. This server allows MCP clients like Claude Desktop, Cursor, and other MCP-compatible applications to interact with Pearl's advanced AI assistants and human experts.

Features

  • Support for both stdio and SSE transports
  • Integration with Pearl API for AI and expert assistance
  • Session management for continuous conversations
  • Multiple interaction modes:
    • AI-only mode for quick automated responses
    • AI-Expert mode for AI-assisted human expert support
    • Expert mode for direct human expert assistance
  • Conversation history tracking
  • Stateful session management

Prerequisites

  • Python 3.12 or higher
  • Pearl API Key (Contact Pearl to obtain your API key)
  • pip or uv package manager

Installation

  1. Clone the repository:
git clone https://github.com/Pearl-com/pearl_mcp_server.git
cd pearl_mcp_server
  1. Create a virtual environment and activate it:
python -m venv .venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate
  1. Install dependencies:
pip install -e .

Configuration

  1. Create a .env file in the src directory:
PEARL_API_KEY=your-api-key-here

Running the Server

Local Development

Start the server using either stdio (default) or SSE transport:

# Using stdio transport (default)
pearl-mcp-server --api-key your-api-key

# Using SSE transport on custom port
pearl-mcp-server --api-key your-api-key --transport sse --port 8000

Using Remote Server

Pearl provides a hosted MCP server at:

https://mcp.pearl.com/mcp

This can be used directly with any MCP client without installing the Python application locally.

Available Tools

The server provides the following tools:

  1. ask_pearl_ai

    • Quick AI-only responses without human review
    • Best for general inquiries and non-critical situations
    • Parameters:
      • question: The user's query
      • chat_history (optional): Previous conversation context
      • session_id (optional): For continuing conversations
  2. ask_pearl_expert

    • AI-assisted human expert support
    • Best for complex topics requiring expert verification
    • Parameters: Same as ask_pearl_ai
  3. ask_expert

    • Direct human expert assistance
    • Best for complex or sensitive topics
    • Parameters: Same as ask_pearl_ai
  4. get_conversation_status

    • Check the status of an active conversation
    • Parameter: session_id
  5. get_conversation_history

    • Retrieve full conversation history
    • Parameter: session_id

Expert Categories

Pearl's MCP server provides access to a wide range of expert categories. The appropriate expert category is automatically determined by Pearl's API based on the context of your query, ensuring you're connected with the most relevant expert for your needs.

Here are the main categories of expertise available:

  • Medical & Healthcare

    • General Medicine
    • Dental Health
    • Mental Health
    • Nutrition & Diet
    • Fitness & Exercise
    • Veterinary Medicine
  • Legal & Financial

    • Legal Advice
    • Tax Consultation
    • Financial Planning
    • Business Law
    • Employment Law
    • Real Estate Law
  • Technical & Professional

    • Software Development
    • IT Support
    • Computer Repair
    • Electronics
    • Mechanical Engineering
    • Home Improvement
  • Education & Career

    • Academic Tutoring
    • Career Counseling
    • Resume Writing
    • Test Preparation
    • College Admissions
    • Professional Development
  • Lifestyle & Personal

    • Relationship Advice
    • Parenting
    • Pet Care
    • Personal Styling
    • Interior Design
    • Travel Planning

Each expert category can be accessed through the ask_expert or ask_pearl_expert tools. You don't need to specify the category - simply describe your question or problem, and Pearl's AI will automatically route your request to the most appropriate expert type based on the context.

Connecting with MCP Clients

Local Connection (stdio transport)

For connecting to a local MCP server using stdio transport, add the following configuration to your MCP client:

{
    "pearl-mcp-server": {
        "type": "stdio",
        "command": "pearl-mcp-server",
        "args": ["--api-key", "your-api-key"],
        "env": {
            "PEARL_API_KEY": "Your Pearl Api Key"
        }
    }
}

Remote Connection using mcp-remote

Some MCP clients don't support direct connection to remote MCP servers. For these clients, you can use the mcp-remote package as a bridge:

  1. Prerequisites:

    • Node.js 18 or higher
    • npm (Node Package Manager)
  2. Configuration for remote server:

{
    "mcpServers": {
        "pearl-remote": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.pearl.com/sse"
            ]
        }
    }
}
  1. Configuration file locations:

    • Claude Desktop:
      • Windows: %APPDATA%\Claude\claude_desktop_config.json
      • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
    • Cursor: ~/.cursor/mcp.json
    • Windsurf: ~/.codeium/windsurf/mcp_config.json
  2. Additional Options:

    • Force latest version: Add @latest to npx command
    "args": ["mcp-remote@latest", "https://mcp.pearl.com/sse"]
    
  3. Troubleshooting:

    • Clear stored credentials: rm -rf ~/.mcp-auth
    • View logs:
      • Windows (PowerShell): Get-Content "$env:APPDATA\Claude\Logs\mcp.log" -Wait -Tail 20
      • macOS/Linux: tail -n 20 -F ~/Library/Logs/Claude/mcp*.log
    • Test connection: npx mcp-remote-client https://mcp.pearl.com/sse

Custom Python Client

import asyncio
from mcp.client.session import ClientSession
from mcp.client.stdio import StdioServerParameters, stdio_client

async def main():
    # For stdio transport
    async with stdio_client(
        StdioServerParameters(command="pearl-mcp-server", args=["--api-key", "your-api-key"])
    ) as (read, write):
        async with ClientSession(read, write) as session:
            await session.initialize()
            
            # List available tools
            tools = await session.list_tools()
            print(tools)
            
            # Call Pearl AI
            result = await session.call_tool(
                "ask_pearl_ai", 
                {
                    "question": "What is MCP?",
                    "session_id": "optional-session-id"
                }
            )
            print(result)

asyncio.run(main())

API Key

To obtain a Pearl API key for using this server:

  1. Visit Pearl Contact Page
  2. Request an API key for MCP server integration
  3. Follow the provided instructions to complete the registration process

Keep your API key secure and never commit it to version control.

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured