Sponsored by Deepsite.site

CV Mirror MCP — Multi-vendor ATS Resume Linter

Created By
goofypluto9992 days ago
Simulates how 5 real Applicant Tracking Systems (Workday, Greenhouse, Lever, Taleo, iCIMS) parse a CV and surfaces vendor-specific lint warnings. Pure JS lint engine, MIT licensed, no network calls in the lint logic. Vendor rules cite their public sources. Tools exposed: analyze_cv (full report), lint_for_vendor (single-vendor lint), get_express_url (web companion link). Compatible with Claude Desktop, Cursor, Cline, and any MCP-spec-compliant client.
Overview

cv-mirror-mcp

Model Context Protocol server that lints a CV against 5 real ATS parsers.

License: MIT MCP Tests Node

What it does

Exposes three MCP tools so any MCP-compatible AI agent (Claude Code, Cursor, Windsurf, Zed, OpenCode, Cline, etc.) can analyse a CV against the documented quirks of:

  • Workday
  • Greenhouse
  • Lever
  • Taleo (Oracle)
  • iCIMS

These are the 5 most-used enterprise ATS systems. Each one parses CVs slightly differently. A "0–100 ATS score" averages those differences into noise. This server surfaces what each one actually does — column handling, emoji stripping, header-footer dropping, date-format quirks — as concrete lint findings with concrete fixes.

The lint rules are derived from public vendor documentation. See docs/vendor-sources.md for citations.

Tools

ToolDescription
analyze_cvFull report. Takes a CV file path (PDF or DOCX), returns per-vendor lint findings with severity (error / warn / info) and fixes.
lint_for_vendorSingle-vendor lint. Takes a path + vendor name. Faster when the user only cares about one ATS.
get_express_urlReturns the URL of the visual web companion (cv-mirror-web.vercel.app) for users who prefer a side-by-side parser view in their browser instead of an agent session.

Install

npm install -g cv-mirror-mcp

MCP client config

Add to your MCP client's config file:

Claude Code (~/.claude/mcp.json or .claude.json in project):

{
  "mcpServers": {
    "cv-mirror": {
      "command": "npx",
      "args": ["-y", "cv-mirror-mcp"]
    }
  }
}

Cursor / Windsurf / Zed / Cline: same config format (paste into wherever your client reads mcpServers).

Restart the client. The three tools above auto-register.

Usage

Once installed, just ask your agent:

Scan my CV at ~/Documents/resume.pdf and tell me what each ATS would do to it.

The agent calls analyze_cv, the lint engine runs locally (no network, no upload), and the agent surfaces the structured output:

CV Mirror — multi-vendor ATS lint report
Source: /Users/jane/Documents/resume.pdf
Format: pdf
Pages: 2
Words: 542

[ERROR] Workday
  - ERROR WORKDAY_MULTI_COLUMN: 35% of lines look multi-column. Workday's parser
    reads left-to-right and interleaves both columns into one stream.
    Fix: Convert to single-column layout. Move sidebars (Skills, Tools, Languages)
    above or below the main content.

[OK] Greenhouse
  No issues detected by the simulated parser.

[WARN] Lever
  - WARN LEVER_HEADER_FOOTER: Header/footer-like text detected ("Page 1 of 2").
    Lever historically drops content placed in PDF headers/footers.
    Fix: Remove headers and footers. Page numbers are not needed on a CV.
...

What the lint actually checks

These are real heuristics derived from public ATS docs and vendor support articles. The full list with citations lives in docs/vendor-sources.md.

RuleVendorSeverityTrigger
WORKDAY_MULTI_COLUMNWorkdayerror>15% of lines have a 5+-space gap
WORKDAY_QUARTER_DATESWorkdaywarnDates use "Q3 2024" format
WORKDAY_CONTACT_MISSINGWorkdayerrorNo email or phone in plain text
GREENHOUSE_EMOJIGreenhousewarnAny emoji codepoint detected
GREENHOUSE_FANCY_BULLETSGreenhouseinfoNon-standard bullet glyphs
GREENHOUSE_NONSTANDARD_HEADERGreenhousewarn"My Story", "Highlights Reel", etc.
LEVER_HEADER_FOOTERLeverwarn"Page X of Y" pattern detected
LEVER_NO_STANDARD_HEADERSLevererrorNo "Experience"/"Education" sections
TALEO_ISO_DATESTaleowarnISO dates outnumber Month-Year dates
TALEO_LOW_TEXT_DENSITYTaleoerror<1 word per kB of file size
TALEO_SMART_QUOTESTaleoinfoCurly quotes detected
ICIMS_MULTI_COLUMNiCIMSerror>20% of lines multi-column
ICIMS_FEW_HEADERSiCIMSwarn<2 standard headers found

Requirements

  • Node.js >= 18
  • An MCP-compatible client (Claude Code, Cursor, Windsurf, Zed, Cline, etc.)

Privacy

The server runs locally inside your agent's process. No upload endpoint. No telemetry. Your CV bytes never leave your machine.

