# Glassdoor Jobs Scraper (`api-empire/glassdoor-jobs-scraper`) Actor

💼 Glassdoor Jobs Scraper extracts Glassdoor job postings at scale: titles, companies, locations, salary ranges, employer ratings, descriptions & URLs. 📊 Export-ready data for HR, recruiters & analysts to build pipelines, track pay trends and monitor competitors. 🚀

- **URL**: https://apify.com/api-empire/glassdoor-jobs-scraper.md
- **Developed by:** [API Empire](https://apify.com/api-empire) (community)
- **Categories:** Jobs, Developer tools, Automation
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $4.99 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.

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

## Glassdoor Jobs Scraper

Apify Actor that collects Glassdoor job listings from **job search (SERP) URLs** using the same BFF + employer-overview strategy as the reference implementation. Output rows match the structured schema (job fields, company fields, and `all` raw payload).

### Features

- **Bulk input:** multiple Glassdoor job search URLs in one run.
- **Filters:** salary, age, company substring, industry, domain, employer size, job type, seniority, remote, radius, rating (client-side where applicable).
- **Proxy ladder (default direct):** direct → Apify **DATACENTER** → Apify **RESIDENTIAL** (up to 3 URL retries per step); after a successful residential response, **sticky residential** for the rest of the run.
- **Live dataset push:** each job is pushed as it is built.

### Input

The Console form is grouped into **Search settings**, **Salary settings**, **Search filters**, and **Proxy settings** (see `actor.json`).

| Field | Description |
| --- | --- |
| `keyword` | Job search text (used with `country` when `urls` is empty). |
| `country` | Regional Glassdoor site (`us`, `gb`, `de`, …). |
| `urls` | Optional: advanced bulk Glassdoor job search URLs; if present, `keyword`/`country` are ignored. |
| `proxyConfiguration` | Apify proxy settings (used when falling back from direct; ensure proxy is enabled on the Apify account for DC/residential). |
| `maxItems` | Max jobs per search run (after filters). Default `200`. |
| `location` | Free text resolved via Glassdoor location AJAX. |
| `includeNoSalaryJob` | If `false`, drop listings without pay data. |
| `companyName` | Employer name substring filter. |
| `minSalary` / `maxSalary` | Salary filters (site currency). |
| `fromAge` | `ANY` or `1` / `3` / `7` / `14` / `30` (days). |
| `jobType` | `all`, `fulltime`, `parttime`, `contract`, … or seniority-like `internship`, `entrylevel`. |
| `radius` | km string: `0`, `6`, `12`, `18`, … |
| `industryType` / `domainType` / `employerSizes` | Symbolic or numeric IDs (see code maps). |
| `remoteWorkType` | `true` = remote-only filter; `false`/omit = no remote-only filter. |
| `seniorityType` | e.g. `all`, `internship`. |
| `minRating` | Minimum employer rating `0`–`5`. |
| `requestDelayMs` | Extra delay between pagination requests. |

### Output

One dataset item per job: `job_title`, `job_id`, `job_url`, `job_location`, `job_salary`, `company_*`, `job_benefits_tags`, `all` (full merged jobview), etc., as produced by `build_output()`.

### Local run

```bash
cd Glassdoor-Jobs-Scraper
pip install -r requirements.txt
````

Create `storage/key_value_stores/default/INPUT.json` with your run input (fields match `.actor/actor.json`). Set **`APIFY_LOCAL_STORAGE_DIR`** to the **absolute path of the `storage` directory** (the folder that contains `key_value_stores`), not the project root:

```powershell
$env:APIFY_LOCAL_STORAGE_DIR = "D:\path\to\Glassdoor-Jobs-Scraper\storage"
python -m src
```

On the Apify platform, input is injected automatically; **APIFY\_TOKEN** (or proxy password) is available so datacenter/residential fallback works.

Provide input via the Apify Console, CLI, or local KVS `INPUT` as above.

### Legal

Use only in compliance with Glassdoor’s terms and applicable laws. You are responsible for lawful use of scraped data.

# Actor input Schema

## `keyword` (type: `string`):

💼 Type the **role, skills, or title** you care about (e.g. *Software Engineer*, *Data Analyst*). This is your main search — make it sparkle! ✨ Leave *Optional bulk URLs* empty to use this mode.

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

🎁✨ Set your **sweet spot** — from a tiny taste 🧁 to a **big harvest** 🌾! Higher = more rows in your dataset — **max 500** for power users. 📈🚀

## `country` (type: `string`):

🗺️ Choose the **country / language** version of Glassdoor that matches your job hunt. Each option is a real regional site — pick where you want to search! 🌟

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

🌆🎯 Narrow the map: *London*, *Berlin*, *Bay Area*… or leave **blank** for a **worldwide vibe** 🌍✨ — your call!

## `includeNoSalaryJob` (type: `boolean`):

✅ **On** — you’ll also see posts where pay isn’t shown (still useful!). ❌ **Off** — focus only on listings that mention compensation. 💵

## `companyName` (type: `string`):

🎯 Type part of a **company name** to lean toward those employers — or leave empty to see everyone. ✨

## `minSalary` (type: `integer`):

🎯 Only show roles **at or above** this number (uses the **local currency** for the site you picked). Set **0** for *no minimum* — dream big! 🌈

## `maxSalary` (type: `integer`):

🎀 Cap the range if you want — or leave empty / use **0** for *no upper limit*. Same currency as the site you chose! 🌍

## `fromAge` (type: `string`):

🆕 Prefer **brand-new posts** or don’t mind older ones? Pick how many **days back** you’re happy with — great for staying on top of new openings! ⚡

## `jobType` (type: `string`):

🧩 **Full-time**, **part-time**, **contract**, **internship**… pick what fits your life stage. Choose **All** to keep every option on the table! 🎉

## `radius` (type: `string`):

🗺️ When you use a **place**, this is the **circle around it** — wider = more nearby cities; tighter = closer to home. 🏡

## `industryType` (type: `string`):

🎯 **All** = every industry 🌈 — or pick a **sector** to zoom in (finance 💰, consulting 📊, HR 👥, tech 💻…). Default: **All**. ✨

## `domainType` (type: `string`):

🗂️ **All** = open playing field 🌿 — or choose a **domain** (engineering ⚙️, legal ⚖️, sales 📣…). Default: **All**. 🎨

## `employerSizes` (type: `string`):

🐣🌆 From **tiny teams** to **huge enterprises** — pick your **company-size vibe** or stay **All** for everything! 💼✨

## `applicationType` (type: `string`):

🖱️ **All** = every style ✨ — **Easy Apply included** = mix of flows — **Easy Apply only** = one-click heaven! 🎯 Default: **All**.

## `remoteWorkType` (type: `string`):

🌍 **Any** = remote **and** on-site listings 🏢 — **Remote only** = lean into **WFH-friendly** roles! 🛋️✨ Default: **Any**.

## `seniorityType` (type: `string`):

🌱 Match your **career chapter**: intern 🎓, entry 🌿, mid–senior 📊, director 👔, executive ⭐ — or **All** to explore! 🚀

## `minRating` (type: `string`):

💖 Only show employers rated **at least** this high by the community — or **0** for *no bar*. Trust your gut! 🤝

## `proxyConfiguration` (type: `object`):

🛡️ **Optional.** Use Apify’s proxies for **extra reliability** or when browsing from certain regions — pick what feels right for you. ✨ **Default:** start without extra routing; you can always enable more here! 🚀💫

## Actor input object example

```json
{
  "keyword": "Software Engineer",
  "maxItems": 200,
  "country": "us",
  "location": "",
  "includeNoSalaryJob": false,
  "companyName": "",
  "minSalary": 0,
  "fromAge": "ANY",
  "jobType": "all",
  "radius": "18",
  "industryType": "ALL",
  "domainType": "ALL",
  "employerSizes": "ALL",
  "applicationType": "ALL",
  "remoteWorkType": "ANY",
  "seniorityType": "all",
  "minRating": "0",
  "proxyConfiguration": {
    "useApifyProxy": 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 = {
    "keyword": "Software Engineer",
    "proxyConfiguration": {
        "useApifyProxy": false
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("api-empire/glassdoor-jobs-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 = {
    "keyword": "Software Engineer",
    "proxyConfiguration": { "useApifyProxy": False },
}

# Run the Actor and wait for it to finish
run = client.actor("api-empire/glassdoor-jobs-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 '{
  "keyword": "Software Engineer",
  "proxyConfiguration": {
    "useApifyProxy": false
  }
}' |
apify call api-empire/glassdoor-jobs-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Glassdoor Jobs Scraper",
        "description": "💼 Glassdoor Jobs Scraper extracts Glassdoor job postings at scale: titles, companies, locations, salary ranges, employer ratings, descriptions & URLs. 📊 Export-ready data for HR, recruiters & analysts to build pipelines, track pay trends and monitor competitors. 🚀",
        "version": "1.0",
        "x-build-id": "Q9RB7aJcQY1Xaked6"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/api-empire~glassdoor-jobs-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-api-empire-glassdoor-jobs-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/api-empire~glassdoor-jobs-scraper/runs": {
            "post": {
                "operationId": "runs-sync-api-empire-glassdoor-jobs-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/api-empire~glassdoor-jobs-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-api-empire-glassdoor-jobs-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": {
                    "keyword": {
                        "title": "🔎✨ What are you looking for?",
                        "type": "string",
                        "description": "💼 Type the **role, skills, or title** you care about (e.g. *Software Engineer*, *Data Analyst*). This is your main search — make it sparkle! ✨ Leave *Optional bulk URLs* empty to use this mode."
                    },
                    "maxItems": {
                        "title": "🔢📊 How many jobs should we gather?",
                        "minimum": 1,
                        "maximum": 500,
                        "type": "integer",
                        "description": "🎁✨ Set your **sweet spot** — from a tiny taste 🧁 to a **big harvest** 🌾! Higher = more rows in your dataset — **max 500** for power users. 📈🚀",
                        "default": 200
                    },
                    "country": {
                        "title": "🌍🌐 Which Glassdoor site?",
                        "enum": [
                            "us",
                            "ar",
                            "au",
                            "be_nl",
                            "be_fr",
                            "br",
                            "ca_en",
                            "ca_fr",
                            "de",
                            "es",
                            "fr",
                            "hk",
                            "in",
                            "ie",
                            "it",
                            "mx",
                            "nl",
                            "nz",
                            "at",
                            "ch_de",
                            "ch_fr",
                            "sg",
                            "gb",
                            "jp",
                            "kr"
                        ],
                        "type": "string",
                        "description": "🗺️ Choose the **country / language** version of Glassdoor that matches your job hunt. Each option is a real regional site — pick where you want to search! 🌟",
                        "default": "us"
                    },
                    "location": {
                        "title": "📍🏙️🗺️ City or region (optional)",
                        "type": "string",
                        "description": "🌆🎯 Narrow the map: *London*, *Berlin*, *Bay Area*… or leave **blank** for a **worldwide vibe** 🌍✨ — your call!",
                        "default": ""
                    },
                    "includeNoSalaryJob": {
                        "title": "💰📭 Include jobs without a listed salary?",
                        "type": "boolean",
                        "description": "✅ **On** — you’ll also see posts where pay isn’t shown (still useful!). ❌ **Off** — focus only on listings that mention compensation. 💵",
                        "default": false
                    },
                    "companyName": {
                        "title": "🏢💼 Dream employer? (optional)",
                        "type": "string",
                        "description": "🎯 Type part of a **company name** to lean toward those employers — or leave empty to see everyone. ✨",
                        "default": ""
                    },
                    "minSalary": {
                        "title": "💵⬆️ Minimum salary (floor)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "🎯 Only show roles **at or above** this number (uses the **local currency** for the site you picked). Set **0** for *no minimum* — dream big! 🌈",
                        "default": 0
                    },
                    "maxSalary": {
                        "title": "💵⬇️ Maximum salary (ceiling)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "🎀 Cap the range if you want — or leave empty / use **0** for *no upper limit*. Same currency as the site you chose! 🌍"
                    },
                    "fromAge": {
                        "title": "📅⏰ How fresh should listings be?",
                        "enum": [
                            "ANY",
                            "1",
                            "3",
                            "7",
                            "14",
                            "30"
                        ],
                        "type": "string",
                        "description": "🆕 Prefer **brand-new posts** or don’t mind older ones? Pick how many **days back** you’re happy with — great for staying on top of new openings! ⚡",
                        "default": "ANY"
                    },
                    "jobType": {
                        "title": "📄🤝 Contract & work style",
                        "enum": [
                            "all",
                            "fulltime",
                            "parttime",
                            "contract",
                            "temporary",
                            "temp-to-hire",
                            "internship",
                            "entrylevel",
                            "apprenticeship"
                        ],
                        "type": "string",
                        "description": "🧩 **Full-time**, **part-time**, **contract**, **internship**… pick what fits your life stage. Choose **All** to keep every option on the table! 🎉",
                        "default": "all"
                    },
                    "radius": {
                        "title": "📍🚗 How wide should we search?",
                        "enum": [
                            "0",
                            "6",
                            "12",
                            "18",
                            "31",
                            "62",
                            "124"
                        ],
                        "type": "string",
                        "description": "🗺️ When you use a **place**, this is the **circle around it** — wider = more nearby cities; tighter = closer to home. 🏡",
                        "default": "18"
                    },
                    "industryType": {
                        "title": "🏭🧱 Industry — sector focus",
                        "enum": [
                            "ALL",
                            "FINANCIAL",
                            "MANAGEMENT_AND_CONSULTING",
                            "HUMAN_RESSOURCES_AND_RECRUITMENT",
                            "INFORMATION_TECHNOLOGIE"
                        ],
                        "type": "string",
                        "description": "🎯 **All** = every industry 🌈 — or pick a **sector** to zoom in (finance 💰, consulting 📊, HR 👥, tech 💻…). Default: **All**. ✨",
                        "default": "ALL"
                    },
                    "domainType": {
                        "title": "ℹ️🎓 Domain — job family",
                        "enum": [
                            "ALL",
                            "ADMINISTATION",
                            "AFFAIRS",
                            "CONSEIL",
                            "FORMATION",
                            "ENGENERING",
                            "FINANCE",
                            "HUMAN_RESSOURCES_AND_RECRUITMENTS",
                            "INFORMATION_TECHNOLOGIE",
                            "LEGAL",
                            "MEDIA_AND_COMMUNICATION",
                            "PRODUCT_PROJECT_MANAGEMENT",
                            "SCIENCE_RESEARCH",
                            "SELL_AREA"
                        ],
                        "type": "string",
                        "description": "🗂️ **All** = open playing field 🌿 — or choose a **domain** (engineering ⚙️, legal ⚖️, sales 📣…). Default: **All**. 🎨",
                        "default": "ALL"
                    },
                    "employerSizes": {
                        "title": "👥🏢 Employer size — team scale",
                        "enum": [
                            "ALL",
                            "TINY",
                            "SMALL",
                            "MEDIUM",
                            "LARGE",
                            "HUGE"
                        ],
                        "type": "string",
                        "description": "🐣🌆 From **tiny teams** to **huge enterprises** — pick your **company-size vibe** or stay **All** for everything! 💼✨",
                        "default": "ALL"
                    },
                    "applicationType": {
                        "title": "🔗📎 Application type — how to apply",
                        "enum": [
                            "ALL",
                            "EASY_APPLY_INCLUDED",
                            "EASY_APPLY_ONLY"
                        ],
                        "type": "string",
                        "description": "🖱️ **All** = every style ✨ — **Easy Apply included** = mix of flows — **Easy Apply only** = one-click heaven! 🎯 Default: **All**.",
                        "default": "ALL"
                    },
                    "remoteWorkType": {
                        "title": "🏡🌴 Remote work — WFH filter",
                        "enum": [
                            "ANY",
                            "REMOTE_ONLY"
                        ],
                        "type": "string",
                        "description": "🌍 **Any** = remote **and** on-site listings 🏢 — **Remote only** = lean into **WFH-friendly** roles! 🛋️✨ Default: **Any**.",
                        "default": "ANY"
                    },
                    "seniorityType": {
                        "title": "🙌📈 Seniority — career stage",
                        "enum": [
                            "all",
                            "internship",
                            "entrylevel",
                            "midseniorlevel",
                            "director",
                            "executive"
                        ],
                        "type": "string",
                        "description": "🌱 Match your **career chapter**: intern 🎓, entry 🌿, mid–senior 📊, director 👔, executive ⭐ — or **All** to explore! 🚀",
                        "default": "all"
                    },
                    "minRating": {
                        "title": "⭐🛡️ Minimum employer rating",
                        "enum": [
                            "0",
                            "1",
                            "2",
                            "3",
                            "4",
                            "5"
                        ],
                        "type": "string",
                        "description": "💖 Only show employers rated **at least** this high by the community — or **0** for *no bar*. Trust your gut! 🤝",
                        "default": "0"
                    },
                    "proxyConfiguration": {
                        "title": "🌐🔒 Connection & privacy (Apify Proxy)",
                        "type": "object",
                        "description": "🛡️ **Optional.** Use Apify’s proxies for **extra reliability** or when browsing from certain regions — pick what feels right for you. ✨ **Default:** start without extra routing; you can always enable more here! 🚀💫"
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
