All feed pages

Country feed

US job listings API

US jobs from companies posting on Greenhouse, Lever, Ashby, and Workable — direct from employer career sites, not re-scraped from other job boards. Filter, paginate, and wire into your product with a single HTTP call.

The Problem

Building a US job board usually requires maintaining dozens of fragile scrapers for different ATS platforms, leading to stale data and broken layouts when sites change.

Our Solution

We aggregate and normalize job postings from the top 4 ATS platforms used by US tech companies into a single, stable JSON feed, updated continuously.

What you're getting

Source
Direct postings from ATS and employers career sites.
Companies
This batch includes roles from Commonwealth Fusion Systems, Ennoble Care, Dynamis, Inc., and PlayStation Global, and more.
Volume
Preview shows 10 roles (limit 10, with more pages available). Authenticate and paginate to explore the full United States index.
Filters
Filter by country, state, city, title, remote setting, experience level, and salary. Full filter reference in the Jobs API docs.

At a glance

  • The largest volume of any region in our index. Filter by state, city, remote, title, or experience level to scope exactly the feed your job board needs.
  • Jobs come from companies actively hiring on Greenhouse, Lever, Ashby, and Workable — tech companies, startups, and scale-ups with structured, consistent postings.
  • New roles appear continuously. Sort by newest first and paginate with cursors to run nightly syncs or real-time feeds without re-downloading everything.

When you are ready for every filter, validation rule, and response field, use the Jobs API reference.

Example request

Same query as the playground, as cURL. Use your real key on the server only.

curl -X GET "https://api.cleanjobdata.com/jobs?country_id=238" \
  -H "Authorization: Bearer YOUR_API_KEY"

How to integrate

1. Get an API key

Sign up for CleanJobData, open the dashboard, and create or copy your API key. Send it as Authorization: Bearer <token> on every request (server-side only in production—never expose keys in mobile apps or public repos).

2. Query United States listings

Start from country_id 238 (United States), then add title, workSetting, experience_level, city_id, or state_id when you need a tighter audience.

Use a modest limit while prototyping, default to sort_by=published for recency, then follow pagination.next_page for large imports. Back off with exponential retry if you hit rate limits.

3. Shape data for your product

Choose which fields you render in job cards versus what you index for search. On list endpoints, trim payloads with fields, include_fields, or exclude_fields, and only request description when you truly need full text on list views.

FAQ

Can I use this in production for a paid job board?
Yes—that is the intended use case. Pick a plan that matches your query volume, keep keys on your server, cache responses where it makes sense, and follow the pagination contract for large imports. Contact support if you need higher limits or contract terms.
How do I narrow results beyond United States?
Add state_id, city_id, or location, combine with a keyword in title, or filter remote-only roles. Each option is spelled out in the Jobs API reference (/docs/api/jobs) with validation rules you can copy into code.
What rate limits or quotas should I expect?
Limits depend on the plan you choose. Higher tiers support more queries per second so job boards with heavy traffic or large sync jobs stay smooth. Paginate with the API's cursors and retry politely if you occasionally receive a 429 response.
How is this different from scraping job boards myself?
We normalize employers, locations, salary text, and remote flags into one schema, refresh listings continuously, and expose stable HTTP filters. You spend time on product and UX instead of repairing scrapers every time a site changes markup.
How fresh is the job data?
We refresh listings continuously from our sources, so you are not stuck with a stale export. Use sort_by=published when you want the newest posts first, and run incremental syncs on a schedule that matches how often your job board should update.
Do you return full job descriptions on list endpoints?
Descriptions are available but not included in lightweight list responses by default. Request them explicitly when building detail views so list pages and mobile clients stay fast and cheap to render.