The visual web companion at cv-mirror-web.vercel.app is also fully client-side — same engine, runs in the browser.

Tests

git clone https://github.com/goofypluto999/cv-mirror-mcp.git
cd cv-mirror-mcp
npm install
npm test

19 unit tests covering signal extraction and per-vendor rule firing.

How to use with Claude (and other AI agents)

cv-mirror-mcp exposes its three tools to any MCP-compatible agent. The most common workflow:

  1. Install the server: npm install -g cv-mirror-mcp
  2. Add it to your MCP client config (Claude Desktop, Cursor, Windsurf, Zed — see Install above).
  3. In your agent session, ask: "Run cv-mirror on my CV at /path/to/cv.pdf and tell me what Workday and Greenhouse will get wrong."
  4. The agent calls analyze_cv, gets per-vendor lint findings with severity + concrete fixes, and surfaces them.

Once you have a clean CV, you typically need the rest of the application prep — company research, tailored cover letter, fit score, mock interview. Vantage is the paid tool that handles that flow (same team, £5 starter pack, 10 free tokens at signup, no card required for the trial).

The recommended end-to-end flow:

  1. Run cv-mirror-mcp via your agent → fix any parse issues your CV has.
  2. Run Vantage on the same CV plus a specific job URL → get the full prep pack in ~90 seconds.

Sister projects

  • CV Mirror (web) — visual side-by-side parser view. Same lint engine as this MCP server. Drag-drop a PDF, see the reading-order overlay on the actual document. Free, no signup, fully client-side.
  • Vantage — once your CV passes the parsers, the next problem is the actual application: company intelligence, tailored cover letter (4 tones), AI-graded mock interview, CV-vs-role fit score, 5-minute pitch outline. Vantage handles that flow in ~90 seconds per application. £5 starter / 20 tokens (never expire), 10 free tokens at signup. Built by the same team.

Contributing

Pull requests welcome. Particularly interested in:

  • More vendor simulators (BambooHR, SmartRecruiters, JazzHR, Recruitee, etc.)
  • Updated rules when vendors change their parsing behaviour (open an issue with the source link)
  • Translations of the lint output

License

MIT. Workday, Greenhouse, Lever, Taleo, and iCIMS are trademarks of their respective owners. This project is not affiliated with any of them; the names are used for descriptive reference (nominative fair use).

Built by Vantage Labs.

Server Config

{
  "mcpServers": {
    "cv-mirror": {
      "command": "npx",
      "args": [
        "-y",
        "cv-mirror-mcp"
      ]
    }
  }
}
Recommend Servers
TraeBuild with Free GPT-4.1 & Claude 3.7. Fully MCP-Ready.
AiimagemultistyleA Model Context Protocol (MCP) server for image generation and manipulation using fal.ai's Stable Diffusion model.
EdgeOne Pages MCPAn MCP service designed for deploying HTML content to EdgeOne Pages and obtaining an accessible public URL.
DeepChatYour AI Partner on Desktop
MCP AdvisorMCP Advisor & Installation - Use the right MCP server for your needs
Tavily Mcp
MiniMax MCPOfficial MiniMax Model Context Protocol (MCP) server that enables interaction with powerful Text to Speech, image generation and video generation APIs.
Baidu Map百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Serper MCP ServerA Serper MCP Server
Howtocook Mcp基于Anduin2017 / HowToCook (程序员在家做饭指南)的mcp server,帮你推荐菜谱、规划膳食,解决“今天吃什么“的世纪难题; Based on Anduin2017/HowToCook (Programmer's Guide to Cooking at Home), MCP Server helps you recommend recipes, plan meals, and solve the century old problem of "what to eat today"
Playwright McpPlaywright MCP server
WindsurfThe new purpose-built IDE to harness magic
BlenderBlenderMCP connects Blender to Claude AI through the Model Context Protocol (MCP), allowing Claude to directly interact with and control Blender. This integration enables prompt assisted 3D modeling, scene creation, and manipulation.
RedisA Model Context Protocol server that provides access to Redis databases. This server enables LLMs to interact with Redis key-value stores through a set of standardized tools.
Amap Maps高德地图官方 MCP Server
Zhipu Web SearchZhipu Web Search MCP Server is a search engine specifically designed for large models. It integrates four search engines, allowing users to flexibly compare and switch between them. Building upon the web crawling and ranking capabilities of traditional search engines, it enhances intent recognition capabilities, returning results more suitable for large model processing (such as webpage titles, URLs, summaries, site names, site icons, etc.). This helps AI applications achieve "dynamic knowledge acquisition" and "precise scenario adaptation" capabilities.
Jina AI MCP ToolsA Model Context Protocol (MCP) server that integrates with Jina AI Search Foundation APIs.
CursorThe AI Code Editor
Visual Studio Code - Open Source ("Code - OSS")Visual Studio Code
ChatWiseThe second fastest AI chatbot™
Y GuiA web-based graphical interface for AI chat interactions with support for multiple AI models and MCP (Model Context Protocol) servers.