openreplay-mcp-server

rsp2k/openreplay-mcp-server

3.2

If you are the rightful owner of openreplay-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

The OpenReplay Session Analysis MCP Server is designed to analyze OpenReplay session recordings and user behavior patterns, providing AI-driven insights and problem detection.

Tools
  1. search_sessions

    Search sessions with advanced filters.

  2. get_session_details

    Get detailed session information.

  3. get_user_session_history

    View all sessions for a specific user.

  4. analyze_user_journey

    Map user navigation patterns and page flows.

  5. detect_problem_patterns

    Find rage clicks, form issues, and errors.

  6. generate_session_summary

    AI-powered session insights and recommendations.

  7. find_similar_sessions

    Discover related problematic sessions.

OpenReplay Session Analysis MCP Server

A Model Context Protocol (MCP) server for analyzing OpenReplay session recordings and user behavior patterns. This server enables AI assistants to analyze user sessions, detect problems, and provide actionable insights from OpenReplay data.

šŸ”„ Features

  • šŸ” Session Search & Filtering - Find sessions by date, user, errors, duration
  • šŸ“Š User Journey Analysis - Track page flows and navigation patterns
  • šŸ› Problem Detection - Identify rage clicks, form abandonment, errors
  • šŸ¤– AI-Powered Insights - Generate intelligent session summaries
  • šŸ‘„ User Behavior Analysis - Analyze patterns across multiple sessions
  • šŸ”— Similar Session Finding - Discover sessions with comparable issues

šŸš€ Quick Start

  1. Clone and setup:

    git clone https://github.com/rsp2k/openreplay-mcp-server.git
    cd openreplay-mcp-server
    python -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    pip install -r requirements.txt
    
  2. Configure OpenReplay credentials:

    cp .env.example .env
    # Edit .env with your OpenReplay API credentials
    
  3. Run the server:

    python run_server.py
    

āš™ļø Configuration

Set these environment variables in your .env file:

OPENREPLAY_API_URL=https://api.openreplay.com
OPENREPLAY_API_KEY=your_api_key_here
OPENREPLAY_PROJECT_ID=your_project_id_here

To get your OpenReplay API credentials:

  1. Go to your OpenReplay dashboard
  2. Navigate to Settings → API Keys
  3. Generate a new API key
  4. Copy your Project ID from the URL or project settings

šŸ› ļø Available Tools

Session Management

  • search_sessions - Search sessions with advanced filters
  • get_session_details - Get detailed session information
  • get_user_session_history - View all sessions for a specific user

Analysis Tools

  • analyze_user_journey - Map user navigation patterns and page flows
  • detect_problem_patterns - Find rage clicks, form issues, and errors
  • generate_session_summary - AI-powered session insights and recommendations
  • find_similar_sessions - Discover related problematic sessions

šŸ“‹ Usage with Claude Desktop

Add to your Claude Desktop MCP configuration (claude_desktop_config.json):

{
  "mcpServers": {
    "openreplay-analysis": {
      "command": "python",
      "args": ["/path/to/openreplay-mcp-server/run_server.py"],
      "env": {
        "OPENREPLAY_API_KEY": "your_api_key_here",
        "OPENREPLAY_PROJECT_ID": "your_project_id_here"
      }
    }
  }
}

šŸ’¬ Example Queries

Once connected to Claude Desktop or another MCP client, you can ask:

  • "Find sessions with errors from the last week"
  • "Analyze user journey for session ABC123"
  • "Generate a summary of problematic sessions today"
  • "Show me all sessions for user "
  • "Find sessions similar to XYZ456 that had form abandonment"
  • "Debug session DEF789 and tell me what went wrong"

🐳 Docker Usage

For containerized deployment:

# Set environment variables in .env file
docker-compose up

Or build and run manually:

docker build -t openreplay-mcp .
docker run -e OPENREPLAY_API_KEY=your_key -e OPENREPLAY_PROJECT_ID=your_project openreplay-mcp

šŸ”§ Development

The server is built with:

  • FastMCP - Official Python MCP SDK for server implementation
  • httpx - Async HTTP client for OpenReplay API
  • asyncio - Async/await support

Project Structure

openreplay-mcp-server/
ā”œā”€ā”€ openreplay_session_analyzer.py  # OpenReplay client and analysis logic
ā”œā”€ā”€ run_server.py                   # FastMCP server with tools
ā”œā”€ā”€ mcp.py                          # Django MCP configuration (optional)
ā”œā”€ā”€ settings.py                     # Django settings (optional)
ā”œā”€ā”€ requirements.txt                # Python dependencies
ā”œā”€ā”€ .env.example                    # Environment variables template
ā”œā”€ā”€ Dockerfile                      # Container configuration
ā”œā”€ā”€ docker-compose.yml              # Docker Compose setup
└── README.md                       # This file

Adding New Analysis Features

  1. Add new methods to the SessionAnalyzer class in openreplay_session_analyzer.py
  2. Create corresponding @mcp.tool() decorated functions in run_server.py
  3. Test with your OpenReplay data

šŸ“Š Session Analysis Capabilities

Problem Detection

  • Rage Clicks: Multiple rapid clicks indicating frustration
  • Form Abandonment: Users starting but not completing forms
  • Dead Clicks: Clicks on non-interactive elements
  • Error Tracking: JavaScript errors and exceptions

Journey Analysis

  • Page Flow Mapping: Track user navigation through your site
  • Duration Analysis: Understand time spent on each page
  • Bounce Rate: Identify single-page sessions
  • Action Breakdown: Analyze user interactions (clicks, scrolls, inputs)

AI Insights

  • Automated Summaries: Natural language session descriptions
  • Problem Identification: Highlight potential UX issues
  • Performance Analysis: Identify slow-loading content
  • Behavioral Patterns: Recognize user intent and goals

šŸ”— Integration Examples

Debugging Workflow

# Search for recent error sessions
sessions = await search_sessions(has_errors=True, start_date="2024-06-01")

# Analyze specific problematic session
summary = await generate_session_summary(session_id="abc123")
problems = await detect_problem_patterns(session_id="abc123")

# Find similar issues
similar = await find_similar_sessions(reference_session_id="abc123", criteria="errors")

UX Research Workflow

# Analyze user behavior over time
user_history = await get_user_session_history(user_id="user123")

# Study navigation patterns
for session in user_sessions:
    journey = await analyze_user_journey(session_id=session.id)
    # Analyze patterns...

šŸ“ API Requirements

This server requires:

  • OpenReplay account with API access
  • Valid API key and project ID
  • Network access to OpenReplay API endpoints
  • Python 3.8+ environment

šŸ¤ Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

šŸ“„ License

This project is licensed under the MIT License - see the file for details.

šŸ™ Acknowledgments

šŸ“ž Support

If you encounter any issues or have questions:

  1. Check the Issues page
  2. Create a new issue with detailed information
  3. Join the discussion in existing issues

Built with ā¤ļø for better user experience analysis