Skillquality 0.46

competitor-intel

Run end-to-end competitor research and monitoring through the Hyper MCP — pick the set, scrape every public surface (site, blog, pricing, organic social, search rank, mentions, demand) via Firecrawl + HyperSEO + the Apify scrapers, diff against last run, and synthesize a brief. U

Price
free
Protocol
skill
Verified
no

What it does

Competitor Intel

End-to-end competitor research and monitoring. Define the set, pull from every public surface that matters, diff against last run (or your own), and produce a brief that's actually useful — battle card, weekly digest, board update, or comparison-page input.

Out of scope — defer to other skills

RequestSend them to
Competitor paid ads (Facebook / Instagram active ads)meta-ads-library
Pure SEO / keyword research with HyperSEO as the primary surfaceseo-research — uses the same HyperSEO toolkit but goes much deeper on keyword work
Generating creative (images / copy) for a comparison campaign once the intel is inad-creative-generation
Pulling data from competitor email programsNot feasible — opt-in only. Use firecrawl_scrape_url on their landing pages instead.

competitor-intel is the integration layer — it pulls from every source and synthesizes. It uses HyperSEO for the rank/backlink/intersection slice but isn't the SEO research skill itself.

Requirements

  • Hyper MCP installed and connected. https://app.hyperfx.ai/mcp
  • At least one of these toolkits connected at https://app.hyperfx.ai/integrations:
    • Firecrawl (highly recommended — backbone for any site/blog/pricing-page work)
    • HyperSEO (needed for rank, backlink, domain-overlap analysis)
    • Apify scrapers — Instagram, TikTok, LinkedIn, Twitter, Reddit, Google search, Google Trends
    • Image generation (optional — only if the brief feeds a comparison-page or battle-card asset downstream)

If none of those tool prefixes appear in the agent's tool list (firecrawl_*, hyperseo_*, scrape_instagram*, scrape_tiktok*, search_tweets, scrape_reddit*, search_google_results, scrape_google_trends, web_scrape_page), stop and tell the user to enable the Hyper MCP and connect at least Firecrawl + one social scraper. The LinkedIn scraper (scrape_linkedin_profiles) is only present when that specific integration is enabled — gracefully skip the LinkedIn slice if it's missing rather than failing the whole brief.

Tool surface

PhaseTools
Site & web contentfirecrawl_scrape_url, firecrawl_batch_scrape, firecrawl_crawl_website, firecrawl_screenshot, firecrawl_extract_branding, web_scrape_page (JS-rendering fallback, supports ai_query for targeted extraction), web_fetch_page, web_loader
Search rankings & backlinkshyperseo_competitors, hyperseo_competitors_domain, hyperseo_domain_overview, hyperseo_domain_keywords, hyperseo_domain_intersection, hyperseo_keywords_for_site, hyperseo_backlinks_history, hyperseo_historical_rank, hyperseo_track_mentions
Brand mentions in AI search & SERPshyperseo_ai_overview, hyperseo_ai_search_volume, hyperseo_track_mentions, search_google_results, web_search
Organic social — Instagramscrape_instagram, scrape_instagram_posts, scrape_instagram_followers_count
Organic social — TikTokscrape_tiktok_videos, scrape_tiktok_comments
Organic social — LinkedInscrape_linkedin_profiles (conditional — only available when the LinkedIn-scraper integration is enabled in your Hyper workspace)
Organic social — Twitter / Xsearch_tweets
Community / sentiment — Redditscrape_reddit, scrape_reddit_leads
Ecommerce competitor specificsscrape_ecommerce_products, scrape_ecommerce_reviews
Demand / trend signalsscrape_google_trends, hyperseo_search_volume, hyperseo_search_intent
Optional: comparison-page assetsopenai_image_generation, nano_banana_image_generation, seedream_image_generation, nano_banana_multi_turn

