# Douban Tracker — China Movie/TV Ratings & Hot Lists (`nexgendata/douban-tracker`) Actor

Track Douban (China's IMDb/Goodreads): hot lists, top-rated charts, now-playing, and keyword search for movies and TV. Public data only.

- **URL**: https://apify.com/nexgendata/douban-tracker.md
- **Developed by:** [NexGenData](https://apify.com/nexgendata) (community)
- **Categories:** News
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $50.00 / 1,000 rated items

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

## 🎬 Douban Tracker — China Movie & TV Ratings + Hot Lists (豆瓣)

**Optional delivery:** Send results straight to your own Notion database or Supabase table in the same run, via Apify's native [MCP connectors](https://docs.apify.com/platform/integrations/mcp-connectors) — the Actor never sees your credentials. One-click connect: [Notion](https://console.apify.com/account/integrations/mcp-connectors/new?serverUrl=https%3A%2F%2Fmcp.notion.com%2Fmcp) or [Supabase](https://console.apify.com/account/integrations/mcp-connectors/new?serverUrl=https%3A%2F%2Fmcp.supabase.com%2Fmcp). Leave blank to get the dataset as usual.

Pull **Douban (豆瓣)** movie and TV ratings, hot lists, and Top 250 rankings as clean structured data — the China cultural-zeitgeist source that almost no Western scraper can reach. Douban is rate-sensitive and anti-bot defended; this actor clears it through residential proxy and Douban's own open rated-list endpoint, returning title, rating, rank, Douban ID, cover art, and direct subject URLs as flat JSON / CSV / Excel. No login, no Chinese phone number, no Douban API key.

If you do APAC market research, content licensing, entertainment analytics, or simply need to know **what China is actually watching and rating right now**, this is the data feed — and it's genuinely hard to get anywhere else.

### 📊 Sample Output

[![Douban Tracker sample output — China movie hot list with title, Douban rating, Douban ID, and subject URL for APAC entertainment analytics and content research](https://api.apify.com/v2/key-value-stores/8gLgXMBveEI1tTz1z/records/douban-tracker-sample)](https://apify.com/nexgendata/douban-tracker?fpr=2ayu9b)

Real titles returned by this actor for **`category: movie`, `listType: hot`** — every row below comes straight from a live run on the Chinese-language Douban hot list:

| # | Title (电影) | Rating | Douban ID | Subject URL |
|---|---|---|---|---|
| 1 | 大濛 | 8.0 | 36680492 | movie.douban.com/subject/36680492/ |
| 2 | 木挽町复仇记 | 7.2 | 37516907 | movie.douban.com/subject/37516907/ |
| 3 | 单程夜航 | 6.8 | 38407729 | movie.douban.com/subject/38407729/ |
| 4 | 我的妈耶 | 6.6 | 36217763 | movie.douban.com/subject/36217763/ |
| 5 | 幽旅巫咒 | 6.1 | 37226826 | movie.douban.com/subject/37226826/ |
| 6 | 杀木池 | 5.3 | 37233517 | movie.douban.com/subject/37233517/ |
| 7 | 世界的主人 | 9.1 | 37116612 | movie.douban.com/subject/37116612/ |
| 8 | 女士优先 | 6.3 | 37067461 | movie.douban.com/subject/37067461/ |
| 9 | 双喜 | 7.5 | 36576765 | movie.douban.com/subject/36576765/ |
| 10 | 家弑服务 | 7.1 | 36367195 | movie.douban.com/subject/36367195/ |

> Each title also carries a high-resolution `cover_image` poster URL and the original Chinese title — handy for building content catalogs, recommendation datasets, or licensing trackers.

### What you get

Per title, you get a flat, typed record:

- **Identity** — `title` (Chinese), `original_title`, `douban_id`, `douban_url` (direct subject page)
- **Score** — `rating` (Douban's 10-point score), `rating_count` *where Douban exposes it on the endpoint*
- **Ranking** — `rank` (position in the requested list), `list_type`, `category`
- **Metadata** — `year`, `genres[]`, `director`, `author`, `artist`, `is_new`, `playable` *(populated where the endpoint returns them)*
- **Media** — `cover_image` (high-res poster URL)
- **Reference** — `summary`, `data_source`, `scraped_at`

> Note: Douban's open hot-list endpoint returns `title`, `rating`, `cover_image`, `douban_id`, and `douban_url` for every item. Fields like `rating_count`, `year`, and `genres` are only populated when you query the Top 250 / detail-backed lists or a specific `query`; on the lightweight hot list they may be empty. We never fabricate fields the source doesn't return.

### Sample inputs

**1. China movie hot list (what's hot right now)**
```json
{ "category": "movie", "listType": "hot", "maxItems": 12 }
````

**2. The Douban Top 250 (the canonical China film ranking)**

```json
{ "category": "movie", "listType": "top250", "maxItems": 100 }
```

**3. TV dramas, now playing**

```json
{ "category": "tv", "listType": "now-playing", "maxItems": 40 }
```

**4. Keyword title lookup (works across categories)**

```json
{ "category": "movie", "query": "流浪地球", "maxItems": 20 }
```

### 📊 Sample Output (JSON)

One representative record, straight from a live run:

```json
{
  "category": "movie",
  "list_type": "hot",
  "title": "大濛",
  "original_title": "大濛",
  "rating": 8.0,
  "rating_count": null,
  "year": null,
  "genres": [],
  "cover_image": "https://img3.doubanio.com/view/photo/s_ratio_poster/public/p2925804842.jpg",
  "douban_id": "36680492",
  "douban_url": "https://movie.douban.com/subject/36680492/",
  "rank": 0,
  "data_source": "douban.com/j/search_subjects",
  "scraped_at": "2026-06-15T04:07:16Z"
}
```

### How it works

Douban (豆瓣) is one of the most anti-bot-defended sites in the Chinese web — datacenter IPs get rate-limited and challenged almost immediately. This actor routes through **Apify residential proxy** and reads movie/TV lists from **Douban's own open `search_subjects` rated-list endpoint** rather than scraping anti-bot-defended HTML list pages. That keeps it fast, low-compute, and reliable while returning clean flat fields. The `maxItems` cap (1–200) is a hard ceiling — compute never outruns it. Book and music categories are supported via keyword `query` only, since their list pages are more heavily defended.

### 💰 Pricing example

This actor uses **Pay-Per-Event** pricing — you only pay for what actually lands in your dataset:

- **Actor start:** $0.005
- **Per item:** $0.05

A **100-title pull = $0.005 + (100 × $0.05) = $5.01**. A quick 12-title hot-list check = $0.005 + (12 × $0.05) = **$0.605**. No monthly minimum, no seats, no surprise overage bills.

### 🌏 Unique APAC content data

This is **unique China-market data**. Douban is *the* rating and review authority for film, TV, books, and music among Chinese audiences — there is no Western equivalent that carries the same cultural weight, and almost no general-purpose scraper can reach it reliably. If you're tracking what China watches and rates, this feed is genuinely hard to source anywhere else.

### ⚖️ Legal & ToS

This actor reads **only Douban's public, unauthenticated rated-list endpoints** — the same ratings and rankings any visitor sees without logging in. It collects public rating and catalog metadata. It does **not** access private user accounts, reviews behind login, or anything requiring authentication. You are responsible for using the output in line with Douban's terms and your local regulations.

### ❓ FAQ

**Q: Do I need a Douban account or a Chinese phone number?**
A: No. The actor works entirely off Douban's public rated-list endpoints — no login, no registration, no Chinese SIM.

**Q: Why are `year`, `genres`, or `rating_count` sometimes empty?**
A: Douban's lightweight hot-list endpoint only returns `title`, `rating`, `cover_image`, and IDs. Richer metadata appears on the Top 250 / detail-backed lists and keyword `query` lookups. We never fabricate fields the source doesn't expose.

**Q: Can I get the Douban Top 250?**
A: Yes — set `listType: "top250"` with `category: "movie"`. That returns the canonical high-rated China film ranking.

**Q: Do book and music work?**
A: Books (图书) and music (音乐) are supported via keyword `query` search only — their list pages are too heavily anti-bot-defended to enumerate. Movie and TV support the full list endpoints.

**Q: Why did I get fewer items than `maxItems`?**
A: That list simply had fewer entries available. `maxItems` is a ceiling, not a target — getting fewer is normal, not an error.

### 🔗 Related Actors

Pair this with the rest of the NexGenData APAC data stack:

- [📈 China Trends Tracker — Weibo / Baidu / Douyin Hot Topics](https://apify.com/nexgendata/china-trends-tracker?fpr=2ayu9b) — track what's trending across China's biggest platforms in one feed
- [🔥 Weibo Hot Search Tracker — Real-Time China Trending](https://apify.com/nexgendata/weibo-hot-search-tracker?fpr=2ayu9b) — the live Weibo 热搜 leaderboard as structured data
- [📺 Bilibili Video Search — China's YouTube/Niconico](https://apify.com/nexgendata/bilibili-video-search?fpr=2ayu9b) — search and rank Bilibili videos with view, like, and creator stats
- 🏢 **About NexGenData** — we maintain 260+ production Apify actors for lead-gen, competitive intelligence, and hard-to-reach APAC web data. Browse the full catalog at [apify.com/nexgendata](https://apify.com/nexgendata?fpr=2ayu9b).

***

### ⭐ Found this useful?

If this actor saved you research time, a quick **[review on the Apify Store](https://apify.com/nexgendata/douban-tracker?fpr=2ayu9b)** helps other teams discover it. Feature request or bug? Open it from the **Issues** tab — we read every one.

# Actor input Schema

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

What to track. movie/tv use Douban's open rated-list endpoint (fully supported). book/music only support keyword `query` search (their list pages are anti-bot defended).

## `listType` (type: `string`):

Which Douban list to pull (movie/tv only). Ignored when `query` is set.

## `query` (type: `string`):

Optional keyword search via Douban's open suggest endpoint. When set, overrides listType. Works across categories for title lookups.

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

Hard cap on returned items (1-200).

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

Residential proxy is strongly recommended for Douban (rate-sensitive, anti-bot). Defaults to Apify RESIDENTIAL.

## `notionConnector` (type: `string`):

Optional. Connect your Notion workspace and the results are also written as a Notion page in the same run — the Actor never sees your Notion credentials. Authorize a Notion MCP connector in Apify Console → Settings → API & Integrations, then select it here.

## `notionParentId` (type: `string`):

Optional. The Notion page ID to create the page under. If blank, Notion creates a private page in your workspace.

## `supabaseConnector` (type: `string`):

Optional. Connect your own Supabase project and the results are also inserted into a table in the same run — the Actor never sees your Supabase credentials. Authorize a write-scoped, project-scoped Supabase MCP connector in Apify Console (Settings -> Integrations), then select it here.

## `supabaseTable` (type: `string`):

Target table in the public schema (created if missing, with id, a jsonb data column, and a scraped\_at timestamp). Default: nexgendata\_leads.

## `supabaseProjectId` (type: `string`):

Your Supabase project reference (e.g. abcdefghijklmnop). Required unless your connector URL is already project-scoped. Find it in your project URL: supabase.com/dashboard/project/THIS\_PART.

## `deliveryDedup` (type: `boolean`):

When on (default), records already delivered in a previous run are not delivered again to the same destination — so scheduled runs only push new items. Turn off to deliver every record on every run.

## Actor input object example

```json
{
  "category": "movie",
  "listType": "hot",
  "maxItems": 20,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  },
  "supabaseTable": "nexgendata_leads",
  "deliveryDedup": true
}
```

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

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

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {};

// Run the Actor and wait for it to finish
const run = await client.actor("nexgendata/douban-tracker").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("nexgendata/douban-tracker").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 nexgendata/douban-tracker --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Douban Tracker — China Movie/TV Ratings & Hot Lists",
        "description": "Track Douban (China's IMDb/Goodreads): hot lists, top-rated charts, now-playing, and keyword search for movies and TV. Public data only.",
        "version": "0.0",
        "x-build-id": "A4HOSGsHfh9bLEEOV"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/nexgendata~douban-tracker/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-nexgendata-douban-tracker",
                "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/nexgendata~douban-tracker/runs": {
            "post": {
                "operationId": "runs-sync-nexgendata-douban-tracker",
                "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/nexgendata~douban-tracker/run-sync": {
            "post": {
                "operationId": "run-sync-nexgendata-douban-tracker",
                "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": [
                    "category"
                ],
                "properties": {
                    "category": {
                        "title": "Category",
                        "enum": [
                            "movie",
                            "tv",
                            "book",
                            "music"
                        ],
                        "type": "string",
                        "description": "What to track. movie/tv use Douban's open rated-list endpoint (fully supported). book/music only support keyword `query` search (their list pages are anti-bot defended).",
                        "default": "movie"
                    },
                    "listType": {
                        "title": "List type",
                        "enum": [
                            "hot",
                            "top250",
                            "now-playing",
                            "new",
                            "top-rated"
                        ],
                        "type": "string",
                        "description": "Which Douban list to pull (movie/tv only). Ignored when `query` is set.",
                        "default": "hot"
                    },
                    "query": {
                        "title": "Search query (optional)",
                        "type": "string",
                        "description": "Optional keyword search via Douban's open suggest endpoint. When set, overrides listType. Works across categories for title lookups."
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 200,
                        "type": "integer",
                        "description": "Hard cap on returned items (1-200).",
                        "default": 20
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Residential proxy is strongly recommended for Douban (rate-sensitive, anti-bot). Defaults to Apify RESIDENTIAL.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    },
                    "notionConnector": {
                        "title": "Deliver to Notion (optional)",
                        "type": "string",
                        "description": "Optional. Connect your Notion workspace and the results are also written as a Notion page in the same run — the Actor never sees your Notion credentials. Authorize a Notion MCP connector in Apify Console → Settings → API & Integrations, then select it here."
                    },
                    "notionParentId": {
                        "title": "Notion parent page ID (optional)",
                        "type": "string",
                        "description": "Optional. The Notion page ID to create the page under. If blank, Notion creates a private page in your workspace."
                    },
                    "supabaseConnector": {
                        "title": "Deliver to Supabase (optional)",
                        "type": "string",
                        "description": "Optional. Connect your own Supabase project and the results are also inserted into a table in the same run — the Actor never sees your Supabase credentials. Authorize a write-scoped, project-scoped Supabase MCP connector in Apify Console (Settings -> Integrations), then select it here."
                    },
                    "supabaseTable": {
                        "title": "Supabase table name (optional)",
                        "type": "string",
                        "description": "Target table in the public schema (created if missing, with id, a jsonb data column, and a scraped_at timestamp). Default: nexgendata_leads.",
                        "default": "nexgendata_leads"
                    },
                    "supabaseProjectId": {
                        "title": "Supabase project ID (optional)",
                        "type": "string",
                        "description": "Your Supabase project reference (e.g. abcdefghijklmnop). Required unless your connector URL is already project-scoped. Find it in your project URL: supabase.com/dashboard/project/THIS_PART."
                    },
                    "deliveryDedup": {
                        "title": "Deduplicate deliveries across runs",
                        "type": "boolean",
                        "description": "When on (default), records already delivered in a previous run are not delivered again to the same destination — so scheduled runs only push new items. Turn off to deliver every record on every run.",
                        "default": true
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
