JobHound
Connects to Greenhouse job board API to fetch, score, and apply to job listings.
Connects to Wellfound (formerly AngelList) to fetch job listings for scoring and application.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@JobHoundscan for new remote backend jobs"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
JobHound ๐
MCP server that lets Claude Code scan, score, and apply to jobs autonomously.
JobHound connects directly to Ashby, Greenhouse, and Lever job board APIs โ no browser required for discovery. It scores every listing with a keyword heuristic, queues high-scoring roles, and uses Claude Code as the tailor to write per-role CVs and cover letters.
Includes a TUI dashboard for tracking your pipeline in real time.
Table of Contents
Why I Built This
Job searching is miserable. LinkedIn Easy Apply is a black hole โ you click apply, it goes nowhere, you never hear back. Premium job alerts cost money and send you garbage. Manually browsing 5 job boards daily is a part-time job in itself.
The APIs are free. Ashby, Greenhouse, Lever โ they all have public APIs that list every open role. Why am I manually scrolling?
JobHound exists because my agent should handle job discovery, not me. It scans APIs, scores listings against my skills and preferences, queues the good ones, and hands the tailoring work to Claude Code. I review the generated CV and cover letter, say yes or no, and it submits.
The TUI exists because I want to see my pipeline at a glance โ 47 tracked, 3 queued, 12 applied, 2 interviewing โ without opening a browser tab.
What It Does
Feature | What It Does |
Scan | Fetches from Ashby, Greenhouse, Lever, RemoteOK, HN Hiring, Wellfound |
Score | Keyword heuristic matches job description against your skills and preferences |
Queue | High-scoring roles enter a queue for review |
Tailor | Exposes job + your resume to Claude Code for per-role CV and cover letter generation |
Apply | Submits tailored applications via API where supported |
Track | SQLite-backed pipeline tracking with status (new โ queued โ applied โ interviewing โ rejected) |
Dashboard | Real-time TUI with live updates every 30 seconds |
Daemon | Background scan loop runs on a schedule |
Current Pain Points
These are the battles I'm actively fighting:
Keyword scoring is crude โ It's a heuristic: count keyword matches between job description and your config. It doesn't understand that "React" and "frontend" are related, or that "5 years experience" in a job description is flexible. A real scoring model would learn from what you actually applied to and got interviews for.
Not every board has an API โ RemoteOK and HN Hiring require scraping. Scraping breaks when they change their HTML. The browser automation layer (
playwright-stealth) is overkill for simple HTML scraping but necessary because some sites block basic requests.Auto-apply is limited โ Ashby and some Greenhouse instances support direct API application. Most don't. For those, JobHound generates the tailored docs and you apply manually. The "autonomous" part stops at "here's your CV and cover letter, go submit it."
The TUI is Textual-dependent โ Textual is great but heavy. On a slow terminal or over SSH it can lag. The dashboard is pretty but not essential โ the core value is the MCP server and scan queue.
Config management is manual โ
config.yamlneeds your skills, preferences, API keys for each source. Updating it is editing YAML. I want the agent to infer my skills from my GitHub repos and update the config automatically.No integration with Grayson โ Grayson is my outreach automation tool (cold emails, networking). JobHound finds the jobs, Grayson finds the people. They don't talk to each other. A warm referral beats a cold application.
End Goals โ Where This Is Headed
Short Term (now โ 3 months)
Better scoring โ move from keyword heuristic to embedding-based semantic similarity
Auto-config from GitHub โ read my repos, infer my stack, auto-populate config.yaml
Per-source rate limit handling โ respect Ashby/Greenhouse rate limits, back off gracefully
Medium Term (3โ6 months)
Grayson integration โ for every queued job, Grayson finds a mutual connection or relevant person to reach out to
Unified agent pipeline โ Blackreach researches the company, Huginn scrapes their blog/docs, JobHound scores the role, Grayson finds the contact, all in one workflow
Auto-apply expansion โ support more application flows (Lever API, custom forms)
Long Term (6โ12 months)
Fully autonomous job search โ "Find me senior backend roles at AI startups in Toronto, apply to the top 10, network with hiring managers, track everything"
Interview prep integration โ after an application, auto-research the company, generate likely interview questions, prepare answers
Salary negotiation assistant โ track market data, suggest negotiation strategies based on role/company/location
Install
git clone https://github.com/Null-Phnix/jobhound
cd jobhound
pip install -e .
cp config.example.yaml config.yaml # fill in your detailsConnect to Claude Code
Add to your ~/.claude/settings.json (or .claude/settings.json in the project):
{
"mcpServers": {
"jobhound": {
"type": "stdio",
"command": "jobhound-server"
}
}
}MCP Tools
Tool | Description |
| Fetch all sources, score jobs, queue high-scoring ones |
| List jobs by status (queued, applied, failed, etc.) |
| Full job details + generated docs |
| Job description + your resume for Claude to tailor |
| Submit a tailored application |
| Manually set status (interviewing, rejected) |
| Pause the daemon scan loop |
| Resume the daemon scan loop |
Workflow
jobhound_scan() # find what's new
jobhound_list("queued") # see what's waiting
jobhound_get_for_tailoring(42) # get job + resume
[Claude writes tailored CV + letter]
jobhound_apply_tailored(42, cv, letter) # submit + recordTUI Dashboard
jobhound-tuiLive two-pane view of your entire job pipeline. Polls SQLite every 30 seconds, shows status by color.
โโ JobHound โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ [LIVE] 47 tracked ยท 3 queued ยท 12 applied ยท 2 interviewing โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโฌโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โถ Bree applied โ Bree โ Software Engineer, Backend โ
โ Modal applied โ Applied: 2026-03-11 via Ashby โ
โ LangChain applied โ Score: 87/100 โ
โ Cohere queued โ Method: direct POST โ
โ Anthropic new โ โ
โ Cursor failed โ Cover Letter: โ
โ โ > The line that stood out in your... โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ [s]can [p]ause [f]ilter [o]pen URL [x]export [q]uit โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโTUI Keybinds
Key | Action |
| Scan sources (fetch + score, no auto-apply) |
| Pause / resume daemon |
| Cycle filter: all โ new โ queued โ applied โ failed โ interviewing |
| Open highlighted job URL in browser |
| Export current view to |
| Quit |
Config
See config.example.yaml. Supports Ashby, Greenhouse, Lever, RemoteOK, HN Hiring, and Wellfound.
Stack
Python 3.11+
fastmcpโ MCP serverhttpxโ source API callssqlite3โ job trackingtextualโ TUI dashboardrichโ terminal output
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/Null-Phnix/jobhound'
If you have feedback or need assistance with the MCP directory API, please join our Discord server