Critical rules

  1. Public-only data. Never scrape behind login walls or paywalls. If a target is gated, stop and surface that — don't try to bypass.
  2. Pick the competitor set before scraping. 3–5 competitors is the sweet spot. 10+ produces an unreadable brief and burns scraper credits. If the user doesn't have a list, run hyperseo_competitors(domain=<their_domain>) first to surface the top organic competitors, then confirm the set with them.
  3. Snapshot, then diff. First run is just a baseline — there's nothing to compare against. The value compounds on the second and third runs (what changed in pricing, what new posts went up, who lost rank). Make this expectation clear when the user runs it for the first time.
  4. HyperSEO is credit-metered. Be intentional. Don't loop hyperseo_domain_overview over 12 competitors when you only need 4. Each call has cost — batch and cache.
  5. Apify scrapers can be slow and rate-limited. Don't kick off 8 scrapes in parallel. Sequence them, and surface partial results to the user as they arrive instead of waiting for the full run.
  6. Snapshot what you scraped, not just the analysis. Always include the source URL, scrape timestamp, and a short excerpt for any claim in the brief — otherwise next week's diff has nothing to compare against and the brief becomes unfalsifiable.
  7. Don't over-interpret single data points. "Competitor X dropped a Reel that got 12K likes" is noise. "Competitor X has averaged 8K likes/post for the last 30 days, up from 2K" is signal. Build comparisons on aggregates, not anecdotes.
  8. Stay clearly factual. Use neutral language ("Competitor X published Y on date Z, copy reads as…") not value judgments ("Competitor X's strategy is broken…"). The brief is intel, not opinion.
  9. Disambiguate brand-name SERPs. A search for <competitor> alone often returns unrelated results that share the brand name (e.g. a search for "hyperfx" returns mostly HyperX headphones, not hyperfx.ai). Always pair the brand with a category modifier — <competitor> alternative, <competitor> reviews, <competitor> pricing, <competitor> vs <us> — to get clean SERPs.
  10. Apify-backed scrapers fail intermittently. Expect occasional "fetch failed" or empty-result responses from scrape_instagram*, scrape_tiktok*, scrape_reddit*, scrape_google_trends, search_tweets, and search_google_results. Retry once after a short delay before reporting the source as missing — and surface partial results to the user rather than failing the whole brief if a scraper stays down.

Workflow

Phase 1 — Define the competitor set

Ask the user (or infer):

  1. Their domain — needed to ground all relative comparisons.
  2. Their competitor set — 3–5 names + domains. If unclear, surface the top organic competitors. hyperseo_competitors takes the keywords the user wants to win, not their domain — so first agree on 3–5 high-intent keywords for the user's category, then run:
hyperseo_competitors(
  keywords=["<category keyword 1>", "<category keyword 2>", "<category keyword 3>"],
  location_code=2840,  # 2840=US, 2826=UK, 2124=CA, 2036=AU
  limit=10
)

Then confirm the surfaced set with the user before continuing — never guess and proceed.

  1. The job — what is this brief for? The shape changes by job:
    • Battle card for sales → focus on positioning, pricing, "what to say when…" objection lines.
    • Weekly digest for marketing/exec team → focus on what changed this week.
    • Comparison-page input for marketing → focus on objective, comparable feature/pricing data.
    • Board / board-prep update → focus on aggregate position (share of voice, rank deltas, growth).
  2. The cadence — one-shot or recurring? Recurring scopes the source matrix tighter so each run completes in reasonable time.

If the user can't answer #3, stop and ask. Building intel without knowing the artifact is a guaranteed waste.

Phase 2 — Build the source matrix

Not every source matters for every competitor or every job. Per-competitor, decide which surfaces to pull from.

Competitor typeSources that matter most
Direct SaaS / B2BSite, blog, pricing page, LinkedIn company posts (if available), AI-search citations (hyperseo_ai_overview), domain rank delta
Ecommerce / DTC brandSite, product catalog (scrape_ecommerce_products), product reviews (scrape_ecommerce_reviews), Instagram, TikTok, Reddit threads, Google Trends interest
Consumer / creator brandInstagram, TikTok, Twitter, YouTube (via the YouTube toolkit if connected), Reddit
Content-led / publicationSite, blog (full crawl), backlinks history, AI-search citations, search rank trend
Local / multi-locationSite, Google search results for "[brand] near me", Reddit / Twitter sentiment, Google Trends regional

The full per-source playbook (when to use, what it reveals, quirks) lives in references/source-by-source.md.

Phase 3 — Pull the data

Sequence the pulls; don't fire everything in parallel. Order matters for cost and for letting partial results inform the next call.

Order to use:

  1. Cheapest first — HyperSEO baselines (one call per competitor, reuse data across the brief):
hyperseo_domain_overview(domain="<competitor>.com", location_code=2840)
hyperseo_domain_keywords(domain="<competitor>.com", limit=50, location_code=2840)
hyperseo_domain_intersection(
  domain1="yourbrand.com",
  domain2="<competitor>.com",
  limit=50,
  location_code=2840
)
  1. Site content via Firecrawl:
firecrawl_scrape_url(url="https://<competitor>.com/pricing")
firecrawl_scrape_url(url="https://<competitor>.com/")
firecrawl_extract_branding(url="https://<competitor>.com")  # logo, colors, voice

For a full-blog-archive deep dive use firecrawl_crawl_website once and check status with firecrawl_check_crawl_status. If Firecrawl returns near-empty for a JS-heavy SPA, fall back to web_scrape_page(url=..., use_proxy=true, ai_query="extract pricing tiers and prices").

  1. Social — sequenced per platform (note: most scrapers take arrays of identifiers, not a single username):
