Reportcnn.com·checked 2026-05-21 20:24 UTC·methodology v0.1 (preview)·canaifind.com/r/z19E8MtH
NoAI engines are likely blocked from indexing cnn.com.

This is a static-scan check (robots.txt + llms.txt + schema.org + headers). Live engine probes across ChatGPT, Claude, Gemini, and Perplexity arrive in a future build — currently in queue. Real visibility lives in category and comparison queries, which we measure with a 100-prompt stratified set on the Audit tier.

╴ Check your own domain

Same scan, free, no signup. Results in ~5 seconds at your own permanent canaifind.com/r/{slug} URL.

AI crawler robots.txt audit

§1 of 4
⚠ Conflict detected
All AI search-index crawlers are disallowed.

Every search-index crawler we track (OAI-SearchBot, Claude-SearchBot, PerplexityBot, GoogleOther) is disallowed by cnn.com's robots.txt. If this is intentional (regulated industry, deliberate opt-out), no action needed. If the expectation is that AI engines should cite it, this is the root cause: AI engines retrieve via these crawlers at inference time.

Read the full explanation →

No Content Signals in robots.txt.Content Signals (IETF draft, contentsignals.org) are a declarative way to state AI-usage preferences: `Content-Signal: search=yes, ai-input=yes, ai-train=no`. Compliance is voluntary today, but the signals are cheap to publish and align with the direction the standards are heading.

