MWID MCP Server
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., "@MWID MCP Servershow me the latest 10 manual sales"
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.
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
Related MCP server: CrewAI Enterprise MCP Server
Deploy to Railway
Step-by-Step Deployment
Push to GitHub:
git add . git commit -m "Add Railway configuration" git push origin mainCreate New Project on Railway:
Go to railway.app
Click "New Project"
Select "Deploy from GitHub repo"
Choose your repository:
mwid-mcp-server
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-hereOptional variables:
MWID_REQUEST_TIMEOUT=30 MWID_DEBUG=falseRailway Auto-Detection:
Railway will automatically detect:
✅
Dockerfilefor containerized deployment✅
railway.jsonfor build/deploy configuration✅
Procfilefor process management✅ Port configuration (Railway sets
PORTautomatically)
Deploy:
Railway will automatically build and deploy. Monitor the deployment in the Railway dashboard logs.
Get Your MCP Server URL:
Railway provides a public URL like:
https://mwid-mcp-server-production-xxxx.up.railway.appYou can also set a custom domain in Railway settings.
Configure Your AI Assistant:
ChatGPT: Add MCP server at
https://your-railway-url.railway.app/sseClaude 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.pyServer 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-serverConfiguration
Environment Variables
Variable | Required | Default | Description |
| Yes |
| Backend API endpoint |
| Yes |
| Authentication method: |
| For JWT | - | JWT authentication token |
| For Supabase | - | Supabase project URL |
| For Supabase | - | Supabase anon key |
| For Google | - | Google OAuth access token |
| No |
| Server port (Railway sets automatically) |
ChatGPT Configuration
Add the MCP server in ChatGPT settings:
Server URL: https://your-app.railway.app/sseClaude 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,adjustmentTypePagination:
page,pageSize(max 500)
get_manual_sale- Get specific sale details by IDlist_manual_investors- List investor records with filtering/pagination (1,064+ records)Filters:
email,userId,countryPagination:
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 infolist_assets- List all assetsget_asset- Get asset detailscreate_asset- Create new assetupdate_asset- Update assetdelete_asset- Delete asset (admin only)get_asset_phases- Get asset phasesget_asset_tasks- Get tasks for assetcalculate_minimum_time- Calculate task completion time
Task Management
get_task- Get task detailsupdate_task- Update taskassign_task- Assign task to userunassign_task- Remove task assignmentget_assigned_tasks- Get user's assigned tasksget_unassigned_tasks- Get unassigned tasksget_my_department_tasks- Get department tasksget_task_comments- Get task commentscreate_task_comment- Add comment to taskget_task_progress- Get task progressupdate_task_progress- Update task progress
Phase Management
update_phase- Update phase detailsget_phase_tasks- Get tasks for a phase
User & Department Management
list_users- List all users (admin only)get_user- Get user detailsget_users_for_assignment- Get assignable usersget_my_team- Get team membersget_department_members- Get department memberslist_departments- List departmentsget_department- Get department detailsget_department_stats- Get department statistics
Notifications
get_notifications- Get user notificationsget_unread_notification_count- Get unread countmark_notification_read- Mark notification as readmark_all_notifications_read- Mark all as read
Workflow Templates
list_workflow_templates- List available templatesget_workflow_template- Get template detailsapply_workflow_template- Apply template to asset
Legacy Internal API
list_investor_records- List internal investor recordsget_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_TOKENis valid and not expiredVerify backend API is accessible from Railway
Ensure backend CORS settings allow Railway domain
Empty Responses
Issue: Tools return empty data
Solution:
Verify
MWID_API_URLpoints to correct backendCheck JWT token has necessary permissions
Test backend API directly with curl/Postman
Development
Running Tests
python test_server.pyDebug Logging
Enable debug logging:
export MWID_DEBUG=true
python serve.pyContributing
Fork the repository
Create a feature branch
Make your changes
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
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ServiceWare20/mwid-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server