meta-ads-library
Research competitor Facebook and Instagram ads from the Meta Ads Library via the Hyper MCP — search by keyword, pull full ad creative and metadata, enrich with page contact info for lead generation, and surface structured ad-intelligence summaries in chat. Use when the user wants
What it does
Meta Ads Library
Guide for searching the Meta Ads Library and producing structured competitor ad intelligence.
The skill's job is to turn raw scraped ads into useful summaries: top advertisers, common CTAs, recurring hooks, recently launched creatives, and (optionally) enriched lead lists. All output is presented inline in chat — there is no database or persistence layer.
Out of scope — defer to other skills
| Request | Send them to |
|---|---|
| Multi-source competitor research (site, social, search rank, etc., not just ads) | competitor-intel |
| Generating new ad creative based on what you found | ad-creative-generation |
Requirements
- Hyper MCP installed and connected. https://app.hyperfx.ai/mcp
- Apify integration connected at https://app.hyperfx.ai/integrations — the Meta Ads Library tools run via Apify under the hood.
If search_facebook_ads is not in the tool list, stop and tell the user to enable Hyper MCP and connect Apify.
Tool surface
| Tool | Purpose |
|---|---|
search_facebook_ads | Search the Meta Ads Library by keyword. Returns compact results (title, body, CTA, link, page name, dates, platforms). Max 40 per call. |
get_facebook_ad_details | Get full details for a specific ad. Requires both ad_archive_id and page_id — both come from search_facebook_ads results. |
search_facebook_ads_enriched | Search + enrich each result with page contact info (email, phone, website). Slower (multiple API calls per result). Max 20 per call. |
search_facebook_pages | Search Facebook pages by category + location (not by keyword). Useful for building a lead list from a vertical. |
scrape_facebook_pages | Scrape detailed data from specific Facebook page URLs. |
Critical rules
- Public-only data. The Meta Ads Library is public. Don't attempt to bypass any access control or scrape private content.
- Count limits differ between tools.
search_facebook_adsallowscountup to 40.search_facebook_ads_enrichedcaps at 20 — exceeding this returns an error. get_facebook_ad_detailsneeds two IDs. Bothad_archive_idandpage_idare required. Both are returned in everysearch_facebook_adsresult row — pass them through together.- Enriched search is slow. It makes a Facebook page scrape per ad and optionally a website scrape. Only use it when contact info matters (lead-gen workflows). For pure ad intelligence, use the regular
search_facebook_ads. - Apify-backed tools fail intermittently. Expect occasional
"fetch failed"responses. Retry once after a short delay before reporting the source as missing. - Don't over-interpret a single ad. "Brand X is running a discount" is noise. "5 of the top 10 advertisers in this query are running discounts" is signal. Always aggregate before drawing conclusions.
Workflow
Phase 1 — Define the query
Before running anything, agree on:
- The search query — keyword(s) competitors would target. Examples:
"meal kit delivery","AI marketing tools","skincare for sensitive skin". - Country — ISO code (e.g.
"US","GB","AU"). Default to"ALL"only if the user explicitly wants global. - Active vs all —
active_status="active"is usually what you want. Inactive ads are historical and noisier. - Time window —
periodaccepts"last24h","last7d","last14d","last30d", or"all_time". Match the window to the user's intent (weekly digest →"last7d", trend research →"last30d"). - The job — what is this for?
- Creative trend report → use
search_facebook_ads, summarize patterns across hooks, CTAs, formats. - Top advertiser snapshot → use
search_facebook_ads, group bypage_name. - Lead list → use
search_facebook_ads_enriched, filter for rows withcontact_emailorcontact_website.
- Creative trend report → use
Phase 2 — Pull the ads
search_facebook_ads(
query="meal kit delivery",
country="US",
active_status="active",
count=40, # max for this tool
period="last30d"
)
Each result row includes: ad_archive_id, page_id, page_name, is_active, start_date_formatted, end_date_formatted, title, body, cta_text, link_url, caption, ad_library_url, page_categories, publisher_platform.
For more than 40 ads, paginate by re-calling with offset=40, offset=80, etc.
For lead-gen with contact info:
search_facebook_ads_enriched(
query="meal kit delivery",
country="US",
active_status="active",
count=20, # max for the enriched tool
scrape_websites=True,
filter_spam=False
)
Enriched rows add: contact_email, contact_phone, contact_website, page_followers, page_rating, address, business hours.
Phase 3 — Get full creative for the most interesting ads (optional)
search_facebook_ads returns truncated bodies for some ads. To get the complete creative — including video URLs and images — call get_facebook_ad_details on the specific ads worth a deeper look:
get_facebook_ad_details(
ad_archive_id="559220927273823", # from search results
page_id="328127803978438" # from search results
)
Both args come from the same row in search_facebook_ads. Do this for the top 3–5 ads, not all 40 — each detail call is a separate Apify run.
Phase 4 — Surface the intelligence
Present the findings inline in chat. Pick the format that matches the user's job from Phase 1.
Top advertisers (group by page):
| Page | Active ads | Categories | Notable angle |
|---|---|---|---|
| Brand A | 12 | Restaurant, Meal Kit | "Skip the grocery store" hook in 8/12 ads |
| Brand B | 7 | Software, Subscription | Heavy on UGC video, "$1 first week" offer |
Common CTAs and hooks:
| Pattern | Count | Examples |
|---|---|---|
Sign up CTA | 18 | … |
Shop now CTA | 12 | … |
| Price-anchor opener ("From $X/week") | 9 | … |
| Founder-story opener | 4 | … |
Recently launched ads (last 7 days):
| Page | Started | CTA | Hook | Library URL |
|---|---|---|---|---|
| Brand A | 2026-04-28 | Sign up | "Skip the grocery run this week" | <ad_library_url> |
Lead list (enriched only):
| Page | Website | Followers | Active ads | |
|---|---|---|---|---|
| Brand A | hello@a.com | a.com | 12K | 7 |
Phase 5 — Recurring monitoring (optional)
If the user wants ongoing tracking:
- Save the query, country, and
active_statussettings. - Re-run weekly with
period="last7d". - Brief becomes a delta report — new ads since the last run, advertisers that changed posting cadence, CTA / offer shifts.
This is when competitor-intel becomes the better skill — it handles multi-source diffing across many surfaces, not just Meta ads.
Output standards
- Always cite the
ad_library_urlfor any specific ad referenced in the brief — the user can click through to verify. - Aggregate before quoting. Don't paste raw ad bodies; extract the pattern and quote 1–2 representative examples.
- Mark interpretation explicitly. "Observation: 8 of 10 top advertisers use a 'first week free' offer. Possible interpretation: …".
- Note the time window. Every brief should state the search query, country, and date range it was generated from.
Capabilities
Install
Quality
deterministic score 0.46 from registry signals: · indexed on github topic:agent-skills · 24 github stars · SKILL.md body (7,478 chars)