# Dental Laboratories Email Scraper (`contacts-api/dental-laboratories-email-scraper`) Actor

Dental laboratories email scraper to extract verified emails from dental labs, dental prosthetic manufacturers, dental technology centers, and dental industry directories 📧🦷🔬 Perfect for B2B outreach, supplier partnerships, and dental industry lead generation.

- **URL**: https://apify.com/contacts-api/dental-laboratories-email-scraper.md
- **Developed by:** [Lead Heaven](https://apify.com/contacts-api) (community)
- **Categories:** Lead generation, Automation, Developer tools
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $1.99 / 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

### 🦷 Dental Laboratories Email Scraper — Find Verified Leads In Minutes

> The fastest way to build a targeted dental laboratories list. This dental laboratories email scraper searches Google Maps for dental labs across any city, crawls their websites, and extracts public dental laboratories email addresses, phone numbers, and social media profiles — all in one clean, export-ready dataset.

---

#### 🚀 Quick Start

1. Enter your search term — e.g., "Dental Laboratories"
2. Add one or more target locations — e.g., "New York", "Los Angeles"
3. Set your desired number of businesses with emails
4. Hit Run and get your results in minutes

No coding required. Export to CSV, JSON, or Excel instantly.

---

#### 💡 What Is The Dental Laboratories Email Scraper?

The Dental Laboratories Email Scraper is a purpose-built lead generation and contact discovery tool for:

- Dental product manufacturers and distributors
- Outsourced crown/bridge, ortho, and implant solution providers
- Marketing and sales teams targeting labs
- Researchers and data analysts mapping lab ecosystems

It combines Google Maps listing discovery with deep website crawling to extract publicly available contact data — producing an accurate, deduplicated pipeline of dental laboratories leads ready for immediate use. Whether you need a dental laboratories lead finder to surface prospects, a dental laboratories email extractor for verified inboxes, or a dental laboratories contact finder to enrich your CRM, this actor covers it all. Use it as your dental laboratories lead scraper for discovery at scale or as a dental laboratories email finder for precise outreach.

In short, if you're building a dental laboratories list across multiple regions, this dental laboratories email scraper automates the entire process reliably.

---

#### 📦 What Data Does It Extract?

| Field | Description |
|---|---|
| Business Name | Lab or company name from Google Maps |
| Website | Official website URL |
| Phone | Primary phone from the listing or website |
| Full Address | Complete address as listed |
| City / State / ZIP | Parsed location components |
| Country Code | ISO country code where available |
| Emails | All public dental laboratories email addresses found on the website |
| Additional Phones | Extra phone numbers discovered during crawl |
| Social Media Links | Facebook, Instagram, LinkedIn, Twitter, and more |
| Email Count | Total unique emails found per business |
| Pages Scraped | Number of website pages crawled per domain |
| Rating | Average Google Maps star rating |
| Reviews | Total number of Google reviews |
| Latitude / Longitude | Geo-coordinates for mapping and filtering |
| Place ID | Google Maps place identifier |
| Scrape Status | Per-record status: success, partial, or error |

---

#### ⚙️ Input Configuration

##### Minimal Example

```json
{
  "googleMapsSearchTerm": "Dental Laboratories",
  "googleMapsLocation": ["New York"],
  "maxBusinesses": 50
}
````

##### Full Example With All Options

```json
{
  "googleMapsSearchTerm": "Dental Laboratories",
  "googleMapsLocation": [
    "New York",
    "Los Angeles, California",
    "Chicago, Illinois"
  ],
  "maxBusinesses": 200,
  "scrapeMaxBusinessesPerLocation": true,
  "proxyConfiguration": {
    "useApifyProxy": true
  }
}
```

##### Input Parameters

| Parameter | Type | Required | Description |
|---|---|---|---|
| `googleMapsSearchTerm` | String | ✅ Yes | Business type or niche — e.g., "Dental Laboratories", "dental labs", "ceramic dental lab" |
| `googleMapsLocation` | Array | ✅ Yes | One or more locations — e.g., \["New York", "Dallas, Texas"] |
| `maxBusinesses` | Number | ❌ No | Target number of businesses with emails to return (1–1,000). The run stops when this is reached |
| `scrapeMaxBusinessesPerLocation` | Boolean | ❌ No | If true, applies `maxBusinesses` per location. If false, it's a combined total across all locations |
| `proxyConfiguration` | Object | ❌ No | Proxy settings. Recommended for larger runs to avoid rate limits |

***

#### 📤 Sample Output

```json
[
  {
    "name": "Precision Dental Lab",
    "website": "https://www.precisiondentallabny.com",
    "phone": "+1 212-555-0148",
    "full_address": "245 W 35th St, Suite 1201, New York, NY 10001, United States",
    "city": "New York",
    "state": "NY",
    "zip": "10001",
    "country_code": "US",
    "scraped_emails": [
      "info@precisiondentallabny.com",
      "orders@precisiondentallabny.com"
    ],
    "scraped_phones": ["+1 212-555-0148", "+1 212-555-0172"],
    "scraped_social_media": [
      "linkedin:https://www.linkedin.com/company/precision-dental-lab-ny",
      "facebook:https://www.facebook.com/precisiondentallabny"
    ],
    "emails_found": 2,
    "pages_scraped": 11,
    "avg_rating": 4.7,
    "total_reviews": 53,
    "lat": 40.7529,
    "long": -73.9925,
    "place_id": "ChIJ-EXAMPLENYID",
    "scrape_status": "success"
  }
]
```

***

#### 🔧 How It Works — Under The Hood

```
Step 1 → Search Google Maps using your term + locations
Step 2 → Collect lab listings (name, address, phone, website)
Step 3 → Visit each website and crawl key pages (Home, Contact, About, Footer)
Step 4 → Extract public emails, phone numbers, and social media links
Step 5 → Deduplicate and normalize all contact data
Step 6 → Return structured results ready for export or API consumption
```

Built to function as both a dental laboratories lead scraper (discovery) and a dental laboratories email extractor (contact capture) in a single automated workflow.

***

#### ✨ Key Features

##### 🎯 Precise Location Targeting

Enter any city, state, or region. The actor pinpoints labs in your exact target areas — delivering hyper-local dental laboratories leads you can act on.

##### 🔍 Deep Website Crawl

Goes beyond the listing. Crawls homepages, contact pages, about pages, and footers to surface every public dental laboratories email, phone, and profile link, acting as a dependable dental laboratories contact scraper.

##### 🌎 Multi-Location Scaling

Run across dozens of cities at once. Choose a combined cap or a per-location cap — perfect for building a large, multi-market dental laboratories list without manual effort.

##### 🧹 Smart De-Duplication

Automatically removes duplicate emails per domain so your dataset stays clean and accurate — no messy cleanup required after export.

##### 📊 Structured, CRM-Ready Output

Consistent fields and normalized values make it easy to plug results into HubSpot, Salesforce, Apollo, Instantly, or any outreach stack. It’s a reliable dental laboratories data scraper for analytics and reporting.

##### 🛡️ Proxy-Ready For Reliability

Built-in proxy support enables stable, large-scale runs without rate-limiting or IP blocks — ideal for agency-level campaigns.

##### ⏱️ Stop At Your Target

The dental laboratories email scraper halts as soon as your `maxBusinesses` limit is reached — no wasted compute, no overage.

##### 🔄 Schedulable & Repeatable

Run daily, weekly, or monthly to continuously grow and refresh your dental laboratories leads.

***

#### 🎯 Use Cases

##### 💼 B2B Outreach & Sales

- Build pitch lists of crown/bridge, ortho, and implant labs by region. Use this dental laboratories lead finder to fuel cold email sequences and inbound pipelines.
- Enrich cold outreach with verified dental laboratories email addresses for higher deliverability.

##### 🧪 Supplier & Manufacturer Targeting

- Identify labs that fit your product profile (CAD/CAM, zirconia, full contour). Treat it as your dental laboratories contact finder for product demos and samples.
- Quickly generate a regional dental laboratories list for trade-show follow-ups.

##### 🗺️ Market Mapping & Research

- Map active labs, ratings, and locations across markets to assess coverage and demand. The actor doubles as a dental laboratories data scraper for competitive analysis.

##### 🧑‍💻 Agency Client Delivery

- Run repeatable scrapes and deliver fresh dental laboratories leads to clients on predictable schedules using the built-in scheduler and exports.

##### 🗃️ CRM Enrichment & Data Hygiene

- Use the dental laboratories email finder to fill in missing emails, phones, and social links on existing records. De-duplicate by domain to keep data clean.

##### 🧑‍🔧 Recruiting & Staffing

- Identify labs by specialty and region to source owners and ops contacts. Use the dental laboratories lead scraper to uncover contact points not listed on directories.

***

#### 📈 How Many Results Can You Get?

Scale from a small prospect list to a large regional database — results depend on:

- Number of locations added
- Search term breadth (e.g., “Dental Laboratories” vs. “Zirconia Dental Labs”)
- Website density and email visibility in each market
- `maxBusinesses` setting and per-location vs. combined mode
- Proxy configuration and run timeout

##### Typical Output Ranges

| Campaign Size | Businesses With Emails |
|---|---|
| Small (1–3 cities) | 30 – 120 |
| Medium (5–15 cities) | 200 – 600 |
| Large (20+ cities / states) | 800 – 1,000+ per run |

Run across different regions to continuously grow your dental laboratories list without hitting hard platform limits.

***

#### 🔌 Integrations & Export Options

Once your run completes, you can:

| Option | Details |
|---|---|
| JSON | Full structured data download |
| CSV / Excel | Import directly into spreadsheets |
| Apify API | Stream results into your own apps or workflows |
| Zapier / Make | Trigger automations when new leads are found |
| Webhooks | Push results to your CRM or pipeline on run completion |

Plug directly into Instantly, Smartlead, Apollo, HubSpot, Salesforce, or any outreach platform that accepts CSV/JSON imports.

***

#### 🛠️ Step-By-Step Usage Guide

- Step 1 — Log In To Apify\
  Create a free account or sign in at apify.com.

- Step 2 — Open The Actor\
  Search for "Dental Laboratories Email Scraper" in the Apify Store and click Try for Free.

- Step 3 — Set Your Search Term\
  Enter "Dental Laboratories" or a niche variant like "CAD/CAM dental lab", "zirconia dental lab", or "denture lab".

- Step 4 — Add Target Locations\
  Enter one or more city/state combos — e.g., "New York", "Dallas, Texas", "Seattle, Washington".

- Step 5 — Set Your Limit\
  Choose how many businesses with emails you want — 20 for a quick test, up to 1,000 for a full campaign.

- Step 6 — Choose Scaling Strategy\
  • Combined cap: The total across all locations combined\
  • Per-location cap: Applies your limit independently to each city

- Step 7 — Enable Proxies\
  Turn on Apify Proxy for stable, uninterrupted crawling at scale.

- Step 8 — Run 🚀\
  Click Start and let the dental laboratories email scraper do the work.

- Step 9 — Export\
  Download as JSON, CSV, or Excel — or pull via API straight into your stack.

***

#### ⚖️ Legal & Compliance

This actor collects only publicly available business contact information — emails and phone numbers published openly on websites.

Best practices to stay compliant:

- Only use publicly visible contact data
- Do not bypass login walls or paywalls
- Respect each website’s robots.txt and Terms of Service
- Include an unsubscribe option in all outreach
- Follow applicable laws in your jurisdiction

Relevant regulations to be aware of:

- GDPR (European Union)
- CAN-SPAM Act (United States)
- CASL (Canada)
- PECR (United Kingdom)

This tool is intended for ethical business prospecting only. You are responsible for how you use the data collected.

***

#### ❓ Frequently Asked Questions

**Does this scrape private or personal emails?**\
No. The actor only extracts emails that are publicly visible on business websites — general lab inboxes, admin contacts, and order addresses. It functions as a compliant dental laboratories email extractor.

**Can I search multiple cities in one run?**\
Yes. Add as many locations as needed. Use per-location capping for even geographic distribution.

**Does it deduplicate results?**\
Yes. Emails are deduplicated per domain to keep your dental laboratories leads accurate and clean.

**Is a proxy required?**\
Not for small runs, but strongly recommended for 200+ business runs to avoid rate limits and maximize stability.

**What niches do the search terms support?**\
Any Google Maps searchable term — try "dental laboratories", "dental lab CAD/CAM", "denture laboratory", or "ceramic crown lab".

**How is this different from manual searching?**\
Manual search is slow and inconsistent. This actor automates discovery and extraction — serving as a dental laboratories lead finder and dental laboratories contact scraper — and returns a structured dataset in minutes.

**Can agencies resell or white-label this?**\
Yes. Run it on behalf of clients and deliver refreshed datasets. Many agencies rely on a dental laboratories lead scraper to power ongoing outreach.

**Can I use it purely for research?**\
Absolutely. Treat it as a dental laboratories data scraper to analyze markets, map coverage, and benchmark ratings/reviews.

***

#### 🧑‍💻 Support & Custom Solutions

Have a question, feature request, or need a custom build?\
Email: scrapermindapi@gmail.com

We’re happy to help with:

- Custom input/output configurations
- Niche-specific adaptations (e.g., CAD/CAM, zirconia, ortho)
- Bulk or enterprise run support
- Integration assistance

For any help or custom solution, contact via this mail: scrapermindapi@gmail.com

# Actor input Schema

## `googleMapsSearchTerm` (type: `string`):

Enter the business type or niche for email scraper (e.g., 'coffee shops', 'dentists').

## `googleMapsLocation` (type: `array`):

Target geographic location for the email scraper (e.g., 'Miami, Florida').

## `maxBusinesses` (type: `integer`):

Target number of businesses to find (1-1000). The scraper will stop when this target is reached.

## `scrapeMaxBusinessesPerLocation` (type: `boolean`):

If enabled, the scraper will collect up to `maxBusinesses` results per location. If disabled, it combines all locations up to a single total limit.

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

Proxy settings for scraping. Recommended for large-scale scraping.

## Actor input object example

```json
{
  "googleMapsSearchTerm": "Dental Laboratories",
  "googleMapsLocation": [
    "New York"
  ],
  "maxBusinesses": 5,
  "scrapeMaxBusinessesPerLocation": false,
  "proxyConfiguration": {
    "useApifyProxy": true
  }
}
```

# 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 = {
    "googleMapsSearchTerm": "Dental Laboratories",
    "googleMapsLocation": [
        "New York"
    ],
    "maxBusinesses": 5,
    "proxyConfiguration": {
        "useApifyProxy": true
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("contacts-api/dental-laboratories-email-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 = {
    "googleMapsSearchTerm": "Dental Laboratories",
    "googleMapsLocation": ["New York"],
    "maxBusinesses": 5,
    "proxyConfiguration": { "useApifyProxy": True },
}

# Run the Actor and wait for it to finish
run = client.actor("contacts-api/dental-laboratories-email-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 '{
  "googleMapsSearchTerm": "Dental Laboratories",
  "googleMapsLocation": [
    "New York"
  ],
  "maxBusinesses": 5,
  "proxyConfiguration": {
    "useApifyProxy": true
  }
}' |
apify call contacts-api/dental-laboratories-email-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Dental Laboratories Email Scraper",
        "description": "Dental laboratories email scraper to extract verified emails from dental labs, dental prosthetic manufacturers, dental technology centers, and dental industry directories 📧🦷🔬 Perfect for B2B outreach, supplier partnerships, and dental industry lead generation.",
        "version": "1.0",
        "x-build-id": "jKaeo57pOaMDIg0ZD"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/contacts-api~dental-laboratories-email-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-contacts-api-dental-laboratories-email-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/contacts-api~dental-laboratories-email-scraper/runs": {
            "post": {
                "operationId": "runs-sync-contacts-api-dental-laboratories-email-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/contacts-api~dental-laboratories-email-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-contacts-api-dental-laboratories-email-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",
                "required": [
                    "googleMapsLocation",
                    "googleMapsSearchTerm"
                ],
                "properties": {
                    "googleMapsSearchTerm": {
                        "title": "Search Term",
                        "type": "string",
                        "description": "Enter the business type or niche for email scraper (e.g., 'coffee shops', 'dentists').",
                        "default": "Dental Laboratories"
                    },
                    "googleMapsLocation": {
                        "title": "Location",
                        "type": "array",
                        "description": "Target geographic location for the email scraper (e.g., 'Miami, Florida').",
                        "default": [
                            "New York"
                        ],
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxBusinesses": {
                        "title": "Maximum Businesses With Emails",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Target number of businesses to find (1-1000). The scraper will stop when this target is reached.",
                        "default": 5
                    },
                    "scrapeMaxBusinessesPerLocation": {
                        "title": "Scrape Max Businesses Per Location",
                        "type": "boolean",
                        "description": "If enabled, the scraper will collect up to `maxBusinesses` results per location. If disabled, it combines all locations up to a single total limit.",
                        "default": false
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings for scraping. Recommended for large-scale scraping."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
