AI Quality Gate
Automates code quality by running ESLint with over 600 rules to identify and fix security issues, bugs, and code smells.
Enforces modern JavaScript best practices and fundamentals through core linting rules and ecosystem-specific plugins.
Ensures consistent code styling by automatically formatting code according to the project's Prettier configuration.
Leverages SonarSource technology to perform static analysis and report quality gate results for code improvements.
Integrates with SonarQube servers for an optional secondary phase of deep code analysis and security auditing.
Provides specialized linting rules and quality checks specifically designed for TypeScript codebases.
AI Quality Gate
MCP Server for AI code quality automation.
What It Does
AI writes code β calls quality_fix β Server fixes what it can β Reports remaining issues to AI.
Hybrid Approach:
Phase 1: ESLint + 627 rules + Prettier (~2-8s, always runs)
Phase 2: SonarQube Server (~30-60s, optional)
Important: ESLint vs Prettier
Tool | Source | Config |
ESLint | Project's config (if exists) or MCP's embedded |
|
Prettier | Project's own | Project's |
ESLint rules are controlled by MCP for consistent quality gates. Prettier uses project's config so formatting matches project preferences.
Phase 1 Rule Coverage:
Plugin | Rules | Description |
SonarJS | 201 | Security, bugs, code smells |
Unicorn | 127 | Modern JS best practices |
ESLint Core | 108 | JavaScript fundamentals |
TypeScript-ESLint | 99 | TypeScript-specific rules |
RegExp | 60 | Regex best practices |
Import | 11 | Import/export rules |
Promise | 10 | Async/await best practices |
Node.js (n) | 9 | Node.js specific rules |
Unused Imports | 2 | Auto-remove unused imports |
Total | 627 |
Installation
Prerequisites
Node.js 18+ on your PATH (
node -v).Cursor (or another MCP-capable editor) with MCP enabled.
Project root is auto-detected when PROJECT_ROOT is omitted: the server walks up from the MCP process working directory until it finds package.json or tsconfig.json. Set PROJECT_ROOT in env only to analyze a different tree than the inferred root.
MCP configuration (Cursor)
Open Settings β Tools & MCP β Edit (user mcp.json). Add one server block; the examples below match .cursor/mcp.json.example (JSONC with comments β if your editor rejects comments, copy the JSON blocks below only).
Server name vs tool name: The key under mcpServers (e.g. "ai-quality-gate") is only the label for that connection in Cursor. The MCP tool your agent calls is always quality_fix β that name is fixed by this package and is separate from the server key and from ai-quality-gate.
A) Recommended: npx (no global install)
Always runs the published package; good for teams and CI-like setups.
{
"mcpServers": {
"ai-quality-gate": {
"command": "npx",
"args": ["-y", "ai-quality-gate"]
}
}
}B) Optional: global npm install
After npm i -g ai-quality-gate, the ai-quality-gate binary is on your PATH:
{
"mcpServers": {
"ai-quality-gate": {
"command": "ai-quality-gate",
"args": []
}
}
}C) SonarQube (Phase 2)
Requires a running SonarQube instance, sonar-scanner available (see SonarQube Setup), and all three variables below. Phase 1 still runs first.
{
"mcpServers": {
"ai-quality-gate": {
"command": "npx",
"args": ["-y", "ai-quality-gate"],
"env": {
"SONAR_HOST_URL": "http://localhost:9000",
"SONAR_TOKEN": "your_sonar_token",
"SONAR_PROJECT_KEY": "your_project_key"
}
}
}
}D) Optional environment variables (any server)
Add an "env" object when you need overrides. Merge order for config is defaults β .quality-gate.yaml / .quality-gate.json β environment variables.
Variable | When to set |
| Absolute path to a specific |
| Force project root if auto-detection is wrong for your layout. |
| SonarQube server URL (with Phase 2). |
| SonarQube token (with Phase 2). |
| SonarQube project key (with Phase 2). |
| Full path to |
| Phase 1 timeout (ms), default |
| Phase 2 timeout (ms), default |
|
|
Local development (this repository)
To dogfood or contribute:
yarn buildβ generatesdist/server.js.Point MCP at the built file (absolute paths):
{
"mcpServers": {
"ai-quality-gate-dev": {
"command": "node",
"args": ["/ABSOLUTE/PATH/TO/ai-quality-gate/dist/server.js"]
}
}
}Reload MCP. Use
env.PROJECT_ROOTonly if the repo you analyze differs from the inferred root.
2. Add AI Rule
Settings β Rules and Commands β Add Rule:
After every code change, before telling the user "done",
AI must call the quality_fix MCP tool. This is mandatory.3. Use It
AI writes code β calls quality_fix β Fixes errors β "Done β
"CLI: interactive config (--setup)
The interactive wizard creates or updates .quality-gate.yaml without hand-editing: it walks you through project root, optional SonarQube (host URL + project key; token is not saved to disk β use SONAR_TOKEN in your environment), which Phase 1 tools to enable (ESLint, curly-brace / arrow AST fixers, Prettier, JSON validator), timeouts, and i18n rules. The generated file includes a fixers: block you can adjust later.
After yarn build (or install from npm), run from the target project (or any path under it):
node dist/server.js --setupPROJECT_ROOT is inferred when unset (see MCP configuration). Use the same entrypoint as the MCP server (node dist/server.js or npx ai-quality-gate); only the --setup flag switches to wizard mode. Answer prompts in the terminal; on success you get a ready-to-use config next to your project root.
Other CLI modes: --check (read-only Phase 1), --fix (default behavior when using CLI quality run), --phase1-only, --phase2-only β see docs/DEVELOPMENT.md.
Optional: SonarQube Server (Phase 2)
Configure Sonar env in MCP as in C) SonarQube (Phase 2) above, or copy from .cursor/mcp.json.example. You need sonar-scanner on your machine for analysis (see below).
SonarQube Setup
Docker (Recommended)
# Start SonarQube
docker run -d --name sonarqube -p 9000:9000 sonarqube:community
# First login: admin/admin β change password
# http://localhost:9000Docker Compose
# docker-compose.yml
version: '3'
services:
sonarqube:
image: sonarqube:community
ports:
- '9000:9000'
volumes:
- sonarqube_data:/opt/sonarqube/data
- sonarqube_logs:/opt/sonarqube/logs
- sonarqube_extensions:/opt/sonarqube/extensions
volumes:
sonarqube_data:
sonarqube_logs:
sonarqube_extensions:docker-compose up -dCreating SonarQube Token
http://localhost:9000 β Login (admin)
My Account β Security β Generate Tokens
Select token type: Global Analysis Token
Copy token β use as
SONAR_TOKEN
Installing sonar-scanner
Platform | Method | Command |
Windows | npm (global) |
|
Windows | Chocolatey |
|
macOS | npm (global) |
|
macOS | Homebrew |
|
Linux | npm (global) |
|
Docker | Container |
|
For custom path: SONAR_SCANNER_PATH env var
Configuration
Optional files (discovered by walking up from the inferred project root β same algorithm as package.json / tsconfig.json β or from PROJECT_ROOT when set): .quality-gate.yaml (preferred) or .quality-gate.json. Same fields as environment variables (camelCase); you may nest Sonar settings under sonar: { hostUrl, token, projectKey, scannerPath }.
Merge order: defaults β config file β environment variables (ENV wins on conflicts).
Set QUALITY_GATE_CONFIG to an explicit path to skip discovery.
Custom rules (customRules)
Optional line-based regex checks on lintable files (Phase 1). Each match is reported as an issue with rule set to custom:<id> (and included in quality_fix remaining). Example:
customRules:
- id: no-console
message: 'Console.log is not allowed'
pattern: 'console\\.log\\('
severity: error
- id: no-debugger
message: 'Debugger statement found'
pattern: 'debugger'
severity: warningPatterns use JavaScript RegExp source (escape backslashes as in YAML strings). Invalid patterns are skipped at runtime with a log line.
JSON validator & i18n locale files
When fixers.jsonValidator is enabled and you pass JSON paths that match locale patterns (for example locales/en.json / locales/tr.json), the tool compares keys across those files.
Syntax errors, invalid UTF-8 BOM, etc. β reported as
issuesand fail Phase 1 /quality_fixuntil fixed.Missing or extra keys between locale files β collected as
i18nIssuesin the validator result and printed as warnings on stderr during Phase 1. They do not setpassed: falseand do not block the gate.
Treat i18nIssues as advisory unless you add your own CI check on top.
Environment Variables
All variables are optional unless you use Phase 2, which requires SONAR_HOST_URL, SONAR_TOKEN, and SONAR_PROJECT_KEY together.
Variable | Description | Example |
| Absolute path to a |
|
| Override detected project root. Default: walk up from the process cwd until |
|
| SonarQube server base URL (Phase 2). |
|
| SonarQube authentication token (Phase 2). Prefer env / secret store; avoid committing. |
|
| SonarQube project key (Phase 2). |
|
| Full path to the |
|
| Phase 1 subprocess timeout in milliseconds. |
|
| Phase 2 (Sonar) timeout in milliseconds. |
|
| Set to |
|
Auto-Fix
Phase 1 automatically fixes these issues:
ESLint Auto-Fix (~100+ rules)
// var β const/let
var x = 1 β const x = 1
// forEach β for...of (unicorn/no-array-for-each)
arr.forEach(x => f(x)) β for (const x of arr) f(x)
// Nested ternary β extracted (unicorn/no-nested-ternary)
a ? b : c ? d : e β const temp = c ? d : e; a ? b : temp
// Unused imports removed
import { unused } from 'x' β (removed)
// Type imports (consistent-type-imports)
import { Type } from 'x' β import type { Type } from 'x'
// Optional chain (prefer-optional-chain)
a && a.b && a.b.c β a?.b?.c
// Regex optimization (regexp/*)
/[0-9]/ β /\d/AST Auto-Fix
// Remove unnecessary curly braces (single-line if)
if (x) { return true } β if (x) return truePrettier Formatting
After ESLint fixes, Prettier runs to ensure consistent formatting:
// ESLint removes braces but leaves awkward format:
if (x)
return true
// Prettier fixes to single line:
if (x) return trueNote: Prettier uses project's config, not MCP's.
Everything else: Reported to AI, AI fixes it.
API
Tool: quality_fix
// Input
{
files: string[] // File paths to check
}
// Output
{
phase: "local" | "server" | "complete",
success: boolean,
message: string,
fixed: {
eslint: number, // ESLint auto-fixes
curlyBraces: number, // AST: single-statement if braces
singleLineArrow: number, // AST: arrow body style
prettier: number, // Prettier formatting
json: number // JSON validation passes counted
},
remaining: Issue[],
timing: {
phase1: string,
phase2?: string,
total: string
}
}Feature Flags
ENABLE_I18N_RULES
For projects with internationalization (i18n), enable literal string detection:
{
"env": {
"ENABLE_I18N_RULES": "true"
}
}When enabled:
// β οΈ Warning
<h1>Hello World</h1>
// β
OK
<h1>{t('hello')}</h1>Troubleshooting
MCP: quality_fix does not appear
Node.js 18+ β run
node -vandnpx --version.Reload Cursor after editing
mcp.json(or use the MCP refresh control).JSON β the file must be valid JSON (no trailing commas). Copy from the MCP configuration section if unsure.
Global install β if you use
"command": "ai-quality-gate", runnpm i -g ai-quality-gateonce so the binary exists.
Windows
"npx not found" error:
# Node.js must be in PATH
# Check in PowerShell:
where.exe npxPermission denied:
# Run PowerShell as AdministratormacOS / Linux
"Permission denied" error:
# Fix npm global directory
mkdir ~/.npm-global
npm config set prefix '~/.npm-global'
echo 'export PATH=~/.npm-global/bin:$PATH' >> ~/.zshrc
source ~/.zshrc"sonar-scanner not found" error:
# Install via Homebrew
brew install sonar-scanner
# Or via npm
npm install -g sonarqube-scannerSonarQube
"Insufficient privileges" error:
SonarQube β Administration β Security β Global Permissions
Give Anyone group Browse and Execute Analysis permissions
"Project not found" error:
Create project manually for first analysis: Projects β Create Project β Manually
Clone & build (contributors)
git clone https://github.com/mustafacagri/ai-quality-gate.git
cd ai-quality-gate
yarn install
yarn buildUse Local development (this repository) for MCP pointing at dist/server.js.
Docs
SETUP.md β Local setup (if included in your tree)
AGREEMENTS.md, docs/ARCHITECTURE.md, etc. β optional; some files may be omitted in minimal clones. README +
.cursor/mcp.json.exampleare enough to run the published package.
Principles
β 627 ESLint rules (SonarJS, Unicorn, TypeScript-ESLint, etc.)
β Prettier integration (uses project's config)
β AST-based transforms (no regex)
β Verify after each fix
β Rollback on error
β ESLint config discovery (uses project config if available, otherwise embedded)
β Zero workaround
β Principal level
License
MIT Β© Mustafa ΓaΔrΔ± GΓΌven
v0.0.1 β Initial release! MCP quality_fix, Phase 1/2 pipeline, CLI, config files, custom rules (see CHANGELOG)
This server cannot be installed
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/mustafacagri/ai-quality-gate'
If you have feedback or need assistance with the MCP directory API, please join our Discord server