JobScannerMCP
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., "@JobScannerMCPFind senior software engineer jobs and score my fit for each."
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.
JobScannerMCP
One MCP server, any host. A Model Context Protocol server that exposes a job-posting scanner as clean, typed tools — then drives the unmodified server from two different agent hosts (Claude and Goose) to show that MCP is a portability layer, not a buzzword.
What this is: a small, working FastMCP server (search jobs, check scan health, score fit, draft outreach) with a built-in guardrail — plus the config to run it from Claude Code and a validated Goose recipe. Build the tools once; any MCP host can use them.
What this is not: a live scraper or a product. It serves synthetic sample data so it runs offline with no keys and no private code.
Why I built it
"MCP" gets said a lot; far fewer people have actually built a server and consumed it from more than one host. I wanted a concrete artifact that shows the whole loop — clean tool schemas, a governance guardrail, and genuine host-portability — on a domain I know (a job scanner). The payoff is "build once, integrate everywhere": the same four tools work in Claude, Goose, Cursor, or anything that speaks MCP.
(Clean-room + synthetic data only — no real résumé, no private scanner code, no credentials.)
Related MCP server: trackly-cli
The idea in one picture
┌─────────────────────────────┐
Claude Code ───▶│ │
(MCP client) │ job-scanner (FastMCP) │
│ │
Goose ───▶│ tools: search_jobs │──▶ synthetic
(recipe) │ get_company_health │ postings +
│ score_fit │ company health
│ draft_outreach 🔒 │ (offline, no keys)
│ resource: companies://… │
└─────────────────────────────┘
two hosts, ONE unmodified server 🔒 = dry-run guardrail (never sends)Quickstart (no API key)
git clone https://github.com/singhalpooja9/JobScannerMCP
cd JobScannerMCP
pip install -e ".[dev]"
pytest -q # 8 in-memory MCP tests, fully offline
python -m jobscanner.server # run the server over stdioThe tools
Tool | What it does | Notes |
| keyword search over postings | read-only |
| per-company scan status (ok/blocked/…) | explains why a company returned nothing |
| 0–100 fit + label for a posting | deterministic heuristic; for a calibrated LLM judge see JobFitJudge |
| drafts a note — | 🔒 the guardrail: the server cannot send |
Plus an MCP resource (companies://registry) and a reusable prompt (find_roles).
The guardrail (governance by design)
draft_outreach is the only "write-ish" tool, and it is dry-run only — it returns a
draft with sent: false and never has a code path that sends. A host (or a hijacked
prompt) cannot make this server take a real-world action. That "the server enforces
safety, not the prompt" stance is the governance point, and it's covered by a test.
Run it from two hosts
Host 1 — Claude Code / Claude Desktop
Add the server from recipes/claude_mcp_config.json
to your MCP config (set the absolute path to your clone), then ask Claude:
"Use search_jobs to find conversational-AI roles, score each with score_fit, and summarize the good ones."
Host 2 — Goose
The same server, wired into a validated Goose recipe
(recipes/find_roles.yaml):
goose recipe validate recipes/find_roles.yaml # ✓ recipe file is valid
goose run --recipe recipes/find_roles.yaml --params keywords="conversational AI"
goose recipe deeplink recipes/find_roles.yaml # shareable linkSame tools, two hosts, zero server changes — that's the whole point.
Use it for your own scanner / data
Point the tools at your own postings — no code changes:
Replace
data/postings.jsonl(one JSON posting per line:id, company, title, descriptionrequired;location, department, remote, urloptional).Replace
data/companies.yamlwith your company/health list.Restart the server. Both hosts pick up the new data automatically.
To swap the naive score_fit heuristic for a real, calibrated LLM judge, drop in the
companion project JobFitJudge.
What this repo demonstrates (concepts + stack)
Concept | Where it lives |
MCP server (tools + resource + prompt, typed schemas) |
|
MCP client / host portability |
|
Guardrails / safe-by-design tools |
|
Tool schema design | typed args + docstrings the model reads |
In-memory protocol testing |
|
Structured responses | Pydantic models + Goose recipe |
Offline-first / deterministic CI | synthetic data, green with zero API keys |
Stack: Python · FastMCP (Model Context Protocol) · Pydantic · PyYAML · pytest + pytest-asyncio · GitHub Actions · Goose recipe · Claude MCP config.
Project layout
jobscanner/
server.py # the FastMCP server: 4 tools + 1 resource + 1 prompt + guardrail
store.py # load synthetic postings + company health (offline)
fit.py # deterministic fit heuristic (swap for JobFitJudge's LLM judge)
models.py # Job + CompanyHealth (Pydantic)
data/
postings.jsonl # synthetic postings (REPLACE with your own)
companies.yaml # synthetic company/health registry
recipes/
claude_mcp_config.json # Host 1: Claude Code / Desktop MCP config
find_roles.yaml # Host 2: validated Goose recipe
tests/ # 8 offline in-memory MCP testsHonest scope & limitations
Working MCP server, not a product. Synthetic data, no live scraping, no auth.
score_fitis a naive keyword heuristic — deliberately, so this repo stays about the protocol layer. Rigorous fit scoring lives in the companion JobFitJudge repo.All shipped data is synthetic. No real résumé, no private code, no credentials.
Part of a larger series
Repo 2 of a small set exploring the agentic-AI ecosystem hands-on — evaluation (JobFitJudge), MCP (this repo), multi-agent orchestration, RAG, and spec-driven development. More at singhalpooja.com.
Built by Pooja Singhal — Senior Technical Program Manager.
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/singhalpooja9/JobScannerMCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server