MCP Recruitment Pipeline
Turns a recruitment database into an AI-queryable pipeline, enabling natural language queries to search contractors, build shortlists, draft outreach, and book engagements.
README
MCP Recruitment Pipeline — Proof of Concept
An MCP server that turns a recruitment database into an AI-queryable pipeline. Instead of clicking through dashboards and writing filters, you ask Claude plain-English questions and it searches contractors, builds shortlists, drafts outreach, and books engagements — all through structured tool calls against a live PostgreSQL database. Built to demonstrate how service businesses can make their methodology accessible through Claude. Built by HelloCrossman.
What It Does
19 MCP tools that cover the full contractor recruitment lifecycle. Connect Claude to your database and ask:
- "Show me available contractors in London with ISO 27001 under £600/day"
- "What open jobs do we have that are marked as urgent?"
- "Find matching contractors for the FinConnect pen testing role"
- "Create a shortlist for the Meridian Bank compliance audit"
- "Draft outreach for the top candidates — mention their PCI DSS experience"
- "Book Sarah Chen for the senior auditor role at £575/day"
- "Give me a full pipeline overview"
- "Generate a PDF comparison of these three candidates"
Claude calls the right tools, chains them together, and handles the workflow end-to-end.
Screenshots
See the /screenshots directory for examples of Claude Desktop interacting with the server.
Architecture
Claude Desktop / Claude.ai
│
▼
MCP Server (Express.js)
├── Streamable HTTP POST /mcp
└── SSE GET /sse
│
▼
PostgreSQL
├── contractors (50 enriched profiles)
├── jobs (10 open roles)
├── shortlists + shortlist_items
├── engagements
└── outreach_drafts
Stack: TypeScript · Node.js 20 · @modelcontextprotocol/sdk · Express · PostgreSQL · PDFKit · Google OAuth 2.1 · Vitest
MCP Tools
| Tool | What it does | Key parameters |
|---|---|---|
search_contractors |
Search by location, skills, certs, rate, clearance, free text | query, location, availability, certifications, skills, sector, max_rate, min_experience, clearance, limit |
get_contractor |
Full profile by ID | id |
get_contractor_cv |
Complete CV: work history, education, projects, languages | id |
list_jobs |
List open roles with filters | status, sector, urgency, location, limit |
get_job |
Full job details by ID | id |
find_matching_contractors |
Auto-match contractors to a job's requirements | job_id, limit |
update_job_status |
Move job through pipeline stages | id, status |
create_shortlist |
Create a named shortlist for a role | name, description, role_title, client_name |
add_to_shortlist |
Add contractor to shortlist with notes | shortlist_id, contractor_id, notes |
get_shortlist |
View shortlist with all candidates | id |
list_shortlists |
List all shortlists | status |
update_candidate_status |
Track candidate through pipeline | shortlist_id, contractor_id, status |
draft_outreach |
Save a personalised outreach email | contractor_id, shortlist_id, subject, body |
list_outreach |
View outreach drafts | contractor_id, status |
book_contractor |
Book contractor for a role | contractor_id, role_title, client_name, start_date, end_date, agreed_rate |
get_pipeline |
Full recruitment pipeline overview | — |
generate_contractor_pdf |
PDF report with full contractor CV | contractor_id |
generate_shortlist_pdf |
PDF report of a shortlist | shortlist_id |
generate_comparison_pdf |
Side-by-side PDF comparing 2–10 contractors | contractor_ids |
Quick Start
# 1. Clone the repo
git clone https://github.com/hellocrossman/mcp-recruitment-pipeline.git
cd mcp-recruitment-pipeline
# 2. Install dependencies
npm install
# 3. Set up PostgreSQL
# Create a database and note the connection string.
# On Replit, this is handled automatically.
# 4. Configure environment variables
cp .env.example .env
# Edit .env with your DATABASE_URL and auth settings
# 5. Run database migrations
npm run migrate
# 6. Seed the database with sample data
npm run seed
# 7. Start the server
npm run dev
The server starts on port 5000 with 50 contractor profiles and 10 open roles.
Connect to Claude
Claude Desktop (SSE)
Add to your Claude Desktop MCP config (claude_desktop_config.json):
{
"mcpServers": {
"recruitment": {
"url": "https://your-deployment-url/sse",
"headers": {
"Authorization": "Bearer YOUR_MCP_API_KEY"
}
}
}
}
Claude.ai (Streamable HTTP)
In Claude.ai settings, add a custom MCP connector:
- URL:
https://your-deployment-url/mcp - Auth: Bearer token (your
MCP_API_KEY)
Make It Your Own
This is a proof of concept — the structure is designed to be forked and adapted to any service domain. Key steps:
-
Define your data model. Replace
contractorswith your domain entities (candidates, properties, products, inventory). Update the migration files inmigrations/and the schema insrc/db.ts. -
Update the seed data. Edit
src/seed.tswith realistic records for your domain. The current 50 contractor profiles show the level of enrichment that makes AI interactions useful. -
Modify the tool handlers. Each function in
src/tools.tsmaps to one MCP tool. Rename them, change the query logic, add new tools. The pattern is always: validate input → build parameterised query → return structured result. -
Deploy. Push to Replit, Railway, Fly.io, or any Node.js host with PostgreSQL access.
Project Structure
src/
index.ts Entry point — Express server, 19 MCP tool registrations
types.ts Shared TypeScript interfaces and constants
db.ts Database pool and schema initialization
auth.ts Google OAuth + API key middleware
tools.ts Query builders for all 16 data tools
pdf.ts PDF report generators (contractor CV, shortlist, comparison)
seed.ts 50 contractor profiles + 10 sample jobs
migrations/ Numbered SQL migration files
scripts/ Utility scripts (migrate runner)
__tests__/ 111 tests (unit + integration)
Environment Variables
| Variable | Required | Description |
|---|---|---|
DATABASE_URL |
Yes | PostgreSQL connection string |
PORT |
No | Server port (default: 5000) |
GOOGLE_CLIENT_ID |
No | Google OAuth client ID for token verification |
MCP_API_KEY |
No | API key for direct access without OAuth |
At least one auth method (GOOGLE_CLIENT_ID or MCP_API_KEY) is recommended for production.
Running Tests
npm test # Run all 111 tests
npm run test:coverage # Run with coverage report
npm run test:watch # Watch mode during development
npm run lint # Type-check without emitting
Coverage: 100% on tool handlers, 90%+ on auth, 95%+ on database layer. Tests include unit tests with mocked DB, integration tests against real PostgreSQL, and edge cases for invalid inputs and SQL injection attempts.
License
MIT — see LICENSE.
Built By
HelloCrossman — We turn service businesses into agentic software.
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。