# Mastodon Scraper (`glassventures/mastodon-scraper`) Actor

Scrape posts from any Mastodon instance. Extract toots, profiles, trending posts, and search results. Export to JSON, CSV, Excel.

- **URL**: https://apify.com/glassventures/mastodon-scraper.md
- **Developed by:** [Glass Ventures](https://apify.com/glassventures) (community)
- **Categories:** Social media
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

Pay per usage

This Actor is paid per platform usage. The Actor is free to use, and you only pay for the Apify platform usage, which gets cheaper the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-usage

## 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

## Mastodon Scraper

Scrape posts from any Mastodon instance. Extract toots, profiles, trending posts, and search results with full metadata.

### What does Mastodon Scraper do?

Mastodon Scraper extracts posts (toots) from any Mastodon-compatible instance using the standard Mastodon REST API. It works with mastodon.social, fosstodon.org, hachyderm.io, and any other Mastodon or Mastodon-compatible server.

The actor can scrape posts from specific user profiles, search for posts by keyword, fetch the public timeline, or collect trending posts. All data is returned in a structured format with full metadata including engagement counts, media attachments, and hashtags.

Whether you're doing social media research, tracking conversations about specific topics across the fediverse, or analyzing engagement patterns, this actor provides the data you need without requiring any API keys or authentication.

### Use Cases

- **Social media researchers** -- Monitor conversations and trends across the fediverse
- **Data analysts** -- Analyze engagement patterns, posting frequency, and content trends on Mastodon
- **Journalists** -- Track public discourse and trending topics on decentralized social media
- **Developers** -- Collect Mastodon data for building dashboards, bots, or analytics tools
- **Marketing teams** -- Monitor brand mentions and sentiment across Mastodon instances

### Features

- Scrape posts from any Mastodon-compatible instance
- Extract user profile posts by URL
- Search for posts by keyword
- Fetch public timeline and trending posts
- Full pagination support for large datasets
- Automatic deduplication of posts
- Proxy support with automatic rotation
- Handles pagination and large datasets automatically
- Exports to JSON, CSV, Excel, or connect via API

### How much will it cost?

| Results | Estimated Cost |
|---------|---------------|
| 100     | ~$0.01        |
| 1,000   | ~$0.05        |
| 10,000  | ~$0.25        |

| Cost Component | Per 1,000 Results |
|----------------|-------------------|
| Platform compute | ~$0.03 |
| Proxy (datacenter) | ~$0.02 |
| **Total** | **~$0.05** |

Mastodon has a public REST API, so scraping is very lightweight and cost-effective. No browser rendering is needed.

### How to use

1. Go to the Mastodon Scraper page on Apify Store
2. Click "Start" or "Try for free"
3. Enter Mastodon profile URLs (e.g., `https://mastodon.social/@Mastodon`) or search terms
4. Optionally change the target instance (default: mastodon.social)
5. Set the maximum number of items
6. Click "Start" and wait for the results

### Input parameters

| Parameter | Type | Description | Default |
|-----------|------|-------------|---------|
| startUrls | array | Mastodon profile URLs to scrape | - |
| searchTerms | array | Search queries for finding posts | - |
| instance | string | Default Mastodon instance for search/trending | mastodon.social |
| scrapePublicTimeline | boolean | Scrape the public timeline | false |
| scrapeTrending | boolean | Scrape trending posts | false |
| maxItems | number | Max posts to return | 100 |
| maxConcurrency | number | Parallel request limit | 10 |
| proxyConfig | object | Proxy settings | Apify Proxy |

### Output

The actor produces a dataset with the following fields:

```json
{
    "url": "https://mastodon.social/@Mastodon/123456789",
    "content": "Welcome to Mastodon! This is a decentralized social network.",
    "author": "Mastodon",
    "handle": "@Mastodon@mastodon.social",
    "instance": "mastodon.social",
    "favouritesCount": 42,
    "reblogsCount": 15,
    "repliesCount": 3,
    "createdAt": "2024-01-15T10:30:00.000Z",
    "mediaAttachments": ["https://media.mastodon.social/image.jpg"],
    "tags": ["mastodon", "fediverse"],
    "language": "en",
    "scrapedAt": "2024-01-16T08:00:00.000Z"
}
````

| Field | Type | Description |
|-------|------|-------------|
| url | string | Post URL |
| content | string | Post text content (HTML stripped) |
| author | string | Display name of the author |
| handle | string | Full handle (e.g., @user@instance) |
| instance | string | Mastodon instance domain |
| favouritesCount | number | Number of favourites/likes |
| reblogsCount | number | Number of reblogs/boosts |
| repliesCount | number | Number of replies |
| createdAt | string | Post creation timestamp (ISO 8601) |
| mediaAttachments | array | Media attachment URLs |
| tags | array | Hashtags used in the post |
| language | string | Post language code |
| scrapedAt | string | Scrape timestamp (ISO 8601) |

### Integrations

Connect Mastodon Scraper with other tools:

- **Apify API** -- REST API for programmatic access
- **Webhooks** -- get notified when a run finishes
- **Zapier / Make** -- connect to 5,000+ apps
- **Google Sheets** -- export directly to spreadsheets

#### API Example (Node.js)

```javascript
import { ApifyClient } from 'apify-client';
const client = new ApifyClient({ token: 'YOUR_TOKEN' });
const run = await client.actor('YOUR_USERNAME/mastodon-scraper').call({
    startUrls: [{ url: 'https://mastodon.social/@Mastodon' }],
    maxItems: 100,
});
const { items } = await client.dataset(run.defaultDatasetId).listItems();
```

#### API Example (Python)

```python
from apify_client import ApifyClient
client = ApifyClient('YOUR_TOKEN')
run = client.actor('YOUR_USERNAME/mastodon-scraper').call(run_input={
    'startUrls': [{'url': 'https://mastodon.social/@Mastodon'}],
    'maxItems': 100,
})
items = client.dataset(run['defaultDatasetId']).list_items().items
```

#### API Example (cURL)

```bash
curl "https://api.apify.com/v2/acts/YOUR_USERNAME~mastodon-scraper/runs" \
  -X POST \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer YOUR_TOKEN" \
  -d '{"startUrls": [{"url": "https://mastodon.social/@Mastodon"}], "maxItems": 100}'
```

### Tips and tricks

- Start with a small `maxItems` (10-20) to test before running large scrapes
- You can scrape any Mastodon-compatible instance, not just mastodon.social
- Combine profile scraping with search terms to get comprehensive coverage
- The public timeline and trending endpoints give you a quick snapshot of activity on any instance
- No authentication or API keys are needed -- Mastodon's public API is open

### FAQ

**Q: Does this actor require login credentials?**
A: No. Mastodon has a public REST API that does not require authentication for reading public posts.

**Q: How fast is the scraping?**
A: Very fast. Since it uses the REST API directly, it can scrape 500-1,000+ posts per minute depending on the instance.

**Q: Can I scrape any Mastodon instance?**
A: Yes, any instance running Mastodon or a compatible server (Pleroma, Akkoma, etc.) that exposes the standard Mastodon API.

**Q: What should I do if I get rate limited?**
A: Lower the maxConcurrency setting and enable proxy rotation. Most Mastodon instances have generous rate limits (300 requests per 5 minutes).

**Q: Can I scrape private/followers-only posts?**
A: No. This actor only accesses publicly available posts through the public API.

### Is it legal to scrape Mastodon?

Web scraping of publicly available data is generally legal based on precedents like the LinkedIn v. HiQ Labs case. This actor only accesses publicly available data through Mastodon's official public REST API. Mastodon instances explicitly provide these API endpoints for public access. Always review and respect individual instance rules and Terms of Service. For more information, see [Apify's blog on web scraping legality](https://blog.apify.com/is-web-scraping-legal/).

### Limitations

- Only public posts are accessible (no private/followers-only content)
- Search functionality depends on the instance having search enabled
- Some smaller instances may have stricter rate limits
- Trending posts endpoint may not be available on all instances

### Changelog

- **v0.1** (2026-04-23) -- Initial release

# Actor input Schema

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

Mastodon profile URLs to scrape posts from. Works with any Mastodon instance (e.g. mastodon.social, fosstodon.org).

## `searchTerms` (type: `array`):

Search queries to find posts across the specified instance.

## `instance` (type: `string`):

Default Mastodon instance for search and trending. Used when searchTerms are provided.

## `scrapePublicTimeline` (type: `boolean`):

Also scrape the public timeline of the specified instance.

## `scrapeTrending` (type: `boolean`):

Also scrape trending posts from the specified instance.

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

Maximum number of posts to scrape. Use 0 or leave empty for unlimited.

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

Maximum number of requests processed in parallel.

## `debugMode` (type: `boolean`):

Enables verbose logging for troubleshooting.

## `extendOutputFunction` (type: `string`):

A JavaScript function to customize each output item. Receives { data, request }.

## `proxyConfig` (type: `object`):

Select proxies to be used.

## Actor input object example

```json
{
  "startUrls": [
    {
      "url": "https://mastodon.social/@Mastodon"
    }
  ],
  "searchTerms": [
    "open source"
  ],
  "instance": "mastodon.social",
  "scrapePublicTimeline": false,
  "scrapeTrending": false,
  "maxItems": 100,
  "maxConcurrency": 10,
  "debugMode": false,
  "extendOutputFunction": "async ({ data }) => {\n    return data;\n}",
  "proxyConfig": {
    "useApifyProxy": 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 = {
    "startUrls": [
        {
            "url": "https://mastodon.social/@Mastodon"
        }
    ],
    "searchTerms": [
        "open source"
    ],
    "instance": "mastodon.social",
    "extendOutputFunction": async ({ data }) => {
        return data;
    },
    "proxyConfig": {
        "useApifyProxy": true
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("glassventures/mastodon-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://mastodon.social/@Mastodon" }],
    "searchTerms": ["open source"],
    "instance": "mastodon.social",
    "extendOutputFunction": """async ({ data }) => {
    return data;
}""",
    "proxyConfig": { "useApifyProxy": True },
}

# Run the Actor and wait for it to finish
run = client.actor("glassventures/mastodon-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://mastodon.social/@Mastodon"
    }
  ],
  "searchTerms": [
    "open source"
  ],
  "instance": "mastodon.social",
  "extendOutputFunction": "async ({ data }) => {\\n    return data;\\n}",
  "proxyConfig": {
    "useApifyProxy": true
  }
}' |
apify call glassventures/mastodon-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Mastodon Scraper",
        "description": "Scrape posts from any Mastodon instance. Extract toots, profiles, trending posts, and search results. Export to JSON, CSV, Excel.",
        "version": "0.1",
        "x-build-id": "I1y0kGErfXdAYfiDn"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/glassventures~mastodon-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-glassventures-mastodon-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/glassventures~mastodon-scraper/runs": {
            "post": {
                "operationId": "runs-sync-glassventures-mastodon-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/glassventures~mastodon-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-glassventures-mastodon-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": "Mastodon profile URLs to scrape posts from. Works with any Mastodon instance (e.g. mastodon.social, fosstodon.org).",
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "searchTerms": {
                        "title": "Search Terms",
                        "type": "array",
                        "description": "Search queries to find posts across the specified instance.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "instance": {
                        "title": "Instance",
                        "type": "string",
                        "description": "Default Mastodon instance for search and trending. Used when searchTerms are provided.",
                        "default": "mastodon.social"
                    },
                    "scrapePublicTimeline": {
                        "title": "Scrape Public Timeline",
                        "type": "boolean",
                        "description": "Also scrape the public timeline of the specified instance.",
                        "default": false
                    },
                    "scrapeTrending": {
                        "title": "Scrape Trending Posts",
                        "type": "boolean",
                        "description": "Also scrape trending posts from the specified instance.",
                        "default": false
                    },
                    "maxItems": {
                        "title": "Max Items",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Maximum number of posts to scrape. Use 0 or leave empty for unlimited.",
                        "default": 100
                    },
                    "maxConcurrency": {
                        "title": "Max Concurrency",
                        "minimum": 1,
                        "maximum": 100,
                        "type": "integer",
                        "description": "Maximum number of requests processed in parallel.",
                        "default": 10
                    },
                    "debugMode": {
                        "title": "Debug Mode",
                        "type": "boolean",
                        "description": "Enables verbose logging for troubleshooting.",
                        "default": false
                    },
                    "extendOutputFunction": {
                        "title": "Extend Output Function",
                        "type": "string",
                        "description": "A JavaScript function to customize each output item. Receives { data, request }."
                    },
                    "proxyConfig": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Select proxies to be used."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
