# Booksy Scraper (`crawlerbros/booksy-scraper`) Actor

Scrape Booksy - the world's leading beauty appointment booking platform. Search salons, barbers, nail studios, spas, and more by keyword or location. Get ratings, reviews, services, staff, contact info, and booking availability.

- **URL**: https://apify.com/crawlerbros/booksy-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Automation, E-commerce, Lead generation
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $3.00 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

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

## Booksy Scraper

Scrape **Booksy** — the world's leading beauty appointment booking platform with 35M+ users across 150+ countries. Extract salon, barber, nail studio, spa, and other beauty business data including ratings, reviews, services, staff, location, and booking availability.

### What data can you extract?

Each business record includes:

| Field | Description |
|---|---|
| `businessId` | Unique Booksy business identifier |
| `name` | Business name |
| `slug` | URL slug |
| `profileUrl` | Full Booksy profile URL |
| `address` | Full street address |
| `city` | City |
| `latitude` / `longitude` | GPS coordinates |
| `rating` | Average rating (0–5 scale) |
| `reviewCount` | Total number of reviews |
| `starRating` | Star rating (1–5) |
| `category` | Primary service category (e.g. "hair", "nails") |
| `categoryId` | Booksy category ID |
| `serviceCategories` | All service categories offered |
| `staff` | List of staff member names |
| `description` | Business description / bio |
| `website` | Business website URL |
| `facebookUrl` | Facebook page URL |
| `instagramUrl` | Instagram profile URL |
| `ecommerceUrl` | Business's online shop / e-commerce URL (when available) |
| `bookingEnabled` | Whether online booking is available |
| `isRecommended` | Booksy recommended badge |
| `bestOfBooksyBadge` | Best of Booksy award winner |
| `isMobileService` | Mobile/traveling service |
| `pricingLevel` | Pricing tier (1=budget, 4=luxury) |
| `distanceKm` | Straight-line distance from the search location (km), calculated from GPS coordinates |
| `amenities` | Available amenities (parking, WiFi, etc.) |
| `topServices` | Most popular services |
| `imageUrl` | Cover photo URL |
| `logoUrl` | Logo image URL |
| `openHours` | Opening hours by day |
| `isPromoted` | Whether the business has a paid "Promoted" placement |
| `maxDiscountRate` | Maximum active discount rate (%) across services, 0 if none |
| `hasLowAvailability` | Whether Booksy flags the business as having low booking availability |
| `offersVirtualServices` | Whether the business offers online/virtual services |
| `offersOnlineVouchers` | Whether the business sells online vouchers/gift certificates |
| `acceptsBooksyGiftCards` | Whether the business accepts Booksy gift cards |
| `acceptsBooksyPay` | Whether the business accepts Booksy Pay |
| `state` | State/region (`byBusinessId` mode only) |
| `zipCode` | ZIP/postal code (`byBusinessId` mode only) |
| `bookingPolicy` | Cancellation/change policy text, e.g. "Changes allowed up to 2 hours before visit" (`byBusinessId` mode only) |
| `bookingLeadTimeDays` | How many days in advance you can book (`byBusinessId` mode only) |
| `topReviews` | Up to a few recent written reviews with text, rating, reviewer name, date, and service (`byBusinessId` mode only) |
| `sourceUrl` | Booksy search URL used |
| `scrapedAt` | UTC timestamp of scrape |
| `recordType` | Always `"business"` |

### Modes

#### Search mode (default)
Search for businesses by keyword near a location.

