# LoopNet $1.2💰 URL | Search | Enriched Output (`abotapi/loopnet-scraper`) Actor

From $1.2/1K. Scrape LoopNet across the US including office, retail, industrial, multifamily, land, and hotels. Search by city or URL. Extract 25+ fields such as address, price, size, broker contact, and photos, with optional detail enrichment for cap rate, year built, class, and description.

- **URL**: https://apify.com/abotapi/loopnet-scraper.md
- **Developed by:** [AbotAPI](https://apify.com/abotapi) (community)
- **Categories:** Real estate, Automation, Developer tools
- **Stats:** 13 total users, 8 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $1.00 / 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.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

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

## LoopNet Commercial Properties Scraper

Pull commercial property listings from LoopNet across the United States, Canada (loopnet.com) and the United Kingdom / international markets (loopnet.co.uk): offices, retail, industrial, multifamily, land, hotels and more. Search by location or paste your own LoopNet URLs. Returns 30+ fields per listing including address, price, size, broker contacts, photos and a full description. Tuned for fast, low-cost, stable runs.

### Why this scraper

- **Two markets, one actor.** Choose loopnet.com (US / Canada) or loopnet.co.uk (UK / international); URL mode auto-detects the site per link.
- **Rich results without extra fetches.** On the UK site every result already carries title, address, size range, full description and broker names, so the default run is fast and cheap with detail fetching off.
- **30+ fields per listing**: location, price, size, year built, building class, broker contacts, photos, coordinates and more.
- **Two modes**: search by location and filters, or paste specific search / listing URLs (multiple URLs supported).
- **Resilient connections.** Connections are managed automatically to keep results flowing.
- **Predictable cost.** One small default result cap, per-record output, and an optional per-listing detail surcharge only when you turn detail fetching on.

### Data you get

> Sample shape, values are illustrative placeholders, not from a live listing.

| Field | Example |
|---|---|
| id | `00000001` |
| url | `https://www.loopnet.co.uk/listing/sample-road-london/00000001/` |
| title | `Sample Logistics Park, Unit 1` |
| listingType | `for-lease` |
| propertyType | `industrial-properties` |
| listingTypeName | `Industrial to Let` |
| addressRaw | `London, AA0 0AA` |
| city | `London` |
| zipCode | `AA0 0AA` |
| country | `GB` |
| price | `null` |
| priceRaw | `£00.00 - £00.00 sq ft pa` |
| sizeSqftMin | `1000` |
| sizeSqftMax | `25000` |
| size | `1,000 - 25,000 sq ft` |
| brokerNames | `["Sample Agency", "Example Partners"]` |
| description | `Full listing description text appears here.` |
| primaryPhoto | `https://images.loopnet.co.uk/i2/000000000/117/sample.jpg` |
| state | `CA` (US listings; UK uses postcode) |
| latitude / longitude | `51.5000 / -0.1000` (US: included by default; UK: with detail fetch) |
| brokerPhone | `+440000000000` (with detail fetch) |
| scrapedAt | `2026-01-01T00:00:00.000Z` |

### How to use

Search the UK site (nationwide industrial to let):

```json
{
  "mode": "search",
  "site": "co-uk",
  "locations": ["united-kingdom"],
  "listingType": "for-lease",
  "propertyType": "industrial-properties",
  "maxListings": 20
}
````

Search a specific UK city (use the full location slug):

```json
{
  "mode": "search",
  "site": "co-uk",
  "locations": ["london-england--united-kingdom"],
  "listingType": "for-lease",
  "maxListings": 20
}
```

Search the US site (loopnet.com), on Apify Residential:

```json
{
  "mode": "search",
  "site": "com",
  "locations": ["los-angeles-ca", "new-york-ny"],
  "listingType": "for-sale",
  "propertyType": "office-space",
  "maxListings": 30,
  "proxy": { "useApifyProxy": true, "apifyProxyGroups": ["RESIDENTIAL"] }
}
```

Paste your own URLs (site auto-detected per link):

```json
{
  "mode": "url",
  "urls": [
    "https://www.loopnet.co.uk/search/commercial-property/london-england--united-kingdom/for-rent/",
    "https://www.loopnet.co.uk/search/office-space/manchester-gtm--united-kingdom/for-rent/"
  ],
  "maxListings": 50
}
```

### Input parameters

| Parameter | Type | Default | Description |
|---|---|---|---|
| mode | string | `search` | `search` builds URLs from filters; `url` passes through your URLs. |
| site | string | `com` | `com` for US / Canada, `co-uk` for UK / international. Auto-detected in URL mode. |
| locations | array | `["los-angeles-ca"]` | Location slugs. US: `los-angeles-ca`. UK: `united-kingdom` or `london-england--united-kingdom`. |
| listingType | string | `for-sale` | `for-sale`, `for-lease` (For Rent on the UK site), or `auction` (US only). |
| propertyType | string | `all-commercial` | Office, retail, industrial, multifamily, land, hotels, and more. |
| minPrice / maxPrice | integer | none | Price range filter (applied to results). |
| minSqft / maxSqft | integer | none | Size range filter (applied to results). |
| sortBy | string | `default` | Most recent, price or size ordering. |
| urls | array | sample | URL mode only. Multiple URLs supported. |
| fetchDetails | boolean | `false` | Adds coordinates, street, broker phone and JSON-LD fields per listing. |
| maxPages | integer | `200` | Safety ceiling on results pages per location/URL. |
| maxListings | integer | `20` | Stop after this many listings. `0` = unlimited. |
| proxy | object | Residential | Connection settings, see below. |

### Send results into your apps (MCP connectors)

Optionally pipe the scraped results into the apps you already use, via Model Context Protocol (MCP) connectors. This is an extra delivery step **after** the scrape — the Apify dataset is never changed.

**What gets written to the connector:** a condensed, human-readable **summary** of each record — not the full JSON. Each item becomes one entry with a **title** and its key fields flattened to plain text. The **complete record always stays in the Apify dataset**.

1. Authorize a connector once under **Apify → Settings → Integrations** (Notion, Linear, Airtable, or Apify).
2. Select it in the **"Pipe results into your apps"** input field. (If the picker is empty, you haven't authorized a connector yet.)
3. For **Notion**, also set `notionParentPageUrl` to the page where items should be created.

The connection is mediated by Apify's MCP proxy, so this actor never sees your third-party credentials. Leave the field empty to skip.

### Output example

> Sample shape, values are illustrative placeholders, not from a live listing.

```json
{
  "id": "00000001",
  "url": "https://www.loopnet.co.uk/listing/sample-road-london/00000001/",
  "title": "Sample Logistics Park, Unit 1",
  "listingType": "for-lease",
  "propertyType": "industrial-properties",
  "listingTypeName": "Industrial to Let",
  "addressRaw": "London, AA0 0AA",
  "city": "London",
  "state": null,
  "zipCode": "AA0 0AA",
  "country": "GB",
  "price": null,
  "priceRaw": "£00.00 - £00.00 sq ft pa",
  "priceUnit": "per_sqft_year",
  "size": "1,000 - 25,000 sq ft",
  "sizeSqftMin": 1000,
  "sizeSqftMax": 25000,
  "brokerNames": ["Sample Agency", "Example Partners"],
  "description": "Full listing description text appears here.",
  "primaryPhoto": "https://images.loopnet.co.uk/i2/000000000/117/sample.jpg",
  "latitude": 51.5000,
  "longitude": -0.1000,
  "scrapedAt": "2026-01-01T00:00:00.000Z"
}
```

### Connection

This actor needs Apify Residential proxy (Starter plan or higher). Both sites work on the Residential default; regional connections are handled automatically, so leave the connection as is for most runs.

- **loopnet.co.uk (UK / international)** runs on Apify Residential out of the box.
- **loopnet.com (US / Canada)** also runs on Apify Residential. If a US run occasionally returns zero results during heavy traffic periods, simply re-run, or optionally supply your own residential proxy URLs in the connection field (`proxyUrls`) for extra headroom.

If a run returns zero results, the dataset includes a single record noting what to adjust.

# Actor input Schema

## `mode` (type: `string`):

search = build URLs from the filters below; url = pass through your own LoopNet URLs.

## `site` (type: `string`):

Which LoopNet site to search. loopnet.co.uk covers the UK and international listings and works on Apify Residential out of the box. loopnet.com covers US and Canada listings but refuses Apify connection ranges — to use it, supply your own residential proxy URLs in the proxy field. In URL mode this is auto-detected from each URL.

## `locations` (type: `array`):

Search mode only. For loopnet.com use city slugs like "los-angeles-ca" or "new-york-ny" (or "usa" for nationwide). For loopnet.co.uk use "united-kingdom" for nationwide or a full slug like "london-england--united-kingdom". Multi-location supported.

## `listingType` (type: `string`):

Search mode only. For Sale, For Lease (For Rent on the UK site), or Auction (US site only).

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

Search mode only. Choose All Types for every category.

## `minPrice` (type: `integer`):

Search mode only. Keep listings priced at or above this value.

## `maxPrice` (type: `integer`):

Search mode only. Keep listings priced at or below this value.

## `minSqft` (type: `integer`):

Search mode only. Keep listings with size at or above this value.

## `maxSqft` (type: `integer`):

Search mode only. Keep listings with size at or below this value.

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

Search mode only.

## `urls` (type: `array`):

URL mode only. Paste loopnet.com or loopnet.co.uk search or listing URLs. The site is auto-detected per URL. Filter fields above are ignored. Results continue from the page number in the URL onward.

## `fetchDetails` (type: `boolean`):

Adds extra fields per listing (coordinates, street address, broker phone, JSON-LD). The UK site already returns title, address, size, full description and broker names on the results page, so leaving this off is faster and cheaper.

## `maxPages` (type: `integer`):

Safety ceiling on results pages walked per location/URL. Pages stop early once Max listings is reached.

## `maxListings` (type: `integer`):

Stop after this many listings across all searches. 0 = unlimited.

## `proxy` (type: `object`):

Apify Residential is required. loopnet.co.uk works on Residential GB/EU (regional connections are handled automatically). loopnet.com refuses Apify connection ranges, so for US listings supply your own residential proxy URLs here.

## `mcpConnectors` (type: `array`):

Optionally send the scraped results into the apps you already use, via Model Context Protocol (MCP) connectors. Authorize a connector once under Apify → Settings → Integrations, then select it here. The connector receives a condensed, human-readable summary per item (title + key fields), not the full JSON — the complete record stays in the dataset. Leave empty to skip. Supported: Notion (https://mcp.notion.com/mcp), Linear (https://mcp.linear.app/sse), Airtable (https://mcp.airtable.com/mcp), Apify (https://mcp.apify.com).

## `notionParentPageUrl` (type: `string`):

URL (or id) of the Notion page under which item pages are created. Required to enable the Notion export; ignored by other connectors.

## `maxNotifyListings` (type: `integer`):

Cap on items written to each connector per run. Does not affect the dataset.

## Actor input object example

```json
{
  "mode": "search",
  "site": "co-uk",
  "locations": [
    "united-kingdom"
  ],
  "listingType": "for-sale",
  "propertyType": "all-commercial",
  "sortBy": "default",
  "urls": [
    "https://www.loopnet.co.uk/search/commercial-property/london-england--united-kingdom/for-rent/"
  ],
  "fetchDetails": false,
  "maxPages": 200,
  "maxListings": 20,
  "proxy": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  },
  "maxNotifyListings": 50
}
```

# Actor output Schema

## `overview` (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 = {
    "locations": [
        "united-kingdom"
    ],
    "urls": [
        "https://www.loopnet.co.uk/search/commercial-property/london-england--united-kingdom/for-rent/"
    ],
    "proxy": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ]
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("abotapi/loopnet-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 = {
    "locations": ["united-kingdom"],
    "urls": ["https://www.loopnet.co.uk/search/commercial-property/london-england--united-kingdom/for-rent/"],
    "proxy": {
        "useApifyProxy": True,
        "apifyProxyGroups": ["RESIDENTIAL"],
    },
}

# Run the Actor and wait for it to finish
run = client.actor("abotapi/loopnet-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 '{
  "locations": [
    "united-kingdom"
  ],
  "urls": [
    "https://www.loopnet.co.uk/search/commercial-property/london-england--united-kingdom/for-rent/"
  ],
  "proxy": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}' |
apify call abotapi/loopnet-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "LoopNet $1.2💰 URL | Search | Enriched Output",
        "description": "From $1.2/1K. Scrape LoopNet across the US including office, retail, industrial, multifamily, land, and hotels. Search by city or URL. Extract 25+ fields such as address, price, size, broker contact, and photos, with optional detail enrichment for cap rate, year built, class, and description.",
        "version": "3.0",
        "x-build-id": "7p5EFSKujye1oStm6"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/abotapi~loopnet-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-abotapi-loopnet-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/abotapi~loopnet-scraper/runs": {
            "post": {
                "operationId": "runs-sync-abotapi-loopnet-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/abotapi~loopnet-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-abotapi-loopnet-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": [
                    "mode"
                ],
                "properties": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "search",
                            "url"
                        ],
                        "type": "string",
                        "description": "search = build URLs from the filters below; url = pass through your own LoopNet URLs.",
                        "default": "search"
                    },
                    "site": {
                        "title": "Site / region",
                        "enum": [
                            "co-uk",
                            "com"
                        ],
                        "type": "string",
                        "description": "Which LoopNet site to search. loopnet.co.uk covers the UK and international listings and works on Apify Residential out of the box. loopnet.com covers US and Canada listings but refuses Apify connection ranges — to use it, supply your own residential proxy URLs in the proxy field. In URL mode this is auto-detected from each URL.",
                        "default": "co-uk"
                    },
                    "locations": {
                        "title": "Locations",
                        "uniqueItems": true,
                        "type": "array",
                        "description": "Search mode only. For loopnet.com use city slugs like \"los-angeles-ca\" or \"new-york-ny\" (or \"usa\" for nationwide). For loopnet.co.uk use \"united-kingdom\" for nationwide or a full slug like \"london-england--united-kingdom\". Multi-location supported.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "listingType": {
                        "title": "Listing type",
                        "enum": [
                            "for-sale",
                            "for-lease",
                            "auction"
                        ],
                        "type": "string",
                        "description": "Search mode only. For Sale, For Lease (For Rent on the UK site), or Auction (US site only).",
                        "default": "for-sale"
                    },
                    "propertyType": {
                        "title": "Property type",
                        "enum": [
                            "all-commercial",
                            "office-space",
                            "retail-space",
                            "industrial-properties",
                            "multifamily",
                            "land",
                            "hotels",
                            "restaurants",
                            "healthcare-properties",
                            "special-purpose",
                            "sports-and-entertainment"
                        ],
                        "type": "string",
                        "description": "Search mode only. Choose All Types for every category.",
                        "default": "all-commercial"
                    },
                    "minPrice": {
                        "title": "Minimum price",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Search mode only. Keep listings priced at or above this value."
                    },
                    "maxPrice": {
                        "title": "Maximum price",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Search mode only. Keep listings priced at or below this value."
                    },
                    "minSqft": {
                        "title": "Minimum size (sq ft)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Search mode only. Keep listings with size at or above this value."
                    },
                    "maxSqft": {
                        "title": "Maximum size (sq ft)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Search mode only. Keep listings with size at or below this value."
                    },
                    "sortBy": {
                        "title": "Sort by",
                        "enum": [
                            "default",
                            "most-recent",
                            "price-asc",
                            "price-desc",
                            "size-asc",
                            "size-desc"
                        ],
                        "type": "string",
                        "description": "Search mode only.",
                        "default": "default"
                    },
                    "urls": {
                        "title": "LoopNet URLs",
                        "uniqueItems": true,
                        "type": "array",
                        "description": "URL mode only. Paste loopnet.com or loopnet.co.uk search or listing URLs. The site is auto-detected per URL. Filter fields above are ignored. Results continue from the page number in the URL onward.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "fetchDetails": {
                        "title": "Fetch detail pages",
                        "type": "boolean",
                        "description": "Adds extra fields per listing (coordinates, street address, broker phone, JSON-LD). The UK site already returns title, address, size, full description and broker names on the results page, so leaving this off is faster and cheaper.",
                        "default": false
                    },
                    "maxPages": {
                        "title": "Max pages per search",
                        "minimum": 1,
                        "maximum": 200,
                        "type": "integer",
                        "description": "Safety ceiling on results pages walked per location/URL. Pages stop early once Max listings is reached.",
                        "default": 200
                    },
                    "maxListings": {
                        "title": "Max listings (total)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Stop after this many listings across all searches. 0 = unlimited.",
                        "default": 20
                    },
                    "proxy": {
                        "title": "Connection",
                        "type": "object",
                        "description": "Apify Residential is required. loopnet.co.uk works on Residential GB/EU (regional connections are handled automatically). loopnet.com refuses Apify connection ranges, so for US listings supply your own residential proxy URLs here.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    },
                    "mcpConnectors": {
                        "title": "Pipe results into your apps (optional)",
                        "type": "array",
                        "description": "Optionally send the scraped results into the apps you already use, via Model Context Protocol (MCP) connectors. Authorize a connector once under Apify → Settings → Integrations, then select it here. The connector receives a condensed, human-readable summary per item (title + key fields), not the full JSON — the complete record stays in the dataset. Leave empty to skip. Supported: Notion (https://mcp.notion.com/mcp), Linear (https://mcp.linear.app/sse), Airtable (https://mcp.airtable.com/mcp), Apify (https://mcp.apify.com)."
                    },
                    "notionParentPageUrl": {
                        "title": "Notion parent page (Notion connector only)",
                        "type": "string",
                        "description": "URL (or id) of the Notion page under which item pages are created. Required to enable the Notion export; ignored by other connectors."
                    },
                    "maxNotifyListings": {
                        "title": "Max items to export per connector",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Cap on items written to each connector per run. Does not affect the dataset.",
                        "default": 50
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
