# Wortimmo Scraper — Luxembourg Property Listings & Prices (`studio-amba/wortimmo-scraper`) Actor

Scrape property listings from Wortimmo.lu, Luxembourg's Mediahuis-operated real estate portal. Get rental and sale prices, photos, dimensions, and agency info.

- **URL**: https://apify.com/studio-amba/wortimmo-scraper.md
- **Developed by:** [Studio Amba](https://apify.com/studio-amba) (community)
- **Categories:** Real estate
- **Stats:** 4 total users, 2 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $8.00 / 1,000 result scrapeds

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

## WortImmo Scraper

Scrape real estate listings from [Wortimmo.lu](https://www.wortimmo.lu) — Luxembourg's property portal by Mediahuis, the publisher behind the Luxemburger Wort newspaper — with prices, property details, photos, and agency information in English, French, or German.

### What is WortImmo Scraper?

**WortImmo Scraper** extracts property listings from Wortimmo.lu, Luxembourg's second real estate portal. While atHome.lu dominates the Luxembourg market, Wortimmo carries listings from agencies and developers who specifically target the Luxemburger Wort readership — the Grand Duchy's most widely read newspaper. This means exclusive listings you won't find elsewhere.

- **Capture listings missing from atHome.lu:** some Luxembourg agencies prefer Wortimmo or list there before other portals. Scraping both gives you the most complete view of the market
- **Track Luxembourg's rental market:** with rents in Luxembourg City regularly exceeding EUR 2,000/month for a two-bedroom apartment, structured rental data is essential for budgeting and negotiation
- **Monitor new construction projects:** Wortimmo's buy section features development projects with individual unit listings, letting you track what's being built and at what price point
- **Build cross-portal datasets:** combine Wortimmo data with atHome.lu data by matching on listing IDs or addresses to identify price differences across platforms
- **Support multilingual research:** scrape in English, French, or German to match your workflow — URLs, categories, and results adapt to the selected language

The scraper uses **HTTP requests only** with Cheerio HTML parsing — no browser required — keeping it fast and cheap.

### What data does WortImmo Scraper extract?

🏠 **Title** — descriptive headline (e.g., "House with 5 bedroom(s) to rent in Wasserbillig")
💰 **Price** — asking price or monthly rent in EUR
🏗️ **Property type** — apartment, house, office, shop, garage, structural works, investment property, land, housing development
🔑 **Transaction type** — sale or rent
📍 **City** — extracted from listing title and URL
🛏️ **Bedrooms** count
📐 **Surface area** — living space in square meters
🌳 **Land area** — plot size in m2 (converted from ares)
🅿️ **Parking** spaces
📸 **Main photo** and **all image URLs** from the listing carousel
🏢 **Agency name** — the listing agent
🆔 **Listing ID** — Wortimmo's internal reference number
🔗 **Direct URL** to the listing on Wortimmo.lu
🕐 **Scraped timestamp** — when the data was collected

### How to scrape Wortimmo.lu

Configure the scraper through the Apify Console or via the API. All filters are optional.

#### Input options

| Input | Type | Default | Description |
|-------|------|---------|-------------|
| **Transaction Type** | `rent` / `buy` | `rent` | Rent or buy |
| **Property Type** | select | All types | Apartment, house, office, shop, garage, structural works, investment property, land, housing developments |
| **City** | string | All Luxembourg | City name (e.g., `Luxembourg`, `Esch-sur-Alzette`, `Mertert`) |
| **Max Results** | integer | `100` | Maximum listings to return (1 – 10,000) |
| **Language** | `en` / `fr` / `de` | `en` | Language for the interface, URLs, and listing data |
| **Proxy Configuration** | object | — | Optional proxy for large scraping runs |

#### Tips for best results

- **Set language to French (`fr`)** if you want descriptions that match what most Luxembourg agencies write natively
- **Try the buy section separately:** Wortimmo structures buy pages differently from rental pages, with project cards containing multiple child listings. The scraper handles both formats automatically
- **Land area is converted for you:** Wortimmo displays land in ares (1 are = 100 m2). The scraper converts this to square meters so all your data uses consistent units
- **Proxy is usually not needed** — Wortimmo has minimal anti-bot protection, but proxy helps for runs above 500 listings

### Output

Results are stored in a dataset you can download as JSON, CSV, Excel, XML, or HTML from the Apify Console.

#### JSON example (rental)

```json
{
    "title": "House with 5 bedroom(s) to rent in Wasserbillig",
    "price": 3250,
    "currency": "EUR",
    "propertyType": "House",
    "transactionType": "rent",
    "url": "https://www.wortimmo.lu/en/rent-house-east-wasserbillig-id_489249",
    "scrapedAt": "2026-04-03T11:00:00.000Z",
    "listingId": "489249",
    "city": "Wasserbillig",
    "bedrooms": 5,
    "surface": 181,
    "landArea": 260,
    "parking": 2,
    "agencyName": "Immobiliere Piret",
    "imageUrl": "https://www.wortimmo.lu/images/listings/489249/main.jpg",
    "imageUrls": [
        "https://www.wortimmo.lu/images/listings/489249/main.jpg",
        "https://www.wortimmo.lu/images/listings/489249/002.jpg",
        "https://www.wortimmo.lu/images/listings/489249/003.jpg"
    ]
}
````

#### JSON example (buy — project unit)

```json
{
    "title": "Apartment to buy in Esch-sur-Alzette",
    "price": 557000,
    "currency": "EUR",
    "propertyType": "Apartment",
    "transactionType": "sale",
    "url": "https://www.wortimmo.lu/en/buy-apartment-south-esch-sur-alzette-id_501234",
    "scrapedAt": "2026-04-03T11:00:00.000Z",
    "listingId": "501234",
    "city": "Esch-sur-Alzette",
    "bedrooms": 2,
    "surface": 78,
    "agencyName": "Tracol Immobilier",
    "imageUrl": "https://www.wortimmo.lu/images/listings/501234/main.jpg"
}
```

### How much does it cost to scrape Wortimmo.lu?

WortImmo Scraper uses **HTTP requests only** (no browser), making it extremely affordable.

| Scenario | Est. cost | Time |
|----------|-----------|------|
| 100 listings | ~$0.40 | ~30 sec |
| 500 listings | ~$1.50 | ~2 min |
| 1,000 listings | ~$2.50 | ~4 min |

The scraper includes a 500ms polite delay between page requests to avoid overwhelming the server.

### Can I integrate WortImmo Scraper with other apps?

Yes. WortImmo Scraper connects with any tool through [Apify integrations](https://apify.com/integrations):

- **Google Sheets** — export Luxembourg property data to a spreadsheet, refreshed on every run
- **Slack / Email** — get alerted when new properties matching your criteria appear on Wortimmo
- **Zapier / Make** — build workflows that trigger when new data arrives
- **Airtable** — maintain a Luxembourg property database with photos and agent details
- **REST API** — call the scraper from any programming language
- **Webhooks** — receive a notification when a run completes

### Can I use WortImmo Scraper as an API?

Yes. Use the [Apify API](https://docs.apify.com/api/v2) to run WortImmo Scraper programmatically.

**Python:**

```python
from apify_client import ApifyClient

client = ApifyClient("YOUR_API_TOKEN")
run = client.actor("studio-amba/wortimmo-scraper").call(run_input={
    "transactionType": "rent",
    "propertyType": "apartment",
    "city": "Luxembourg",
    "maxResults": 200,
    "language": "en",
})

for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(f"{item['title']} — €{item['price']}/month — {item.get('surface', '?')} m²")
```

**JavaScript:**

```javascript
import { ApifyClient } from 'apify-client';

const client = new ApifyClient({ token: 'YOUR_API_TOKEN' });
const run = await client.actor('studio-amba/wortimmo-scraper').call({
    transactionType: 'buy',
    propertyType: 'house',
    maxResults: 100,
    language: 'fr',
});

const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach(item => console.log(`${item.title} — €${item.price.toLocaleString()}`));
```

Check the [API tab](https://apify.com/studio-amba/wortimmo-scraper/api) for full documentation.

### FAQ

#### What is Wortimmo.lu?

Wortimmo.lu is Luxembourg's real estate portal operated by Mediahuis Luxembourg, the publisher of the Luxemburger Wort — the Grand Duchy's oldest and most widely read daily newspaper, founded in 1848. The Wort brand carries significant trust in Luxembourg, and many agencies list on Wortimmo to reach its established readership. The portal covers residential and commercial properties for both sale and rent.

#### How does WortImmo Scraper work?

The scraper fetches search result pages from Wortimmo.lu via HTTP and parses the HTML with Cheerio. For rental pages, it extracts data from structured listing cards (`[id^="obj_"]`). For buy pages, it handles a different page structure with project cards and child listing tables. The scraper automatically detects which format is present and parses accordingly. Pagination is handled by following `?page=N` links.

#### How is Wortimmo different from atHome.lu?

atHome.lu is Luxembourg's largest property portal with the widest selection. Wortimmo.lu carries a smaller but distinct inventory, particularly from agencies connected to the Luxemburger Wort ecosystem. Some listings appear on both platforms, while others are exclusive to one. For maximum coverage of the Luxembourg market, scrape both and deduplicate.

#### Is it legal to scrape Wortimmo.lu?

This scraper extracts publicly available property listing data that Wortimmo.lu displays to all visitors. The data is factual real estate information (prices, property characteristics, agency names) published by Luxembourg agencies and developers. Use the data responsibly and in compliance with Luxembourg and EU regulations.

#### Can I scrape in German?

Yes. Set `language` to `"de"` for German. This changes the URL structure (e.g., `/de/mieten/` instead of `/en/rent/`) and returns German-language results where available. You can also use `"fr"` for French or `"en"` for English.

#### Does the scraper handle new build projects?

Yes. On Wortimmo's buy pages, new developments are displayed as project cards with expandable tables of individual units. The scraper parses these child listings individually, so each apartment or house within a project becomes its own result with specific price, surface, and bedroom data.

### Limitations

- **Luxembourg only.** Wortimmo.lu covers the Grand Duchy of Luxembourg exclusively.
- **Smaller inventory than atHome.lu.** Wortimmo has fewer total listings. For comprehensive Luxembourg market data, combine with atHome.lu Scraper.
- **No price/bedroom filters in the input.** Wortimmo's URL structure doesn't support price or bedroom filtering at the search level. You'll need to filter results after scraping.
- **City extraction is approximate.** City names are parsed from listing titles and URL slugs rather than structured data, so occasional mismatches are possible.
- **Buy page structure differs from rent.** The scraper handles both, but the buy page parsing is more complex and may occasionally miss edge-case project layouts.
- **No GPS coordinates.** Unlike atHome.lu, Wortimmo doesn't expose latitude/longitude data in its listing cards.

### Other real estate scrapers

Build a complete Benelux property dataset by combining WortImmo Scraper with these actors:

- 🏛️ [Biddit Scraper](https://apify.com/studio-amba/biddit-scraper) — Belgian notarial property auctions
- 🇫🇷 [Logic-Immo Scraper](https://apify.com/studio-amba/logicimmo-scraper) — French real estate listings from Logic-Immo.com
- 🏡 [Immovlan Scraper](https://apify.com/studio-amba/immovlan-scraper) — Belgian property listings (VTM/DPG network)
- 🇱🇺 [Athome.lu Scraper](https://apify.com/studio-amba/athome-scraper) — Luxembourg's #1 real estate portal with GPS and energy data

### Your feedback

Found a bug, have a feature request, or need help? Open an issue on the [Issues tab](https://apify.com/studio-amba/wortimmo-scraper/issues). We actively maintain this scraper and respond to all reports.

# Actor input Schema

## `transactionType` (type: `string`):

Type of transaction to search for.

## `propertyType` (type: `string`):

Filter by property type. Leave empty for all types.

## `city` (type: `string`):

Filter by city name (e.g., 'Luxembourg', 'Esch-sur-Alzette'). Leave empty for all Luxembourg.

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

Maximum number of listings to return.

## `language` (type: `string`):

Language for the site interface and listing data.

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

Proxy settings for better reliability on large scraping runs.

## Actor input object example

```json
{
  "transactionType": "rent",
  "propertyType": "",
  "city": "",
  "maxResults": 100,
  "language": "en"
}
```

# 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("studio-amba/wortimmo-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("studio-amba/wortimmo-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 studio-amba/wortimmo-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Wortimmo Scraper — Luxembourg Property Listings & Prices",
        "description": "Scrape property listings from Wortimmo.lu, Luxembourg's Mediahuis-operated real estate portal. Get rental and sale prices, photos, dimensions, and agency info.",
        "version": "0.1",
        "x-build-id": "u6ocyX97af9AmDmYD"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~wortimmo-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-wortimmo-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/studio-amba~wortimmo-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-wortimmo-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/studio-amba~wortimmo-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-wortimmo-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": {
                    "transactionType": {
                        "title": "Transaction Type",
                        "enum": [
                            "rent",
                            "buy"
                        ],
                        "type": "string",
                        "description": "Type of transaction to search for.",
                        "default": "rent"
                    },
                    "propertyType": {
                        "title": "Property Type",
                        "enum": [
                            "",
                            "apartment",
                            "house",
                            "office",
                            "shop",
                            "garage-parking",
                            "big-work",
                            "investment-property",
                            "ground",
                            "housing-developments-residence"
                        ],
                        "type": "string",
                        "description": "Filter by property type. Leave empty for all types.",
                        "default": ""
                    },
                    "city": {
                        "title": "City",
                        "type": "string",
                        "description": "Filter by city name (e.g., 'Luxembourg', 'Esch-sur-Alzette'). Leave empty for all Luxembourg.",
                        "default": ""
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of listings to return.",
                        "default": 100
                    },
                    "language": {
                        "title": "Language",
                        "enum": [
                            "en",
                            "fr",
                            "de"
                        ],
                        "type": "string",
                        "description": "Language for the site interface and listing data.",
                        "default": "en"
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings for better reliability on large scraping runs."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
