editorconfig_mcp
Formats files using .editorconfig rules to ensure consistent formatting, especially for AI-generated code.
README
EditorConfig MCP Server
A Model Context Protocol (MCP) compliant server that formats files using .editorconfig rules.
This project started from a specific workflow issue I kept running into. I found that while working with AI coding agents, they would often generate code with minor formatting errors, like trailing whitespace or inconsistent newlines. Our linters would then flag these issues, and the agent would spend valuable cycles fixing its own simple mistakes.
This EditorConfig MCP Server is the tool I built to solve that problem for myself. It acts as a proactive formatting gatekeeper, using your project's .editorconfig rules to ensure files are correct from the start. My hope is that it might be useful to others who've encountered a similar frustration in their AI-assisted development process.
Installation
Global Installation (Recommended)
npm install -g editorconfig-mcp-server
Then start the server:
editorconfig-mcp-server
Using npx (No Installation)
npx editorconfig-mcp-server
Local Installation
npm install editorconfig-mcp-server
Then add to your project's scripts in package.json:
{
"scripts": {
"format-server": "editorconfig-mcp-server"
}
}
From Source
git clone https://github.com/yourusername/editorconfig-mcp-server.git
cd editorconfig-mcp-server
npm install
npm start
Features
- MCP Compliant: Follows all MCP design patterns and best practices
- JSON Schema Validation: All inputs are validated using JSON Schema
- Rate Limiting: Built-in rate limiting (100 requests/minute)
- OpenAPI Spec: Self-documenting API with OpenAPI 3.0 specification
- Versioned API: Uses semantic versioning with
/v1/prefix - Stateless: No state retained between requests
- Security: Path validation prevents directory traversal attacks
- Error Handling: Consistent error format with helpful hints
Installation
npm install
Usage
Starting the Server
# If installed globally
editorconfig-mcp-server
# Using npx
npx editorconfig-mcp-server
# With custom port
PORT=8080 editorconfig-mcp-server
# From source
npm start
The server will start on port 8432 by default.
Configuration
PORT- Server port (default: 8432)- Default port chosen to avoid conflicts with common development servers
- Example:
PORT=8080 editorconfig-mcp-server
Integration with AI Tools
Claude Code
To add this server to Claude Code, run:
claude mcp add editorconfig npx editorconfig-mcp-server
Other MCP-Compatible Tools
This server is designed to be used with AI coding assistants that support MCP. Configure your AI tool to connect to:
- Base URL:
http://localhost:8432 - Protocol: MCP over HTTP
API Endpoints
Tools (Actions)
POST /v1/tools/format_file
Format a single file using .editorconfig rules.
Request:
{
"file_path": "src/index.js"
}
Response:
{
"success": true,
"file_path": "src/index.js",
"bytes": 1234
}
POST /v1/tools/format_files
Format multiple files matching a glob pattern.
Request:
{
"pattern": "**/*.js"
}
Response:
{
"success": true,
"pattern": "**/*.js",
"count": 5,
"files": ["src/index.js", "src/utils.js", ...]
}
Metadata
GET /openapi.json- OpenAPI 3.0 specificationGET /.well-known/mcp/servers.json- MCP server manifestGET /health- Health check endpoint
Error Handling
All errors follow a consistent format:
{
"error": "Error type",
"message": "Human-readable message",
"hint": "Helpful suggestion",
"expected_format": {} // Optional, for validation errors
}
Rate Limiting
The server implements rate limiting:
- Window: 1 minute
- Max requests: 100 per window
- Returns 429 status when exceeded
Security
- Input validation using JSON Schema
- Path traversal protection
- Payload size limit (1MB)
- Ignores sensitive directories (node_modules, .git)
Versioning
This project follows Semantic Versioning:
- MAJOR version for incompatible API changes
- MINOR version for backwards-compatible functionality additions
- PATCH version for backwards-compatible bug fixes
To release a new version:
# For a patch release (1.0.0 -> 1.0.1)
npm version patch
# For a minor release (1.0.0 -> 1.1.0)
npm version minor
# For a major release (1.0.0 -> 2.0.0)
npm version major
This will:
- Run the linter
- Update the version in package.json
- Create a git commit and tag
- Push the commit and tag to GitHub
Publishing
NPM Package
To publish this package to npm:
- Create an npm account at https://www.npmjs.com
- Login to npm:
npm login - Update version using
npm version(see above) - Run:
npm publish
For automated publishing via GitHub:
- Add your npm token as a GitHub secret named
NPM_TOKEN - Create a GitHub release - the publish workflow will automatically publish to npm
MCP Server Registry
To register this server in the MCP registry:
- Ensure your server implements the MCP specification
- Host your server publicly (e.g., npm, GitHub releases)
- Submit a PR to the MCP registry repository
Development
# Install dependencies
npm install
# Run linter
npm run lint
# Fix linting issues
npm run lint:fix
# Start server
npm start
License
MIT
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.
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.
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.
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.