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