scrape_instagram(direct_urls=["https://www.instagram.com/<competitor>/"], results_type="posts", results_limit=30)
scrape_instagram_followers_count(usernames=["<competitor>"])  # cheap, do it weekly
scrape_tiktok_videos(profiles=["<competitor>"], results_per_page=30)
search_tweets(from_user="<competitor_handle>", max_items=50)

# Only if scrape_linkedin_profiles is in your MCP tool list:
scrape_linkedin_profiles(urls=["https://www.linkedin.com/company/<competitor>"])
  1. Sentiment & demand:
scrape_reddit(searches=["<competitor>"], max_items=50, sort="new", time="month")
scrape_google_trends(
  search_terms=["<competitor>", "yourbrand"],
  time_range="today 3-m",  # options: now 7-d, today 1-m, today 3-m, today 5-y, all
  geo="US"
)
search_google_results(query="<competitor> reviews", num_results=20, country="us")
  1. AI search visibility (only for SaaS/B2B usually):
# AI Overview takes ONE keyword at a time + integer location_code
hyperseo_ai_overview(keyword="<your category keyword>", location_code=2840)

# track_mentions runs the query against OpenAI / Claude / Perplexity and returns citations
hyperseo_track_mentions(
  query="best <your category> tools",
  brands=["<competitor>", "yourbrand"]
)

Surface partial results as each phase completes — don't wait for the whole pull to finish before showing the user something.

Phase 4 — Diff

The point of the skill is delta, not snapshot. For each competitor, compare:

SourceCompare against
Pricing pageLast scrape (changes in tier names, prices, plan limits, new add-ons)
Homepage heroLast scrape (new positioning copy, new CTA, new logos)
Domain rankhyperseo_historical_rank(domain=..., date_from=..., date_to=...) vs last 30/90 days
Domain keywordsNet-new keywords ranking, lost keywords
Domain intersection (theirs ∩ yours)Keywords they rank for and you don't — content gaps
Instagram / TikTokPosts since last run, follower delta, engagement-rate delta
Twitter / RedditVolume of mentions vs prior period
AI-search citationsNew AI Overview citations vs last run

For a first run, there's no "last" — the diff section in the brief becomes "baseline established, will diff against this on next run." Tell the user this explicitly so they don't expect insight on day 1.

Phase 5 — Brief

Synthesize into the artifact. Brief shapes by job (full templates in references/brief-templates.md):

  • Battle card — 1 page, per-competitor: positioning summary, 3 strongest competitor claims, 3 counter-claims for our side, common objections + responses, win-loss patterns.
  • Weekly digest — 1 page total, all competitors: bullet list of what changed this week per competitor, ranked by significance.
  • Comparison-page input — feature matrix table, pricing table, plan limits table — all sourced with URLs and timestamps.
  • Board-prep update — share-of-voice, rank deltas, content velocity, sentiment trend over the period.

Output standards (apply to every brief):

  • Always cite source + timestamp for every claim. "Competitor X raised the Pro tier from $79 → $99 (pricing page, 2026-04-29)" beats "X raised prices."
  • Use neutral language. Brief is for the reader to draw their own conclusion.
  • Distinguish observation from interpretation. Mark interpretation explicitly: "Observation: rank dropped 12 positions on 'invoice automation' over 30d. Possible interpretation: …".
  • Keep one ranked list of "things that matter" at the top of the brief. Bury everything else below it. Most readers stop after the first 3 bullets.

Phase 6 — Monitor on cadence (optional)

If the user wants ongoing monitoring rather than a one-shot:

  1. Save the source matrix and competitor set somewhere durable (bigquery_*, Notion, a Sheets tab, or just inline in the user's prompt template).
  2. Schedule the agent to re-run the pull on a cadence — weekly is the sweet spot. Daily produces too much noise; monthly misses fast moves.
  3. The brief shape becomes the weekly digest by default, with the option to escalate to a deep brief when something significant changes.

Reference workflows

ReferenceWhen to read
references/source-by-source.mdPer-source playbook — what each scraper / HyperSEO call reveals, when to use it, and the quirks (rate limits, JS-rendering issues, cache windows, credit cost)
references/brief-templates.mdBattle card, weekly digest, comparison-page, and board-prep templates with worked examples and output structure

Capabilities

skillsource-hyperfx-aiskill-competitor-inteltopic-agent-skillstopic-ai-agenttopic-claudetopic-claude-codetopic-claude-skillstopic-codextopic-cursortopic-google-adstopic-hermestopic-marketingtopic-mcptopic-meta-ads

Install

Installnpx skills add hyperfx-ai/marketing-skills
Transportskills-sh
Protocolskill

Quality

0.46/ 1.00

deterministic score 0.46 from registry signals: · indexed on github topic:agent-skills · 24 github stars · SKILL.md body (14,841 chars)

Provenance

Indexed fromgithub
Enriched2026-05-18 19:05:15Z · deterministic:skill-github:v1 · v1
First seen2026-05-07
Last seen2026-05-18

Agent access