# Intellectual Property Attorneys Email Scraper (`contacts-api/intellectual-property-attorneys-email-scraper`) Actor

Intellectual property attorneys email scraper to extract verified IP attorney emails from law firms, legal directories, and business listings 📧⚖️ Perfect for legal outreach, partnerships, and targeted intellectual property lead generation.

- **URL**: https://apify.com/contacts-api/intellectual-property-attorneys-email-scraper.md
- **Developed by:** [Lead Heaven](https://apify.com/contacts-api) (community)
- **Categories:** Lead generation, Automation, Other
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN 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

### ⚖️ Intellectual Property Attorneys Email Scraper — Find Verified Law Firm Contacts in Minutes

> The fastest way to build a targeted intellectual property attorneys list. This actor searches Google Maps for IP law firms in any city, crawls their websites, and extracts public emails, phone numbers, and social media profiles — all in one export-ready dataset tailored for legal outreach and BD teams.

---

#### 🚀 Quick Start

1. Enter your search term — e.g., "Intellectual Property Attorneys", "trademark lawyers", "patent attorneys"
2. Add one or more target locations — e.g., "San Francisco, California", "London, UK"
3. Set your desired number of businesses with emails
4. Hit Run and get results in minutes

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

---

#### 💡 What Is the Intellectual Property Attorneys Email Scraper?

The Intellectual Property Attorneys Email Scraper is a specialized lead-generation and contact discovery tool built for:

- Legal marketing teams and business development managers
- Software vendors selling to IP practices (docketing, trademark monitoring, e-billing)
- B2B sales reps and agencies targeting IP boutiques and practice groups

It combines Google Maps discovery with deep website crawling to extract publicly available contact data — producing an accurate, deduplicated intellectual property attorneys list ready for outreach.

Whether you need it as an intellectual property attorneys lead finder, an intellectual property attorneys lead scraper, or an intellectual property attorneys contact finder, this actor covers discovery and extraction in a single automated run. It also functions as an intellectual property attorneys email finder and intellectual property attorneys email extractor for rapid contact capture, and as an intellectual property attorneys data scraper to standardize results across firms.

---

#### 📦 What Data Does It Extract?

| Field | Description |
|---|---|
| Business Name | Law firm or practice 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 intellectual property attorneys email addresses discovered during crawl |
| Additional Phones | Extra phone numbers found on firm sites |
| Social Media Links | LinkedIn, Twitter/X, Facebook, Instagram, 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 |

Note: Emails are collected from publicly visible pages such as Contact, Team, About, and Footer sections — useful for building intellectual property attorneys leads at scale.

---

#### ⚙️ Input Configuration

##### Minimal Example

```json
{
  "googleMapsSearchTerm": "Intellectual Property Attorneys",
  "googleMapsLocation": ["New York"],
  "maxBusinesses": 50
}
````

##### Full Example with All Options

```json
{
  "googleMapsSearchTerm": "Intellectual Property Attorneys",
  "googleMapsLocation": [
    "New York",
    "San Francisco, California",
    "Chicago, Illinois"
  ],
  "maxBusinesses": 200,
  "scrapeMaxBusinessesPerLocation": true,
  "proxyConfiguration": {
    "useApifyProxy": true
  }
}
```

##### Input Parameters

| Parameter | Type | Required | Description |
|---|---|---|---|
| `googleMapsSearchTerm` | String | ✅ Yes | Business type to search — e.g., "Intellectual Property Attorneys", "patent lawyers", "trademark attorneys" |
| `googleMapsLocation` | Array | ✅ Yes | One or more locations — e.g., \["New York", "London, UK"] |
| `maxBusinesses` | Number | ❌ No | Max businesses with emails to return (1–1,000). Actor stops when this limit is reached |
| `scrapeMaxBusinessesPerLocation` | Boolean | ❌ No | If true, applies the cap per location; if false, total is combined across all locations |
| `proxyConfiguration` | Object | ❌ No | Proxy settings. Strongly recommended for large runs to avoid rate limits |

***

#### 📤 Sample Output

```json
[
  {
    "name": "Apex IP Law Group",
    "website": "https://www.apexiplawgroup.com",
    "phone": "+1 212-555-0142",
    "full_address": "445 Madison Ave, New York, NY 10022, United States",
    "city": "New York",
    "state": "NY",
    "zip": "10022",
    "country_code": "US",
    "scraped_emails": [
      "info@apexiplawgroup.com",
      "trademarks@apexiplawgroup.com"
    ],
    "scraped_phones": ["+1 212-555-0142", "+1 212-555-0177"],
    "scraped_social_media": [
      "linkedin:https://www.linkedin.com/company/apex-ip-law-group",
      "twitter:https://twitter.com/apexiplaw"
    ],
    "emails_found": 2,
    "pages_scraped": 18,
    "avg_rating": 4.7,
    "total_reviews": 53,
    "lat": 40.7591,
    "long": -73.9745,
    "place_id": "ChIJ7-EXAMPLEID",
    "scrape_status": "success"
  }
]
```

***

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

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

The pipeline operates as both a discovery engine and an intellectual property attorneys email scraper, ensuring you get verified contacts with minimal noise.

***

#### ✨ Key Features

##### 🎯 Precise Geo-Targeting

Pinpoint IP firms and practice groups in any city, region, or country. Build hyper-local intellectual property attorneys leads aligned to your territories.

##### 🔍 Deep Website Crawl for Contacts

Goes beyond Google listings. Crawls Contact, Team, and About pages to surface every available public intellectual property attorneys email and phone number.

##### 🧭 Purpose-Built for Legal BD

Designed around law-firm sites and practice pages — ideal as an intellectual property attorneys contact scraper and intellectual property attorneys contact finder for outreach.

##### 🧹 Smart De-Duplication

Cleans duplicate emails per domain so your export is precise and CRM-ready.

##### 🌎 Multi-Location Scaling

Run across dozens of cities or countries at once. Choose a combined cap or a per-location cap — perfect for growing an intellectual property attorneys list efficiently.

##### 🛡️ Proxy-Ready Reliability

Built-in proxy support enables stable, large-scale runs without rate-limiting — essential for agency-grade intellectual property attorneys data scraper workflows.

##### ⚡ Instant, Structured Output

Normalized fields with consistent naming. Ready for HubSpot, Salesforce, Apollo, or Instantly without reformatting.

##### ⏱️ Target-Based Stop

Stops automatically when your maxBusinesses threshold is hit — no wasted compute.

***

#### 🎯 Use Cases

##### 💼 B2B Sales & Partnerships

Fill your pipeline with intellectual property attorneys leads for software, research tools, docketing services, and litigation support. Use as an intellectual property attorneys lead scraper to fuel targeted campaigns.

##### 📣 Legal Marketing & ABM

Run city-by-city campaigns, capture team inboxes and practice contacts, and build a clean intellectual property attorneys list for account-based initiatives.

##### 🧪 Product Validation & Research

Validate market coverage for legaltech offerings by compiling firm coverage with an intellectual property attorneys data scraper.

##### 🤝 Channel & Ecosystem Mapping

Identify boutiques and practice groups for referral and reseller partnerships using the built-in intellectual property attorneys lead finder.

##### 🧑‍💼 Recruiting & Lateral Outreach

Locate firms and practice contacts for recruiter pipelines with an effective intellectual property attorneys contact finder.

***

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

Scale from a small prospect list to a national database. Results depend on:

- Number of locations added
- Breadth of your search term (e.g., “patent attorney” vs. “intellectual property law firm”)
- Website density and email visibility in each market
- maxBusinesses limit and per-location vs. combined mode
- Proxy configuration and run timeout

Typical output ranges:

- Small (1–3 cities): 20–100 businesses with emails
- Medium (5–15 cities): 200–600 businesses with emails
- Large (20+ cities / states): 800–1,000+ per run

Run multiple times across different regions and practice keywords to continuously grow your intellectual property attorneys leads.

***

#### 🔌 Integrations & Export Options

Once your run completes, you can:

- Download JSON for full structured data
- Export CSV / Excel for spreadsheets
- Consume data via the Apify API
- Trigger Zapier/Make automations on completion
- Use webhooks to push results into your CRM

Plug directly into Instantly, Smartlead, Apollo, HubSpot, Salesforce, or any 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 "Intellectual Property Attorneys Email Scraper" in the Apify Store and click Try for free.

- Step 3 — Set Your Search Term
  Enter "Intellectual Property Attorneys" or a niche variant like "patent attorneys", "trademark lawyers", or "IP litigation firm".

- Step 4 — Add Target Locations
  Enter one or more city/state/country targets — e.g., "New York", "Austin, Texas", "Toronto, Canada".

- 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 (all locations) or per-location cap for even geographic distribution.

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

- Step 8 — Run 🚀
  Click Start and let the Intellectual Property Attorneys 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 law firm websites.

Best practices to stay compliant:

- Use only 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:

- GDPR (EU)
- CAN-SPAM Act (US)
- CASL (Canada)
- PECR (UK)

This tool is intended for ethical business prospecting only. You are responsible for how you use the data collected. Use the intellectual property attorneys email extractor capabilities responsibly.

***

#### ❓ Frequently Asked Questions

Q: Does this scrape private or personal emails?
A: No. The actor only extracts emails that are publicly visible on firm websites — practice inboxes, admin contacts, and general inquiry addresses. It focuses on intellectual property attorneys email data that’s openly published.

Q: Can I search multiple cities in one run?
A: Yes. Add as many locations as needed. Use per-location capping for even geographic distribution and a balanced intellectual property attorneys list.

Q: Does it deduplicate results?
A: Yes. Emails are deduplicated per domain to keep your CRM entries clean.

Q: Can I schedule recurring runs?
A: Absolutely. Use Apify’s scheduler to run weekly or monthly and keep your intellectual property attorneys leads fresh.

Q: What search terms work best?
A: Try "Intellectual Property Attorneys", "patent attorney", "trademark lawyer", "IP law firm", or "IP litigation". For broader coverage, run separate campaigns per keyword using this intellectual property attorneys lead finder.

Q: Are proxies required?
A: Not for small runs, but strongly recommended for 200+ businesses to avoid rate limits and ensure reliability for your intellectual property attorneys contact scraper workflows.

Q: What export formats are available?
A: JSON, CSV, and Excel. You can also consume results via the Apify API or webhook.

Q: How is this different from manual search?
A: Manual search is slow and inconsistent. This actor automates discovery and extraction end-to-end — acting as an intellectual property attorneys email finder and lead scraper — so you get results in minutes.

Q: Can agencies white-label or resell this?
A: Yes. Run it on behalf of clients and deliver fresh intellectual property attorneys leads on a recurring basis.

***

#### 🧑‍💻 Support & Custom Solutions

Have a question, feature request, or need a custom build for your legal niche (e.g., patent boutiques, brand protection teams, or IP litigation groups)? We can help with:

- Custom input/output fields and enrichment
- Niche-specific page targeting (Team/Attorney pages, practice pages)
- Scaling and proxy setup
- CRM integrations and automations

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": "Intellectual Property Attorneys",
  "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": "Intellectual Property Attorneys",
    "googleMapsLocation": [
        "New York"
    ],
    "maxBusinesses": 5,
    "proxyConfiguration": {
        "useApifyProxy": true
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("contacts-api/intellectual-property-attorneys-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": "Intellectual Property Attorneys",
    "googleMapsLocation": ["New York"],
    "maxBusinesses": 5,
    "proxyConfiguration": { "useApifyProxy": True },
}

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

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Intellectual Property Attorneys Email Scraper",
        "description": "Intellectual property attorneys email scraper to extract verified IP attorney emails from law firms, legal directories, and business listings 📧⚖️ Perfect for legal outreach, partnerships, and targeted intellectual property lead generation.",
        "version": "1.0",
        "x-build-id": "d3TSWTmb0ueNGUFex"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/contacts-api~intellectual-property-attorneys-email-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-contacts-api-intellectual-property-attorneys-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~intellectual-property-attorneys-email-scraper/runs": {
            "post": {
                "operationId": "runs-sync-contacts-api-intellectual-property-attorneys-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~intellectual-property-attorneys-email-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-contacts-api-intellectual-property-attorneys-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": "Intellectual Property Attorneys"
                    },
                    "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
