• job_description_pattern_or
    array<string>
    default: []

    Regex patterns to look for in job descriptions. Case-insensitive. Results will include jobs whose description matches any of these patterns. Can pass more than one.

  • job_description_pattern_not
    array<string>
    default: []

    Regex patterns to look for in job descriptions. Results will include jobs whose description don't match any of these patterns. Can pass more than one.

  • job_description_pattern_is_case_insensitive
    booleannullable
    default: true
    deprecated

    Whether to make searches on job descriptions case-sensitive or insensitive. Deprecated field and won't work, use job_description_pattern_case_sensitive_or instead.

  • job_description_contains_or
    array<string>
    default: []

    Search for whole words in job descriptions using word boundaries (\b). Case-insensitive by default, except for the patterns that are uppercase - in that case we'll respect it. Only finds complete words (e.g., searching 'quality' won't match 'inequality'). Results will include jobs whose description contains any of these words.

  • job_description_contains_not
    array<string>
    default: []

    Exclude jobs whose description contains any of these whole words using word boundaries (\b). Case-insensitive by default, except for the patterns that are uppercase - in that case we'll respect it. Only finds complete words (e.g., searching 'quality' won't match 'inequality'). Results will exclude jobs whose description contains any of these words.

  • job_description_pattern_case_sensitive_or
    array<string>
    default: []

    Regex patterns to look for in job descriptions. Case-sensitive. If patterns are uppercase, they will be searched case-sensitively. Results will include jobs whose description matches any of these patterns.

  • remote
    booleannullable

    True: only show remote jobs. False: only show non-remote jobs. None: show all jobs.

  • only_jobs_with_reports_to
    booleannullable
    deprecated

    Only return jobs where we identified the role the hired person would report to. Deprecated field, use reports_to_exists instead.

  • reports_to_exists
    booleannullable
    deprecated

    Only return jobs where we identified the role the hired person would report to. If True, only return jobs where we identified the role the hired person would report to. If False, only return jobs where we didn't identify the role the hired person would report to. If None, return all jobs.

  • final_url_exists
    booleannullable
    deprecated

    (Use property_exists_or / property_exists_and instead) Only return jobs with a final URL. Typically jobs that were originally posted on an ATS. If True, only return jobs with a final URL. If False, only return jobs without a final URL. If None, return all jobs.

  • only_jobs_with_hiring_managers
    booleannullable
    deprecated

    Only return jobs with a hiring manager. If True, only return jobs with a hiring manager. If False, only return jobs without a hiring manager. If None, return all jobs.

  • hiring_managers_exists
    booleannullable
    deprecated

    (Use property_exists_or / property_exists_and instead) If True, only return jobs with a hiring manager. If False, only return jobs without a hiring manager. If None, return all jobs.

  • job_id_or
    array<integer>
    default: []

    Get jobs with these IDs only.

  • job_id_not
    array<integer>
    default: []

    Exclude jobs with these IDs.

  • job_ids
    array<integer>
    default: []
    deprecated

    Get jobs with these IDs only. Deprecated parameter, use job_id_or instead.

  • job_seniority_or
    array<string>
    default: []

    Will return jobs where the seniority is any of the ones passed here

  • min_salary_usd
    numbernullable

    Minimum annual salary in USD. For example, 100000 means $100,000.

  • max_salary_usd
    numbernullable

    Maximum annual salary in USD. For example, 150000 means $150,000.

  • job_technology_slug_or
    array<string>
    default: []

    Will return jobs where any of these technologies appear. Case sensitive. Pass slugs. Check out all the technologies we track with the technologies endpoint. If you pass more than one technology, we will return jobs that mentnion all of the technologies.

  • job_technology_slug_not
    array<string>
    default: []

    Will return jobs where none of these technologies appear. Case sensitive. Pass slugs. Check out all the technologies we track with the technologies endpoint.

  • job_technology_slug_and
    array<string>
    default: []

    Will return jobs where all of these technologies appear. Case sensitive. Pass slugs. Check out all the technologies we track with the technologies endpoint.

  • job_location_pattern_or
    array<string>
    default: []

    Regex patterns to match job locations. Case-insensitive. Searches both the location field and the enhanced locations array (using normalized city and state name fields within each location element). Jobs matching ANY of the provided patterns will be returned. Use this to find jobs in specific cities, states, or regions.

  • job_location_pattern_not
    array<string>
    default: []

    Regex patterns to exclude job locations. Case-insensitive. Searches both the location field and the enhanced locations array (using normalized city and state name fields within each location element). Jobs matching ANY of the provided patterns will be EXCLUDED from results. Use this to filter out specific locations.

  • job_location_or
    array<JobLocationFilter>
    default: []

    Filter jobs by location. Returns jobs whose locations match ANY of the specified location criteria. Each location criteria is specified using a JobLocationFilter object. (You can find location IDs using the locations catalog endpoint)

  • job_location_not
    array<JobLocationFilter>
    default: []

    Filter jobs by location. Returns jobs whose locations DO NOT match ANY of the specified location criteria. Each location criteria is specified using a JobLocationFilter object. (You can find location IDs using the locations catalog endpoint)

  • url_domain_or
    array<string>
    default: []

    Include jobs only if their URL domain is in the provided case-insensitive list. For example, ['greenhouse.io', 'workable.com'] will match URLs containing 'greenhouse.io' or 'workable.com'. Refer to our list of sources at https://theirstack.com/en/docs/data/job/sources.

  • url_domain_not
    array<string>
    default: []

    Exclude jobs if their URL domain is in the provided case-insensitive list. For example, ['greenhouse.io', 'workable.com'] will exclude URLs containing 'greenhouse.io' or 'workable.com'. Refer to our list of sources at https://theirstack.com/en/docs/data/job/sources.

  • scraper_name_pattern_or
    array<string>
    default: []
    deprecated

    Regex patterns to match job sources. Case-insensitive.

  • easy_apply
    booleannullable

    If True, only return jobs that can be applied directly through the job board. If False, only return jobs that require redirecting to the company's website.

  • employment_statuses_or
    array<Commitment>nullable

    Filter jobs by employment status. Returns jobs that match any of the specified employment types. If no values are provided or an empty list is sent, all jobs regardless of employment status will be returned.

  • company_name_or
    array<string>
    default: []

    Only return companies that match these names exactly, case-sensitively. This filter acts as an OR filter, so if you pass more than one company name, it will return companies that match any of the names.

  • company_name_case_insensitive_or
    array<string>
    default: []

    Only return companies that match these names exactly, case-insensitively.

  • company_id_or
    array<string>
    default: []

    Only return companies that match these IDs exactly. This filter acts as an OR filter, so if you pass more than one company ID, it will return companies that match any of the IDs.

  • company_domain_or
    array<string>
    default: []

    Only return companies that match these domains exactly. It accepts full urls (https://www.google.com/) and emails (john.polo@gmail.com). This filter acts as an OR filter, so if you pass more than one company domain, it will return companies that match any of the domains.

  • company_domain_not
    array<string>
    default: []

    Only return companies that don't match these domains exactly. It accepts full urls (https://www.google.com/) and emails (john.polo@gmail.com).

  • company_name_not
    array<string>
    default: []

    Only return companies that don't match these names exactly, case-sensitively.

  • company_name_partial_match_or
    array<string>
    default: []

    Company names. Will return companies whose name contain any of the the substrings passed here, case-insensitively. For example, if you pass "google", it will return "Google", "Google LLC", "Google Inc", etc.

  • company_name_partial_match_not
    array<string>
    default: []

    Company names. Will return companies whose name doesn't contain any of the the substrings passed here, case-insensitively. For example, if you pass 'google', it will exclude 'Google', 'Google LLC', 'Google Inc', etc.

  • company_linkedin_url_or
    array<string>
    default: []

    Return companies whose LinkedIn URL matches any of the slugs passed here. Can also pass full LinkedIn company URLs.

  • blur_company_data
    boolean
    default: false

    Enable preview mode to return blurred data without consuming API credits. When enabled, sensitive company fields (name, domain, URLs, descriptions) and job-specific fields (description, URLs) are blurred. This mode is useful for sales software integrations to show data previews to end users. Not available when filtering by company identifiers (company_name, company_domain, company_linkedin_url, company_id). Learn more about here

  • property_exists_or
    array<string>
    default: []

    Return jobs that have any of these fields not null. For example, if you pass ['final_url'], it will return jobs that have a final_url set. This field also support chaining of fields. For example, if you pass ['company_object.domain', 'company_object.linkedin_url'], it will return jobs that have a company domain or a company linkedin_url set.

  • property_exists_and
    array<string>
    default: []
  • company_description_pattern_or
    array<string>
    default: []

    Case-insensitive patterns to match in the company description. Will return companies that match any of the patterns.

  • company_description_pattern_not
    array<string>
    default: []

    Case-insensitive patterns to match in the company description. Will return companies that match any of the patterns.

  • company_description_pattern_accent_insensitive
    booleannullable
    default: false

    Set to True to make company description searches accent insensitive. For example, "á" will match "a" as well.

  • min_revenue_usd
    integernullable

    Minimum company revenue, in USD

  • max_revenue_usd
    integernullable

    Maximum company revenue, in USD

  • min_employee_count
    integernullable

    Minimum number of employees in a company

  • max_employee_count
    integernullable

    Maximum number of employees in a company

  • min_employee_count_or_null
    integernullable

    Minimum number of employees in a company. If we don't have company size information, we will return it as well.

  • max_employee_count_or_null
    integernullable

    Maximum number of employees in a company. If we don't have company size information, we will return it as well.

  • min_funding_usd
    integernullable

    Minimum company funding, in USD

  • max_funding_usd
    integernullable

    Maximum company funding, in USD

  • funding_stage_or
    array<string>
    default: []

    Funding stages of companies returned. Possible values: ['angel', 'convertible_note', 'debt_financing', 'equity_crowdfunding', 'other', 'private_equity', 'seed', 'series_a', 'series_b', 'series_c', 'series_d', 'series_e', 'series_f', 'series_g', 'series_h', 'venture_round_not_specified', 'series_i', 'series_j', 'undisclosed', 'series_unknown', 'pre_seed', 'post_ipo_secondary', 'post_ipo_equity', 'post_ipo_debt', 'non_equity_assistance', 'late_vc', 'initial_coin_offering', 'growth_equity_vc', 'grant', 'early_vc', 'corporate_round', 'secondary_market', 'product_crowdfunding']

  • industry_or
    array<string>
    default: []
    deprecated

    Names of industries, case-insensitive. Results will only include companies that belong to any of the industries specified in this parameter. Available values: GET /v0/catalog/industries

    WARNING: Deprecated parameter. Use the industry_id_or field instead. 
  • industry_not
    array<string>
    default: []
    deprecated

    Names of industries, case-insensitive. Results will exclude companies that belong to any of the industries specified in this parameter. Available values: GET /v0/catalog/industries

    WARNING: Deprecated parameter. Use the industry_id_not field instead. 
  • industry_id_or
    array<integer>
    default: []

    Industry codes. You can use any of LinkedIn's Industry Codes V2 or GET /v0/catalog/industries

  • industry_id_not
    array<integer>
    default: []

    Industry ids to exclude.You can use any of LinkedIn's Industry Codes V2 or GET /v0/catalog/industries

  • company_tags_or
    array<string>
    default: []

    Return companies that match any of these keywords

  • company_type
    stringnullable

    Filter by company type.

  • company_investors_or
    array<string>
    default: []

    Investors of the company

  • company_investors_partial_match_or
    array<string>
    default: []

    Investors of the company. Will return companies for which any of their investors contains any of the substrings passed here. For example, if you pass 'andree', all funds that match it (like 'Andreessen Horowitz', 'Andreessen Horowitz LLC', etc).

  • company_technology_slug_or
    array<string>
    default: []

    Will return jobs from companies that that have mentioned any of these technologies in their jobs (not necessarily in the jobs returned). Case sensitive. Pass slugs. Check out all the technologies we track at GET /v0/catalog/technologies

  • company_technology_slug_and
    array<string>
    default: []

    Will return jobs from companies that that have mentioned all of these technologies in their jobs (not necessarily in the jobs returned). Case sensitive. Pass slugs. Check out all the technologies we track at GET /v0/catalog/technologies

  • company_technology_slug_not
    array<string>
    default: []

    Will return jobs from companies that that haven't mentioned any of these technologies in their jobs. Case sensitive. Pass slugs. Check out all the technologies we track at GET /v0/catalog/technologies

  • only_yc_companies
    booleannullable
    default: false

    Only return YC companies

  • company_location_pattern_or
    array<string>
    default: []

    Return companies whose city matches any of the patterns passed here. Case insensitive. For example, if you pass 'san francisco', it will return companies whose city is 'San Francisco', 'San Francisco Bay Area', etc.

  • company_country_code_or
    array<string>
    default: []

    Return companies whose HQ country code is any of the ones passed here, case sensitive. Pass ISO2 country codes.

  • company_country_code_not
    array<string>
    default: []

    Return companies whose HQ country code is not any of the ones passed here, case sensitive. Pass ISO2 country codes.

  • company_list_id_or
    array<integer>
    default: []

    Return companies that belong to any of the company lists passed here

  • company_list_id_not
    array<integer>
    default: []

    Return companies that don't belong to any of the company lists passed here

  • company_linkedin_url_exists
    booleannullable
    deprecated

    (Use property_exists_or / property_exists_and instead) Only return companies with a LinkedIn URL

  • revealed_company_data
    booleannullable
    deprecated

    This field is deprecated and has no effect.

  • last_funding_round_date_lte
    stringnullable
    date

    Only return companies whose last funding round date is before or on this date. Format: 'YYYY-MM-DD'

  • last_funding_round_date_gte
    stringnullable
    date

    Only return companies whose last funding round date is after or on this date. Format: 'YYYY-MM-DD'

  • include_total_results
    boolean
    default: false

    When enabled, calculates and returns total_results and total_companies fields in the response. WARNING: This significantly slows down responses as it requires reading the entire dataset. Recommended usage: enable only for the initial request to get totals, then disable for subsequent pagination requests.

  • [key: string]
    never
  • Response Body

    application/json

    application/json

    application/json

    application/json

    application/json

    curl -X POST "https://api.theirstack.com/v1/jobs/search" \  -H "Content-Type: application/json" \  -d '{    "page": 0,    "limit": 25,    "job_country_code_or": [      "US"    ],    "posted_at_max_age_days": 7  }'
    {
      "metadata": {
        "total_results": 2034,
        "truncated_results": 0,
        "truncated_companies": 0,
        "total_companies": 1045
      },
      "data": [
        {
          "id": 1234,
          "job_title": "Senior Data Engineer",
          "url": "https://example.com/job/1234",
          "date_posted": "2021-01-01",
          "has_blurred_data": false,
          "company": "Google",
          "final_url": "https://carecrafterhealth.com/careers/job-details/MFC286442-4",
          "source_url": "https://www.linkedin.com/jobs/view/1234567890",
          "location": "New York",
          "short_location": "Tulsa, OK",
          "long_location": "Methuen, MA 01844",
          "state_code": "OK",
          "latitude": 37.774929,
          "longitude": -96.726486,
          "postal_code": "01844",
          "remote": true,
          "hybrid": true,
          "salary_string": "$100,000 - $120,000",
          "min_annual_salary": 100000,
          "min_annual_salary_usd": 100000,
          "max_annual_salary": 100000,
          "max_annual_salary_usd": 100000,
          "avg_annual_salary_usd": 100000,
          "salary_currency": "USD",
          "countries": [
            "United States",
            "Canada",
            "Spain",
            "France",
            "Australia"
          ],
          "country": "United States",
          "country_codes": [
            "US",
            "CA",
            "ES",
            "FR",
            "AU"
          ],
          "country_code": "US",
          "cities": [
            "New York",
            "San Francisco",
            "London",
            "Paris",
            "Sydney"
          ],
          "continents": [
            "North America",
            "Europe",
            "Asia",
            "Australia",
            "South America"
          ],
          "seniority": "c_level",
          "discovered_at": "2024-01-01T00:00:00",
          "company_domain": "acme.com",
          "hiring_team": [
            {
              "first_name": "John Doe",
              "full_name": "John Doe",
              "image_url": "https://media.licdn.com/dms1234567890",
              "linkedin_url": "https://www.linkedin.com/in/john-doe-1234567890",
              "role": "CEO",
              "thumbnail_url": "https://media.licdn.com/dms1234567890"
            }
          ],
          "reposted": true,
          "date_reposted": "2024-01-01",
          "employment_statuses": [
            "full_time"
          ],
          "easy_apply": true,
          "technology_slugs": [
            "google-firebase",
            "postgresql",
            "jira"
          ],
          "description": "## About the Role\nWe are looking for a Senior Data Engineer with 5+ years of experience in data engineering to join our growing data team. You will be responsible for designing and implementing scalable data pipelines, data models, and data warehouses that support our business intelligence and analytics initiatives.\n\n## Key Responsibilities\n- Design, build, and maintain robust, scalable data pipelines using modern data engineering tools and frameworks\n- Develop and optimize data models and schemas for data warehouses and data lakes\n- Collaborate with data scientists, analysts, and product teams to understand data requirements and deliver solutions\n- Implement data quality monitoring and validation processes to ensure data accuracy and reliability\n- Optimize query performance and data processing workflows for large-scale datasets\n- Build and maintain ETL/ELT processes using tools like Apache Airflow, dbt, or similar\n- Work with cloud data platforms (AWS, GCP, or Azure) and their native data services\n- Establish data governance practices and ensure compliance with data privacy regulations\n- Mentor junior data engineers and contribute to technical documentation\n\n## Required Qualifications\n- Bachelor's degree in Computer Science, Engineering, or related technical field\n- 5+ years of experience in data engineering or related roles\n- Strong proficiency in Python and SQL\n- Experience with big data technologies (Spark, Kafka, Hadoop ecosystem)\n- Hands-on experience with cloud data platforms (AWS Redshift, GCP BigQuery, Azure Synapse, etc.)\n- Experience with data orchestration tools (Airflow, Prefect, or similar)\n- Knowledge of data modeling concepts and best practices\n- Experience with version control systems (Git) and CI/CD pipelines\n- Strong problem-solving skills and attention to detail\n\n## Preferred Qualifications\n- Experience with real-time data processing and streaming analytics\n- Knowledge of data visualization tools (Tableau, Looker, PowerBI)\n- Experience with containerization (Docker, Kubernetes)\n- Familiarity with machine learning workflows and MLOps practices\n- Experience with data governance and cataloging tools\n\n## What We Offer\n- Competitive salary and equity package\n- Comprehensive health, dental, and vision insurance\n- Flexible work arrangements and remote-friendly culture\n- Professional development budget for conferences and training\n- State-of-the-art equipment and technology stack\n- Collaborative and inclusive work environment\n- Opportunity to work with cutting-edge data technologies",
          "company_object": {
            "id": "google",
            "name": "Google",
            "domain": "google.com",
            "industry": "internet",
            "country": "United States",
            "country_code": "string",
            "employee_count": 7543,
            "logo": "https://example.com/logo.png",
            "num_jobs": 746,
            "num_technologies": 746,
            "possible_domains": [],
            "url": "google.com",
            "industry_id": 0,
            "linkedin_url": "http://www.linkedin.com/company/google",
            "num_jobs_last_30_days": 34,
            "num_jobs_found": 23,
            "yc_batch": "W21",
            "apollo_id": "5b839bd0324d4445051f9a5a",
            "linkedin_id": "string",
            "url_source": "string",
            "is_recruiting_agency": true,
            "founded_year": 2019,
            "annual_revenue_usd": 189000000,
            "annual_revenue_usd_readable": "189M",
            "total_funding_usd": 500000,
            "last_funding_round_date": "2020-01-01",
            "last_funding_round_amount_readable": "$1.2M",
            "employee_count_range": "1001-5000",
            "long_description": "Google is a California-based multinational technology company that offers internet-related services such as a search engine, online advertising and cloud computing.",
            "seo_description": "string",
            "city": "Mountain View",
            "postal_code": "28040",
            "company_keywords": [
              "string"
            ],
            "alexa_ranking": 1,
            "publicly_traded_symbol": "GOOG",
            "publicly_traded_exchange": "NASDAQ",
            "investors": [
              "string"
            ],
            "funding_stage": "angel",
            "has_blurred_data": false,
            "technology_slugs": [
              "kafka",
              "elasticsearch"
            ],
            "technology_names": [
              "Kafka",
              "Elasticsearch"
            ]
          },
          "locations": [
            {
              "admin1_code": "CA",
              "admin1_name": "California",
              "admin2_code": "101",
              "admin2_name": "Sutter",
              "continent": "NA",
              "country_code": "US",
              "country_name": "United States",
              "display_name": "Live Oak, California, United States",
              "feature_code": "PPL",
              "id": 5367315,
              "latitude": 37,
              "longitude": -122,
              "name": "Live Oak",
              "state": "California",
              "state_code": "CA",
              "type": "city"
            }
          ],
          "normalized_title": "string",
          "manager_roles": [
            "string"
          ],
          "matching_phrases": [],
          "matching_words": []
        }
      ]
    }
    {
      "request_id": null,
      "error": {
        "code": "E-001",
        "title": "Not allowed exception",
        "description": "string"
      }
    }
    {
      "request_id": null,
      "error": {
        "code": "E-001",
        "title": "Not allowed exception",
        "description": "string"
      }
    }
    {
      "request_id": null,
      "error": {
        "code": "E-001",
        "title": "Not allowed exception",
        "description": "string"
      }
    }
    {
      "request_id": null,
      "error": {
        "code": "E-001",
        "title": "Not allowed exception",
        "description": "string"
      }
    }

    How is this guide?

    Last updated on

    Avoiding getting the same job twice

    Learn how to avoid duplicate jobs when making repeated calls to the Job Search endpoint.

    Company Search POST

    This endpoint lets you search for companies by technology stack, hiring signals, and firmographics. It returns a list of companies that match the search criteria, along with the jobs and technology objects for each company that match the filters you've passed.