# Bark.com Profile Scraper (`scrapesage/bark-scraper`) Actor

Extract Bark.com business profiles as structured data (JSON, CSV, Excel) — name, location, categories, ratings, reviews, and contact signals — for lead generation and market research. Fast HTTP-first engine, ~$2 per 1,000 profiles, no subscription. Unofficial, not affiliated with Bark.com.

- **URL**: https://apify.com/scrapesage/bark-scraper.md
- **Developed by:** [Scrape Sage](https://apify.com/scrapesage) (community)
- **Categories:** Lead generation, Developer tools, E-commerce
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

$2.00 / 1,000 profile 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

## Bark.com Profile Scraper

Turn a list of [Bark.com](https://www.bark.com) company-profile URLs into clean, structured JSON — **company name, location, categories, description, ratings, hires, response time, services, and optional individual reviews**. Built on a fast **HTTP-first engine** with an automatic headless-browser fallback only when a page needs it.

**No login, no cookies.** This scraper reads only public business-profile pages — no accounts, no private user data, no CAPTCHA bypass.

> ⚠️ **Unofficial.** This actor is not affiliated with, endorsed by, or sponsored by Bark.com. "Bark" and "Bark.com" are trademarks of their respective owners, used here only to describe the public website this tool extracts data from.

### Why this Bark scraper?

| | Typical scrapers | This actor |
|---|---|---|
| Engine | Browser-only, slow & costly | HTTP-first, browser fallback only when needed |
| Reviews | Capped or unavailable | Full review list, uncapped (toggle with `includeReviews`) |
| Reputation data | Rating only | Rating, review count, hires on Bark, response time |
| Failed URLs | Silently dropped | Recorded in the dataset, never charged |
| Pricing | Monthly rental or start fee | Flat **$0.002 per profile**, no rental, no start fee |
| Cost guard | None | `maxItems` hard cap stops a runaway URL list |

### Use cases

- **Lead generation** — build targeted prospect lists of service businesses by city and category, with profile image and contactable firmographics.
- **Market research** — size and benchmark a local service market using aggregate ratings, review counts, hires on Bark, and stated response times.
- **Competitor analysis** — pull the full service catalog (title + description) each rival advertises and see exactly how they position themselves.
- **ICP & messaging** — mine real customer language from individual reviews (author, date, rating, text, verified flag) to sharpen your ideal-customer profile.
- **Reputation monitoring** — re-run a fixed list of profile URLs on a schedule to track how ratings, review counts, and hire totals move over time.

### How to use

1. [Sign up for Apify](https://console.apify.com/sign-up) — the free plan is enough to try this actor.
2. Open the **Bark.com Profile Scraper**, fill in the inputs you need, and click **Start**.
3. Watch results stream into the dataset table as each record is parsed.
4. **Export** as JSON, CSV, Excel, XML, or RSS — or pull results programmatically via the [Apify API](https://docs.apify.com/api/v2).

### Input

```json
{
  "startUrls": [
    { "url": "https://www.bark.com/en/us/company/athena-playground/2noOY/" },
    { "url": "https://www.bark.com/en/gb/company/some-london-plumber/aB3xY/" }
  ],
  "includeReviews": true,
  "maxItems": 500,
  "maxConcurrency": 5,
  "minRequestDelayMs": 2000,
  "maxRequestRetries": 5,
  "useBrowserFallback": true,
  "proxyConfiguration": { "useApifyProxy": true, "apifyProxyGroups": ["RESIDENTIAL"] }
}
````

- **`startUrls`** (array, required) — Bark.com company profile URLs to scrape. Must match the pattern `https://www.bark.com/{lang}/{country}/company/{slug}/{id}/`.
- **`includeReviews`** (boolean, default `false`) — when `true`, scrape and return the full review list for each profile. Adds weight per record.
- **`maxItems`** (integer, default `1000`, range 1–10000) — hard cap on the number of profiles scraped and charged in a run; a cost guard against an oversized URL list.
- **`maxConcurrency`** (integer, default `5`, range 1–10) — maximum parallel requests. Higher is faster; lower is gentler on the target site.
- **`minRequestDelayMs`** (integer, default `2000`) — minimum wait before each request, jittered up to +3 seconds.
- **`maxRequestRetries`** (integer, default `5`, range 1–10) — retries per failed request, each with a fresh session/IP.
- **`useBrowserFallback`** (boolean, default `true`) — auto-promote a request to a headless Chromium browser if it can't be parsed over plain HTTP. Disable for cheaper, HTTP-only runs.
- **`proxyConfiguration`** (object) — Apify Proxy configuration. Residential group is strongly recommended for production; datacenter IPs are blocked more aggressively on directory sites.

### Output

```json
{
  "profileId": "2noOY",
  "slug": "athena-playground",
  "canonicalUrl": "https://www.bark.com/en/us/company/athena-playground/2noOY/",
  "name": "Athena Playground",
  "locationRaw": "4724 Melrose Avenue, Los Angeles, CA",
  "categories": [
    { "name": "Dog & Pet Grooming", "slug": "pet-grooming" }
  ],
  "description": "Athena Playground is a grooming salon offering full-service dog and cat grooming.",
  "ratingValue": 5,
  "reviewCount": 2,
  "hiresOnBark": 1,
  "responseTimeMinutes": 59,
  "services": [
    { "title": "Bathing Package", "description": "We offer a full detangle, bath, blow-dry, and finish." }
  ],
  "logoUrl": "https://d1k8hez1mxkuxw.cloudfront.net/s/avatar_v2/abc123/logo.png",
  "reviews": [
    {
      "author": "AmandaW",
      "datePublished": "2023-10-09",
      "ratingValue": 5,
      "text": "My fur baby always looks like a superstar after a visit here.",
      "category": null,
      "verified": false
    }
  ],
  "scrapedAt": "2026-05-28T12:00:00.000Z"
}
```

Notes:

- `ratingValue` and `reviewCount` are `null` when a profile has no reviews (distinct from a rated zero). `hiresOnBark`, `responseTimeMinutes`, `locationRaw`, `description`, and `logoUrl` are `null` when not shown on the profile.
- The `reviews` array is present only when `includeReviews` is `true`; it is an empty array when a profile has no reviews. `categories` and `services` are empty arrays when none are listed.
- Failed URLs are not silently dropped — they land in the dataset as a record with `url`, `error` (e.g. `"failed_after_retries"`), `retryCount`, and `errorMessages`, and are **not** charged.
- Records carry only public business-profile data; the actor performs no login and accesses no private user data.

### Automate & schedule

Run this actor on autopilot and pull results into your own stack:

- **[Apify API](https://docs.apify.com/api/v2)** — start runs, fetch datasets, and manage schedules over REST.
- **[apify-client for JavaScript](https://docs.apify.com/api/client/js/)** and **[apify-client for Python](https://docs.apify.com/api/client/python/)** — official SDKs.
- **[Schedules](https://docs.apify.com/platform/schedules)** — run it on a cron to keep your data fresh.
- **[Webhooks](https://docs.apify.com/platform/integrations/webhooks)** — trigger downstream actions the moment a run finishes.

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

const client = new ApifyClient({ token: 'MY_APIFY_TOKEN' });

const run = await client.actor('scrapesage/bark-scraper').call({
    startUrls: [
        { url: 'https://www.bark.com/en/us/company/athena-playground/2noOY/' },
    ],
    includeReviews: true,
    maxItems: 500,
    proxyConfiguration: { useApifyProxy: true, apifyProxyGroups: ['RESIDENTIAL'] },
});

const { items } = await client.dataset(run.defaultDatasetId).listItems();
console.log(`Got ${items.length} records`);
```

### Integrate with any app

Connect the dataset to 5,000+ apps — no code required:

- **[Make](https://docs.apify.com/platform/integrations/make)** — multi-step automation scenarios.
- **[Zapier](https://docs.apify.com/platform/integrations/zapier)** — push new records straight into your CRM or sheet.
- **[Slack](https://docs.apify.com/platform/integrations/slack)** — get notified when a run finds something new.
- **[Google Drive / Sheets](https://docs.apify.com/platform/integrations/drive)** — auto-export every run to a spreadsheet.
- **[Airbyte](https://docs.apify.com/platform/integrations/airbyte)** — pipe results into your data warehouse.
- **[GitHub](https://docs.apify.com/platform/integrations/github)** — trigger runs from commits or releases.

### Use with AI assistants (MCP)

The output is clean, LLM-ready JSON. Call this actor from Claude, ChatGPT, or any agent framework through the **[Apify MCP server](https://docs.apify.com/platform/integrations/mcp)** — ask your assistant to "scrape these Bark.com company profiles and give me their ratings, hires, and services" and let it run this scraper for you.

### More scrapers from scrapesage

Need data from somewhere else? These scrapers pair well with this one:

- [Bark Listing Scraper](https://apify.com/scrapesage/bark-listing-scraper) — Bark.com service-provider directory listings (feed its profile URLs straight into this actor).
- [SAM.gov Scraper](https://apify.com/scrapesage/sam-gov-scraper) — US federal contract opportunities & contacts.
- [Eventbrite Scraper](https://apify.com/scrapesage/eventbrite-scraper) — events plus organizer leads with contacts.
- [Sched Conference Scraper](https://apify.com/scrapesage/sched-conference-scraper) — conference speakers, sessions, sponsors & leads.
- [LinkedIn Jobs Scraper](https://apify.com/scrapesage/linkedin-jobs-scraper) — filter-based LinkedIn job postings, no login.
- [Facebook Ad Library Scraper](https://apify.com/scrapesage/facebook-ad-library-scraper) — Meta/Instagram competitor ad intelligence.
- [Google Ads Transparency Scraper](https://apify.com/scrapesage/google-ads-transparency-scraper) — see who's advertising what on Google.
- [Airbnb Scraper](https://apify.com/scrapesage/airbnb-scraper) — short-stay listings, prices, availability & market monitor.

### Tips

- **Keep residential proxies on for production.** Datacenter IPs flag faster on directory sites; the input defaults to the residential group for a reason.
- **Leave `useBrowserFallback` on** to maximize success rate against bot detection. Disable it only for cheaper, HTTP-only runs when you're confident pages parse over plain HTTP.
- **Set `maxItems` as a spend cap.** Because billing is per profile, the cap is your safety net against an accidentally huge URL list.
- **Turn on `includeReviews` only when you need reviews** — it adds weight per record. Leave it off for the cheapest, lightest runs.
- **Source profile URLs from the directory.** Pair this actor with a Bark listing/search scraper that outputs profile URLs, then pipe those URLs straight into `startUrls`.

### FAQ

**Which Bark regions are supported?** Any public Bark.com profile whose URL matches the `…/{lang}/{country}/company/{slug}/{id}/` pattern, across Bark's regional sites.

**Is this legal?** The actor reads only public business-profile data — no logins, no private user data, no CAPTCHA bypass. As with any scraping, you are responsible for how you use the data and for complying with applicable laws and Bark's terms.

**How do I get profile URLs to feed it?** Browse or search Bark.com for a category and location, open the listings, and collect the profile URLs — or run a Bark listing/directory scraper and feed its output into `startUrls`.

**What export formats are available?** JSON, CSV, Excel, XML, and RSS, plus programmatic access via the Apify API and official clients.

**What happens to URLs that fail?** They are recorded in the dataset with `url`, `error`, `retryCount`, and `errorMessages`, and are **not** charged — so your pipeline always knows what didn't extract.

**Why are some fields null?** Optional fields (`ratingValue`, `reviewCount`, `hiresOnBark`, `responseTimeMinutes`, `locationRaw`, `description`, `logoUrl`) are `null` when the profile doesn't display them. Empty results are reported as success, not failure.

### Need help?

Open an issue on the actor's **Issues** tab, or visit the [Apify help center](https://help.apify.com/). Feature requests are welcome — this actor is actively maintained.

# Actor input Schema

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

Bark.com company profile URLs to scrape. Must match the pattern https://www.bark.com/{lang}/{country}/company/{slug}/{id}/ — for example https://www.bark.com/en/us/company/athena-playground/2noOY/.

## `includeReviews` (type: `boolean`):

If true, scrape and return the full review list for each profile. Adds weight per record. Default: false.

## `maxConcurrency` (type: `integer`):

Maximum parallel requests. Higher is faster; lower is gentler on the target site. Default: 5.

## `minRequestDelayMs` (type: `integer`):

Minimum wait time before each request (jittered up to +3 seconds). Default: 2000.

## `maxRequestRetries` (type: `integer`):

How many times to retry a failed request with a fresh session/IP before giving up. Default: 5.

## `useBrowserFallback` (type: `boolean`):

When true, the crawler may auto-promote a request to a headless Chromium browser if it can't be parsed via HTTP — recommended to maximize success rate against bot detection. Disable for cheaper, HTTP-only runs.

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

Hard cap on the number of profiles scraped (and charged for) in a single run. Acts as a cost guard so a mistakenly large URL list can't run up an unexpected bill. Default: 1000.

## `debugRenderPath` (type: `boolean`):

Diagnostic only. When true, every dataset record gets a `_renderedBy` field ('http' / 'browser' / 'unknown') indicating which path served it. Use to measure the HTTP-vs-browser fallback ratio. Off by default to keep customer output clean.

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

Apify Proxy configuration. Residential group is strongly recommended for production runs — datacenter IPs are blocked more aggressively on directory sites.

## Actor input object example

```json
{
  "startUrls": [
    {
      "url": "https://www.bark.com/en/us/company/athena-playground/2noOY/"
    }
  ],
  "includeReviews": false,
  "maxConcurrency": 5,
  "minRequestDelayMs": 2000,
  "maxRequestRetries": 5,
  "useBrowserFallback": true,
  "maxItems": 1000,
  "debugRenderPath": false,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}
```

# Actor output Schema

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

No description

# API

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

## JavaScript example

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

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

// Prepare Actor input
const input = {
    "startUrls": [
        {
            "url": "https://www.bark.com/en/us/company/athena-playground/2noOY/"
        }
    ],
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ]
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("scrapesage/bark-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": [{ "url": "https://www.bark.com/en/us/company/athena-playground/2noOY/" }],
    "proxyConfiguration": {
        "useApifyProxy": True,
        "apifyProxyGroups": ["RESIDENTIAL"],
    },
}

# Run the Actor and wait for it to finish
run = client.actor("scrapesage/bark-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": [
    {
      "url": "https://www.bark.com/en/us/company/athena-playground/2noOY/"
    }
  ],
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}' |
apify call scrapesage/bark-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Bark.com Profile Scraper",
        "description": "Extract Bark.com business profiles as structured data (JSON, CSV, Excel) — name, location, categories, ratings, reviews, and contact signals — for lead generation and market research. Fast HTTP-first engine, ~$2 per 1,000 profiles, no subscription. Unofficial, not affiliated with Bark.com.",
        "version": "0.1",
        "x-build-id": "2WyDZOGHzoZxCP1IJ"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/scrapesage~bark-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-scrapesage-bark-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/scrapesage~bark-scraper/runs": {
            "post": {
                "operationId": "runs-sync-scrapesage-bark-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/scrapesage~bark-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-scrapesage-bark-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "startUrls"
                ],
                "properties": {
                    "startUrls": {
                        "title": "Bark profile URLs",
                        "type": "array",
                        "description": "Bark.com company profile URLs to scrape. Must match the pattern https://www.bark.com/{lang}/{country}/company/{slug}/{id}/ — for example https://www.bark.com/en/us/company/athena-playground/2noOY/.",
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "includeReviews": {
                        "title": "Include individual reviews",
                        "type": "boolean",
                        "description": "If true, scrape and return the full review list for each profile. Adds weight per record. Default: false.",
                        "default": false
                    },
                    "maxConcurrency": {
                        "title": "Max concurrent requests",
                        "minimum": 1,
                        "maximum": 10,
                        "type": "integer",
                        "description": "Maximum parallel requests. Higher is faster; lower is gentler on the target site. Default: 5.",
                        "default": 5
                    },
                    "minRequestDelayMs": {
                        "title": "Minimum delay between requests (ms)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Minimum wait time before each request (jittered up to +3 seconds). Default: 2000.",
                        "default": 2000
                    },
                    "maxRequestRetries": {
                        "title": "Max retries per request",
                        "minimum": 1,
                        "maximum": 10,
                        "type": "integer",
                        "description": "How many times to retry a failed request with a fresh session/IP before giving up. Default: 5.",
                        "default": 5
                    },
                    "useBrowserFallback": {
                        "title": "Enable headless browser fallback",
                        "type": "boolean",
                        "description": "When true, the crawler may auto-promote a request to a headless Chromium browser if it can't be parsed via HTTP — recommended to maximize success rate against bot detection. Disable for cheaper, HTTP-only runs.",
                        "default": true
                    },
                    "maxItems": {
                        "title": "Max profiles to scrape",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Hard cap on the number of profiles scraped (and charged for) in a single run. Acts as a cost guard so a mistakenly large URL list can't run up an unexpected bill. Default: 1000.",
                        "default": 1000
                    },
                    "debugRenderPath": {
                        "title": "Debug: tag records with rendering path",
                        "type": "boolean",
                        "description": "Diagnostic only. When true, every dataset record gets a `_renderedBy` field ('http' / 'browser' / 'unknown') indicating which path served it. Use to measure the HTTP-vs-browser fallback ratio. Off by default to keep customer output clean.",
                        "default": false
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Apify Proxy configuration. Residential group is strongly recommended for production runs — datacenter IPs are blocked more aggressively on directory sites.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
