MCP Hub
Back to servers

Ashby MCP Server

Connects Claude to the Ashby ATS to manage the hiring pipeline through natural conversation. It enables users to browse jobs, manage candidate profiles, track applications, and coordinate interview stages.

glama
Updated
Mar 19, 2026

Ashby MCP Server

A Model Context Protocol (MCP) server that connects Claude to your Ashby ATS. Browse jobs, manage candidates, track applications through your hiring pipeline, and more — all through natural conversation.

Prerequisites

Setup

1. Install uv

If you don't already have uv installed:

# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# macOS via Homebrew
brew install uv

After installing, find the absolute path to the uvx command (you'll need this for the config):

which uvx

This will return something like /Users/yourname/.local/bin/uvx. Keep this path handy.

2. Get your Ashby API key

Go to https://app.ashbyhq.com/admin/api/keys and create a new API key. Make sure it has at least:

  • candidatesRead
  • jobsRead
  • candidatesWrite (if you want to create candidates, add notes, or move applications)

3. Configure Claude Desktop

Open your Claude Desktop config file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

Add the following to the mcpServers section, replacing the placeholders with your actual values:

{
  "mcpServers": {
    "ashby": {
      "command": "/absolute/path/to/uvx",
      "args": [
        "--from", "git+https://github.com/PlenishAI/mcp-ashby.git",
        "ashby"
      ],
      "env": {
        "ASHBY_API_KEY": "your-ashby-api-key"
      }
    }
  }
}

Important: Replace /absolute/path/to/uvx with the output from which uvx (e.g. /Users/yourname/.local/bin/uvx). Claude Desktop does not inherit your shell's PATH, so the full path is required.

4. Restart Claude Desktop

Quit and reopen Claude Desktop. The Ashby server should connect automatically. You can verify by asking Claude something like "list my open jobs in Ashby."

Alternative: Local Clone Setup

If the git+ URL method doesn't work (e.g. private repo or network restrictions), you can clone the repo locally:

git clone https://github.com/PlenishAi/mcp-ashby.git ~/projects/mcp-ashby

Then use uv (not uvx) in your config, pointing to the local directory:

{
  "mcpServers": {
    "ashby": {
      "command": "/absolute/path/to/uv",
      "args": [
        "--directory", "/absolute/path/to/mcp-ashby",
        "run", "ashby"
      ],
      "env": {
        "ASHBY_API_KEY": "your-ashby-api-key"
      }
    }
  }
}

Note: When using a local clone, run which uv to get the path — the command is uv, not uvx.

To update, just git pull from the repo directory.

Available Tools

Jobs

ToolDescription
job_listList all jobs with optional status filter (Draft, Open, Closed, Archived)
job_infoGet details of a single job by ID
job_searchSearch jobs by title

Candidates

ToolDescription
candidate_listList all candidates with cursor pagination
candidate_searchSearch candidates by email and/or name
candidate_infoGet full details of a candidate by ID
candidate_createCreate a new candidate
candidate_create_noteAdd an HTML-formatted note to a candidate
candidate_list_notesList all notes for a candidate
candidate_add_tagAdd a tag to a candidate
candidate_tag_listList all available candidate tags

Applications

ToolDescription
application_listList applications with optional jobId, status, and date filters
application_infoGet full details of an application by ID
application_createCreate an application linking a candidate to a job
application_change_stageMove an application to a different interview stage

Interviews & Pipeline

ToolDescription
interview_stage_listList interview stages for a given interview plan
interview_plan_listList all interview plans
interview_listList all interviews with cursor pagination
interview_infoGet details of a single interview by ID

Reference Data

ToolDescription
department_listList all departments
user_listList all users (team members)
source_listList all candidate sources
archive_reason_listList all archive reasons
location_listList all locations

Troubleshooting

"No such file or directory" on startup

Claude Desktop can't find uvx. Make sure you're using the full absolute path from which uvx in your config, not just "uvx".

"Package not found in registry"

If you see a PyPI resolution error, make sure the --from argument uses the git+https:// URL, not a package name.

"module has no attribute 'run_async'"

You're running an older version of the server code against a newer MCP SDK. Pull the latest version of this repo.

API errors (401/403)

Your Ashby API key is missing or doesn't have the required permissions. Verify it at https://app.ashbyhq.com/admin/api/keys.

API Reference

This server communicates with the Ashby REST API:

  • Base URL: https://api.ashbyhq.com
  • Auth: Basic Auth (API key as username, empty password)
  • Method: All endpoints are POST with JSON bodies
  • Pagination: Cursor-based (moreDataAvailable + nextCursor)

License

MIT

Reviews

No reviews yet

Sign in to write a review