```json
{
  "mode": "search",
  "searchQuery": "hair salon",
  "location": "New York",
  "maxItems": 50
}
````

#### By Category mode

Browse all businesses in a specific service category.

```json
{
  "mode": "byCategory",
  "category": "nails",
  "location": "Los Angeles",
  "maxItems": 100
}
```

Available categories: `hair`, `barber`, `nails`, `skin-care`, `brows-and-lashes`, `massage`, `makeup`, `wellness-and-spa`, `braids-and-locs`, `tattoos`, `medical-aesthetics`, `hair-removal`, `home-services`, `piercing`, `pet-services`, `dental`, `health-and-fitness`, `professional-services`, `other`

#### By Business ID mode

Fetch detailed information for specific Booksy businesses.

```json
{
  "mode": "byBusinessId",
  "businessIds": ["688238", "1439833"]
}
```

### Input Options

| Parameter | Type | Description |
|---|---|---|
| `mode` | string | `search`, `byCategory`, or `byBusinessId` |
| `searchQuery` | string | Keyword to search (search mode) |
| `location` | string | City name for location search |
| `latitude` | number | GPS latitude (overrides location) |
| `longitude` | number | GPS longitude (overrides location) |
| `radiusKm` | integer | Search radius hint in km sent to Booksy (default: 10). Booksy's own search may still surface businesses outside this radius when local inventory is thin — the same behavior you'll see searching directly on booksy.com. Use the returned `distanceKm` field to filter/sort results by actual distance if you need a strict radius. |
| `category` | string | Category slug (byCategory mode) |
| `businessIds` | array | Business IDs (byBusinessId mode) |
| `minRating` | number | Minimum rating filter (0–5) |
| `maxRating` | number | Maximum rating filter (0–5) |
| `minReviewCount` | integer | Minimum review count filter |
| `filterCategory` | string | Category filter for search results |
| `isRecommended` | boolean | Filter to recommended businesses only |
| `maxItems` | integer | Maximum records to return (default: 50) |

### Sample Output

```json
{
  "businessId": "1439833",
  "name": "Idamaris Hair Salon",
  "profileUrl": "https://booksy.com/en-us/1439833_idamaris-hair-salon_hair-salon_34846_providence",
  "address": "921 Chalkstone Ave, Providence, 02908",
  "city": "Providence",
  "latitude": 41.833,
  "longitude": -71.438,
  "rating": 4.73,
  "reviewCount": 30,
  "category": "hair",
  "categoryId": 1,
  "isRecommended": true,
  "bookingEnabled": true,
  "sourceUrl": "https://booksy.com/en-us/s/hair-salon",
  "scrapedAt": "2026-06-30T12:00:00+00:00",
  "recordType": "business"
}
```

### Use Cases

- **Lead generation** — Find beauty businesses by city and service type for B2B outreach
- **Competitive analysis** — Compare ratings and services across salons in a market
- **Market research** — Analyze pricing levels and service availability by geography
- **Booking aggregation** — Build city guides for beauty services
- **Reputation monitoring** — Track ratings and review counts over time

### FAQs

**Does this require a Booksy account?**
No. The scraper uses Booksy's public search API — no login or account required.

**What countries does Booksy cover?**
Booksy operates in 150+ countries. This actor targets the US market (`us.booksy.com`) but the approach can be extended.

**How many businesses can I scrape?**
Booksy shows up to 10,000 businesses per search. Set `maxItems` up to 1,000 per run.

**How fresh is the data?**
Data is scraped in real-time directly from Booksy's API.

**Are reviews included?**
Review counts, average rating, and star rating are included in every mode. Individual written reviews (`topReviews` — text, rating, reviewer name, date, service) are only available in `byBusinessId` mode, which also returns additional business profile details (description, staff, top services, amenities, booking policy, state/ZIP).

**Will results always be within my specified radius?**
`radiusKm` is passed to Booksy as a search hint, not a hard filter — Booksy's own search (including on booksy.com) can surface businesses outside the requested radius when local matches are limited. Each business record includes a real `distanceKm` (great-circle distance computed from GPS coordinates), so you can filter or sort post-scrape if you need a strict radius.

# Actor input Schema

## `mode` (type: `string`):

What to scrape.

## `searchQuery` (type: `string`):

Keyword to search (mode=search). Examples: 'hair salon', 'barber', 'nail salon', 'massage', 'eyebrows'.

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

City name to search near (e.g. 'New York', 'Los Angeles', 'Chicago'). Used when latitude/longitude are not provided.

## `latitude` (type: `number`):

GPS latitude for location-based search. Overrides the Location field if provided.

## `longitude` (type: `number`):

GPS longitude for location-based search. Overrides the Location field if provided.

## `radiusKm` (type: `integer`):

Radius in kilometres around the location to search (default: 10 km). This is a hint to Booksy's search, not a hard filter — Booksy may still include businesses outside this radius when local matches are limited (the same happens on booksy.com). Use the returned distanceKm field to filter strictly by distance if needed.

## `category` (type: `string`):

Service category to browse (mode=byCategory).

## `businessIds` (type: `array`):

Booksy business IDs to fetch details for (mode=byBusinessId). Find them in the Booksy URL, e.g. 688238 from https://booksy.com/en-us/688238\_name

## `minRating` (type: `number`):

Only include businesses with a rating at or above this value (0–5 scale).

## `maxRating` (type: `number`):

Only include businesses with a rating at or below this value (0–5 scale).

## `minReviewCount` (type: `integer`):

Only include businesses with at least this many reviews.

## `filterCategory` (type: `string`):

Filter results to a specific category slug (e.g. 'hair', 'nails'). Useful in search mode to narrow results.

## `isRecommended` (type: `boolean`):

If enabled, only return businesses marked as recommended by Booksy.

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

Maximum number of businesses to return.

## Actor input object example

```json
{
  "mode": "search",
  "searchQuery": "hair salon",
  "location": "New York",
  "radiusKm": 10,
  "category": "hair",
  "businessIds": [],
  "isRecommended": false,
  "maxItems": 20
}
```

# Actor output Schema

## `businesses` (type: `string`):

Dataset containing all scraped Booksy businesses with ratings, location, services, and contact info.

# 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 = {
    "mode": "search",
    "searchQuery": "hair salon",
    "location": "New York",
    "radiusKm": 10,
    "category": "hair",
    "businessIds": [],
    "isRecommended": false,
    "maxItems": 20
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/booksy-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 = {
    "mode": "search",
    "searchQuery": "hair salon",
    "location": "New York",
    "radiusKm": 10,
    "category": "hair",
    "businessIds": [],
    "isRecommended": False,
    "maxItems": 20,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/booksy-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 '{
  "mode": "search",
  "searchQuery": "hair salon",
  "location": "New York",
  "radiusKm": 10,
  "category": "hair",
  "businessIds": [],
  "isRecommended": false,
  "maxItems": 20
}' |
apify call crawlerbros/booksy-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Booksy Scraper",
        "description": "Scrape Booksy - the world's leading beauty appointment booking platform. Search salons, barbers, nail studios, spas, and more by keyword or location. Get ratings, reviews, services, staff, contact info, and booking availability.",
        "version": "1.0",
        "x-build-id": "GxEig4dtmKU431uoF"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~booksy-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-booksy-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/crawlerbros~booksy-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-booksy-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/crawlerbros~booksy-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-booksy-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": [
                    "mode"
                ],
                "properties": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "search",
                            "byCategory",
                            "byBusinessId"
                        ],
                        "type": "string",
                        "description": "What to scrape.",
                        "default": "search"
                    },
                    "searchQuery": {
                        "title": "Search query",
                        "type": "string",
                        "description": "Keyword to search (mode=search). Examples: 'hair salon', 'barber', 'nail salon', 'massage', 'eyebrows'.",
                        "default": "hair salon"
                    },
                    "location": {
                        "title": "Location (city name)",
                        "type": "string",
                        "description": "City name to search near (e.g. 'New York', 'Los Angeles', 'Chicago'). Used when latitude/longitude are not provided.",
                        "default": "New York"
                    },
                    "latitude": {
                        "title": "Latitude",
                        "minimum": -90,
                        "maximum": 90,
                        "type": "number",
                        "description": "GPS latitude for location-based search. Overrides the Location field if provided."
                    },
                    "longitude": {
                        "title": "Longitude",
                        "minimum": -180,
                        "maximum": 180,
                        "type": "number",
                        "description": "GPS longitude for location-based search. Overrides the Location field if provided."
                    },
                    "radiusKm": {
                        "title": "Search radius (km)",
                        "minimum": 1,
                        "maximum": 100,
                        "type": "integer",
                        "description": "Radius in kilometres around the location to search (default: 10 km). This is a hint to Booksy's search, not a hard filter — Booksy may still include businesses outside this radius when local matches are limited (the same happens on booksy.com). Use the returned distanceKm field to filter strictly by distance if needed.",
                        "default": 10
                    },
                    "category": {
                        "title": "Category (mode=byCategory)",
                        "enum": [
                            "hair",
                            "barber",
                            "nails",
                            "skin-care",
                            "brows-and-lashes",
                            "massage",
                            "makeup",
                            "wellness-and-spa",
                            "braids-and-locs",
                            "tattoos",
                            "medical-aesthetics",
                            "hair-removal",
                            "home-services",
                            "piercing",
                            "pet-services",
                            "dental",
                            "health-and-fitness",
                            "professional-services",
                            "other"
                        ],
                        "type": "string",
                        "description": "Service category to browse (mode=byCategory).",
                        "default": "hair"
                    },
                    "businessIds": {
                        "title": "Business IDs (mode=byBusinessId)",
                        "type": "array",
                        "description": "Booksy business IDs to fetch details for (mode=byBusinessId). Find them in the Booksy URL, e.g. 688238 from https://booksy.com/en-us/688238_name",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "minRating": {
                        "title": "Minimum rating",
                        "minimum": 0,
                        "maximum": 5,
                        "type": "number",
                        "description": "Only include businesses with a rating at or above this value (0–5 scale)."
                    },
                    "maxRating": {
                        "title": "Maximum rating",
                        "minimum": 0,
                        "maximum": 5,
                        "type": "number",
                        "description": "Only include businesses with a rating at or below this value (0–5 scale)."
                    },
                    "minReviewCount": {
                        "title": "Minimum review count",
                        "minimum": 0,
                        "maximum": 1000000,
                        "type": "integer",
                        "description": "Only include businesses with at least this many reviews."
                    },
                    "filterCategory": {
                        "title": "Filter by category",
                        "type": "string",
                        "description": "Filter results to a specific category slug (e.g. 'hair', 'nails'). Useful in search mode to narrow results."
                    },
                    "isRecommended": {
                        "title": "Recommended businesses only",
                        "type": "boolean",
                        "description": "If enabled, only return businesses marked as recommended by Booksy.",
                        "default": false
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Maximum number of businesses to return.",
                        "default": 50
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
