# Trustpilot Reviews Scraper (`unfenced-group/trustpilot-scraper`) Actor

Extract 53+ data points per Trustpilot review. Filter by stars, language, date, verified status. Bypass 200-review limit. No API key required.

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

## Pricing

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

## Trustpilot Reviews Scraper
![trustpilot-scraper](https://api.apify.com/v2/key-value-stores/lJlifu6C8YQfZMPKE/records/trustpilot-scraper)

Extract Trustpilot reviews with **53 data points** per review — more fields than any competitor. Scrape any company's reviews with full filtering, company-level analytics, and unlimited pagination. No API key required.

---

### Why this scraper?

#### 📊 Most complete data (53 fields)
Every review includes rating, review text, dates, reviewer profile, verification status, source, reply details, and 20+ company-level metrics — star distribution, TrustScore, category, and claimed status. No competitor comes close.

#### 🚫 Bypass the 200-review limit
Trustpilot's web interface caps results at 200 per view. This scraper uses a per-star-bucket strategy to extract all reviews from any company — not just the most recent 200.

#### 🎯 Precision filters
Filter by star rating (any combination of 1–5 stars), language (ISO code), date range, verified status, and reviews with company replies. All filters combine cleanly.

#### ⚡ Fast and economical
Smart hybrid architecture: one browser request per company to bypass WAF, plain HTTP for all pagination. Runs on 1024 MB and extracts a full page of reviews in under 3 seconds.

#### 🔄 Incremental / daily feeds
Enable `skipReposts` to only extract reviews not seen in previous runs. Pair with a daily schedule for continuous monitoring.

#### 💬 Full reply extraction
Company reply text, date, and update date are captured on every review — including the exact reply timestamp.

---

### Input parameters

| Parameter | Type | Default | Description |
|---|---|---|---|
| `startUrls` | array | `[]` | Trustpilot review URLs or domains. E.g. `https://www.trustpilot.com/review/amazon.com` |
| `domain` | string | `""` | Single company domain shorthand. E.g. `amazon.com` |
| `maxResults` | integer | `200` | Maximum reviews to extract across all companies |
| `filterStars` | array | `[]` | Star ratings to include. Empty = all. E.g. `[1,2]` |
| `filterLanguage` | string | `""` | ISO language code. E.g. `en`, `de`, `fr`. Empty = all |
| `sortBy` | string | `"recency"` | Sort order: `recency` or `relevance` |
| `filterDateRange` | string | `""` | Date range: `last30days`, `last90days`, `last365days`. Empty = all |
| `verifiedOnly` | boolean | `false` | Only return verified customer reviews |
| `withRepliesOnly` | boolean | `false` | Only return reviews that have a company reply |
| `includeCompanyInfo` | boolean | `true` | Include company-level fields in every review record |
| `skipReposts` | boolean | `false` | Skip reviews already seen in previous runs |

---

### Output schema

#### Always present (every review)

| Field | Type | Description |
|---|---|---|
| `id` | string | Trustpilot review ID |
| `url` | string | Direct URL to the review on Trustpilot |
| `title` | string | Review headline written by the reviewer |
| `text` | string | Full review body text |
| `rating` | number | Star rating: 1 (worst) – 5 (best) |
| `publishedAt` | string | ISO 8601 publication date of the review |
| `updatedAt` | string\|null | ISO 8601 date of last edit (null if never edited) |
| `experienceDate` | string\|null | ISO 8601 date of the customer's experience |
| `language` | string | ISO 2-letter language code of the review (e.g. "en") |
| `isVerified` | boolean | Whether Trustpilot verified this as a genuine customer |
| `verificationLevel` | string\|null | Verification type, e.g. `VERIFIED_ORDER`, `ORGANIC` |
| `verificationSource` | string\|null | How verification was obtained |
| `isAnonymous` | boolean | Whether the reviewer chose to remain anonymous |
| `reviewerName` | string\|null | Reviewer's display name on Trustpilot |
| `reviewerReviewCount` | number\|null | Total reviews written by this reviewer |
| `reviewerLocation` | string\|null | Reviewer's self-reported location (e.g. "London, GB") |
| `reviewerCountryCode` | string\|null | ISO 2-letter country code of the reviewer |
| `reviewerProfileUrl` | string\|null | Full URL to reviewer's Trustpilot profile |
| `reviewSource` | string\|null | How the review was submitted (e.g. `InvitationLink`, `Direct`) |
| `likes` | number | Number of helpful votes the review received |
| `reportCount` | number | Number of times the review was reported |
| `hasReply` | boolean | Whether the company posted a reply to this review |
| `replyText` | string\|null | Full text of the company reply (null if no reply) |
| `replyDate` | string\|null | ISO 8601 date the company replied (null if no reply) |
| `replyUpdatedDate` | string\|null | ISO 8601 date the reply was last edited (null if not edited) |
| `productName` | string\|null | Product name if review is linked to a specific product |
| `productUrl` | string\|null | URL to the product the review refers to |
| `isPendingModeration` | boolean | Whether the review is under moderation |
| `contentHash` | string | MD5 fingerprint of review text for change detection |
| `source` | string | Always `"trustpilot.com"` |
| `scrapedAt` | string | ISO 8601 timestamp of when this record was scraped |

#### With `includeCompanyInfo: true` (default)

| Field | Type | Description |
|---|---|---|
| `companyId` | string | Trustpilot business unit ID |
| `companyName` | string | Company display name on Trustpilot |
| `companyDomain` | string | Domain used to identify the company (e.g. `amazon.com`) |
| `companyWebsite` | string\|null | Company's official website URL |
| `companyTrustScore` | number\|null | Trustpilot TrustScore (e.g. 3.4) |
| `companyStarRating` | number\|null | Average star rating rounded to nearest 0.5 |
| `companyTotalReviews` | number | Total number of reviews the company has received |
| `companyCategories` | array | Business categories, e.g. `["Electronics & Technology"]` |
| `companyCountry` | string\|null | Company's country code |
| `companyClaimed` | boolean\|null | Whether the company has claimed its Trustpilot profile |
| `companyProfileUrl` | string | Full URL to company's Trustpilot review page |
| `companyCity` | string\|null | Company's city from their Trustpilot contact info |
| `companyAddress` | string\|null | Company's street address from their Trustpilot contact info |
| `companyZipCode` | string\|null | Company's postal code from their Trustpilot contact info |
| `companyPhone` | string\|null | Company's public phone number from their Trustpilot contact info |
| `companyEmail` | string\|null | Company's public email address from their Trustpilot contact info |
| `companyIsClosed` | boolean | Whether the company has permanently closed its Trustpilot profile |
| `companyHasConsumerAlert` | boolean | Whether Trustpilot has issued a consumer alert for this company |
| `companyLocationsCount` | number\|null | Number of business locations (multi-location companies) |
| `companyResponseRate` | number\|null | Percentage of reviews the company has responded to (0–100) |
| `companyAvgResponseDays` | number\|null | Average days the company takes to reply to a review |

#### Sample output record

```json
{
  "id": "65a1f2c3d4e5f6a7b8c9d0e1",
  "url": "https://www.trustpilot.com/reviews/65a1f2c3d4e5f6a7b8c9d0e1",
  "title": "Excellent customer support",
  "text": "Had an issue with my order and the support team resolved it within minutes. Very impressed with the quick response and professional handling.",
  "rating": 5,
  "publishedAt": "2024-03-15T09:42:00.000Z",
  "updatedAt": null,
  "experienceDate": "2024-03-14T00:00:00.000Z",
  "language": "en",
  "isVerified": true,
  "verificationLevel": "VERIFIED_ORDER",
  "verificationSource": "AUTOMATIC",
  "isAnonymous": false,
  "reviewerName": "Sarah Mitchell",
  "reviewerReviewCount": 23,
  "reviewerLocation": "Manchester, GB",
  "reviewerCountryCode": "GB",
  "reviewerProfileUrl": "https://www.trustpilot.com/users/sarah_mitchell_uk",
  "reviewSource": "InvitationLink",
  "likes": 4,
  "reportCount": 0,
  "hasReply": true,
  "replyText": "Thank you Sarah! We're glad we could resolve your issue quickly. Please don't hesitate to reach out again.",
  "replyDate": "2024-03-15T14:20:00.000Z",
  "replyUpdatedDate": null,
  "productName": null,
  "productUrl": null,
  "isPendingModeration": false,
  "contentHash": "a1b2c3d4e5f6a7b8",
  "source": "trustpilot.com",
  "scrapedAt": "2024-06-01T08:15:32.000Z",
  "companyId": "4a35a40700006400050db8cc",
  "companyName": "Example Shop",
  "companyDomain": "exampleshop.com",
  "companyWebsite": "https://www.exampleshop.com",
  "companyTrustScore": 4.2,
  "companyStarRating": 4,
  "companyTotalReviews": 12450,
  "companyCategories": ["Ecommerce & Shopping"],
  "companyCountry": "NL",
  "companyCity": "Utrecht",
  "companyAddress": "Papendorpseweg 100",
  "companyZipCode": "3528BJ",
  "companyPhone": "030 - 310 4999",
  "companyEmail": "klantenservice@bol.com",
  "companyClaimed": true,
  "companyProfileUrl": "https://www.trustpilot.com/review/exampleshop.com"
}
````

***

### Examples

**Scrape the 100 most recent reviews for a company:**

```json
{
  "domain": "amazon.com",
  "maxResults": 100,
  "sortBy": "recency"
}
```

**Scrape only 1-star and 2-star English reviews for competitor analysis:**

```json
{
  "domain": "competitor.com",
  "filterStars": [1, 2],
  "filterLanguage": "en",
  "maxResults": 500
}
```

**Scrape multiple companies using direct URLs:**

```json
{
  "startUrls": [
    { "url": "https://www.trustpilot.com/review/amazon.com" },
    { "url": "https://www.trustpilot.com/review/ebay.com" },
    { "url": "https://www.trustpilot.com/review/etsy.com" }
  ],
  "maxResults": 200,
  "includeCompanyInfo": true
}
```

**Daily feed — only new verified reviews from the last 30 days (schedule daily):**

```json
{
  "domain": "mycompany.com",
  "filterDateRange": "last30days",
  "verifiedOnly": true,
  "skipReposts": true,
  "maxResults": 1000
}
```

***

### 💰 Pricing

**$0.49 per 1,000 results** — you only pay for successfully extracted reviews.
Failed requests and skipped reposts are never charged.

| Results | Cost |
|---------|------|
| 100 | ~$0.05 |
| 1,000 | ~$0.49 |
| 10,000 | ~$4.90 |
| 100,000 | ~$49.00 |

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

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

***

### Performance

| Run size | Time |
|---|---|
| 20 reviews (1 page) | ~20 seconds |
| 100 reviews (5 pages) | ~50 seconds |
| 1,000 reviews | ~4–6 minutes |
| 5,000 reviews | ~20–30 minutes |

***

### Known limitations

- **Star-bucket pagination:** When no star filter is set, a single company run is capped at 200 reviews (the Trustpilot web interface limit). To extract more, set `filterStars` to a subset of stars — each star bucket gives up to 200 reviews, enabling up to 1,000 total.
- **Very high-volume companies:** Companies with tens of thousands of reviews may require multiple targeted runs using star and language filters.
- **Review text language:** `filterLanguage` filters by the review's detected language. A reviewer writing in a non-native language may appear in the unexpected bucket.
- **Moderated reviews:** Reviews under moderation (`isPendingModeration: true`) are included but may be removed from Trustpilot before you use the data.

***

### Technical details

- **Source:** trustpilot.com — global consumer review platform with 70M+ reviews
- **Memory:** 1024 MB
- **Dedup storage:** KeyValueStore `trustpilot-scraper-dedup`
- **Retry:** Automatic retry on network errors, exponential backoff, 3 attempts per request

***

### 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 — 50+ markets covered.*
*Built by [unfenced-group](https://apify.com/unfenced-group) · Issues? Open a ticket or send a message.*

# Actor input Schema

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

List of Trustpilot review page URLs or company domains to scrape. E.g. https://www.trustpilot.com/review/amazon.com or just amazon.com.

## `domain` (type: `string`):

A single company domain to scrape, e.g. amazon.com. Alternative to startUrls.

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

Maximum total reviews to extract across all companies.

## `filterStars` (type: `array`):

Only return reviews with these star ratings. Leave empty for all ratings. E.g. \[1, 2] for 1- and 2-star reviews.

## `filterLanguage` (type: `string`):

ISO 2-letter language code to filter reviews. E.g. 'en' for English, 'de' for German. Leave empty for all languages.

## `sortBy` (type: `string`):

How to sort reviews. 'recency' (newest first) or 'relevance' (most helpful first).

## `filterDateRange` (type: `string`):

Date range filter. E.g. 'last30days', 'last90days', 'last365days'. Leave empty for all dates.

## `verifiedOnly` (type: `boolean`):

Only return verified customer reviews.

## `withRepliesOnly` (type: `boolean`):

Only return reviews that have a company reply.

## `includeCompanyInfo` (type: `boolean`):

Include company-level fields (trust score, star distribution, categories, etc.) in every review record.

## `skipReposts` (type: `boolean`):

Skip reviews already scraped in previous runs. Useful for daily incremental feeds.

## Actor input object example

```json
{
  "startUrls": [],
  "domain": "revolut.com",
  "maxResults": 20,
  "filterStars": [],
  "filterLanguage": "",
  "sortBy": "recency",
  "filterDateRange": "",
  "verifiedOnly": false,
  "withRepliesOnly": false,
  "includeCompanyInfo": true,
  "skipReposts": false
}
```

# Actor output Schema

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

Link to the dataset containing all extracted Trustpilot reviews.

# 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 = {
    "startUrls": [],
    "domain": "revolut.com"
};

// Run the Actor and wait for it to finish
const run = await client.actor("unfenced-group/trustpilot-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 = {
    "startUrls": [],
    "domain": "revolut.com",
}

# Run the Actor and wait for it to finish
run = client.actor("unfenced-group/trustpilot-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 '{
  "startUrls": [],
  "domain": "revolut.com"
}' |
apify call unfenced-group/trustpilot-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Trustpilot Reviews Scraper",
        "description": "Extract 53+ data points per Trustpilot review. Filter by stars, language, date, verified status. Bypass 200-review limit. No API key required.",
        "version": "0.0",
        "x-build-id": "QuAARk9h4wTt4x1QP"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/unfenced-group~trustpilot-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-unfenced-group-trustpilot-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~trustpilot-scraper/runs": {
            "post": {
                "operationId": "runs-sync-unfenced-group-trustpilot-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~trustpilot-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-unfenced-group-trustpilot-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": {
                    "startUrls": {
                        "title": "Start URLs",
                        "type": "array",
                        "description": "List of Trustpilot review page URLs or company domains to scrape. E.g. https://www.trustpilot.com/review/amazon.com or just amazon.com.",
                        "default": [],
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "domain": {
                        "title": "Company domain",
                        "type": "string",
                        "description": "A single company domain to scrape, e.g. amazon.com. Alternative to startUrls.",
                        "default": "revolut.com"
                    },
                    "maxResults": {
                        "title": "Max results",
                        "minimum": 1,
                        "type": "integer",
                        "description": "Maximum total reviews to extract across all companies.",
                        "default": 20
                    },
                    "filterStars": {
                        "title": "Filter by star rating",
                        "type": "array",
                        "description": "Only return reviews with these star ratings. Leave empty for all ratings. E.g. [1, 2] for 1- and 2-star reviews.",
                        "default": []
                    },
                    "filterLanguage": {
                        "title": "Filter by language",
                        "type": "string",
                        "description": "ISO 2-letter language code to filter reviews. E.g. 'en' for English, 'de' for German. Leave empty for all languages.",
                        "default": ""
                    },
                    "sortBy": {
                        "title": "Sort order",
                        "enum": [
                            "recency",
                            "relevance"
                        ],
                        "type": "string",
                        "description": "How to sort reviews. 'recency' (newest first) or 'relevance' (most helpful first).",
                        "default": "recency"
                    },
                    "filterDateRange": {
                        "title": "Filter by date range",
                        "type": "string",
                        "description": "Date range filter. E.g. 'last30days', 'last90days', 'last365days'. Leave empty for all dates.",
                        "default": ""
                    },
                    "verifiedOnly": {
                        "title": "Verified reviews only",
                        "type": "boolean",
                        "description": "Only return verified customer reviews.",
                        "default": false
                    },
                    "withRepliesOnly": {
                        "title": "With company replies only",
                        "type": "boolean",
                        "description": "Only return reviews that have a company reply.",
                        "default": false
                    },
                    "includeCompanyInfo": {
                        "title": "Include company info",
                        "type": "boolean",
                        "description": "Include company-level fields (trust score, star distribution, categories, etc.) in every review record.",
                        "default": true
                    },
                    "skipReposts": {
                        "title": "Skip previously seen reviews",
                        "type": "boolean",
                        "description": "Skip reviews already scraped in previous runs. Useful for daily incremental feeds.",
                        "default": false
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
