MWID MCP Server

MWID MCP Server

Model Context Protocol (MCP) server for the MetaWealth Asset Launch Dashboard. It enables AI assistants like ChatGPT and Claude to interact with the MWID Dashboard API for asset management, task tracking, and team collaboration.

Category
Visit Server

README

MWID MCP Server

Model Context Protocol (MCP) server for the MetaWealth Asset Launch Dashboard. This server enables AI assistants like ChatGPT and Claude to interact with the MWID Dashboard API for asset management, task tracking, and team collaboration.

Features

  • šŸ”§ Comprehensive Tool Suite: 40+ tools for assets, tasks, users, departments, and teams
  • šŸ” Multiple Auth Methods: JWT, Supabase, and Google OAuth support
  • šŸ“Š Real-time Data: Access to live dashboard data via REST API
  • 🌐 SSE Transport: Server-Sent Events for reliable AI assistant connections
  • šŸš€ Production Ready: Dockerized and optimized for cloud deployment

Deploy to Railway

Step-by-Step Deployment

  1. Push to GitHub:

    git add .
    git commit -m "Add Railway configuration"
    git push origin main
    
  2. Create New Project on Railway:

    • Go to railway.app
    • Click "New Project"
    • Select "Deploy from GitHub repo"
    • Choose your repository: mwid-mcp-server
  3. Configure Environment Variables:

    In Railway Dashboard → Variables, add these required variables:

    MWID_API_URL=https://your-backend-api.com/api/v1
    MWID_AUTH_METHOD=jwt
    MWID_JWT_TOKEN=your-jwt-token-here
    

    Optional variables:

    MWID_REQUEST_TIMEOUT=30
    MWID_DEBUG=false
    
  4. Railway Auto-Detection:

    Railway will automatically detect:

    • āœ… Dockerfile for containerized deployment
    • āœ… railway.json for build/deploy configuration
    • āœ… Procfile for process management
    • āœ… Port configuration (Railway sets PORT automatically)
  5. Deploy:

    Railway will automatically build and deploy. Monitor the deployment in the Railway dashboard logs.

  6. Get Your MCP Server URL:

    Railway provides a public URL like: https://mwid-mcp-server-production-xxxx.up.railway.app

    You can also set a custom domain in Railway settings.

  7. Configure Your AI Assistant:

    • ChatGPT: Add MCP server at https://your-railway-url.railway.app/sse
    • Claude Desktop: Add to claude_desktop_config.json (see configuration below)

Manual Deployment

Prerequisites

  • Python 3.13+
  • pip
  • Docker (optional)

Local Development

# Clone the repository
git clone https://github.com/MetaWealth/mwid-mcp-server.git
cd mwid-mcp-server

# Create virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

# Create .env file
cat > .env << EOF
MWID_API_URL=http://localhost:8080/api/v1
MWID_AUTH_METHOD=jwt
MWID_JWT_TOKEN=your-token-here
EOF

# Run the server
python serve.py

Server will start on http://localhost:8000

Docker Deployment

# Build image
docker build -t mwid-mcp-server .

# Run container
docker run -p 8000:8000 \
  -e MWID_API_URL=https://your-api.com/api/v1 \
  -e MWID_AUTH_METHOD=jwt \
  -e MWID_JWT_TOKEN=your-token \
  mwid-mcp-server

Configuration

Environment Variables

Variable Required Default Description
MWID_API_URL Yes http://localhost:8080/api/v1 Backend API endpoint
MWID_AUTH_METHOD Yes jwt Authentication method: jwt, supabase, or google
MWID_JWT_TOKEN For JWT - JWT authentication token
MWID_SUPABASE_URL For Supabase - Supabase project URL
MWID_SUPABASE_KEY For Supabase - Supabase anon key
MWID_GOOGLE_ACCESS_TOKEN For Google - Google OAuth access token
PORT No 8000 Server port (Railway sets automatically)

ChatGPT Configuration

Add the MCP server in ChatGPT settings:

Server URL: https://your-app.railway.app/sse

