Lever ATS MCP Server
Integrates Lever ATS with Claude Desktop to manage hiring pipelines through natural language, offering tools for candidate search, pipeline management, file and application handling, and advanced sourcing.
README
Lever ATS MCP Server
An MCP (Model Context Protocol) server that integrates Lever ATS with Claude Desktop, enabling recruiters to manage their hiring pipeline through natural language conversations.
Features
This MCP server provides the following tools for Claude Desktop:
Core Tools
- lever_search_candidates - Search for candidates by query, stage, etc.
- lever_get_candidate - Get detailed information about a specific candidate
- lever_add_note - Add notes to candidate profiles
- lever_list_open_roles - List all published job postings
- lever_find_candidates_for_role - Find candidates for a specific role
- lever_archive_candidate - Archive candidates with reasons
- lever_get_stages - Get all available pipeline stages
- lever_get_archive_reasons - Get all archive reasons
Advanced Search & Sourcing Tools 🔍
- lever_advanced_search - Multi-criteria search (companies, skills, locations, tags)
- lever_find_by_company - Source candidates from specific companies
- lever_find_internal_referrals_for_role - Find employees who can refer for a role
File Management Tools 📄
- lever_list_files - List all files attached to a candidate (shows filename, type, size)
Application Management Tools 📋
- lever_list_applications - List all applications for a candidate
- lever_get_application - Get specific application details
- lever_create_application - Apply candidate to a job posting
Prerequisites
- Python 3.8+
- Lever API key (get from Lever Settings > Integrations > API)
- Claude Desktop installed
Installation
- Clone or download this repository:
git clone https://github.com/yourusername/lever-mcp-server.git
cd lever-mcp-server
- Create a virtual environment (recommended):
python -m venv venv
source venv/bin/activate # On macOS/Linux
# or
venv\Scripts\activate # On Windows
- Install dependencies:
pip install -r requirements.txt
- Create
.envfile from the example:
cp .env.example .env
Note: The .env file should be in the project root directory, not in the mcp/ subdirectory.
- Add your Lever API key to
.env:
LEVER_API_KEY=your_actual_api_key_here
Claude Desktop Configuration
-
Open Claude Desktop configuration file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
- macOS:
-
Add the Lever MCP server configuration:
{
"mcpServers": {
"lever-ats": {
"command": "/path/to/your/venv/bin/python",
"args": ["/Users/sid.dani/Desktop/4. Coding Projects/lever mcp - claude code/mcp/server.py"],
"env": {
"LEVER_API_KEY": "your_lever_api_key_here"
}
}
}
}
Important: Update the paths:
- Replace
/path/to/your/venv/bin/pythonwith the actual path to your Python executable - If using system Python, you can use
python3or the full path
- Restart Claude Desktop
Usage Examples
Once configured, you can use natural language in Claude Desktop:
Basic Searching
- "Search for senior engineers"
- "Find candidates from Google or Meta"
- "Show me candidates in the phone screen stage"
- "Quick find John Smith" (fast search for specific person)
- "Quick find jane@example.com" (email-based quick search)
Advanced Search & Sourcing
- "Use advanced search to find Python developers from Google or Meta in San Francisco"
- "Search for candidates with skills: React, TypeScript, Node.js"
- "Find senior level candidates with AWS and Python experience"
- "Search candidates in London with remote work option"
- "Find candidates from companies: Google, Meta, Apple"
- "Find similar candidates to opportunity ID abc123"
- "Who can refer candidates for the Workplace Experience Manager role?"
Managing Pipeline
- "Get details for candidate [opportunity_id]"
- "Add a note to candidate [opportunity_id]: Great technical skills"
Viewing Roles and Pipeline
- "List all open roles"
- "Show candidates for posting [posting_id]"
- "What stages are available?"
Archiving
- "Get archive reasons"
- "Archive candidate [opportunity_id] with reason [reason_id]"
File Management
- "List all files for candidate [opportunity_id]"
Application Management
- "List all applications for candidate [opportunity_id]"
- "Get application details [application_id] for candidate [opportunity_id]"
- "Apply candidate [opportunity_id] to posting [posting_id]"
Important: Search Limitations
Name Search Constraints
The Lever API does not support text search queries. When searching by name:
- The tool fetches candidates and filters locally
- Search is limited to first 500 candidates to prevent timeouts
- Results may be incomplete for common names
Best Practices for Finding Candidates
-
Use email search when possible - Most reliable method
- "Search for john.doe@example.com"
- "Find candidate with email jane@company.com"
-
Use the quick find tool for individual candidates
- "Quick find Svetlana Krockova"
- "Quick find john@example.com"
- Limited to first 300 candidates but faster
-
Use tags and stages to narrow search
- "Find candidates tagged 'senior' in 'phone screen' stage"
- "Search 'new applicant' stage for recent candidates"
-
For company searches, use dedicated tools
- "Find candidates from Google"
- "Filter by companies Microsoft, Apple"
Troubleshooting
MCP Server Not Showing in Claude
- Check that the config file is valid JSON
- Ensure all paths are absolute paths
- Restart Claude Desktop completely
API Errors
- Verify your API key is correct
- Check Lever API permissions
- Ensure you're not hitting rate limits
Search Not Finding Candidates
- Try using email instead of name
- Use lever_quick_find_candidate for faster results
- Check if candidate might be archived
- Ensure exact spelling of names
Finding IDs
- Opportunity IDs are shown in search results
- Stage IDs can be found using
lever_get_stages - Posting IDs are shown in
lever_list_open_roles - Archive reason IDs are shown in
lever_get_archive_reasons
Development
To modify or extend the server:
- The main server logic is in
server.py - API client with rate limiting is in
client.py - Add new tools by creating new
@mcp.tool()decorated functions - Follow the existing pattern for error handling and response formatting
Rate Limiting
The server implements rate limiting at 8 requests/second (below Lever's 10 req/sec limit) to ensure reliable operation.
Security
- Never commit your
.envfile - Keep your API key secure
- The server only has access to what your Lever API key permits
Support
For issues with:
- Lever API: Check Lever API Documentation
- MCP Protocol: See MCP Documentation
- This server: Check the error messages in Claude Desktop
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.