Gravatar MCP Server
Provides official access to Gravatar profiles, avatars, and AI-inferred interests using email addresses or profile identifiers. This server enables the retrieval of comprehensive user data and customized avatar images with various size and rating options.
README
MCP Server Gravatar
Gravatar's official MCP Server, enabling access to avatars, profiles, and inferred interests.
Quick Install
For quick installation in VS Code, click one of the installation buttons below:
Requirements
Node.js
This MCP server requires:
- Node.js: 20.0.0 or higher
- npm: 10.0.0 or higher
The server is tested and supported on:
- Node.js 20 (Active LTS)
- Node.js 22 (Current LTS)
- Node.js 24 (Current)
Installation
You can install and run this server using npx (recommended) or by building from source.
Tools
-
get_profile_by_id- Retrieve comprehensive Gravatar profile information using a profile identifier
- Required inputs:
profileIdentifier(string): A Profile Identifier (see Identifier Types section)
- Returns: Profile object as JSON with comprehensive user information
-
get_profile_by_email- Retrieve comprehensive Gravatar profile information using an email address
- Required inputs:
email(string): The email address associated with the Gravatar profile. Can be any valid email format - the system will automatically normalize and hash the email for lookup.
- Returns: Profile object as JSON with comprehensive user information
-
get_inferred_interests_by_id- Fetch AI-inferred interests for a Gravatar profile using a profile identifier
- Required inputs:
profileIdentifier(string): A Profile Identifier (see Identifier Types section)
- Returns: List of AI-inferred interest names as JSON
-
get_inferred_interests_by_email- Fetch AI-inferred interests for a Gravatar profile using an email address
- Required inputs:
email(string): The email address associated with the Gravatar profile. Can be any valid email format - the system will automatically normalize and hash the email for lookup.
- Returns: List of AI-inferred interest names as JSON
-
get_avatar_by_id- Retrieve the avatar image for a Gravatar profile using an avatar identifier
- Required inputs:
avatarIdentifier(string): An Avatar Identifier (see Identifier Types section)
- Optional inputs:
size(number, default: undefined): Desired avatar size in pixels (1-2048). Images are square, so this sets both width and height. Common sizes: 80 (default web), 200 (high-res web), 512 (large displays).defaultOption(string, default: undefined): Fallback image style when no avatar exists. Options: '404' (return HTTP 404 error instead of image), 'mp' (mystery person silhouette), 'identicon' (geometric pattern), 'monsterid' (generated monster), 'wavatar' (generated face), 'retro' (8-bit style), 'robohash' (robot), 'blank' (transparent).forceDefault(boolean, default: undefined): When true, always returns the default image instead of the user's avatar. Useful for testing default options or ensuring consistent placeholder images.rating(string, default: undefined): Maximum content rating to display. 'G' (general audiences), 'PG' (parental guidance), 'R' (restricted), 'X' (explicit). If user's avatar exceeds this rating, the default image is shown instead.
- Returns: Avatar image in PNG format
-
get_avatar_by_email- Retrieve the avatar image for a Gravatar profile using an email address
- Required inputs:
email(string): The email address associated with the Gravatar profile. Can be any valid email format - the system will automatically normalize and hash the email for lookup.
- Optional inputs:
size(number, default: undefined): Desired avatar size in pixels (1-2048). Images are square, so this sets both width and height. Common sizes: 80 (default web), 200 (high-res web), 512 (large displays).defaultOption(string, default: undefined): Fallback image style when no avatar exists. Options: '404' (return HTTP 404 error instead of image), 'mp' (mystery person silhouette), 'identicon' (geometric pattern), 'monsterid' (generated monster), 'wavatar' (generated face), 'retro' (8-bit style), 'robohash' (robot), 'blank' (transparent).forceDefault(boolean, default: undefined): When true, always returns the default image instead of the user's avatar. Useful for testing default options or ensuring consistent placeholder images.rating(string, default: undefined): Maximum content rating to display. 'G' (general audiences), 'PG' (parental guidance), 'R' (restricted), 'X' (explicit). If user's avatar exceeds this rating, the default image is shown instead.
- Returns: Avatar image in PNG format
Default Avatar Options
404: Return an HTTP 404 error instead of an image when no avatar existsmp: (mystery-person) A simple, cartoon-style silhouetted outline of a personidenticon: A geometric pattern based on an email hashmonsterid: A generated 'monster' with different colors, faces, etcwavatar: Generated faces with differing features and backgroundsretro: Awesome generated, 8-bit arcade-style pixelated facesrobohash: A generated robot with different colors, faces, etcblank: A transparent PNG image
Rating Options
G: Suitable for display on all websites with any audience typePG: May contain rude gestures, provocatively dressed individuals, the lesser swear words, or mild violenceR: May contain harsh profanity, intense violence, nudity, or hard drug useX: May contain sexual imagery or extremely disturbing violence
Setup
Gravatar API Key
Some parts of the Gravatar API can be used without authentication. However, using an API key is recommended as it increases the rate limits for your queries. You can generate your own API key by visiting the Developer Dashboard.
Once you have your API key, you can configure it in Claude Desktop or VS Code as shown in the sections below.
Claude Desktop Configuration
Add the following to your claude_desktop_config.json:
With API Key (Recommended)
{
"mcpServers": {
"gravatar": {
"command": "npx",
"args": [
"-y",
"@automattic/mcp-server-gravatar"
],
"env": {
"GRAVATAR_API_KEY": "your-api-key-here"
}
}
}
}
Without API Key
[!NOTE]
- Without an API key, strict rate limits will be applied.
- A future release of this server may include tools that will only be available with an API key.
{
"mcpServers": {
"gravatar": {
"command": "npx",
"args": [
"-y",
"@automattic/mcp-server-gravatar"
]
}
}
}
VS Code Configuration
For manual installation, add one of the following JSON blocks to your User Settings (JSON) file in VS Code. You can do this by pressing Cmd + Shift + P (or Ctrl + Shift + P on Windows/Linux) and typing Preferences: Open Settings (JSON).
With API Key Input (Recommended)
This configuration prompts for an API key and stores it securely:
{
"mcp": {
"inputs": [
{
"type": "promptString",
"id": "gravatar_api_key",
"description": "Gravatar API Key (optional)",
"password": true
}
],
"servers": {
"gravatar": {
"command": "npx",
"args": ["-y", "@automattic/mcp-server-gravatar"],
"env": {
"GRAVATAR_API_KEY": "${input:gravatar_api_key}"
}
}
}
}
}
Without API Key
[!NOTE]
- Without an API key, strict rate limits will be applied.
- A future release of this server may include tools that will only be available with an API key.
{
"mcp": {
"servers": {
"gravatar": {
"command": "npx",
"args": ["-y", "@automattic/mcp-server-gravatar"]
}
}
}
}
Optionally, you can add either configuration to a file called .vscode/mcp.json in your workspace. This will allow you to share the configuration with others.
Note that the
mcpkey is not needed in the.vscode/mcp.jsonfile.
Building from Local Source Files
If you want to build and run the MCP server from local source files:
# Clone the repository
git clone https://github.com/Automattic/mcp-server-gravatar.git
cd mcp-server-gravatar
# Install dependencies
npm install
The update your MCP Client configuration:
{
"mcpServers": {
"gravatar": {
"command": "npx",
"args": [
"/path/to/mcp-server-gravatar"
],
"env": {
"GRAVATAR_API_KEY": "your-api-key-here"
}
}
}
}
Or witout an API Key:
{
"mcpServers": {
"gravatar": {
"command": "npx",
"args": [
"/path/to/mcp-server-gravatar"
]
}
}
}
Identifier Types
The Gravatar MCP server uses different types of identifiers to access profile and avatar data:
Profile Identifiers
A Profile Identifier can be one of the following:
- SHA256 Hash (preferred): An email address that has been normalized (lower-cased and trimmed) and then hashed with SHA256
- MD5 Hash (deprecated): An email address that has been normalized (lower-cased and trimmed) and then hashed with MD5
- URL Slug: The username portion from a Gravatar profile URL (e.g., 'username' from gravatar.com/username)
Avatar Identifiers
An Avatar Identifier is an email address that has been normalized (lower-cased and trimmed) and then hashed with either:
- SHA256 (preferred)
- MD5 (deprecated)
Important: Unlike Profile Identifiers, Avatar Identifiers cannot use URL slugs - only email hashes are supported.
Email Addresses
When using email-based tools, you can provide any valid email format. The system will automatically:
- Normalize the email (convert to lowercase and trim whitespace)
- Generate the appropriate hash for API requests
- Process the email securely without storing it
Development
Using the Inspector
The MCP Inspector is a tool that helps validate your MCP server implementation. To run the inspector:
make inspector
This will build the project and then run the MCP Inspector against your server, validating the tools and their schemas.
Development Workflow
Start the TypeScript compiler in watch mode:
make dev
This will watch for changes to your TypeScript files and automatically recompile them.
To run the server after compilation:
npm start
Testing
Run the test suite:
npm test
Run tests with coverage:
npm run test:coverage
Run tests in watch mode:
npm run test:watch
Multi-Node Testing
This project is tested against multiple Node.js versions to ensure compatibility. The CI pipeline automatically tests on:
- Node.js 20 (Active LTS)
- Node.js 22 (Current LTS)
- Node.js 24 (Current)
To test locally with different Node versions using nvm:
# Test with Node 20
nvm use 20
npm ci
npm run type-check
npm test
# Test with Node 22
nvm use 22
npm ci
npm run type-check
npm test
# Test with Node 24
nvm use 24
npm ci
npm run type-check
npm test
Generation System
This project uses a Make-driven architecture for all code generation with proper file-based dependencies:
# Generate everything (API client + MCP schemas)
make generate-all
# OR
npm run generate-all
# Generate just the OpenAPI client
make generate-client
# OR
npm run generate-client
# Generate just the MCP schemas (requires client)
make generate-schemas
# OR
npm run generate-schemas
The schema generation is configured via scripts/schemas.config.json and supports:
- Configurable schema extraction from OpenAPI models
- Array wrapping for responses that need structured containers
- Clean output schemas that match MCP specification exactly
- Automatic dependency tracking via Make
Other Useful Commands
The project includes a Makefile with several useful commands:
make download-spec: Download the Gravatar OpenAPI specmake generate-client: Generate Gravatar API client from OpenAPI specmake generate-schemas: Generate MCP output schemas from API clientmake generate-all: Generate API client and MCP schemasmake build: Build the TypeScript projectmake lint: Run lintingmake lint-fix: Run linting with auto-fixmake format: Format code with Prettiermake format-check: Check code formattingmake quality-check: Run linting and format checkingmake clean: Clean build artifacts and dependencies
Run make help to see all available commands.
Environment Variables
-
GRAVATAR_API_KEY: Optional API key for Gravatar API. If provided, it will be used for API requests, which increases rate limits and provides access to additional features. -
GRAVATAR_API_KEY_ENV_VAR: Optional name of the environment variable that contains the API key. Default isGRAVATAR_API_KEY. This is useful if you need to use a different environment variable name in your deployment environment.
When running the server locally, you can set these environment variables in your shell before starting the server:
# Set API key (recommended)
export GRAVATAR_API_KEY=your_api_key_here
# Start the server
npm start
Or you can provide them inline when starting the server:
GRAVATAR_API_KEY=your_api_key_here npm start
When configuring the server in Claude Desktop or VS Code, you can set these environment variables in the configuration as shown in the Setup section above.
License
This MCP server is licensed under the Mozilla Public License Version 2.0 (MPL-2.0). This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MPL-2.0. For more details, please see the LICENSE file in the project repository.
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.