This is a Model Context Protocol (MCP) server that provides access to all endpoints of the MonkeyType API. The server exposes MCP tools that allow Large Language Models (LLMs) to interact with the MonkeyType API.
- Exposes all MonkeyType API endpoints as MCP tools
- Compatible with any LLM that supports the Model Context Protocol
- Simple API key-based authentication per tool call
- Comprehensive error handling
- Rate limit awareness (respects MonkeyType's rate limits)
The easiest way to run the server is using npx:
npx monkeytype-mcpThis will download and run the latest version of the server directly.
You can also install the package globally:
npm install -g monkeytype-mcp
monkeytype-mcpIf you prefer to clone the repository:
git clone https://github.com/CodeDreamer06/MonkeytypeMCP.git
cd MonkeytypeMCP
npm install
npm startThe server exposes the following MonkeyType API endpoints as MCP tools:
check_username- Check if a username is availableget_personal_bests- Get user's personal bestsget_tags- Get user's tagsget_stats- Get user's statsget_profile- Get user's profilesend_forgot_password_email- Send forgot password emailget_current_test_activity- Get current test activityget_streak- Get user's streak
get_results- Get up to 1000 test resultsget_result_by_id- Get result by IDget_last_result- Get last result
get_speed_histogram- Get speed histogramget_typing_stats- Get typing stats
get_leaderboard- Get leaderboardget_leaderboard_rank- Get leaderboard rankget_daily_leaderboard- Get daily leaderboardget_weekly_xp_leaderboard- Get weekly XP leaderboard
get_psas- Get PSAs
is_submission_enabled- Check if quote submission is enabled
get_configuration- Get server configuration
To get your own MonkeyType API key (ApeKey), follow these steps:
- Sign in to your MonkeyType account
- Click on your profile icon in the top right corner
- Select "Account" from the dropdown menu
- Navigate to the "Ape Keys" tab
- Click "Generate New" to create a new API key
- Give your key a name (e.g., "MCP Server")
- Select the appropriate scopes based on what endpoints you need to access
- Click "Generate"
- Copy the generated key
Important: Keep your API key secure and never share it publicly.
To use this server with an LLM, you'll need to configure the LLM to use this server for MCP tool calls. You must provide your MonkeyType API key (ApeKey) by setting the MONKEYTYPE_API_KEY environment variable in your MCP server configuration.
MONKEYTYPE_API_KEY: (Required) Your MonkeyType API key. You can obtain this from your account settings on monkeytype.com.MONKEYTYPE_USERNAME: (Optional) Your MonkeyType username or UID. This can be used by certain tools (likeget_profile) as a default or when specific keywords are used.
{
"name": "get_configuration",
"arguments": {}
}To integrate this server with LLM platforms like OpenAI, Anthropic, or others:
- Start the MCP server using one of the installation methods above
- Configure your LLM platform to use this server as an MCP tool provider
- Pass the server's stdio as the communication channel
To add MonkeyType MCP to your IDE, add this to your IDE's MCP config file:
{
"mcpServers": {
"monkeytype": {
"command": "sh",
"args": ["-c", "cd $(mktemp -d) && npm install monkeytype-mcp && npx monkeytype-mcp"],
"env": {
"MONKEYTYPE_API_KEY": "YOUR_APE_KEY_HERE"
}
}
}
}- Cursor:
~/.cursor/mcp.json - Windsurf:
~/.codeium/windsurf/mcp_config.json - Cline:
~/.cline/mcp_config.json - Claude:
~/.claude/mcp_config.json
To use this MCP server in VS Code:
- Open VS Code settings
- Search for "MCP Server"
- Add a new MCP server with the following configuration:
- Name: MonkeyType MCP
- Command:
npx monkeytype-mcp - Type: Standard Input/Output (stdio)
The server exposes the following MonkeyType API endpoints as MCP tools:
check_username- Check if a username is availableget_personal_bests- Get user's personal bestsget_tags- Get user's tagsget_stats- Get user's statsget_profile- Get user's profilesend_forgot_password_email- Send forgot password emailget_current_test_activity- Get current test activityget_streak- Get user's streak
Fetches a user's public profile.
Parameters:
uidOrName(string, optional): The UID or username of the user whose profile is to be fetched.- If you provide a specific username or UID, that user's profile will be fetched.
- You can use keywords like "me", "self", "current", or "my". If one of these keywords is used, the tool will use the
MONKEYTYPE_USERNAMEenvironment variable (if set). - If this parameter is omitted entirely, the tool will also attempt to use the
MONKEYTYPE_USERNAMEenvironment variable (if set). - If the
uidOrNameparameter is omitted (or a keyword is used) and theMONKEYTYPE_USERNAMEenvironment variable is not set, an error will occur.
get_results- Get up to 1000 test resultsget_result_by_id- Get result by IDget_last_result- Get last result
get_speed_histogram- Get speed histogramget_typing_stats- Get typing stats
get_leaderboard- Get leaderboardget_leaderboard_rank- Get leaderboard rankget_daily_leaderboard- Get daily leaderboardget_weekly_xp_leaderboard- Get weekly XP leaderboard
get_psas- Get PSAs
is_submission_enabled- Check if quote submission is enabled
get_configuration- Get server configuration
If you're making changes to this server and want to publish your own version:
npm login
npm publishThis project is hosted on GitHub at https://github.com/CodeDreamer06/MonkeytypeMCP.
This project is licensed under the MIT License - see the LICENSE file for details.
- MonkeyType for providing the API
- Model Context Protocol (MCP) for the server architecture
This project is not officially affiliated with MonkeyType. Use at your own risk and ensure you comply with MonkeyType's terms of service and API rate limits.