# Facebook Page Details Scraper - Lead Gen \[NO COOKIES] ✅ (`unseenuser/fb-pages`) Actor

Get everything a Facebook page makes public in one call: email, phone, website, address, category, business hours, ratings, like and follower counts, plus whether the page is currently running ads. No login, no cookies. Built for lead generation, CRM enrichment and competitor research.

- **URL**: https://apify.com/unseenuser/fb-pages.md
- **Developed by:** [Unseen User](https://apify.com/unseenuser) (community)
- **Categories:** Lead generation, Social media, Automation
- **Stats:** 4 total users, 3 monthly users, 100.0% runs succeeded, 4 bookmarks
- **User rating**: 5.00 out of 5 stars

## Pricing

$5.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.

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

## 📘 Facebook Pages Scraper - $5 / 1,000 Pages (No Login)

> **Email, phone, website, ratings and ad-running status in one call.** Public Facebook page data for B2B lead generation, CRM enrichment and competitor research. No login. No cookies.

> ⚠️ **SCOPE - read this first.** This Actor **enriches known Facebook page URLs**. It does **NOT** search or discover pages by keyword. Paste the URLs you already have. (There is no public Facebook page-search API; any tool claiming "search Facebook by keyword" is doing something else under the hood.)

> 🛡️ **Compliance.** Returns public, logged-off page data only. **You are the data controller** for any personal data in the output and own the lawful basis for any outreach. See the Terms of Service section below.

### 🎯 The Outbound Hook: Ad-Activity Signal

The response includes `adLibrary.adStatus` - whether the page is currently running ads via Facebook's Ad Library. **Pages with budget are warmer outbound prospects.** Most Facebook page scrapers in this category do not surface this field; if you sell to advertisers, agencies or brands, ad-running status is a first-class qualification signal you can filter on before the first email.

### 💰 Why $5 / 1,000 - The Pricing Math

| Scraper | Price | Contact Fields | Business Hours | Ad-Running Status | Ratings |
|---|---|---|---|---|---|
| **📘 This Actor** | **$5 / 1k** | ✅ email + phone + website + address | ✅ | ✅ `adLibrary.adStatus` | ✅ |
| Category flagship | ~$12-13 / 1k | ✅ | ✅ | ✅ | ✅ |
| Commodity tier | $1-4 / 1k | partial | usually no | ❌ | sometimes |

Enrich **1,000 prospect pages for $5** - full contact + ratings + ad status - versus hours of manual lookup or paying more than 2x for the flagship that returns the same fields.

See exact per-event pricing on the Actor's Apify page.

### 📦 What You Get - Sample Output (Real Schema)

One row per page. Every field below comes back in a single Actor call:

```json
{
  "source": "https://www.facebook.com/mantraindianfolsom",
  "id": "100088017857524",
  "name": "Mantraindian",
  "url": "https://www.facebook.com/mantraindianfolsom",
  "pageIntro": "Indian Vegan & Vegetarian Restaurant",
  "category": "Restaurant",
  "creationDate": "November 25, 2022",
  "email": "contact@mantraindian.com",
  "phone": "+1 916-999-1749",
  "website": "https://www.mantraindian.com/",
  "address": "1870 Prairie City Rd, Suite 500, Folsom, CA, United States, California",
  "services": "Delivery, Takeaway, Dine in",
  "priceRange": "$",
  "rating": "Not yet rated (1 review)",
  "ratingCount": null,
  "likeCount": 3224,
  "followerCount": 3200,
  "isBusinessPageActive": false,
  "adLibrary": {
    "adStatus": "This Page is currently running ads.",
    "pageId": "104359362513119"
  },
  "businessHours": [
    { "monday": { "open": null, "close": null, "intervals": [], "fullText": "CLOSED" } }
  ],
  "profilePicLarge": "https://scontent-...s200x200...jpg",
  "coverPhoto": { "photo": { "id": "204402652503662", "image": { "uri": "https://...jpg" } } },
  "_metadata": {
    "fetched_at": "2026-06-03T12:34:56.000Z",
    "page_url": "https://www.facebook.com/mantraindianfolsom",
    "addons_enabled": { "posts": false, "events": false, "photos": false, "reels": false }
  }
}
````

That completeness in a single object is the conversion event - contact + ratings + ad signal + hours, no second step.

### 🎯 Use Cases

- **B2B lead generation** - pull email, phone and website for a list of known business pages
- **CRM enrichment** - fill in contact, category, hours and rating fields for accounts you already track
- **Local-business prospecting** - build outreach lists for restaurants, clinics or shops in a vertical
- **Competitor research** - check ratings, follower counts and whether a rival is currently advertising
- **Ad-activity monitoring** - filter prospects to only pages currently running ads (warmer leads, real budget)
- **Market mapping** - profile categories and engagement across a defined set of pages

### 🚀 Quick Start

1. Click **Try for free** on this Actor's page
2. Paste one or more public Facebook page URLs into `startUrls`
3. Run the Actor
4. Download results as JSON, CSV or XLSX, or pull via Apify API

### ⚙️ Inputs

| Input | Type | Required | Default | Description |
|---|---|---|---|---|
| `startUrls` | array of strings | ✅ | - | Public Facebook page URLs (e.g. `https://www.facebook.com/mantraindianfolsom`) |
| `getBusinessHours` | boolean | ❌ | `true` | Include the page's opening hours |
| `includePosts` | boolean | ❌ | `false` | ⚠️ Billed add-on. Pull recent posts |
| `maxPosts` | integer | ❌ | `9` | Max posts per page when posts are on |
| `includeEvents` | boolean | ❌ | `false` | ⚠️ Billed add-on. Pull page events |
| `includePhotos` | boolean | ❌ | `false` | ⚠️ Billed add-on. Pull page photos |
| `maxPhotos` | integer | ❌ | `0` | Max photos per page (0 = single page of results) |
| `includeReels` | boolean | ❌ | `false` | ⚠️ Billed add-on. Pull page reels |
| `maxReels` | integer | ❌ | `10` | Max reels per page when reels are on |

**Add-on toggles are opt-in and billed separately.** Leave add-ons off unless you actually need that data - you pay for nothing you don't use.

### 📤 Output Behavior

- One row per page, streamed to the dataset via Apify's standard pipeline
- Add-on results (`posts[]`, `events[]`, `photos[]`, `reels[]`) are appended to the same row when enabled
- Each row includes `_metadata` with `fetched_at`, `page_url` and `addons_enabled`
- **Per-URL error isolation:** a bad URL emits an `error` row and the run keeps going - one bad input never crashes the batch
- Formats: JSON, CSV, XLSX or via Apify API
- The dataset ships with curated views: **Overview**, **Contact list**, **Ad activity**, **Engagement** and **Errors**
- A `OUTPUT_SUMMARY` record is written to the key-value store at the end of every run with totals and timings
- A live-view status API is exposed during the run (`/health`, `/status`, `/summary`) - see the Actor's OpenAPI schema

### ❓ FAQ

**Q: Does it search or discover pages by keyword?**
A: **No.** This Actor enriches **known page URLs**. There is no public Facebook page-search API. If you need page discovery, source URLs from Google search, a CRM export or a directory first, then run this Actor over the URL list.

**Q: What if a page hides its email or phone?**
A: Those fields come back empty (`null` or omitted). Many pages publish website + address but not email. That is expected and is not a bug - the Actor returns whatever Facebook makes public.

**Q: Coverage by page type?**
A: Business pages have the highest completeness (email/phone/address/hours/category). Creator and community pages return identity, intro, ratings and engagement but often no contact fields. Personal profiles return identity and limited metadata - treat them as personal data, not business contacts.

**Q: Is `adLibrary.adStatus` real-time?**
A: It reflects Facebook's Ad Library status at the time of the call, refreshed by Meta on their schedule. Good signal for outbound qualification; not a guarantee a specific ad is live in a specific country in the next minute.

**Q: Rate limits?**
A: No published hard limit. The Actor handles transient `429/502/503/504` responses automatically with 3 retries and exponential backoff (1s, 2s, 4s).

**Q: Is the data live or cached?**
A: Each run is a live fetch. UnseenUser does not cache or retain the data.

**Q: Is this legal?**
A: The Actor accesses public, logged-off page data only. Your downstream use of the data is your responsibility - see the Terms of Service section below.

**Q: What about Facebook's anti-scraping enforcement?**
A: Meta's Terms restrict automated extraction. Your downstream use must comply with Meta's Terms.

**Q: What if Meta sends a cease-and-desist?**
A: Notify UnseenUser within 48 hours via the Apify profile contact form (https://apify.com/UnseenUser) and cease using this Actor immediately.

**Q: Can I use this data to train AI?**
A: **No.** Meta's Terms prohibit AI training on Facebook data, and page posts and photos are copyrighted by their creators.

**Q: What about minors?**
A: Facebook has many under-18 users and some "pages" are personal profiles. This Actor's Terms strictly prohibit using data of users you know or suspect are minors.

**Q: Are the add-ons billed separately?**
A: Yes. Each enabled add-on (posts/events/photos/reels) is a separate billed event.

**Q: Can I use the emails for cold outreach?**
A: Only with a documented lawful basis and full anti-spam compliance (GDPR, CAN-SPAM, CASL, Israeli Anti-Spam Law). See the Addendum, Section G.

### 🔧 Technical Details

- **Output:** streamed via Apify dataset; JSON, CSV, XLSX or via Apify API
- **Retries:** 3 with exponential backoff (1s, 2s, 4s) on `429/502/503/504`
- **Default path:** one Actor call per page, no pagination
- **Add-on pagination** is handled internally when toggles are enabled
- **Per-URL error isolation:** one bad URL does not crash the run
- **Live-view API** (OpenAPI 3 schema bound to the Actor): `/health`, `/status`, `/summary`

### Related scrapers

Build a complete Facebook business-intelligence stack:

- [Meta Ad Library Scraper](https://apify.com/unseenuser/meta-ads) - the page runs ads? See exactly which ones
- [Instagram Profile Scraper](https://apify.com/unseenuser/igscraping) - the same business on Instagram
- [Google Ads Transparency Scraper](https://apify.com/unseenuser/Google-ads) - their Google ad spend

[See all 18 scrapers by unseenuser →](https://apify.com/unseenuser)

***

## 🛡️ Apify Actor - Terms of Service

**Version:** 4.0
**Effective Date:** May 5, 2026

***

### 0. ACCEPTANCE BY USE - IMPORTANT

**Read this section first.**

These Terms of Service ("Terms") form a binding legal agreement between you ("User," "you," "your") and UnseenUser, the Publisher of this Apify actor ("UnseenUser," "the Publisher," "we," "us," "our").

#### 0.1 How You Accept These Terms

You accept these Terms by **any of the following actions**, each of which constitutes a clear, affirmative act of acceptance:

- (a) **Running the Actor** - Initiating any execution of the Actor on the Apify platform
- (b) **Using any output** returned by the Actor for any purpose
- (c) **Continuing to access** the Actor's listing or documentation after these Terms are visible

#### 0.2 Continuing Acceptance

Each time you run the Actor or use its outputs, you reaffirm your acceptance of the then-current Terms. If you do not agree to these Terms or any subsequent update, you must stop using the Actor immediately.

#### 0.3 No Anonymous Acceptance

You cannot disclaim acceptance by:

- Failing to read these Terms before running the Actor
- Running the Actor through automated systems
- Sharing your Apify account with others who may not have read these Terms

By the act of running the Actor on Apify, you bind yourself, your organization (if applicable), and any individuals or systems acting on your behalf or under your authority.

#### 0.4 If You Do Not Accept

**If you do not agree to these Terms, you must not run the Actor.** No use is authorized without acceptance.

***

### PREAMBLE - UNDERSTANDING THE ARCHITECTURE

Before using the Actor, please understand the technical architecture of the service:

#### The Data Flow

You (User) -> Apify Platform -> Actor (software) -> Third-Party API -> Source Platform

You (User) <- Apify Platform <- Actor (software) <- Third-Party API

#### What Each Party Does

- **You (the User):** Run the Actor on the Apify platform with input parameters you choose
- **Apify:** Operates the cloud infrastructure that hosts and executes Actors. Apify is a Czech-incorporated company (Apify Technologies s.r.o.) governed by its own Terms of Service.
- **The Publisher (us):** Publishes software code (the Actor) on Apify's platform. The Actor is a thin wrapper that translates your input into requests to a third-party API and returns the API's responses to you. **The Publisher does not operate scraping infrastructure. The Publisher does not store or retain data returned by the Actor. The Publisher does not see, log, or process the personal data of any individuals returned in the Actor's outputs beyond what is incidental to passing the data through.**
- **Third-Party API Provider:** HarvestAPI (https://harvest-api.com) or Scrape Creators (https://scrapecreators.com). These are independent third-party companies that operate scraping infrastructure and return data from source platforms.
- **Source Platform:** LinkedIn, TikTok, YouTube, Reddit, Linktree, etc. These are the platforms whose publicly visible data is accessed by the Third-Party API Providers.

#### Why This Matters

Your relationship with the Publisher is that of a **software user** to a **software vendor**. The Publisher has the responsibilities of a software vendor (functional code, accurate documentation) and the limits of one (the Publisher is not responsible for how you use the data you obtain).

***

These Terms operate alongside but do not replace:

- Apify's Terms of Service and Acceptable Use Policy (governing your relationship with Apify)
- HarvestAPI Terms of Service and Scrape Creators Terms of Service (governing the underlying data infrastructure)
- Source Platform terms (LinkedIn, TikTok, etc.) governing the public data accessed
- Applicable law in your jurisdiction and the jurisdictions of data subjects

These Terms incorporate the actor-specific addendum published in each Actor's individual listing ("Addendum"). In the event of a conflict, the more restrictive provision applies.

***

### 1. NATURE OF THE SERVICE

#### 1.1 What the Actor Is

The Actor is a software program published on the Apify platform. Each Actor:

- (a) Accepts structured input from you on the Apify platform
- (b) Translates that input into HTTP requests to a third-party API operated by HarvestAPI or Scrape Creators
- (c) Receives HTTP responses from that third-party API
- (d) Returns the response data to you in a structured format on the Apify platform

The Actor's source code is hosted on Apify's infrastructure. The Actor runs in Apify's cloud, not on the Publisher's servers. The Publisher operates no servers running the Actor.

#### 1.2 What the Actor Is Not

The Actor is **not**:

- (a) A scraping tool - the Publisher does not operate scraping infrastructure, proxies, headless browsers, or fake accounts
- (b) A direct connection to any source platform - connections to source platforms are made by HarvestAPI / Scrape Creators
- (c) A data storage or data retention service - the Publisher does not maintain a database of any data the Actor returns
- (d) A licensed access channel to LinkedIn, TikTok, YouTube, Reddit, X (Twitter), Meta, Linktree, or any other source platform
- (e) Affiliated with, endorsed by, sponsored by, or authorized by any source platform

#### 1.3 The Publisher's Limited Role

The Publisher's role is limited to:

- (a) Designing and writing the Actor's source code
- (b) Publishing the Actor on the Apify Store
- (c) Maintaining the Actor (updating it when API providers change schemas)
- (d) Providing documentation and customer support via Apify's contact mechanism

The Publisher is a software vendor, similar to a developer who publishes an app on the Apple App Store or Google Play Store. The Publisher is not a data provider, data broker, data processor, or data controller for purposes of GDPR, CCPA, Israel's Privacy Protection Law, or equivalent.

#### 1.4 The Third-Party API Providers' Role

HarvestAPI (https://harvest-api.com) and Scrape Creators (https://scrapecreators.com) are independent third-party companies. They:

- (a) Operate the actual data scraping infrastructure
- (b) Maintain relationships with source platforms (or accept the operational risk of accessing public data without such relationships)
- (c) Are themselves Apify publishers (HarvestAPI publishes 9+ actors directly; Scrape Creators publishes 10+)
- (d) Provide their own Terms of Service governing their operations
- (e) Are responsible for compliance obligations relating to the data collection itself

The Publisher is a customer of these providers. The Publisher is not their agent, partner, or representative.

***

### 2. WHO MAY USE THE ACTOR

#### 2.1 Eligibility

You may use the Actor only if:

- (a) You are at least 18 years old or the age of majority in your jurisdiction
- (b) You have legal capacity to enter into binding contracts
- (c) You are not located in or resident of a country subject to comprehensive sanctions by the United States, European Union, United Kingdom, or Israel
- (d) You are not on any prohibited persons list

#### 2.2 User Representations

By using any Actor, you represent and warrant that:

- (a) **Truthful identity:** Information you provide about your identity and intended use is accurate
- (b) **Lawful intent:** Your intended use complies with applicable law in your jurisdiction
- (c) **Source platform compliance:** You will independently comply with the Terms of Service of any source platform whose data you obtain through the Actor
- (d) **Data subject rights:** Where Actor outputs include personal data, you will respect data subject rights under applicable law
- (e) **No prohibited use:** You will not use the Actor for any of the purposes prohibited in Section 4

These representations are continuous - they must remain true throughout your use.

***

### 3. PERMITTED USES

The Actor may be used for any lawful purpose, including:

- Market research and competitive analysis
- Academic research
- Journalism and investigative reporting
- Internal business intelligence
- Brand monitoring
- Recruitment research where consistent with applicable employment law
- Building products that further process publicly available information lawfully

Specific permitted uses for each Actor are described in that Actor's individual listing and Addendum.

***

### 4. PROHIBITED USES

You may not use the Actor for any of the following:

#### 4.1 Illegal Activity

Activity illegal under the law of your jurisdiction, the User's jurisdiction, or the jurisdiction of any data subjects.

#### 4.2 Harassment, Stalking, and Personal Targeting

- Compiling profiles for harassment, stalking, or doxxing
- Tracking individuals' movements or activities without their knowledge
- Building profiles of journalists, activists, dissidents, or vulnerable populations for retaliatory purposes

#### 4.3 Discrimination

- Using outputs for discriminatory employment, lending, housing, or insurance decisions based on protected characteristics
- Building lists for discriminatory purposes

#### 4.4 Spam and Unsolicited Commercial Communication

- Sending unsolicited marketing in violation of CAN-SPAM, CASL, GDPR, PECR, Israeli Anti-Spam Law (Section 30A of the Communications Law), or equivalent laws
- Building "lead lists" from scraped contacts without proper consent infrastructure
- Reselling contact data for spam purposes

#### 4.5 Fraud and Deception

- Identity theft or impersonation
- Generation of fake reviews, testimonials, or coordinated inauthentic behavior
- Election interference or political disinformation
- Securities fraud

#### 4.6 Source Platform Abuse

- Using outputs to circumvent technical protection measures of source platforms
- Creating fake accounts on source platforms based on Actor outputs
- Vote manipulation, engagement manipulation, or platform algorithm gaming
- Building services that competitively substitute for source platforms

#### 4.7 Reselling the Actor's Service

- Reselling raw Actor outputs as your own data product or scraping-as-a-service
- Sharing your Apify credentials to provide third parties indirect access
- Building competing API services using Actor outputs

#### 4.8 AI Training Without Authorization

- Using Actor outputs as training data for commercial AI/ML models without separate licensing authority from the source platform

#### 4.9 Sensitive Targeting

- Specifically targeting or profiling based on health conditions, sexual orientation, religious beliefs, political opinions, or other sensitive characteristics
- Targeting children under 16 (or local age of consent for data processing)

#### 4.10 Privacy Law Violations

- Processing personal data of EU/UK/California/Israeli residents without complying with applicable privacy law
- Failing to honor data subject access, deletion, or objection requests
- Processing data for purposes incompatible with its publication context

***

### 5. SOURCE PLATFORM TERMS - YOUR RESPONSIBILITY

#### 5.1 Acknowledgment

The Actor accesses publicly visible data on third-party platforms ("Source Platforms") through the Third-Party API Providers (HarvestAPI / Scrape Creators). Source Platforms include LinkedIn, TikTok, YouTube, Reddit, X (Twitter), Meta/Facebook, Linktree, Komi, Pillar, Linkbio, Linkme, and Amazon.

#### 5.2 Your Sole Responsibility

You acknowledge:

- (a) **You are solely responsible for ensuring your downstream use of data obtained through the Actor complies with the Source Platform's Terms of Service**
- (b) The Publisher makes no representation that any specific use is permitted under any Source Platform's terms
- (c) The Third-Party API Providers, not the Publisher, bear responsibility for the lawfulness of the data collection itself
- (d) You should review Source Platform terms before commercial use:
  - LinkedIn: https://www.linkedin.com/legal/user-agreement
  - TikTok: https://www.tiktok.com/legal/page/global/terms-of-service/en
  - YouTube: https://www.youtube.com/static?template=terms
  - X: https://twitter.com/en/tos
  - Reddit: https://www.redditinc.com/policies/user-agreement
  - Meta: https://www.facebook.com/legal/terms
  - Linktree: https://linktr.ee/s/terms/

#### 5.3 Cease-and-Desist Compliance

If you receive a cease-and-desist letter or other legal demand from a Source Platform regarding your use of Actor outputs, you must:

- (a) Cease the contested use immediately
- (b) Notify UnseenUser within 48 hours via UnseenUser's Apify profile contact form (https://apify.com/UnseenUser)
- (c) Cooperate with the Publisher as needed to mitigate
- (d) Not assert against the Publisher any claim arising from your inability to use the Actor for that Source Platform

***

### 6. DATA PROTECTION - REFLECTING ACTUAL ARCHITECTURE

#### 6.1 Roles Under Privacy Law

For purposes of GDPR, UK GDPR, CCPA, Israel's Privacy Protection Law (PPL) including Amendment 13, and equivalents:

- **You (the User) are the Data Controller** of any personal data you obtain through the Actor and subsequently process for your own purposes
- **HarvestAPI and Scrape Creators** are the entities that collect data from source platforms - they bear the responsibilities of data processors or controllers (depending on context) for the collection itself
- **The Publisher acts solely as a software vendor**, not as a data controller or processor, because the Publisher does not store, retain, or substantively process personal data - the Actor merely passes API responses through

#### 6.2 No Data Retention by the Publisher

The Publisher confirms:

- (a) The Publisher does not maintain a database of personal data obtained through the Actor
- (b) The Actor passes data from the Third-Party API directly to you on the Apify platform - data does not flow through the Publisher's infrastructure
- (c) Apify's standard execution and operational logging may include limited information about Actor runs (input parameters, run duration, data volume) - this is governed by Apify's own privacy practices
- (d) The Publisher does not access, view, or analyze your Actor outputs except as needed for technical support if you specifically share them with the Publisher

#### 6.3 Your Obligations as Data Controller

Where your use of the Actor involves processing personal data, you are responsible for:

- (a) Establishing a lawful basis for your processing (consent, legitimate interest with documented balancing test, contract, etc.)
- (b) Providing transparent notice to data subjects as required by applicable law
- (c) Honoring data subject access, rectification, erasure, restriction, and portability requests
- (d) Implementing appropriate security measures
- (e) Conducting Data Protection Impact Assessments where required
- (f) Appointing a Data Protection Officer if your operations require one
- (g) Registering databases with applicable supervisory authorities
- (h) Honoring opt-out requests for direct marketing
- (i) Cross-border transfer safeguards where data crosses borders

#### 6.4 Israel's Amendment 13 - User Compliance

If your use of the Actor involves Israeli residents' personal data, you must comply with the Privacy Protection Law as amended (Amendment 13, effective August 14, 2025). These obligations are yours as the data controller, not the Publisher's as the software vendor.

#### 6.5 Sensitive Data Targeting Restrictions

You will not use the Actor to specifically target, profile, or build datasets focused on:

- Health or medical conditions
- Religious beliefs
- Political opinions
- Sexual orientation or gender identity
- Genetic or biometric data
- Criminal history
- Children under 16

***

### 7. INTELLECTUAL PROPERTY

#### 7.1 Actor Code

The Actor's source code, schemas, documentation, and branding are owned by the Publisher. You receive a limited, non-exclusive, non-transferable, revocable license to use the Actor for permitted purposes during your active subscription/run with Apify.

#### 7.2 Output Data

The Publisher claims no ownership over the public data the Actor returns. Source Platforms may have copyright, database rights, or other rights in their data; data subjects may have copyright in user-generated content. Your use of output data must respect these rights independently.

#### 7.3 Restrictions

You may not reverse engineer, decompile, or reuse the Actor's code in a competing actor.

#### 7.4 Feedback

Feedback you provide may be used by the Publisher to improve products without compensation to you.

***

### 8. PRICING AND PAYMENT

#### 8.1 Apify Platform Billing

Pricing is administered through Apify's pricing models. Apify processes all payments. Apify's payment terms govern refunds and disputes.

#### 8.2 Pricing Changes

The Publisher may change Actor pricing with at least 14 days' notice via the Actor's Apify listing.

#### 8.3 No Refunds for Misuse

If your access is suspended or terminated for breach of these Terms, you forfeit any unused balance and are not entitled to refunds.

***

### 9. SERVICE AVAILABILITY AND CHANGES

#### 9.1 No Uptime Guarantee

The Actor depends on:

- (a) The Apify platform
- (b) Underlying API providers (HarvestAPI, Scrape Creators)
- (c) Source Platforms' continued public accessibility

Any of these may change behavior, restrict access, or become unavailable without notice. The Publisher makes no uptime guarantees.

#### 9.2 Service Discontinuation

The Publisher may discontinue any Actor at any time. Reasonable notice will be provided when feasible.

***

### 10. DISCLAIMERS

#### 10.1 "AS IS" Service

THE ACTOR IS PROVIDED "AS IS" AND "AS AVAILABLE" WITHOUT WARRANTIES OF ANY KIND, INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR PURPOSE, NON-INFRINGEMENT, OR ACCURACY OF DATA.

#### 10.2 No Representation of Lawfulness

The Publisher makes no representation that your specific use of the Actor or the data it returns is lawful in your jurisdiction or under any Source Platform's terms. The burden of determining lawfulness for your use case is yours.

#### 10.3 No Endorsement of Source Content

Content returned by the Actor was created by third parties. The Publisher does not endorse, verify, or take responsibility for it.

***

### 11. LIMITATION OF LIABILITY

#### 11.1 Aggregate Liability Cap

TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, IN NO EVENT SHALL THE AGGREGATE LIABILITY OF THE PUBLISHER FOR ALL CLAIMS RELATING TO THE ACTOR EXCEED THE GREATER OF:

- (a) ONE HUNDRED U.S. DOLLARS (US $100), OR
- (b) THE AMOUNTS YOU PAID THROUGH APIFY FOR USE OF THE ACTOR IN THE THREE (3) MONTHS IMMEDIATELY PRECEDING THE EVENT

#### 11.2 Excluded Damages

THE PUBLISHER IS NOT LIABLE FOR INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, EXEMPLARY, OR PUNITIVE DAMAGES, OR FOR LOSS OF PROFITS, REVENUE, OR DATA, EVEN IF ADVISED OF THE POSSIBILITY.

#### 11.3 Time Limit

Any claim must be brought within one (1) year of the event.

***

### 12. INDEMNIFICATION

#### 12.1 Your Indemnification of the Publisher

You agree to defend, indemnify, and hold harmless the Publisher from any:

- Claims arising from your use of the Actor
- Claims arising from your violation of these Terms
- Claims arising from your violation of any law (including privacy law)
- Claims arising from your violation of any Source Platform's Terms of Service
- Claims arising from your processing of personal data obtained through the Actor
- Reasonable attorneys' fees and costs of defending such claims

#### 12.2 Defense

The Publisher may assume defense at your expense. You will cooperate with the Publisher's defense.

#### 12.3 Scope

The indemnification covers reasonable, foreseeable third-party claims arising from your use. It does not extend to:

- Claims arising from the Publisher's gross negligence or willful misconduct
- Claims regarding the Actor's source code itself (those are the Publisher's responsibility)
- Claims regarding the Third-Party API Provider's data collection (those are their responsibility)

***

### 13. SUSPENSION AND TERMINATION

#### 13.1 Termination by the Publisher

The Publisher may terminate your access for material breach, illegal use, breach of warranty, or upon credible legal demand.

#### 13.2 Effects of Termination

Your license ends, you must cease use, and applicable provisions survive.

#### 13.3 Termination by You

You may stop using the Actor at any time on Apify.

***

### 14. DISPUTE RESOLUTION

#### 14.1 Informal Resolution First

Send a detailed written description of the dispute via UnseenUser's Apify profile contact form (https://apify.com/UnseenUser) and wait 60 days for resolution attempt before any formal claim.

#### 14.2 Governing Law

These Terms are governed by the substantive laws of the State of Israel, without regard to conflict of law principles.

#### 14.3 Exclusive Jurisdiction

Any dispute shall be brought exclusively in the competent civil courts of Tel Aviv-Jaffa, Israel.

#### 14.4 No Class Actions

You agree to bring claims only in your individual capacity.

#### 14.5 Attorneys' Fees

The prevailing party recovers reasonable attorneys' fees.

***

### 15. MISCELLANEOUS

#### 15.1 Entire Agreement

These Terms (with Addendum and incorporated documents) are the entire agreement.

#### 15.2 Severability

Unenforceable provisions are reformed to the minimum extent or severed.

#### 15.3 Assignment

You may not assign without the Publisher's consent. The Publisher may assign to affiliates, successors, or acquirers.

#### 15.4 Force Majeure

Neither party is liable for failure due to events beyond reasonable control, including changes by Source Platforms or Third-Party API Providers, or actions by Apify.

#### 15.5 Third-Party Beneficiaries

Apify, HarvestAPI, and Scrape Creators are intended third-party beneficiaries of Sections 4 (Prohibited Uses), 5 (Source Platform Compliance), and 12 (Indemnification).

#### 15.6 Survival

Sections 0 (Acceptance), 4, 5, 6, 7, 10, 11, 12, 14, and 15 survive termination.

#### 15.7 Language

English controls. Translations are for convenience only.

#### 15.8 Publisher Identification for Legal Process

The Publisher operates on the Apify platform under the username **UnseenUser** (apify.com/UnseenUser). The Publisher is a registered legal entity. Upon receipt of valid legal process (subpoena, court order, or equivalent) directed through Apify's official channels, the Publisher's full legal identity may be disclosed as required by law. This Section ensures that you have a valid path to legal recourse if needed.

***

### 16. ACKNOWLEDGMENT

By using any Actor, you acknowledge that:

- (a) You have read these Terms
- (b) You understand the architecture: you are using software (the Actor) on Apify's platform that calls third-party APIs
- (c) You accept responsibility for your use, including for compliance with Source Platform terms
- (d) Your indemnification obligations cover third-party claims arising from your use
- (e) Disputes are resolved in Israeli courts
- (f) The Publisher's identity, while not publicly disclosed in this listing, can be obtained through valid legal process via Apify

For questions, use UnseenUser's Apify profile contact form (https://apify.com/UnseenUser) before running the Actor.

***

### APPENDIX - Document Version History

| Version | Date | Summary |
|---------|------|---------|
| 1.0 | May 5, 2026 | Initial publication |
| 2.0 | May 5, 2026 | Hardened (over-broad - treated User as data broker) |
| 3.0 | May 5, 2026 | Architecturally accurate - Publisher as software vendor |
| 4.0 | May 5, 2026 | **Anonymous Publisher.** All personally identifying information removed. Acceptance-by-Use mechanism formalized. |

***

*These Terms reflect best practices for anonymous Apify actor publishing as of May 2026. Not a substitute for legal advice. Consult qualified Israeli commercial counsel before deploying.*

***

## 🛡️ Actor-Specific ToS Addendum - 📘 Facebook Pages Scraper

This addendum supplements the Master Terms of Service V4.0. By running this Actor, you accept both the Master ToS and this addendum.

#### A. Architectural Disclosure

This Actor is a software wrapper. It accepts your input parameters, calls the Scrape Creators `/v1/facebook/profile` endpoint for each page (and, only when you enable them, the `/profile/posts`, `/profile/events`, `/profile/photos` and `/profile/reels` add-on endpoints), and returns the response data to you on the Apify platform. UnseenUser does not store, log, or substantively process the data returned. The data flows from Scrape Creators through Apify's runtime directly to you.

#### B. Nature of Data Returned

This Actor returns Facebook page details: page name, category, intro, creation date, **email, phone, website and physical address**, services and price range, ratings and rating count, like and follower counts, business hours, an ad-running status signal (`adLibrary.adStatus`), and profile/cover imagery. When add-ons are enabled it also returns posts (text, author, engagement counts, video details, top comments), events, photos (with native captions), and reels.

Where the Actor's output includes individual people's names, photos, contact details, or content authored by them, that data constitutes **personal data** subject to GDPR, CCPA, Israeli Privacy Protection Law (including Amendment 13), and equivalent privacy laws in your downstream processing - but **only in your hands as the data controller**, not in UnseenUser's hands as the software vendor. The core fields here (email, phone, address) are precisely the high-sensitivity contact data that anti-spam and privacy regulators scrutinize most closely.

#### C. Permitted Use Cases

You may use this Actor for the following purposes (non-exhaustive list):

- **B2B lead generation** - pull email, phone and website for a list of known business pages
- **CRM enrichment** - fill in contact, category and rating fields for accounts you already track
- **Local-business prospecting** - build outreach lists for a vertical
- **Competitor research** - check ratings, follower counts and ad-running status
- **Ad-activity monitoring** - surface which pages are currently advertising
- **Market mapping** - profile categories and engagement across a defined set of pages

#### D. Specifically Prohibited Uses

In addition to Master ToS Section 4 prohibitions, you may NOT:

- Send mass cold email or DMs using scraped contact data without anti-spam compliance (GDPR, CAN-SPAM, CASL, Israeli Anti-Spam Law)
- Build or sell a "people search" website or contact list without a consent infrastructure and the required transparency notices
- Resell raw contact lists as a standalone data product (data broker activity)
- Harvest contact details from personal (non-business) profiles for targeting or outreach
- Use ratings, reviews or engagement data to harass or pressure a page owner
- Use sensitive inferences (for example religion or politics inferred from a page's category or content) to make hiring, lending or housing decisions
- Train commercial AI/ML models on page posts, photos or captions without separate licensing authority

#### E. Platform Terms of Service Considerations

Meta's Terms of Service prohibit automated extraction. Meta has aggressively litigated against scrapers (Meta v. BrandTotal - settled with permanent injunction; Meta v. Octopus Data; Meta v. Bright Data - pending). Facebook's Terms of Service prohibit automated extraction. This Actor accesses publicly visible page data via Scrape Creators - Scrape Creators bears responsibility for the lawfulness of the data collection. Your downstream use must independently comply with Meta's Terms of Service.

If Meta issues a cease-and-desist regarding data obtained via this Actor, notify UnseenUser within 48 hours via the Apify profile contact form (apify.com/UnseenUser) and cease your use immediately.

#### F. Contact Data - Heightened Care

Email, phone and address are high-sensitivity personal data. They reveal how to reach and locate a person or business, and they are the exact fields that direct-marketing and anti-spam regimes regulate. Treat them with extra care:

- Store only the contact fields you actually need (data minimization, GDPR Article 5(1)(c))
- Do not retain contact lists indefinitely - set retention limits
- Where a page is a sole proprietor or individual, the "business" address may be a home address - treat it as personal data

#### G. Prospecting Compliance

If you use this Actor for B2B prospecting, cold outreach or lead generation:

- Establish a documented lawful basis (typically legitimate interest with a completed Legitimate Interest Assessment / balancing test)
- Honor opt-outs and the right to object under GDPR Article 21 (absolute for direct marketing, not subject to a balancing test)
- Comply with GDPR, CCPA, Israeli Anti-Spam Law (prior consent required for marketing in Israel), CAN-SPAM, CASL and equivalents
- Issue Article 14 transparency notices when you collect personal data from a source other than the data subject
- Do not use sensitive inferences (health, religion, politics) as a basis for any outreach
- Disclose, when asked, how you found the recipient

#### H. Business vs Personal Pages

Not every "page" is a business. The `/profile` endpoint also returns data for personal profiles and creator pages. When a page is ambiguous or clearly a private individual, treat the data as personal data of an individual (not business contact data) and apply the full data-controller obligations. Do not assume a contact field is fair game for outreach simply because it was publicly visible.

#### I. The Data Broker Question

Contact data across MANY pages IS a data broker asset. California's data broker registration requirements (effective 2024+) apply if you collect personal data from a source that is not the consumer and sell or share that data. If your business model includes selling contact lists or insights derived from them, you may need to register as a data broker in California (and possibly other states), and you trigger GDPR Article 14, the California Delete Act (effective 2026), and Israeli Privacy Law Amendment 13 (statutory damages of NIS 10,000 per data subject without proof of harm). Consult an attorney.

#### J. AI Training - Special Notice

Meta's Terms of Service prohibit using Facebook data to train AI/ML models without authorization. Page posts, photos and captions are no exception. The Publisher (UnseenUser) does NOT authorize, and has no ability to authorize, AI training use. Recent litigation (NYT v. OpenAI, Andersen v. Stability AI, multiple class actions) shows AI training on platform data is contested. Get proper licensing or do not train on this data. Your AI training use is your own legal exposure.

#### K. Cross-Platform Aggregation Limit

Do NOT aggregate this Facebook page data with LinkedIn, Instagram, TikTok, X/Twitter and other personal data to build comprehensive cross-platform identity profiles of named individuals. Cross-platform aggregation multiplies the personal-data risk, triggers heightened GDPR scrutiny (the combination is itself processing), has been the basis for Meta lawsuits (Meta v. BrandTotal, Meta v. Octopus Data), and creates "people search" profiles that the California Delete Act, GDPR Article 14, and Israeli Privacy Law Amendment 13 specifically target.

#### L. Minor Protection - CRITICAL

Facebook has a significant under-18 user population, and some pages are personal profiles that may belong to minors. You MUST:

- NOT use this Actor to scrape contact data or content of users you know or suspect are minors
- NOT use this Actor for any product or service targeted at minors without parental-consent mechanisms compliant with COPPA (US), GDPR Article 8 (EU), and Israeli Privacy Law (heightened sensitivity for minors)
- DELETE any data you discover relates to a minor unless you have valid parental consent

If page metadata or content suggests the subject is under 18, treat the page as belonging to a minor by default. This restriction is non-negotiable - minor-data violations carry the highest regulatory penalties.

#### M. Data Subject Rights - Operational Requirements

Individuals whose personal data you collect have rights under GDPR / CCPA / Israeli Privacy Law:

- **Right to access** - they can demand to know what you hold about them
- **Right to deletion** - they can demand removal from your databases (Article 17)
- **Right to object** - to processing for direct marketing (absolute under GDPR Article 21)
- **Right to rectification** - to correct inaccurate data
- **Right to portability** - a machine-readable copy

Build operational processes from day one to honor these with a typical 30-day SLA: a dedicated request email, a 30-day response SLA, a log of all requests and responses, and a privacy policy linked from any product or outreach using this data.

#### N. Cease-and-Desist Protocol

If a data subject contacts YOU directly demanding deletion of their data:

- Honor the request promptly (typically within 30 days under GDPR)
- Do NOT route them to UnseenUser - UnseenUser is the software vendor, not the data controller
- You may suggest they contact Meta directly (since the data originates there) and comply with your own deletion obligations
- Document the request and your response

If Meta, Scrape Creators, or a regulator contacts UnseenUser regarding your use, UnseenUser will notify Apify per Master ToS Section 8, may suspend access to this Actor pending investigation, and you agree to provide documentation of your lawful basis and processing activities on reasonable request.

***

For questions about these Terms, use UnseenUser's Apify profile contact form: https://apify.com/UnseenUser

***

*Keywords: facebook pages scraper, facebook page contact info, facebook email scraper, facebook page details, facebook lead generation, facebook business scraper, facebook page email phone, facebook crm enrichment, facebook no login scraper.*

# Actor input Schema

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

One or more public Facebook page URLs to scrape. Example: https://www.facebook.com/mantraindianfolsom

## `getBusinessHours` (type: `boolean`):

Add the page's opening hours to the core /profile response.

## `includePosts` (type: `boolean`):

⚠️ COST WARNING: billed add-on. Pull recent posts (3 per request, paginated by cursor). Off by default to avoid surprise billing.

## `maxPosts` (type: `integer`):

Maximum posts to fetch per page when posts are enabled. Posts return 3 per request so deep pulls paginate across multiple billed calls.

## `includeEvents` (type: `boolean`):

⚠️ COST WARNING: billed add-on. Pull the page's public events.

## `includePhotos` (type: `boolean`):

⚠️ COST WARNING: billed add-on. Pull page photos (paginated by next\_page\_id + cursor).

## `maxPhotos` (type: `integer`):

Maximum photos to fetch per page when photos are enabled. Leave at 0 for a single page of results.

## `includeReels` (type: `boolean`):

⚠️ COST WARNING: billed add-on. Pull page reels (10 per request, paginated by next\_page\_id + cursor).

## `maxReels` (type: `integer`):

Maximum reels to fetch per page when reels are enabled. Reels return 10 per request so deep pulls paginate across multiple billed calls.

## Actor input object example

```json
{
  "startUrls": [
    "https://www.facebook.com/mantraindianfolsom"
  ],
  "getBusinessHours": true,
  "includePosts": false,
  "maxPosts": 9,
  "includeEvents": false,
  "includePhotos": false,
  "maxPhotos": 0,
  "includeReels": false,
  "maxReels": 10
}
```

# 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": [
        "https://www.facebook.com/mantraindianfolsom"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("unseenuser/fb-pages").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": ["https://www.facebook.com/mantraindianfolsom"] }

# Run the Actor and wait for it to finish
run = client.actor("unseenuser/fb-pages").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": [
    "https://www.facebook.com/mantraindianfolsom"
  ]
}' |
apify call unseenuser/fb-pages --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Facebook Page Details Scraper - Lead Gen [NO COOKIES] ✅",
        "description": "Get everything a Facebook page makes public in one call: email, phone, website, address, category, business hours, ratings, like and follower counts, plus whether the page is currently running ads. No login, no cookies. Built for lead generation, CRM enrichment and competitor research.",
        "version": "0.0",
        "x-build-id": "M9ga3AYQ02W1n7GRP"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/unseenuser~fb-pages/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-unseenuser-fb-pages",
                "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/unseenuser~fb-pages/runs": {
            "post": {
                "operationId": "runs-sync-unseenuser-fb-pages",
                "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/unseenuser~fb-pages/run-sync": {
            "post": {
                "operationId": "run-sync-unseenuser-fb-pages",
                "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": "Facebook page URLs",
                        "minItems": 1,
                        "uniqueItems": true,
                        "type": "array",
                        "description": "One or more public Facebook page URLs to scrape. Example: https://www.facebook.com/mantraindianfolsom",
                        "items": {
                            "type": "string"
                        }
                    },
                    "getBusinessHours": {
                        "title": "Include business hours",
                        "type": "boolean",
                        "description": "Add the page's opening hours to the core /profile response.",
                        "default": true
                    },
                    "includePosts": {
                        "title": "Include posts (billed add-on)",
                        "type": "boolean",
                        "description": "⚠️ COST WARNING: billed add-on. Pull recent posts (3 per request, paginated by cursor). Off by default to avoid surprise billing.",
                        "default": false
                    },
                    "maxPosts": {
                        "title": "Max posts per page",
                        "minimum": 3,
                        "maximum": 300,
                        "type": "integer",
                        "description": "Maximum posts to fetch per page when posts are enabled. Posts return 3 per request so deep pulls paginate across multiple billed calls.",
                        "default": 9
                    },
                    "includeEvents": {
                        "title": "Include events (billed add-on)",
                        "type": "boolean",
                        "description": "⚠️ COST WARNING: billed add-on. Pull the page's public events.",
                        "default": false
                    },
                    "includePhotos": {
                        "title": "Include photos (billed add-on)",
                        "type": "boolean",
                        "description": "⚠️ COST WARNING: billed add-on. Pull page photos (paginated by next_page_id + cursor).",
                        "default": false
                    },
                    "maxPhotos": {
                        "title": "Max photos per page",
                        "minimum": 0,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Maximum photos to fetch per page when photos are enabled. Leave at 0 for a single page of results.",
                        "default": 0
                    },
                    "includeReels": {
                        "title": "Include reels (billed add-on)",
                        "type": "boolean",
                        "description": "⚠️ COST WARNING: billed add-on. Pull page reels (10 per request, paginated by next_page_id + cursor).",
                        "default": false
                    },
                    "maxReels": {
                        "title": "Max reels per page",
                        "minimum": 10,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Maximum reels to fetch per page when reels are enabled. Reels return 10 per request so deep pulls paginate across multiple billed calls.",
                        "default": 10
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
