AI-powered job search pipeline built on opencode. Evaluate offers, generate tailored CVs, scan portals, negotiate offers, and track everything -- powered by AI agents.
Paste a job URL. Get a scored evaluation, tailored CV, and tracked application â in seconds.
npx --package=job-forge create-job-forge my-job-search
cd my-job-search
npm install
opencodeThe scaffolded opencode.json already has the Geometra MCP (browser automation + PDF) and Gmail MCP (reading replies) wired up â they launch automatically the first time opencode starts. npm install also materializes symlinks for every supported agent harness â OpenCode, Cursor, Claude Code, and Codex â so you can run opencode, cursor, claude, or codex in the same project and each picks up the shared MCP config and instructions.
Then fill in cv.md, config/profile.yml, and portals.yml with your personal data, paste a job URL into opencode, and JobForge evaluates + tracks it.
Upgrade later: npm run update-harness (pulls latest job-forge from npm, re-syncs symlinks, prints the resolved version)
Full setup guide and alternative install paths (including contributing to the harness itself): docs/SETUP.md.
JobForge turns opencode into a full job search command center. Instead of manually tracking applications in a spreadsheet, you get an AI-powered pipeline that:
- Evaluates offers with a unified 10-dimension weighted scoring system
- Generates tailored PDFs -- ATS-optimized CVs with anti-AI-detection writing rules
- Scans portals with fuzzy dedup (catches reposts with new URLs)
- Processes in batch -- evaluate 10+ offers in parallel with sub-agents
- Tracks everything with pipeline integrity checks and canonical state management
- Manages follow-ups -- timing-based nudges so you never miss a window
- Learns from rejections -- pattern analysis across all rejections by stage, archetype, and score
- Negotiates offers -- structured comp breakdown, leverage assessment, counter-offer strategy
Important: This is NOT a spray-and-pray tool. The whole point is to apply only where there's a real match. The scoring system helps you focus on high-fit opportunities instead of wasting everyone's time. Always review before submitting.
| Feature | Description |
|---|---|
| Auto-Pipeline | Paste a URL, get a full evaluation + PDF + tracker entry |
| Unified Scoring | 10 weighted dimensions, consistent across all modes, with calibration anchors |
| Anti-AI-Detection CVs | Writing rules that avoid ATS filters on Indeed, LinkedIn, Workday |
| 6-Block Evaluation | Role summary, CV match, level strategy, comp research, personalization, interview prep (STAR+R) |
| Interview Story Bank | Curated bank of 10-12 stories with match counts, archetype tags, and automatic pruning |
| Follow-Up System | Timing-based nudges: Applied 7+ days ago nudge, Interviewed 1 day ago thank-you note, email scanning via Gmail MCP |
| Gmail Integration | MCP server configured to retrieve emails for interview callbacks, offer responses, and application status updates |
| Rejection Analysis | Captures stage + reason, surfaces patterns (archetype gaps, scoring miscalibration) |
| Offer Negotiation | Total comp breakdown, equity valuation, leverage from pipeline, counter-offer scripts |
| Deep Research | Company research that feeds back into scores and interview prep |
| Smart LinkedIn Outreach | Reads evaluation reports to craft targeted messages using top proof points |
| Portal Scanner | 45+ companies pre-configured with fuzzy dedup for reposts |
| Batch Processing | Parallel evaluation with opencode run workers, with honest verification flagging |
| Pipeline Integrity | Automated merge, dedup, status normalization, health checks |
| Cost-Aware Agent Routing | Three subagents (@general-free, @general-paid, @glm-minimal) with per-task model tiers. On OpenCode, JobForge mixes native free models with free OpenRouter routes so the harness stays no-cost without forcing every task through the same provider. See Subagent Routing in AGENTS.md for the task-to-agent mapping. |
| Automatic Model Fallback | When a model rate-limits or 5xx's, @razroo/opencode-model-fallback rotates the agent through a configured fallback_models chain and replays the request. JobForge's OpenCode defaults stay on free models for both primaries and fallbacks. |
| Token Cost Visibility | job-forge tokens --days 1 for per-session breakdown; job-forge session-report --since-minutes 60 --log to flag sessions over budget and append history to data/token-usage.tsv. Auto-logged after every batch run. |
/job-forge â Show all available commands
/job-forge {paste a JD} â Full auto-pipeline (evaluate + PDF + tracker)
/job-forge scan â Scan portals for new offers
/job-forge pdf â Generate ATS-optimized CV
/job-forge batch â Batch evaluate multiple offers
/job-forge tracker â View application status
/job-forge apply â Fill application forms with AI
/job-forge pipeline â Process pending URLs
/job-forge contact â LinkedIn outreach (uses evaluation report)
/job-forge deep â Deep company research (feeds back into scores)
/job-forge followup â Check what needs follow-up action
/job-forge rejection â Record/analyze rejection patterns
/job-forge negotiation â Structured offer negotiation
/job-forge training â Evaluate a course/cert
/job-forge project â Evaluate a portfolio project
Or just paste a job URL or description directly -- JobForge auto-detects it and runs the full pipeline.
The system is designed to be customized by opencode itself. Modes, archetypes, scoring weights, negotiation scripts -- just ask opencode to change them: "Change the archetypes to backend engineering roles", "Add these 5 companies to portals.yml", "Update my profile with this CV I'm pasting".
You paste a job URL or description
â
âŧ
ââââââââââââââââââââ
â Archetype â Classifies: LLMOps / Agentic / PM / SA / FDE / Transformation
â Detection â
ââââââââââŦââââââââââ
â
ââââââââââŧââââââââââ
â A-F Evaluation â Match, gaps, comp research, STAR stories
â (reads cv.md) â Unified 10-dimension scoring model
ââââââââââŦââââââââââ
â
ââââââŧâââââ
âŧ âŧ âŧ
Report PDF Tracker
.md .pdf .tsv
â
ââââââŧâââââ
âŧ âŧ âŧ
Apply Follow Negotiate
up (if offer)
Your personal project (after npx --package=job-forge create-job-forge my-search):
my-search/
âââ package.json # depends on "job-forge": "^2.0.0" (npm registry)
âââ opencode.json # thin config â enables MCPs + states.yml
âââ cv.md # your CV (personal)
âââ article-digest.md # your proof points (optional, personal)
âââ portals.yml # companies to scan (personal)
âââ config/profile.yml # your identity, target roles (personal)
âââ data/ # applications, pipeline, scan history (personal, gitignored)
âââ reports/ # generated evaluation reports (personal, gitignored)
âââ batch/{batch-input,batch-state}.tsv, tracker-additions/, logs/ # personal
âââ AGENTS.md # personal overrides (opencode + codex)
âââ CLAUDE.md # personal overrides (Claude Code), @-imports CLAUDE.harness.md
â
â # â symlinks into node_modules/job-forge/, regenerated by postinstall sync.mjs
âââ AGENTS.harness.md # â harness instructions (loaded via opencode.json)
âââ CLAUDE.harness.md # â harness instructions (imported from personal CLAUDE.md)
âââ .mcp.json # â Claude Code MCP config
âââ .codex/config.toml # â Codex MCP config
âââ .cursor/mcp.json # â Cursor MCP config
âââ .cursor/rules/main.mdc # â Cursor always-apply rule
âââ .opencode/skills/job-forge.md # â skill router
âââ .opencode/agents/ # â @general-free, @general-paid, @glm-minimal
âââ modes/ # â _shared.md + skill modes
âââ templates/ # â states.yml, portals.example.yml, cv-template.html
âââ batch/batch-prompt.md # â batch worker prompt
âââ batch/batch-runner.sh # â parallel orchestrator
â
âââ node_modules/job-forge/ # the harness (from npm: `job-forge@2.x`)
Symlinks are regenerated on every npm install via the package's postinstall hook. You never have to know about harness internals â just edit cv.md, portals.yml, and config/profile.yml.
The harness itself (this repo, what gets published as job-forge on npm):
JobForge/
âââ iso/ # â SOURCE OF TRUTH for harness configuration
â âââ instructions.md # â AGENTS.md + CLAUDE.md (Claude Code / Codex / Cursor)
â âââ mcp.json # â .mcp.json + .cursor/mcp.json + .codex/config.toml + opencode.json
â âââ agents/*.md # â .opencode/agents/*.md (general-free, general-paid, glm-minimal)
â âââ commands/job-forge.md # â .opencode/skills/job-forge.md
â âââ config.json # per-harness top-level extras (e.g. opencode `instructions` array)
â
âââ package.json # bin: job-forge, create-job-forge; prepack runs iso-harness
âââ bin/
â âââ job-forge.mjs # CLI dispatcher (merge/verify/pdf/tokens/sync/...)
â âââ sync.mjs # postinstall: creates symlinks in consumer project
â âââ create-job-forge.mjs # scaffolder
âââ modes/ # _shared.md + 16 skill modes
âââ templates/ # cv-template.html, portals.example.yml, states.yml
âââ config/profile.example.yml # template for consumer's profile.yml
âââ batch/{batch-prompt.md,batch-runner.sh} # batch orchestrator
âââ scripts/
â âââ token-usage-report.mjs # opencode cost analyzer
â âââ release/check-source.mjs # version gate for npm publish
âââ tracker-lib.mjs / merge-tracker.mjs / dedup-tracker.mjs / verify-pipeline.mjs
âââ normalize-statuses.mjs / generate-pdf.mjs / cv-sync-check.mjs
âââ dashboard/ # optional Go TUI
âââ fonts/ # Space Grotesk + DM Sans (for PDF)
âââ docs/ # architecture, setup, customization
âââ .github/workflows/ # quality.yml + release.yml (CI publish to npm)
All per-harness config trees (.opencode/, .cursor/, .claude/, .codex/, CLAUDE.md, AGENTS.md, .mcp.json, opencode.json) are generated from iso/ by @razroo/iso-harness and gitignored in this repo. npm run build:config regenerates them locally; prepack regenerates them into the tarball at publish time so consumers get everything pre-baked.
Index and cross-links: docs/README.md.
- Setup â both install paths, profile, CV, portals, verify, token tracking, troubleshooting
- Architecture â package architecture, modes, evaluation flow, batch runner, pipeline scripts
- Customization â archetypes, scanner keywords, CV template, states, customizing symlinked modes
- Model Routing â the three cost-tiered subagents, why the architecture exists, and how to swap models or add your own
- Contributing â branch workflow, quality gate, and ideas for PRs
MIT

