# Ashby Jobs \[$0.9💰] API Scraper | Any Company  (/w EMAILS) (`memo23/ashby-scraper`) Actor

\[Only $0.9💰] Scrape every open job from any company on Ashby (jobs.ashbyhq.com). Paste a board URL or org slug and get the full board in one API call — company, title, full description, compensation, location, department, and apply URL. Filter by title, location or remote. No proxy. JSON or CSV.

- **URL**: https://apify.com/memo23/ashby-scraper.md
- **Developed by:** [Muhamed Didovic](https://apify.com/memo23) (community)
- **Categories:** Jobs, Agents, AI
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $0.90 / 1,000 results

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## Ashby Jobs Scraper 🧭

Scrape **every open job from any company hosted on [Ashby](https://www.ashbyhq.com/)** (`jobs.ashbyhq.com`) — title, full description, compensation, location, department, and apply URL — straight from Ashby's public posting API. One request per company returns the whole board, fully detailed. No login, no anti-bot, no browser.

![How Ashby Jobs Scraper works](https://raw.githubusercontent.com/muhamed-didovic/muhamed-didovic.github.io/main/assets/how-it-works-ashby.png)

---

### Why use this scraper

- **Complete boards in one call.** Ashby returns every open role for a company in a single API response — no pagination, no per-job detail fetches. Scraping OpenAI's 700+ roles is one request.
- **Full job detail, not just titles.** Each row carries the entire job: `descriptionHtml` + plain text, compensation range, all locations, employment type, workplace type, and the apply URL.
- **Fast and cheap.** No proxies required (the API has no anti-bot), so runs are quick and your cost stays low.
- **Normalized schema.** Output uses a consistent ATS schema that matches our other ATS scrapers (Lever, Greenhouse, SmartRecruiters) — write one parser, reuse it everywhere.
- **Flexible input.** Paste board URLs, individual job URLs, or just bare company slugs.

---

### Overview

[Ashby](https://www.ashbyhq.com/) is a modern all-in-one recruiting platform used by hundreds of high-growth tech companies (Ramp, Notion, Linear, Vanta, Replit, Cursor, OpenAI, and many more). Each customer gets a public job board at `https://jobs.ashbyhq.com/{company}`.

This actor reads each company's board through Ashby's official, auth-free **posting API** and emits one clean row per open job. Because the API already includes the full job description and compensation inline, there's no second request per job — making this one of the fastest and cheapest job scrapers you can run.

---

### Supported inputs

| Input type | Example | Notes |
|---|---|---|
| **Board URL** | `https://jobs.ashbyhq.com/ramp` | The company's public Ashby board |
| **Job URL** | `https://jobs.ashbyhq.com/ramp/{jobId}` | The org slug is extracted; the whole board is scraped |
| **Bare org slug** | `ramp`, `notion`, `linear` | The part after `jobs.ashbyhq.com/` |

Mix any of these in one run. Provide them in **Start URLs** (URLs) and/or **Organization slugs** (bare slugs).

> **How do I find a company's Ashby slug?** Visit the company's careers page. If it redirects to (or embeds) `jobs.ashbyhq.com/{something}`, that `{something}` is the slug.

---

### Use cases

- **Job boards & aggregators** — ingest fresh, structured tech roles from hundreds of fast-growing companies.
- **Recruiting & sourcing tools** — track which companies are hiring for which roles, with compensation where disclosed.
- **Market & talent intelligence** — monitor hiring velocity, remote-vs-onsite mix, and salary bands across a basket of companies.
- **Lead generation** — companies actively hiring engineers/sales are buying signals for many B2B products.
- **Personal job search** — pull every role across your target companies into one searchable sheet.

---

### How it works

1. **Resolve** each input (board URL, job URL, or slug) to a company org slug.
2. **Fetch** `https://api.ashbyhq.com/posting-api/job-board/{org}?includeCompensation=true` — one HTTP call per company.
3. **Each job arrives fully detailed** in that response (description, compensation, locations, apply URL).
4. **Normalize** every job to a common ATS schema.
5. **Push** one row per job to the dataset.

Companies are fetched in parallel with a sliding-window concurrency cap. No proxy is needed, though you can supply one for IP rotation when scraping very large numbers of companies.

---

### Input configuration

| Field | Type | Default | Description |
|---|---|---|---|
| `startUrls` | array | – | Ashby board URLs, job URLs, or slugs (strings or `{url}` objects). |
| `organizations` | array | – | Bare Ashby org slugs, e.g. `["ramp","notion"]`. Merged with `startUrls`. |
| `maxItems` | integer | `5000` | Max job rows emitted across the whole run. |
| `maxConcurrency` | integer | `10` | How many company boards to fetch in parallel. |
| `titleKeyword` | string | – | Keep only jobs whose title contains this (case-insensitive). |
| `location` | string | – | Keep only jobs whose location contains this. |
| `department` | string | – | Keep only jobs whose department contains this. |
| `employmentType` | string | – | Keep only this type: FullTime / PartTime / Intern / Contract / Temporary. |
| `remoteOnly` | boolean | `false` | Keep only remote jobs. |
| `postedAfter` | string | – | Keep only jobs published on/after this date (YYYY-MM-DD). |
| `includeDescription` | boolean | `true` | Include `descriptionHtml` + `descriptionText`. Turn off for leaner/cheaper rows. |
| `includeRawJson` | boolean | `false` | Attach the original Ashby payload to each row under `raw`. |
| `proxy` | object | – | Optional. Not required (no anti-bot); use only for IP rotation at scale. |

> **Filters run before a row is emitted**, so with pay-per-result pricing you only pay for jobs that match.

#### Example input

```json
{
  "startUrls": [
    "https://jobs.ashbyhq.com/ramp"
  ],
  "organizations": ["notion", "linear", "vanta"],
  "maxItems": 1000,
  "maxConcurrency": 10
}
````

***

### Output

One row per open job. Example (trimmed):

```json
{
  "ats": "ashby",
  "org": "ramp",
  "company": "Ramp",
  "jobId": "34413f8d-26bf-4bbc-8ade-eb309a0e2245",
  "globalId": "ashby:ramp:34413f8d-26bf-4bbc-8ade-eb309a0e2245",
  "title": "Security Engineer, Cloud",
  "department": "Engineering",
  "team": "Backend",
  "employmentType": "FullTime",
  "workplaceType": "Hybrid",
  "isRemote": true,
  "location": "New York, NY (HQ)",
  "locations": ["New York, NY (HQ)", "Miami, FL", "Remote (US)", "Remote (Canada)"],
  "address": { "postalAddress": { "addressRegion": "NY", "addressCountry": "USA", "addressLocality": "New York City" } },
  "compensation": { "compensationTierSummary": "$211.4K – $290.6K • Offers Equity" },
  "salaryText": "$211.4K – $290.6K • Offers Equity",
  "descriptionHtml": "<h1>About Ramp</h1><p>…</p>",
  "descriptionText": "About Ramp\nRamp is building the smart infrastructure for finance teams…",
  "publishedAt": "2026-04-07T17:12:35.753+00:00",
  "jobUrl": "https://jobs.ashbyhq.com/ramp/34413f8d-26bf-4bbc-8ade-eb309a0e2245",
  "applyUrl": "https://jobs.ashbyhq.com/ramp/34413f8d-26bf-4bbc-8ade-eb309a0e2245/application",
  "scrapedAt": "2026-06-12T15:53:01.683Z"
}
```

#### Key output fields

| Field | Description |
|---|---|
| `ats` | Always `"ashby"` — the source platform (useful when combining with other ATS scrapers). |
| `org` | Company board slug. |
| `company` | Company display name (resolved from the board). |
| `globalId` | Stable, unique key `ats:org:jobId` — use it to dedupe across runs. |
| `title` | Job title. |
| `department` / `team` | Org grouping as set by the company. |
| `employmentType` | `FullTime` / `PartTime` / `Intern` / `Contract` / `Temporary`. |
| `workplaceType` / `isRemote` | `Remote` / `Hybrid` / `OnSite`, plus a boolean remote flag. |
| `location` / `locations` | Primary location label + every listed location. |
| `compensation` / `salaryText` | Raw Ashby compensation object + a flattened human string (when the company discloses pay). |
| `descriptionHtml` / `descriptionText` | Full job description as HTML and as plain text. |
| `publishedAt` | When the role was published (ISO). |
| `jobUrl` / `applyUrl` | Public posting URL + application form URL. |

***

### FAQ

**Do I need a proxy?** No. Ashby's posting API is public and has no anti-bot. A proxy field is available only for optional IP rotation when scraping very large numbers of companies.

**Where does `company` come from?** Ashby's posting API doesn't return a display name, so we resolve it once per board from the public board page (e.g. "Ramp"), falling back to a title-cased slug if needed. It's never null.

**Can it discover all companies on Ashby?** No — Ashby has no public directory of all boards (the same is true for every Greenhouse/Lever/SmartRecruiters scraper). You supply the companies you care about by slug or board URL.

**How many jobs per company?** Whatever the company has open — from a handful to 700+. Use `maxItems` to cap total output and control cost.

**What if a slug isn't on Ashby?** That company is skipped with a warning (the API returns 404). The rest of the run continues normally.

**How fresh is the data?** Live — every run hits Ashby in real time.

***

### Support

Found a bug or need a field added? Open an issue on the actor's **Issues** tab in the Apify Console and we'll take a look.

***

### Additional services

Need a different ATS or job board? We also build scrapers for Greenhouse, Lever, SmartRecruiters, Workday, Indeed, LinkedIn, Glassdoor, and many more. Check our Apify Store profile.

***

### Explore more scrapers

- **Greenhouse Jobs Scraper** — open roles from any Greenhouse-hosted company.
- **Workday Jobs Scraper** — jobs from any Workday career site.
- **Indeed / LinkedIn / Glassdoor** — the major job boards, fast and structured.

***

### ⚠️ Disclaimer

This actor collects only **publicly available** job-posting data exposed by Ashby's own public job-board API. It does not access any private, authenticated, or personal data, and it does not bypass any access control. You are responsible for using the scraped data in compliance with Ashby's terms, the source companies' terms, and all applicable laws (including data-protection regulations such as GDPR/CCPA). Use the data ethically and lawfully.

***

### SEO Keywords

Ashby scraper, AshbyHQ scraper, Ashby jobs scraper, jobs.ashbyhq.com scraper, Ashby job board API, Ashby ATS scraper, scrape Ashby jobs, Ashby careers scraper, ATS job scraper, applicant tracking system scraper, tech jobs scraper, startup jobs scraper, job postings API, company careers scraper, recruiting data, hiring data, compensation data scraper, remote jobs scraper.

# Actor input Schema

## `startUrls` (type: `array`):

Ashby board URLs (e.g. https://jobs.ashbyhq.com/ramp) or individual job URLs (https://jobs.ashbyhq.com/ramp/{jobId}). Bare slugs also accepted.

## `organizations` (type: `array`):

Bare Ashby org slugs, e.g. \["ramp", "notion", "linear"]. The slug is the part after jobs.ashbyhq.com/. Merged with any Start URLs above.

## `maxItems` (type: `integer`):

Hard cap on job rows emitted across the whole run (across all companies). Use it to control billing — large boards like OpenAI have 700+ open roles.

## `maxConcurrency` (type: `integer`):

How many company boards to fetch in parallel.

## `titleKeyword` (type: `string`):

Keep only jobs whose title contains this text (case-insensitive), e.g. "engineer".

## `location` (type: `string`):

Keep only jobs whose location (primary or secondary) contains this text, e.g. "remote", "London", "New York".

## `department` (type: `string`):

Keep only jobs whose department contains this text, e.g. "Engineering".

## `employmentType` (type: `string`):

Keep only jobs with this exact employment type.

## `remoteOnly` (type: `boolean`):

Keep only jobs flagged remote.

## `postedAfter` (type: `string`):

Keep only jobs published on or after this date (YYYY-MM-DD). Ideal for scheduled monitoring runs that only want fresh roles.

## `includeDescription` (type: `boolean`):

Include `descriptionHtml` and `descriptionText` on each row. Turn off for leaner, cheaper rows when you only need title/location/compensation/links.

## `includeRawJson` (type: `boolean`):

Attach the original, unmodified Ashby job object to each row under a `raw` field. Useful for advanced fields not in the normalized schema. Off by default to keep rows lean.

## `enrichEmails` (type: `boolean`):

If enabled, tries to find a contact email for the company by discovering its website (Clearbit) and reading its contact/about pages. Adds contactEmail + contactWebsite columns plus a detailed emailEnrichment object. Best-effort, billed per contact email found; only charged when an email is returned, never for misses.

## `proxy` (type: `object`):

Optional. Ashby's public API has no anti-bot, so a proxy is NOT required. Only enable it if you want IP rotation when scraping very large numbers of companies.

## Actor input object example

```json
{
  "startUrls": [
    "https://jobs.ashbyhq.com/ramp"
  ],
  "organizations": [
    "notion",
    "linear"
  ],
  "maxItems": 5000,
  "maxConcurrency": 10,
  "remoteOnly": false,
  "includeDescription": true,
  "includeRawJson": false,
  "enrichEmails": false
}
```

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "startUrls": [
        "https://jobs.ashbyhq.com/ramp"
    ],
    "organizations": [
        "notion",
        "linear"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("memo23/ashby-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {
    "startUrls": ["https://jobs.ashbyhq.com/ramp"],
    "organizations": [
        "notion",
        "linear",
    ],
}

# Run the Actor and wait for it to finish
run = client.actor("memo23/ashby-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "startUrls": [
    "https://jobs.ashbyhq.com/ramp"
  ],
  "organizations": [
    "notion",
    "linear"
  ]
}' |
apify call memo23/ashby-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=memo23/ashby-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Ashby Jobs [$0.9💰] API Scraper | Any Company  (/w EMAILS)",
        "description": "[Only $0.9💰] Scrape every open job from any company on Ashby (jobs.ashbyhq.com). Paste a board URL or org slug and get the full board in one API call — company, title, full description, compensation, location, department, and apply URL. Filter by title, location or remote. No proxy. JSON or CSV.",
        "version": "0.0",
        "x-build-id": "iieeMHVS0bZhyKS0B"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/memo23~ashby-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-memo23-ashby-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/memo23~ashby-scraper/runs": {
            "post": {
                "operationId": "runs-sync-memo23-ashby-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/memo23~ashby-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-memo23-ashby-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "properties": {
                    "startUrls": {
                        "title": "Ashby board / job URLs",
                        "type": "array",
                        "description": "Ashby board URLs (e.g. https://jobs.ashbyhq.com/ramp) or individual job URLs (https://jobs.ashbyhq.com/ramp/{jobId}). Bare slugs also accepted.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "organizations": {
                        "title": "Organization slugs",
                        "type": "array",
                        "description": "Bare Ashby org slugs, e.g. [\"ramp\", \"notion\", \"linear\"]. The slug is the part after jobs.ashbyhq.com/. Merged with any Start URLs above.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxItems": {
                        "title": "Maximum jobs to scrape",
                        "minimum": 1,
                        "type": "integer",
                        "description": "Hard cap on job rows emitted across the whole run (across all companies). Use it to control billing — large boards like OpenAI have 700+ open roles.",
                        "default": 5000
                    },
                    "maxConcurrency": {
                        "title": "Max concurrency",
                        "minimum": 1,
                        "type": "integer",
                        "description": "How many company boards to fetch in parallel.",
                        "default": 10
                    },
                    "titleKeyword": {
                        "title": "Title contains",
                        "type": "string",
                        "description": "Keep only jobs whose title contains this text (case-insensitive), e.g. \"engineer\"."
                    },
                    "location": {
                        "title": "Location contains",
                        "type": "string",
                        "description": "Keep only jobs whose location (primary or secondary) contains this text, e.g. \"remote\", \"London\", \"New York\"."
                    },
                    "department": {
                        "title": "Department contains",
                        "type": "string",
                        "description": "Keep only jobs whose department contains this text, e.g. \"Engineering\"."
                    },
                    "employmentType": {
                        "title": "Employment type",
                        "enum": [
                            "FullTime",
                            "PartTime",
                            "Intern",
                            "Contract",
                            "Temporary"
                        ],
                        "type": "string",
                        "description": "Keep only jobs with this exact employment type."
                    },
                    "remoteOnly": {
                        "title": "Remote only",
                        "type": "boolean",
                        "description": "Keep only jobs flagged remote.",
                        "default": false
                    },
                    "postedAfter": {
                        "title": "Posted on/after",
                        "type": "string",
                        "description": "Keep only jobs published on or after this date (YYYY-MM-DD). Ideal for scheduled monitoring runs that only want fresh roles."
                    },
                    "includeDescription": {
                        "title": "Include full job description",
                        "type": "boolean",
                        "description": "Include `descriptionHtml` and `descriptionText` on each row. Turn off for leaner, cheaper rows when you only need title/location/compensation/links.",
                        "default": true
                    },
                    "includeRawJson": {
                        "title": "Include raw Ashby payload",
                        "type": "boolean",
                        "description": "Attach the original, unmodified Ashby job object to each row under a `raw` field. Useful for advanced fields not in the normalized schema. Off by default to keep rows lean.",
                        "default": false
                    },
                    "enrichEmails": {
                        "title": "Enrich with company contact emails (experimental, billed per email)",
                        "type": "boolean",
                        "description": "If enabled, tries to find a contact email for the company by discovering its website (Clearbit) and reading its contact/about pages. Adds contactEmail + contactWebsite columns plus a detailed emailEnrichment object. Best-effort, billed per contact email found; only charged when an email is returned, never for misses.",
                        "default": false
                    },
                    "proxy": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Optional. Ashby's public API has no anti-bot, so a proxy is NOT required. Only enable it if you want IP rotation when scraping very large numbers of companies."
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
