cv-mirror-mcp
cv-mirror-mcp
5개의 실제 ATS 파서를 기준으로 이력서를 린트(lint)하는 모델 컨텍스트 프로토콜(MCP) 서버입니다.
기능
3개의 MCP 도구를 노출하여 MCP 호환 AI 에이전트(Claude Code, Cursor, Windsurf, Zed, OpenCode, Cline 등)가 다음 ATS의 문서화된 특성에 맞춰 이력서를 분석할 수 있도록 합니다:
Workday
Greenhouse
Lever
Taleo (Oracle)
iCIMS
이들은 가장 많이 사용되는 5가지 엔터프라이즈 ATS 시스템입니다. 각 시스템은 이력서를 조금씩 다르게 파싱합니다. "0–100 ATS 점수"는 이러한 차이를 평균 내어 노이즈로 만듭니다. 이 서버는 열 처리, 이모지 제거, 머리글/바닥글 삭제, 날짜 형식 특성 등 각 시스템이 실제로 수행하는 작업을 구체적인 린트 결과와 해결책으로 제시합니다.
린트 규칙은 공개된 벤더 문서를 기반으로 합니다. 출처는 docs/vendor-sources.md를 참조하세요.
도구
도구 | 설명 |
| 전체 보고서. 이력서 파일 경로(PDF 또는 DOCX)를 입력받아 벤더별 린트 결과(심각도 |
| 단일 벤더 린트. 경로와 벤더 이름을 입력받습니다. 사용자가 특정 ATS 하나만 신경 쓸 때 더 빠릅니다. |
| 에이전트 세션 대신 브라우저에서 나란히 파서 뷰를 보길 원하는 사용자를 위해 시각적 웹 컴패니언(cv-mirror-web.vercel.app)의 URL을 반환합니다. |
설치
npm (권장)
npm install -g cv-mirror-mcpMCP 클라이언트 설정
MCP 클라이언트의 설정 파일에 추가하세요:
Claude Code (~/.claude/mcp.json 또는 프로젝트 내 .claude.json):
{
"mcpServers": {
"cv-mirror": {
"command": "npx",
"args": ["-y", "cv-mirror-mcp"]
}
}
}Cursor / Windsurf / Zed / Cline: 동일한 설정 형식 (mcpServers를 읽는 곳에 붙여넣기).
클라이언트를 재시작하세요. 위의 세 가지 도구가 자동으로 등록됩니다.
사용법
설치 후 에이전트에게 다음과 같이 요청하세요:
~/Documents/resume.pdf에 있는 내 이력서를 스캔해서 각 ATS가 어떻게 처리할지 알려줘.
에이전트가 analyze_cv를 호출하면 린트 엔진이 로컬에서 실행(네트워크 없음, 업로드 없음)되고, 에이전트가 구조화된 출력을 보여줍니다:
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.
...린트 검사 항목
이 항목들은 실제 ATS 문서와 벤더 지원 문서를 기반으로 한 휴리스틱입니다. 출처가 포함된 전체 목록은 docs/vendor-sources.md에 있습니다.
규칙 | 벤더 | 심각도 | 트리거 |
| Workday | error | 줄의 15% 이상이 5칸 이상의 간격을 가짐 |
| Workday | warn | 날짜가 "Q3 2024" 형식을 사용함 |
| Workday | error | 일반 텍스트에 이메일이나 전화번호가 없음 |
| Greenhouse | warn | 이모지 코드 포인트가 감지됨 |
| Greenhouse | info | 표준이 아닌 글머리 기호 |
| Greenhouse | warn | "My Story", "Highlights Reel" 등 |
| Lever | warn | "Page X of Y" 패턴 감지 |
| Lever | error | "Experience"/"Education" 섹션 없음 |
| Taleo | warn | ISO 날짜가 월-년 날짜보다 많음 |
| Taleo | error | 파일 크기 kB당 단어 수 1개 미만 |
| Taleo | info | 스마트 따옴표 감지 |
| iCIMS | error | 줄의 20% 이상이 다단 구성 |
| iCIMS | warn | 표준 헤더 2개 미만 발견 |
요구 사항
Node.js >= 18
MCP 호환 클라이언트 (Claude Code, Cursor, Windsurf, Zed, Cline 등)
개인정보 보호
이 서버는 에이전트 프로세스 내부에서 로컬로 실행됩니다. 업로드 엔드포인트가 없으며 텔레메트리도 없습니다. 이력서 데이터는 절대 기기를 벗어나지 않습니다.
cv-mirror-web.vercel.app의 시각적 웹 컴패니언 또한 완전히 클라이언트 측에서 작동하며, 동일한 엔진이 브라우저에서 실행됩니다.
테스트
git clone https://github.com/goofypluto999/cv-mirror-mcp.git
cd cv-mirror-mcp
npm install
npm test신호 추출 및 벤더별 규칙 실행을 다루는 19개의 단위 테스트가 포함되어 있습니다.
관련 프로젝트
CV Mirror (web) — 시각적 나란히 파서 뷰. 동일한 린트 엔진 사용. PDF를 드래그 앤 드롭하여 실제 문서의 읽기 순서 오버레이를 확인하세요.
Vantage AI — 이력서가 파서를 통과한 후, 다음 단계는 지원입니다: 맞춤형 자기소개서, 모의 면접, 적합성 분석. Vantage가 해당 흐름을 처리합니다. 유료 (£5 스타터 / 20 토큰, 가입 시 10 무료 토큰 제공).
기여
풀 리퀘스트를 환영합니다. 특히 다음 사항에 관심이 있습니다:
더 많은 벤더 시뮬레이터 (BambooHR, SmartRecruiters, JazzHR, Recruitee 등)
벤더의 파싱 동작 변경 시 업데이트된 규칙 (출처 링크와 함께 이슈 생성)
린트 출력 번역
라이선스
MIT. Workday, Greenhouse, Lever, Taleo 및 iCIMS는 각 소유자의 상표입니다. 이 프로젝트는 해당 기업들과 관련이 없으며, 이름은 설명적 참조(명칭적 공정 사용)를 위해 사용되었습니다.
Vantage Labs 제작.
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/goofypluto999/cv-mirror-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server