# Treatwell.co.uk UK Salon Scraper (`unfenced-group/treatwell-scraper`) Actor

Extract salon data from Treatwell.co.uk: venue names, locations, ratings, full service menus with prices, opening hours, GPS coordinates, and images. No proxy, no API key required.

- **URL**: https://apify.com/unfenced-group/treatwell-scraper.md
- **Developed by:** [Unfenced Group](https://apify.com/unfenced-group) (community)
- **Categories:** E-commerce, Other
- **Stats:** 2 total users, 1 monthly users, 0.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

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

## Treatwell Salon Scraper

![Banner](https://i.imgur.com/placeholder_treatwell.png)

Scrape salon and beauty venue data from Treatwell.co.uk at scale — up to 2,000+ venues per search. Extracts business information, service menus with prices, ratings, opening hours, coordinates, and images. No API key required.

---

### Why this scraper?

#### 🎯 Rich service data
Extracts the complete service menu for every salon — service name, duration, display price, original price, and discount type (off-peak, last-minute, sale). Captures up to 3 featured services from search results and all services from the venue detail page.

#### ⭐ Comprehensive ratings
Captures overall star rating and total review count directly from listing cards and venue pages — same data shown to Treatwell customers when choosing a salon.

#### 📍 Precise location data
Extracts structured address, postcode, and GPS coordinates (latitude/longitude) from JSON-LD and venue detail pages for location-based analysis.

#### 🕐 Full opening hours
Fetches complete weekly opening schedules (Mon–Sun, open/close times or Closed) from each venue's detail page.

#### 🏷️ Venue tags and badges
Captures Treatwell-assigned tags such as "top-rated", "off-peak", "last minute", and "new" — useful for competitive analysis and discount monitoring.

#### 🖼️ High-resolution images
Collects all venue image URLs in multiple sizes (360w, 720w, 1080w, 1280w) from Treatwell's CDN.

---

### Input parameters

| Parameter | Type | Default | Description |
|---|---|---|---|
| `treatment` | string | `hair` | Treatment or category to search for. Examples: `balayage`, `gel nails`, `deep tissue massage`, `ladies haircut`, `manicure`, `waxing`, `microblading`. Broad categories also work: `hair`, `nails`, `massage`, `face`, `body`, `hair-removal`. |
| `location` | string | `london` | City, town, or London neighbourhood. Examples: `manchester`, `edinburgh`, `birmingham`, `bristol`, `shoreditch`, `camden`, `brixton`, `notting hill`. |
| `maxResults` | integer | 100 | Maximum number of venues to return. Controls spend — each page contains 20 venues. |
| `fetchDetails` | boolean | `true` | Fetch each venue's detail page for full opening hours (Mon–Sun), complete service menu with prices, GPS coordinates, postcode, phone, and full description. Disable for a fast listing-only run. |
| `startUrls` | array | `[]` | *(Advanced)* Scrape specific venue pages directly by URL — paste `treatwell.co.uk/place/...` URLs. When set, `treatment` and `location` are ignored. |
| `searchUrls` | array | `[]` | *(Advanced)* Supply raw Treatwell browse URLs to override the URL builder entirely. When set, `treatment` and `location` are ignored. |

---

### Output schema

#### Always present

| Field | Type | Description |
|---|---|---|
| `venueId` | string | Treatwell venue slug (unique identifier, e.g. `bottega-hair-salon`) |
| `url` | string | Full Treatwell venue URL |
| `name` | string | Venue/salon name |
| `location` | string | Neighbourhood and city as shown on listing card (e.g. `Barnes, London`) |
| `ratingValue` | number | Average rating out of 5.0 (null if no reviews) |
| `reviewCount` | integer | Total number of customer reviews |
| `images` | array | Array of CDN image URLs in multiple sizes |
| `tags` | array | Treatwell venue tags: `top-rated`, `off-peak`, `last minute`, `new` |
| `services` | array | Up to 3 featured services from search listing, each with `serviceId`, `name`, `duration`, `displayPrice`, `originalPrice`, `discountText` |
| `source` | string | Always `treatwell.co.uk` |
| `scrapedAt` | string | ISO 8601 timestamp of when this record was scraped |
| `contentHash` | string | MD5 fingerprint for change detection |
| `searchUrl` | string | The search URL this venue was found on |
| `descriptionHtml` | string | Venue description as HTML (null if unavailable) |
| `descriptionText` | string | Venue description as plain text |
| `descriptionMarkdown` | string | Venue description as Markdown |

#### With `fetchDetails: true`

| Field | Type | Description |
|---|---|---|
| `address` | string | Full street address (null if not published) |
| `postalCode` | string | UK postcode (null if not published) |
| `coordinates` | object | `{ lat, lon }` — GPS coordinates (null if not published) |
| `openingHours` | array | Weekly schedule, each entry: `{ dayOfWeek, open, from, to }` |
| `phone` | string | Phone number if displayed on venue page (null if not published) |
| `amenities` | array | Venue amenity tags (wheelchair access, parking, etc.) |
| `brands` | array | Hair/beauty product brands used at the venue |
| `ratingDimensions` | array | Category-level rating breakdown where available |
| `allServices` | array | Complete service menu from detail page (more items than `services`) |

#### JSON example

```json
{
  "venueId": "bottega-hair-salon",
  "url": "https://www.treatwell.co.uk/place/bottega-hair-salon/",
  "name": "Bottega Hair Salon",
  "location": "Barnes, London",
  "ratingValue": 4.9,
  "reviewCount": 671,
  "images": [
    "https://cdn1.treatwell.net/images/view/v2.i8009934.w720.h480.x48033557/",
    "https://cdn1.treatwell.net/images/view/v2.i8009933.w720.h480.xBBFDADA0/"
  ],
  "tags": ["top-rated", "off-peak"],
  "services": [
    {
      "serviceId": "1359192819",
      "name": "Glossy Blow Dry",
      "duration": "1 hr",
      "displayPrice": "from £49",
      "originalPrice": null,
      "discountText": "save up to 90%"
    }
  ],
  "address": "49 White Hart Ln, London SW13 0PP",
  "postalCode": "SW13 0PP",
  "coordinates": { "lat": 51.4716, "lon": -0.2464 },
  "openingHours": [
    { "dayOfWeek": "Monday", "open": true, "from": "8:00 AM", "to": "8:00 PM" },
    { "dayOfWeek": "Sunday", "open": false, "from": null, "to": null }
  ],
  "phone": null,
  "amenities": [],
  "brands": ["Elgon", "Olaplex", "L'Oréal"],
  "descriptionHtml": "<p>Benvenuto, to Bottega Hair Salon...</p>",
  "descriptionText": "Benvenuto, to Bottega Hair Salon...",
  "descriptionMarkdown": "Benvenuto, to Bottega Hair Salon...",
  "source": "treatwell.co.uk",
  "scrapedAt": "2026-06-01T10:00:00.000Z",
  "contentHash": "a1b2c3d4e5f6a7b8"
}
````

***

### Examples

**Balayage salons in London:**

```json
{
  "treatment": "balayage",
  "location": "london",
  "maxResults": 100,
  "fetchDetails": true
}
```

**Gel nail bars in Manchester:**

```json
{
  "treatment": "gel nails",
  "location": "manchester",
  "maxResults": 50,
  "fetchDetails": true
}
```

**All massage venues in Edinburgh (fast listing run):**

```json
{
  "treatment": "massage",
  "location": "edinburgh",
  "maxResults": 200,
  "fetchDetails": false
}
```

**Deep tissue massage in a specific London area:**

```json
{
  "treatment": "deep tissue massage",
  "location": "shoreditch",
  "maxResults": 30,
  "fetchDetails": true
}
```

**Scrape specific venues directly by URL:**

```json
{
  "startUrls": [
    { "url": "https://www.treatwell.co.uk/place/bottega-hair-salon/" },
    { "url": "https://www.treatwell.co.uk/place/live-true-london-vauxhall/" }
  ],
  "fetchDetails": true
}
```

**Advanced: raw browse URL override:**

```json
{
  "searchUrls": [
    { "url": "https://www.treatwell.co.uk/places/treatment-group-hair/offer-type-local/in-london-uk/" }
  ],
  "maxResults": 500,
  "fetchDetails": false
}
```

***

### 💰 Pricing

**$1.50 per 1,000 results** — you only pay for successfully saved venues.

| Results | Cost |
|---|---|
| 100 | ~$0.15 |
| 1,000 | ~$1.50 |
| 10,000 | ~$15.00 |
| 100,000 | ~$150.00 |

> Flat-rate alternatives typically charge $29–$49/month regardless of usage.

Use the **Max results** cap in the input to control your spend exactly.

***

### Performance

| Run type | Results | Est. time |
|---|---|---|
| Listing only (`fetchDetails: false`) | 100 | ~30s |
| With details (`fetchDetails: true`) | 100 | ~3–4 min |
| With details | 1,000 | ~30–40 min |

***

### Known limitations

- Opening hours, coordinates, phone, and full service lists require `fetchDetails: true`.
- Treatwell shows a maximum of 20 venues per search page; large categories (2,000+) require multiple pages and longer run times.
- Venue descriptions from listing cards may be shorter than the full description on the detail page.

***

### Technical details

- **Source:** treatwell.co.uk — UK beauty and wellness marketplace
- **Memory:** 512 MB
- **Retry:** Automatic retry on network errors, exponential backoff, 3 attempts per request
- **Self-healing:** Circuit breaker with 5-failure threshold, health signal written after every run

***

### Additional services

Need a custom actor, additional filters, scheduled runs, or integration support?
Send an email to <info@unfencedgroup.nl> — we build on request.

***

*Part of the [Unfenced Group](https://apify.com/unfenced-group) scraper portfolio — beauty, wellness, and beyond.*
*Built by [unfenced-group](https://apify.com/unfenced-group) · Issues? Open a ticket or send a message.*

# Actor input Schema

## `treatment` (type: `string`):

Treatment name or category to search for. Examples: balayage, gel nails, deep tissue massage, ladies haircut, hair colouring, manicure, waxing, microblading. Use a broad category (hair, nails, massage, face, body, hair-removal) to get all venues. Leave blank to search all treatments.

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

City or London area to search in. UK cities: london, manchester, birmingham, bristol, edinburgh, glasgow, leeds, liverpool. London areas/neighbourhoods: shoreditch, camden, brixton, notting hill, hackney, clapham, islington, chelsea, fulham, canary wharf, and many more.

## `maxResults` (type: `integer`):

Maximum number of venues to return. Controls your spend — 20 venues = 1 page.

## `fetchDetails` (type: `boolean`):

Fetch each venue's detail page for full opening hours (Mon–Sun), complete service menu, GPS coordinates, postcode, phone, and full description. Increases run time. Disable for a fast listing-only run.

## `startUrls` (type: `array`):

Scrape specific venue pages directly by URL, bypassing search. Paste one or more treatwell.co.uk/place/... URLs. When set, the treatment and location fields are ignored.

## `searchUrls` (type: `array`):

Override the URL builder entirely — supply raw Treatwell browse URLs (e.g. https://www.treatwell.co.uk/places/treatment-balayage/offer-type-local/in-london-uk/). When set, the treatment and location fields are ignored.

## Actor input object example

```json
{
  "treatment": "hair",
  "location": "london",
  "maxResults": 100,
  "fetchDetails": true,
  "startUrls": [],
  "searchUrls": []
}
```

# Actor output Schema

## `results` (type: `string`):

No description

# 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 = {};

// Run the Actor and wait for it to finish
const run = await client.actor("unfenced-group/treatwell-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 = {}

# Run the Actor and wait for it to finish
run = client.actor("unfenced-group/treatwell-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 '{}' |
apify call unfenced-group/treatwell-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Treatwell.co.uk UK Salon Scraper",
        "description": "Extract salon data from Treatwell.co.uk: venue names, locations, ratings, full service menus with prices, opening hours, GPS coordinates, and images. No proxy, no API key required.",
        "version": "0.0",
        "x-build-id": "ALoyvtCmi5j4ZZfab"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/unfenced-group~treatwell-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-unfenced-group-treatwell-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/unfenced-group~treatwell-scraper/runs": {
            "post": {
                "operationId": "runs-sync-unfenced-group-treatwell-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/unfenced-group~treatwell-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-unfenced-group-treatwell-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "properties": {
                    "treatment": {
                        "title": "Treatment / category",
                        "type": "string",
                        "description": "Treatment name or category to search for. Examples: balayage, gel nails, deep tissue massage, ladies haircut, hair colouring, manicure, waxing, microblading. Use a broad category (hair, nails, massage, face, body, hair-removal) to get all venues. Leave blank to search all treatments.",
                        "default": "hair"
                    },
                    "location": {
                        "title": "Location (city or area)",
                        "type": "string",
                        "description": "City or London area to search in. UK cities: london, manchester, birmingham, bristol, edinburgh, glasgow, leeds, liverpool. London areas/neighbourhoods: shoreditch, camden, brixton, notting hill, hackney, clapham, islington, chelsea, fulham, canary wharf, and many more.",
                        "default": "london"
                    },
                    "maxResults": {
                        "title": "Max results",
                        "minimum": 1,
                        "type": "integer",
                        "description": "Maximum number of venues to return. Controls your spend — 20 venues = 1 page.",
                        "default": 100
                    },
                    "fetchDetails": {
                        "title": "Fetch detail pages",
                        "type": "boolean",
                        "description": "Fetch each venue's detail page for full opening hours (Mon–Sun), complete service menu, GPS coordinates, postcode, phone, and full description. Increases run time. Disable for a fast listing-only run.",
                        "default": true
                    },
                    "startUrls": {
                        "title": "Direct venue URLs (advanced)",
                        "type": "array",
                        "description": "Scrape specific venue pages directly by URL, bypassing search. Paste one or more treatwell.co.uk/place/... URLs. When set, the treatment and location fields are ignored.",
                        "default": [],
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "searchUrls": {
                        "title": "Custom search URLs (advanced)",
                        "type": "array",
                        "description": "Override the URL builder entirely — supply raw Treatwell browse URLs (e.g. https://www.treatwell.co.uk/places/treatment-balayage/offer-type-local/in-london-uk/). When set, the treatment and location fields are ignored.",
                        "default": [],
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