OpenAI
GPTBotTraining crawler for future OpenAI models.✗ Disallowed
OAI-SearchBotChatGPT Search index. Disallowing makes you invisible to ChatGPT Search.✗ Disallowed
ChatGPT-UserUser-initiated retrieval. Ignores robots.txt by design.— Ignores robots.txt
Anthropic
ClaudeBotTraining crawler for Anthropic models.✗ Disallowed
Claude-UserRetrieves pages when a Claude user asks about them. Respects robots.txt (unlike OpenAI's ChatGPT-User).✗ Disallowed
Claude-SearchBotSearch index for Claude. Disallowing reduces Claude search quality.✗ Disallowed
claude-codeClaude Code CLI / IDE retrieval. Documentation-targeted.✓ Allowed
Perplexity
PerplexityBotPerplexity indexing. Disallowing removes you from Perplexity retrieval.✗ Disallowed
Perplexity-UserUser-initiated retrieval. Ignores robots.txt by design.— Ignores robots.txt
Google
Google-ExtendedTraining opt-out for Gemini / Bard. Disallowing opts you out of Google AI training.✗ Disallowed
GoogleOtherCatch-all for non-Search Google crawlers.✗ Disallowed
Meta
Meta-ExternalAgentMeta AI crawler. Disallowing opts you out of Meta AI training/retrieval.✓ Allowed
Apple
Applebot-ExtendedApple Intelligence training opt-out (separate from Applebot Search).✗ Disallowed
ByteDance
BytespiderByteDance / TikTok AI crawler.✗ Disallowed
Common Crawl
CCBotCommon Crawl. Heavily used as a training-corpus source by every major model.✗ Disallowed

Structured data & discovery files

§2 of 4
ArtifactStatusNote
llms.txtA markdown index of the site's most important pages, served at /llms.txt. Anthropic Claude Desktop and Claude.ai fetch this. IDE tooling (Cursor, Claude Code, GitHub Copilot, Cline, Aider) routinely retrieves it. Google has explicitly confirmed it does NOT support it (Gary Illyes, July 2025). OpenAI is unconfirmed.✗ MissingAnthropic Claude respects this; Google has confirmed it does not; OpenAI is unconfirmed.
llms-full.txtOptional full-content companion to llms.txt. Useful for agents with large context windows that prefer a single fetch over crawling. Doesn't replace llms.txt — both can coexist.✗ MissingOptional full-content companion file.
ArtifactStatusNote
schema.org OrganizationThe brand-identity anchor LLMs use to disambiguate the site. Without it, profile links on LinkedIn, Wikidata, Crunchbase, GitHub etc. aren't bound to the homepage's entity in the AI's knowledge graph. The sameAs array is the load-bearing field.✗ MissingEntity anchor for the sameAs graph.
schema.org FAQPagePages with FAQPage JSON-LD show 2.7× citation rate vs without — 41% vs 15% in the Relixir 2025 study. The JSON-LD must mirror visible Q&A content on the page; Google penalises mismatch. Single highest-leverage fix in the audit.✗ Missing2.7× citation rate vs without (Relixir 2025) — highest-leverage single fix.
schema.org ArticleFor journalistic/editorial pages. Declares author, datePublished, dateModified, and section to AI engines. They preferentially cite recent, dated, authored content in answer-engine results.✗ MissingFor editorial pages.
schema.org HowToFor step-by-step procedural content. AI engines preferentially cite HowTo markup when answering procedural queries ("how do I X"). Maps directly to retrieval intent.✗ MissingFor tutorials.
schema.org SoftwareApplicationFor product/app pages. Maps to vendor-evaluation queries ("best X for Y"). Effectively required for B2B SaaS visibility in AI citations — 89% of B2B buyers now use AI for vendor research (Averi 2026).✗ MissingFor product pages.
Person (author entity)Author entity on bylines, linked to the Article entity. E-E-A-T (Experience, Expertise, Authoritativeness, Trustworthiness) signal — AI engines weight content authored by named, credentialed people higher than anonymous content.✗ MissingE-E-A-T signal on bylines.

HTTP headers

§3 of 4
HeaderValue
X-Robots-TagPage-level crawler directives. The proposed `noai` / `noimageai` values request AI crawlers skip the page (publisher hint — honored by some, ignored by others). Not enforced; combine with explicit robots.txt rules for layered defense.— not set
Cache-ControlTells crawlers how aggressively to cache the response. Aggressive `no-store` or `private no-cache` directives hurt retrieval freshness signaling — AI engines may distrust the page or refresh it less often. For public pages, prefer `public, max-age=300` or longer.max-age=60
Link: canonicalCanonical URL declared as an HTTP response header (RFC 8288 + RFC 6596). Processed earlier in the retrieval pipeline than the HTML `<link rel="canonical">` tag, so it works for crawlers that don't fully render HTML.— not set
Content-TypeDeclares the response format. `text/html; charset=utf-8` is the standard for pages. If the site supports Markdown negotiation, the same URL can serve `text/markdown` when `Accept: text/markdown` is sent.text/html; charset=utf-8
Agent-content probeStatusNote
Markdown negotiationEmerging Cloudflare-led standard. When an agent sends Accept: text/markdown, the site returns a markdown rendering of the page instead of HTML. Sibling of llms.txt. Reduces token cost for downstream AI usage and lets agents consume the site without rendering.✗ Returns HTMLNo text/markdown response when Accept: text/markdown is sent.
Agent-discovery Link relsRFC 8288 Link-header relations that let agents find machine-readable surfaces of the site without scraping HTML. We look for api-catalog (RFC 9727), service-desc (OpenAPI), describedby (RDF / JSON-LD), and agent-card (emerging convention).✗ NoneNo api-catalog / service-desc / describedby / agent-card rels.

Top findings

§4 of 4
  1. 1

    All AI search-index crawlers are disallowed.

    Every search-index crawler we track (OAI-SearchBot, Claude-SearchBot, PerplexityBot, GoogleOther) is disallowed by cnn.com's robots.txt. If this is intentional (regulated industry, deliberate opt-out), no action needed. If the expectation is that AI engines should cite it, this is the root cause: AI engines retrieve via these crawlers at inference time.

    High
  2. 2

    No schema.org Organization on the homepage.

    Organization is the entity anchor LLMs use to disambiguate your brand. Without it, the sameAs graph (Wikidata, LinkedIn, Crunchbase) has no central node.

    High
  3. 3

    No FAQPage schema — highest-leverage single fix.

    Pages with FAQPage JSON-LD show 2.7× citation rate vs without (Relixir 2025: 41% vs 15%). Add it to your top-converting pages — the JSON-LD must reflect actual visible Q&A content.

    High
  4. 4

    No llms.txt found.

    Anthropic Claude Desktop and Claude.ai respect llms.txt; IDE tooling (Cursor, Claude Code, GitHub Copilot, Cline, Aider) routinely fetches it. Google has confirmed it does NOT support llms.txt; OpenAI is unconfirmed. Ship one if you want Anthropic + dev-tool visibility — do NOT expect it to move ChatGPT or Gemini.

    Med
  5. 5

    No Content Signals in robots.txt.

    Content Signals (IETF draft, contentsignals.org) are a declarative way to state AI-usage preferences: `Content-Signal: search=yes, ai-input=yes, ai-train=no`. Compliance is voluntary today, but the signals are cheap to publish and align with the direction the standards are heading.

    Tip
╴ Share this report

This report has a permanent URL: canaifind.com/r/z19E8MtH. Screenshot, drop in Slack, quote-tweet, or send to whoever's going to ask. That's how this tool finds the next person who needs it.