Required to run the fountain pen ink MCP server, supporting ink search, color matching, and recommendation features.
Used for installation, building, and running the fountain pen ink MCP server and its dependencies.
Used for type definitions and implementation of the fountain pen ink MCP server's features.
Fountain Pen Ink MCP Server
A Model Context Protocol (MCP) server that provides LLMs with specialized knowledge about fountain pen inks, enabling intelligent ink search, color matching, and recommendations.
Features
This MCP server provides the following tools for LLMs:
🔍 Search Tools
- search_inks_by_name: Fuzzy search for inks by name or manufacturer
- search_inks_by_color: Find inks similar to any given color using RGB matching
- get_inks_by_maker: List all inks from a specific manufacturer
📊 Information Tools
- get_ink_details: Get comprehensive information about a specific ink
- analyze_color: Analyze any color and find the closest matching inks
🎨 Recommendation Tools
- get_color_palette: Generate sophisticated themed ink palettes with color theory support
- 13 predefined themes (warm, cool, earth, ocean, autumn, spring, summer, winter, pastel, vibrant, monochrome, sunset, forest)
- Color harmony generation (complementary, analogous, triadic, split-complementary)
- Custom hex color palettes
Installation
Prerequisites
- Node.js 18 or higher
- npm or yarn
Setup
Usage
Running the Server
MCP Client Configuration
Add this server to your MCP client configuration:
VS Code Integration
For VS Code users, the project includes:
- Tasks: Build, watch, and run the server
- MCP Configuration: Pre-configured in
.vscode/mcp.json
- Debug Support: Use VS Code's integrated terminal to test the server
Available Tools
search_inks_by_name
Search for fountain pen inks using fuzzy text matching.
Parameters:
query
(string): Search term for ink namemax_results
(number, optional): Maximum results to return (default: 20)
Example:
search_inks_by_color
Find inks similar to a given color using RGB color space matching.
Parameters:
color
(string): Hex color code (e.g., "#FF5733")max_results
(number, optional): Maximum results to return (default: 20)
Example:
get_ink_details
Get complete information about a specific ink.
Parameters:
ink_id
(string): The unique identifier for the ink
Example:
get_inks_by_maker
List all inks from a specific manufacturer.
Parameters:
maker
(string): Manufacturer name (e.g., "sailor", "diamine", "pilot")max_results
(number, optional): Maximum results to return (default: 50)
Example:
analyze_color
Analyze a color and provide fountain pen ink context.
Parameters:
color
(string): Hex color code (e.g., "#FF5733")
Example:
get_color_palette
Generate a themed or harmony-based palette of fountain pen inks with sophisticated color theory support.
Parameters:
theme
(string): Theme name, comma-separated hex colors, or single hex color for harmony generationpalette_size
(number, optional): Number of inks in palette (default: 5)harmony
(string, optional): Color harmony rule when using single hex color
Supported Themes:
- Classic: warm, cool, earth, ocean, autumn, spring
- Seasonal: summer, winter
- Mood: pastel, vibrant, monochrome
- Atmospheric: sunset, forest
Harmony Rules:
- complementary: Base color + opposite color
- analogous: Base color + adjacent colors
- triadic: Base color + two equidistant colors
- split-complementary: Base color + colors adjacent to complement
Examples:
Data Sources
The server uses two main data files:
- ink-colors.json: Contains RGB color values and basic ink information
- search.json: Contains metadata including manufacturers, scan dates, and searchable names
All ink data links back to Wilder Writes for detailed information and images.
Development
Project Structure
Scripts
npm run build
: Compile TypeScript to JavaScriptnpm run start
: Run the compiled servernpm run dev
: Build and run in one commandnpm run watch
: Watch for changes and rebuild automatically
Testing
You can test the server by running it and sending MCP protocol messages via stdin/stdout, or integrate it with an MCP-compatible client.
Testing
Run the comprehensive test suite to validate all functionality:
The test suite covers:
- ✅ 13 predefined themes + 4 harmony rules
- ✅ Custom color palette generation
- ✅ MCP protocol compliance
- ✅ Error handling and validation
- ✅ Color space conversions (BGR→RGB, RGB↔HSL)
Color Matching Algorithm
The server uses Euclidean distance in RGB color space to find similar inks:
Future improvements may include:
- LAB color space for better perceptual accuracy
- Weighted color components for fountain pen ink characteristics
- Semantic color descriptions
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
License
This project is licensed under the GNU General Public License v3.0 (GPL-3.0). See the LICENSE file for details.
Links
- Wilder Writes - Source of ink data and detailed ink information
- Model Context Protocol - MCP documentation and examples
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Tools
Provides LLMs with specialized knowledge about fountain pen inks, enabling intelligent ink search, color matching, and recommendations through various tools.
- Features
- Installation
- Usage
- Available Tools
- Data Sources
- Development
- Color Matching Algorithm
- Contributing
- License
- Links
Related Resources
Related MCP Servers
- -securityFlicense-qualityEnables LLMs to perform semantic search and document management using ChromaDB, supporting natural language queries with intuitive similarity metrics for retrieval augmented generation applications.Last updated -Python
- AsecurityAlicenseAqualityEnables seamless integration with any LLM client supporting MCP for creating and optimizing technical content and product positioning using Open Strategy Partners' methodologies.Last updated -6203PythonCC BY-SA 4.0
- -securityAlicense-qualityEnables integration with DuckDuckGo search capabilities for LLMs, supporting comprehensive web search, regional filtering, result types, and safe browsing with caching and customizable search parameters.Last updated -192TypeScriptMIT License
- -securityFlicense-qualityEnables LLMs to interact with DataForSEO and other SEO APIs through natural language, allowing for keyword research, SERP analysis, backlink analysis, and local SEO tasks.Last updated -62747TypeScript