# Google Maps Business Scraper — Local Leads & Place Data (`bovi/google-maps-scraper`) Actor

Scrape Google Maps business listings — 27 fields per place: name, address, phone, website, rating, reviews, category, lat/lng, hours, amenities, parse\_confidence. For lead generation, market research, competitor analysis. Apify residential proxy — no external key needed.

- **URL**: https://apify.com/bovi/google-maps-scraper.md
- **Developed by:** [Vitalii Bondarev](https://apify.com/bovi) (community)
- **Categories:** Other
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $4.00 / 1,000 places

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

## Google Maps Scraper — Local Leads, Contacts & Place Data

Extract **Google Maps** business listings at scale — name, address, phone, **website + emails + social links**, rating, review count, category, latitude/longitude, **plus-code**, price level, **structured opening hours**, amenity tags, owner-verified flag, and more. This **Google Maps scraper** returns **32 fields per place**, each carrying a `parse_confidence` score and a `parse_path` flag, so you always know your data is clean — not silently broken.

Built for **lead generation**, local SEO audits, market research, and competitor analysis across any city, region, or business category. No Google API key, no external proxy key — it runs entirely on **Apify's residential proxy**.

### Why this Google Maps scraper stands out

- **Contact enrichment is INCLUDED, not a paid add-on.** Flip on `scrapeContacts` and every record gains `emails` and `social_links` (Facebook, Instagram, LinkedIn, X/Twitter, YouTube, TikTok, …) pulled from the business website. The market leader charges roughly **+$2 per 1,000 places** for emails/social as a separate add-on; here it is part of the same run at the same price.
- **Breaks the 20-result ceiling.** The actor **auto-paginates** (via the Maps `!8i` offset token) to return up to **300 places per query**, deduplicated by place ID across pages — instead of the single 20-place page most lightweight scrapers stop at.
- **A real B-plan against format drift.** Google reshuffles its internal response layout between releases — the classic silent killer that makes index-based scrapers return *zero* results that *look* like an empty area. This actor has a **secondary regex/structural parser** that recovers places by stable feature-ID anchors when the primary array-index path drifts. Recovered rows are flagged (`parse_path: "fallback"`, lower `parse_confidence`) so degradation is visible, never silent.
- **Self-rotating against blocks.** On a CAPTCHA / consent wall / poisoned IP, the actor rotates to a fresh residential exit and retries (up to 3×) before giving up on a query — and it **never charges you for a blocked or empty query**.
- **32 rich fields** — including `is_claimed` (owner-verified), `plus_code`, `opening_hours` (structured weekday list), `summary`, `description`, `price_level` (numeric 0–4), `place_id` (ChIJ), `amenities`, and `parse_confidence`.
- **No external key, $0 setup.** Uses the Apify residential proxy pool that ships with your account. No Bright Data token, no Google Cloud project.

### How it compares

| | This actor | `compass/crawler-google-places` | `lukaskrivka/…-contact-details` |
|---|---|---|---|
| Base price (per 1k places) | **$1.00** | ~$2.10–$5.00 | ~$2.10 |
| Emails + social links | ✅ included | ➕ paid add-on (+~$2/1k) | ✅ (separate actor) |
| Results per query | up to **300** (auto-paginate) | ~120–300 | ~120 |
| Format-drift fallback parser | ✅ regex B-plan | — | — |
| Per-record quality score | ✅ `parse_confidence` | — | — |
| External key required | ❌ none | ❌ none | ❌ none |

*(Competitor prices/behaviour as observed on the Apify Store, 2026-06; verify current pricing on each listing.)*

### Input

| Field | Type | Required | Description |
|-------|------|----------|-------------|
| `queries` | array of strings | ✅ | Search queries, e.g. `["coffee shops in San Francisco CA", "plumbers near Austin TX"]`. Each query is paginated up to `maxResults`. |
| `maxResults` | integer | — | Max places per query, **1–300** (default 20). The actor paginates automatically. Google caps a single area near 120–300; split into narrower queries for fuller coverage. |
| `scrapeContacts` | boolean | — | Visit each business website to extract `emails` + `social_links`. Default `false`. Slower, but included at no extra charge. |
| `language` | string | — | Result language code (BCP-47). Default `en`. |
| `country` | string | — | Country code for result localisation. Default `us`. |
| `proxyConfiguration` | object | — | Apify proxy settings. **Must be residential** — Google Maps blocks datacenter IPs. Default: Apify `RESIDENTIAL` group. (Note: the `GOOGLE_SERP` group does **not** support Maps.) |

### Output schema (32 fields)

| Field | Type | Description |
|-------|------|-------------|
| `place_id` | string | Google place ID in ChIJ format |
| `place_id_raw` | string | Raw hex feature ID (`0x…:0x…`) |
| `name` | string | Business name |
| `address` | string | Full street address |
| `latitude` / `longitude` | float | Coordinates |
| `plus_code` | string | Open Location Code (e.g. `849VCWC8+R9`) |
| `phone` | string | Phone number |
| `website` | string | Business website URL |
| `emails` | array | Public emails from the website (when `scrapeContacts` on) |
| `social_links` | object | `{platform: url}` social profiles (when `scrapeContacts` on) |
| `contact_enriched` | bool | Whether website enrichment ran for this record |
| `category` | string | Primary category (e.g. "Coffee shop") |
| `categories` | array | All category objects `[{id, title}]` |
| `rating` | float | Star rating 0.0–5.0 |
| `reviews_count` | int | Number of reviews |
| `price_range` | string | Textual price range (e.g. "$1–10") |
| `price_level` | int | Numeric price level 0–4 (0=free, 4=very expensive) |
| `work_status` | string | Open/closed status (e.g. "Open · Closes 9 PM") |
| `opening_hours` | array | Structured weekly hours `[{day, hours}]` |
| `is_claimed` | bool | Whether the listing is claimed/owner-verified |
| `summary` | string | Short tagline from Google Business Profile |
| `description` | string | Longer business description |
| `image_url` | string | Main listing image URL |
| `amenities` | array | Positive amenity/attribute strings |
| `maps_url` | string | Direct Google Maps link |
| `parse_confidence` | float | Per-record data-quality score 0.0–1.0 |
| `parse_path` | string | `"primary"` (array-index) or `"fallback"` (regex recovery) |
| `warnings` | array | Machine-readable quality-warning codes |
| `query` | string | The search query that produced this result |
| `rank` | int | Position in the result set (1-based) |
| `scraped_at` | string | ISO-8601 UTC timestamp |

### Use cases for Google Maps data extraction

- **Lead generation** — build prospect lists of restaurants, contractors, dentists, gyms, or any local business type by city, complete with phone, website, **email, and socials**.
- **Local SEO audit** — bulk-pull competitor ratings, review counts, and owner-verified (`is_claimed`) status.
- **Market research** — map category distribution, price tiers, and amenity coverage across a metro area.
- **Sales prospecting** — export name + phone + website + email straight to your CRM in one pass.
- **Real-estate & territory analysis** — enrich locations with nearby businesses, services, and coordinates.

### Frequently asked questions

**Do I need a Google API key or a proxy key?** No. The actor runs on the Apify residential proxy pool included with your account. No Google Cloud project, no Bright Data token, nothing external.

**How many results per query?** Up to **300**, paginated automatically. Google itself limits a single area to roughly 120–300 places; for exhaustive coverage of a large city, split the search into narrower queries (per neighborhood or subcategory).

**How does the email/social enrichment work?** With `scrapeContacts` on, the actor fetches each business website (homepage and, if needed, `/contact`) over the same residential proxy and extracts public emails and social-profile links. Hit-rate depends on what the business publishes — some sites list nothing. Records without a website come back with `contact_enriched: false`.

**Is the data stable?** It's resilient by design. The primary parser reads Google's structured internal Maps JSON; if Google reshuffles the layout, a **secondary regex parser** recovers places by stable anchors and flags them (`parse_path: "fallback"`), and `parse_confidence` drops so you see the change before it silently corrupts your pipeline.

**What does `parse_confidence` mean?** A float 0.0–1.0. Values ≥ 0.9 mean all critical fields were extracted cleanly on the primary path. Lower values (or a `regex_fallback_path` warning) signal a format change worth checking.

**Will I get charged for failed queries?** No. The actor charges **per place pushed to the dataset**, after the push. Blocked, empty, or errored queries push nothing and cost nothing.

### Pricing

Pay-per-result: **$1.00 per 1,000 places** (`$0.001` per record) — contact enrichment included, no add-on fees. You pay only for places actually delivered to your dataset.

### Not affiliated with Google

This actor is not affiliated with, endorsed by, or sponsored by Google LLC. Google Maps and Google are trademarks of Google LLC. Scrape responsibly and in compliance with applicable laws and terms.

# Actor input Schema

## `queries` (type: `array`):

One or more Google Maps search queries to scrape. Each query returns up to 20 place results. Examples: 'coffee shops in San Francisco CA', 'plumbers near Austin TX 78701', 'Italian restaurants Manhattan NYC'.
## `proxyConfiguration` (type: `object`):

Apify proxy settings. Google Maps requires residential proxies — datacenter IPs are blocked. Default: Apify RESIDENTIAL group. Note: GOOGLE_SERP proxy does NOT support Maps URLs.
## `maxResults` (type: `integer`):

Maximum number of places to return per search query. The actor paginates automatically (20 per page) to exceed Google's single-page limit — set up to 300. Google itself caps a single area at roughly 120–300 places; for fuller coverage of a city, split into narrower queries (per neighborhood or subcategory).
## `scrapeContacts` (type: `boolean`):

When enabled, the actor visits each business website to extract public email addresses and social-media links (Facebook, Instagram, LinkedIn, X/Twitter, YouTube, TikTok, etc.). Adds emails/social_links/contact_enriched to every record. Slower and only as good as the target site's public contact info, but included at no extra charge (competitors bill this as a paid add-on). Default: off.
## `language` (type: `string`):

Two-letter BCP-47 language code for result language. Default: 'en' (English).
## `country` (type: `string`):

Two-letter ISO country code for result localisation (affects which businesses appear in results). Default: 'us'.

## Actor input object example

```json
{
  "queries": [
    "coffee shops in San Francisco CA"
  ],
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  },
  "maxResults": 20,
  "scrapeContacts": false,
  "language": "en",
  "country": "us"
}
````

# 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 = {
    "queries": [
        "coffee shops in San Francisco CA"
    ],
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ]
    },
    "maxResults": 20,
    "language": "en",
    "country": "us"
};

// Run the Actor and wait for it to finish
const run = await client.actor("bovi/google-maps-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 = {
    "queries": ["coffee shops in San Francisco CA"],
    "proxyConfiguration": {
        "useApifyProxy": True,
        "apifyProxyGroups": ["RESIDENTIAL"],
    },
    "maxResults": 20,
    "language": "en",
    "country": "us",
}

# Run the Actor and wait for it to finish
run = client.actor("bovi/google-maps-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 '{
  "queries": [
    "coffee shops in San Francisco CA"
  ],
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  },
  "maxResults": 20,
  "language": "en",
  "country": "us"
}' |
apify call bovi/google-maps-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Google Maps Business Scraper — Local Leads & Place Data",
        "description": "Scrape Google Maps business listings — 27 fields per place: name, address, phone, website, rating, reviews, category, lat/lng, hours, amenities, parse_confidence. For lead generation, market research, competitor analysis. Apify residential proxy — no external key needed.",
        "version": "0.3",
        "x-build-id": "m6gPfqF1Mcjqtg3we"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/bovi~google-maps-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-bovi-google-maps-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/bovi~google-maps-scraper/runs": {
            "post": {
                "operationId": "runs-sync-bovi-google-maps-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/bovi~google-maps-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-bovi-google-maps-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": [
                    "queries"
                ],
                "properties": {
                    "queries": {
                        "title": "Search Queries",
                        "type": "array",
                        "description": "One or more Google Maps search queries to scrape. Each query returns up to 20 place results. Examples: 'coffee shops in San Francisco CA', 'plumbers near Austin TX 78701', 'Italian restaurants Manhattan NYC'.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Apify proxy settings. Google Maps requires residential proxies — datacenter IPs are blocked. Default: Apify RESIDENTIAL group. Note: GOOGLE_SERP proxy does NOT support Maps URLs.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    },
                    "maxResults": {
                        "title": "Max Results Per Query",
                        "minimum": 1,
                        "maximum": 300,
                        "type": "integer",
                        "description": "Maximum number of places to return per search query. The actor paginates automatically (20 per page) to exceed Google's single-page limit — set up to 300. Google itself caps a single area at roughly 120–300 places; for fuller coverage of a city, split into narrower queries (per neighborhood or subcategory).",
                        "default": 20
                    },
                    "scrapeContacts": {
                        "title": "Scrape Contact Details (emails + social links)",
                        "type": "boolean",
                        "description": "When enabled, the actor visits each business website to extract public email addresses and social-media links (Facebook, Instagram, LinkedIn, X/Twitter, YouTube, TikTok, etc.). Adds emails/social_links/contact_enriched to every record. Slower and only as good as the target site's public contact info, but included at no extra charge (competitors bill this as a paid add-on). Default: off.",
                        "default": false
                    },
                    "language": {
                        "title": "Language",
                        "enum": [
                            "en",
                            "es",
                            "fr",
                            "de",
                            "it",
                            "pt",
                            "ja",
                            "ko",
                            "zh"
                        ],
                        "type": "string",
                        "description": "Two-letter BCP-47 language code for result language. Default: 'en' (English).",
                        "default": "en"
                    },
                    "country": {
                        "title": "Country",
                        "enum": [
                            "us",
                            "gb",
                            "ca",
                            "au",
                            "de",
                            "fr",
                            "es",
                            "it",
                            "jp",
                            "br",
                            "mx",
                            "in"
                        ],
                        "type": "string",
                        "description": "Two-letter ISO country code for result localisation (affects which businesses appear in results). Default: 'us'.",
                        "default": "us"
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