Claude Desktop Configuration

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "mwid-dashboard": {
      "url": "https://your-app.railway.app/sse"
    }
  }
}

Available Tools

The server provides 40+ tools organized into these categories:

āœ… Working Features (External API - No JWT Required)

These tools work immediately with just the MWID_EXTERNAL_API_KEY:

Sales & Investor Data

  • list_manual_sales - List sales records with filtering/pagination (3,692+ records)
    • Filters: userId, assetId, adjustmentType
    • Pagination: page, pageSize (max 500)
  • get_manual_sale - Get specific sale details by ID
  • list_manual_investors - List investor records with filtering/pagination (1,064+ records)
    • Filters: email, userId, country
    • Pagination: page, pageSize (max 500)
  • get_manual_investor - Get specific investor details by ID

āš ļø Future Features (Internal API - Requires JWT Token)

These tools require MWID_JWT_TOKEN to be configured. They will return 403 errors until JWT authentication is set up.

Asset Management

  • get_current_user - Get authenticated user info
  • list_assets - List all assets
  • get_asset - Get asset details
  • create_asset - Create new asset
  • update_asset - Update asset
  • delete_asset - Delete asset (admin only)
  • get_asset_phases - Get asset phases
  • get_asset_tasks - Get tasks for asset
  • calculate_minimum_time - Calculate task completion time

Task Management

  • get_task - Get task details
  • update_task - Update task
  • assign_task - Assign task to user
  • unassign_task - Remove task assignment
  • get_assigned_tasks - Get user's assigned tasks
  • get_unassigned_tasks - Get unassigned tasks
  • get_my_department_tasks - Get department tasks
  • get_task_comments - Get task comments
  • create_task_comment - Add comment to task
  • get_task_progress - Get task progress
  • update_task_progress - Update task progress

Phase Management

  • update_phase - Update phase details
  • get_phase_tasks - Get tasks for a phase

User & Department Management

  • list_users - List all users (admin only)
  • get_user - Get user details
  • get_users_for_assignment - Get assignable users
  • get_my_team - Get team members
  • get_department_members - Get department members
  • list_departments - List departments
  • get_department - Get department details
  • get_department_stats - Get department statistics

Notifications

  • get_notifications - Get user notifications
  • get_unread_notification_count - Get unread count
  • mark_notification_read - Mark notification as read
  • mark_all_notifications_read - Mark all as read

Workflow Templates

  • list_workflow_templates - List available templates
  • get_workflow_template - Get template details
  • apply_workflow_template - Apply template to asset

Legacy Internal API

  • list_investor_records - List internal investor records
  • get_investor_record - Get internal investor record details

Architecture

ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”         ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”         ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”
│  ChatGPT/   │  SSE    │  MCP Server  │  HTTP   │   MWID      │
│   Claude    │◄────────┤  (Railway)   │────────►│  Backend    │
ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜         ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜         ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜
                         /sse endpoint             REST API
                         /messages endpoint        (8080)

Troubleshooting

Connection Timeout

Issue: ChatGPT times out connecting to the server

Solution:

  • Ensure Railway deployment is running (check Railway dashboard)
  • Verify environment variables are set correctly
  • Check Railway logs for errors: railway logs

403 Forbidden

Issue: Getting 403 errors

Solution:

  • Check MWID_JWT_TOKEN is valid and not expired
  • Verify backend API is accessible from Railway
  • Ensure backend CORS settings allow Railway domain

Empty Responses

Issue: Tools return empty data

Solution:

  • Verify MWID_API_URL points to correct backend
  • Check JWT token has necessary permissions
  • Test backend API directly with curl/Postman

Development

Running Tests

python test_server.py

Debug Logging

Enable debug logging:

export MWID_DEBUG=true
python serve.py

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Submit a pull request

License

MIT License - see LICENSE file for details

Support

For issues or questions:

  • GitHub Issues: https://github.com/MetaWealth/mwid-mcp-server/issues
  • Documentation: https://your-docs-site.com
  • Email: support@metawealth.co

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