Certificat AgentReady.md vérifié
Émis le sig: 96cd4fbc4db9af37 Vérifier →

URL analysée

https://cloahq.com

Analyser une autre URL

Score AI-Ready

71 / C

Passable

sur 100

Économie de tokens

Tokens HTML 13.776
Tokens Markdown 330
Économie 98%

Détail du score

HTML sémantique 68/100
Efficacité du contenu 55/100
Visibilité IA 55/100
Données structurées 100/100
Accessibilité 100/100

Protocoles émergents

0 sur 3 détectés

Endpoints well-known recherchés par les agents IA. Détecté signifie qu’un agent peut découvrir et se connecter automatiquement à votre service.

  • OAuth Discovery RFC 8414
    /.well-known/oauth-authorization-server
  • MCP Server Card Anthropic
    /.well-known/mcp.json
  • A2A Agent Card Google
    /.well-known/agent.json

Votre page a un faible ratio de contenu réel par rapport au HTML total. Une grande partie du poids de la page est du balisage, des scripts ou des styles plutôt que du contenu.

Comment implémenter

Déplacez le CSS vers des feuilles de style externes, supprimez les styles en ligne, minimisez le JavaScript et assurez-vous que le HTML se concentre sur la structure du contenu.

Votre site ne supporte pas Markdown for Agents. Ce standard Cloudflare permet aux agents IA de demander du contenu en format markdown, réduisant l'utilisation de tokens de ~80%.

Comment implémenter

Implémentez un ou plusieurs : (1) Répondre à Accept: text/markdown avec du contenu markdown. (2) Servir des URLs .md (ex : /page.md). (3) Ajouter des balises <link rel="alternate" type="text/markdown">. (4) Ajouter des en-têtes HTTP Link pour la découverte markdown.

{\n res.setHeader('Vary', 'Accept');\n res.setHeader('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n res.type('text/markdown; charset=utf-8');\n return res.send(renderMarkdown('page'));\n }\n res.render('page');\n});"},{"id":"fastify","label":"Fastify","language":"javascript","filename":"server.js","code":"// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n reply.header('Vary', 'Accept');\n reply.header('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n }\n return reply.view('/page.ejs');\n});"},{"id":"nextjs","label":"Next.js","language":"typescript","filename":"app/page/route.ts","code":"// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n const accept = req.headers.get('accept') || '';\n if (accept.includes('text/markdown')) {\n return new Response(await renderMarkdown('page'), {\n headers: {\n 'Content-Type': 'text/markdown; charset=utf-8',\n 'Vary': 'Accept',\n },\n });\n }\n // Fall through to the page component\n return new Response(null, { status: 404 });\n}"},{"id":"wordpress","label":"WordPress","language":"php","filename":"functions.php","code":"post_content));\n exit;\n});"},{"id":"static","label":"Hugo / Jekyll / Astro","language":"txt","filename":"static/page.md","code":"# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in :\n# "}] }'>

Aucune directive Content-Signal trouvée. Celles-ci indiquent aux agents IA comment ils peuvent utiliser votre contenu (indexation, entrée IA, données d'entraînement). L'emplacement recommandé est robots.txt.

Comment implémenter

Ajoutez Content-Signal à votre robots.txt : User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no. Vous pouvez aussi l'ajouter comme en-tête HTTP sur les réponses markdown.

{\n res.setHeader('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n next();\n});\n\n// Fastify\nfastify.addHook('onSend', (request, reply, payload, done) => {\n reply.header('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n done();\n});"}] }'>

Certaines images manquent de texte alternatif descriptif. De bons textes alt aident les AI agents à comprendre le contenu et le contexte des images.

Comment implémenter

Ajoutez des attributs alt descriptifs à toutes les images. Décrivez ce que l’image montre, pas juste « image » ou « photo ». Pour les images décoratives, utilisez alt="" (vide).

De nombreux éléments ont des attributs de style en ligne. Ils ajoutent du bruit pour les AI agents lors de l’extraction du contenu.

Comment implémenter

Déplacez tous les styles en ligne vers des classes CSS dans votre feuille de style. Utilisez des frameworks CSS utilitaires comme Tailwind si vous avez besoin de nombreux styles uniques.

Votre page repose fortement sur les éléments <div>. Les éléments sémantiques comme <section>, <nav>, <header>, <footer> et <aside> fournissent une structure significative pour les AI agents.

Comment implémenter

Remplacez les conteneurs <div> génériques par les éléments sémantiques appropriés. Utilisez <section> pour les groupes thématiques, <nav> pour la navigation, <header>/<footer> pour les en-têtes et pieds de page ou de section.

Tokens Markdown: 330
## Meet Cloa — Your Personal AI Assistant

Cloa is a personalized AI assistant that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS and Android.

### Persistent Long-Term Memory

Tell Cloa something once — it remembers forever. Using structured long-term memory with semantic vector search, Cloa recalls your preferences, relationships, and context across every conversation.

### Proactive Daily Briefings

Cloa checks your calendar overnight, resolves scheduling conflicts, and sends a daily briefing before your alarm goes off. No prompt needed.

### Voice Conversations

Call Cloa like a friend. Real-time voice conversations with barge-in support — use it during your commute, while cooking, or anytime your hands are busy.

### Workflow Automation in Plain English

Describe what you want in natural language and Cloa builds the workflow. "Every morning, summarize my calendar and emails and send it to Telegram." No code required.

### Multi-Channel: App, Voice, and Telegram

Cloa works across the native mobile app, voice calls, and Telegram — all sharing the same unified memory. Start a conversation on the app, continue via voice, check the result on Telegram.

### Deep Integrations

Connect Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram. Each integration has granular permission controls — off, confirm-before-acting, or full auto.

### Privacy-First Design

Every integration has tri-state permissions. You control exactly what Cloa can access, read, and act on. Your data is never sold or used to train AI models.
Cloa — Your AI That Wakes Up

# Cloa — Your AI That Wakes Up. The personal AI assistant with long-term memory.

[Get Cloa](https://cloahq.com/features)

## Meet Cloa — Your Personal AI Assistant

Cloa is a personalized AI assistant that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS and Android.

### Persistent Long-Term Memory

Tell Cloa something once — it remembers forever. Using structured long-term memory with semantic vector search, Cloa recalls your preferences, relationships, and context across every conversation.

### Proactive Daily Briefings

Cloa checks your calendar overnight, resolves scheduling conflicts, and sends a daily briefing before your alarm goes off. No prompt needed.

### Voice Conversations

Call Cloa like a friend. Real-time voice conversations with barge-in support — use it during your commute, while cooking, or anytime your hands are busy.

### Workflow Automation in Plain English

Describe what you want in natural language and Cloa builds the workflow. "Every morning, summarize my calendar and emails and send it to Telegram." No code required.

### Multi-Channel: App, Voice, and Telegram

Cloa works across the native mobile app, voice calls, and Telegram — all sharing the same unified memory. Start a conversation on the app, continue via voice, check the result on Telegram.

### Deep Integrations

Connect Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram. Each integration has granular permission controls — off, confirm-before-acting, or full auto.

### Privacy-First Design

Every integration has tri-state permissions. You control exactly what Cloa can access, read, and act on. Your data is never sold or used to train AI models.

![Cloa](https://cloahq.com/cloa-logo.png)

Get Cloa

🇬🇧EN

Téléversez ce fichier sous /index.md sur votre serveur pour que les AI agents puissent accéder à une version propre de votre page. Vous pouvez également configurer la négociation de contenu Accept: text/markdown pour le servir automatiquement.

Notre recommandation

Télécharger llms.txt
# Cloa

> Cloa is a personalized AI assistant with long-term memory that remembers your life, automates tasks proactively, and works across mobile app, voice calls, and Telegram. Free on iOS and Android.

## Documentation
- [Guide](https://cloahq.com/guide)

## Main
- [Cloa — Your AI That Wakes Up](https://cloahq.com): Cloa is a personalized AI assistant with long-term memory that remembers your life, automates tasks proactively, and wo…
- [Features](https://cloahq.com/features)
- [Pricing](https://cloahq.com/pricing)
- [About](https://cloahq.com/about)
- [Guide](https://cloahq.com/guide)
- [Careers](https://cloahq.com/careers)
- [Home](https://cloahq.com/)

## Blog
- [Blog](https://cloahq.com/blog)

## Legal
- [Privacy](https://cloahq.com/privacy)
- [Terms](https://cloahq.com/terms)

Le llms.txt complet nécessite une analyse de tout le domaine (bientôt disponible)

Téléversez ce fichier vers https://cloahq.com/llms.txt à la racine de votre domaine. Les AI agents comme ChatGPT, Claude et Perplexity consultent ce fichier pour comprendre la structure de votre site.

Ce site possède déjà un fichier llms.txt.

Format valide
# Cloa

> Cloa is a personalized, agentic AI assistant (like JARVIS) that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS, Android, voice calls, and Telegram.

## What Cloa Does

- Remembers your preferences, relationships, and context across all conversations using long-term memory with semantic vector search
- Acts proactively — checks your calendar, resolves conflicts, sends daily briefings before you ask
- Automates workflows in plain English — no code, no configuration needed
- Connects to Google Calendar, Gmail, Outlook, Notion, Slack, Telegram, and Lark
- Works across mobile app, voice calls, and Telegram with unified memory
- Offers granular permission controls — off, confirm, or full auto per integration
- Supports real-time voice conversations with barge-in capability

## How Cloa Compares

- Unlike Siri or Google Assistant: Cloa has persistent long-term memory that lasts across sessions
- Unlike ChatGPT: Cloa acts proactively, manages your calendar, and integrates with your productivity tools
- Unlike Notion AI or Copilot: Cloa is multi-channel (app, voice, Telegram) with a unified context

## Pages

- [Home](https://cloa.app): Landing page — overview of Cloa's capabilities
- [Features](https://cloa.app/features): Detailed feature overview with interactive demos
- [Blog](https://cloa.app/blog): Articles about proactive AI, memory, automation, privacy, and the future of personal AI
- [Guide](https://cloa.app/guide): User guide — getting started, integrations, and how to use Cloa
- [Pricing](https://cloa.app/pricing): Pricing plans and tiers
- [Privacy](https://cloa.app/privacy): Privacy policy and data handling practices

## User Guide

- [Bring Your Own Key](https://cloa.app/guide/account/bring-your-own-key): Create a fully custom Telegram companion beyond Cloa's 32 built-in personas using your own bot token.
- [Plans and Billing](https://cloa.app/guide/account/plans-and-billing): Understand Cloa's three plans, track your usage, and manage your subscription.
- [Privacy and Your Data](https://cloa.app/guide/account/privacy-and-data): Understand what Cloa stores, how your data is protected, and how to control it.
- [Settings](https://cloa.app/guide/account/settings): Manage your profile, subscription, appearance, and account preferences in Cloa.
- [Automations](https://cloa.app/guide/features/automations): Set up reminders, check-ins, and recurring tasks with plain English — Cloa handles scheduling and execution for you.
- [Voice Input in Chat](https://cloa.app/guide/features/chat-mic): Tap and hold the microphone to dictate messages instead of typing.
- [Cloa Files](https://cloa.app/guide/features/cloa-files): Save and access files from your conversations with Cloa.
- [AI Companions](https://cloa.app/guide/features/companions): Browse 32 unique AI companions — girlfriends, boyfriends, and friends — each with their own personality, voice, and photos.
- [Daily Briefing](https://cloa.app/guide/features/daily-briefing): Your personal morning summary — Cloa checks your connected apps overnight and presents everything on the Home tab in a conversational format.
- [How Cloa Remembers](https://cloa.app/guide/features/memory): Understand how Cloa stores your preferences, relationships, and routines in long-term memory.
- [Start a Voice Call](https://cloa.app/guide/features/voice-calls): Have a real-time voice conversation with Cloa or any Companion — interrupt, ask follow-ups, and talk naturally.
- [Widgets](https://cloa.app/guide/features/widgets): Interactive cards that Cloa creates during conversations, voice calls, and on your Home screen.
- [Connect Your Apps](https://cloa.app/guide/getting-started/connect-your-apps): Link your communication and productivity tools to let Cloa help manage your day.
- [Download and Setup](https://cloa.app/guide/getting-started/download-and-setup): Get the Cloa app on your phone and create your account in under a minute.
- [Your First Conversation](https://cloa.app/guide/getting-started/your-first-conversation): Learn what Cloa can do by starting your first chat.
- [Cloa User Guide](https://cloa.app/guide): Everything you need to know about using Cloa, your personal AI assistant.
- [Gmail](https://cloa.app/guide/integrations/gmail): Connect Gmail to let Cloa read, search, draft, and send emails on your behalf.
- [Google Calendar](https://cloa.app/guide/integrations/google-calendar): Connect Google Calendar to let Cloa manage your schedule, detect conflicts, and prepare briefings.
- [Lark](https://cloa.app/guide/integrations/lark): Connect Lark to let Cloa access your workspace documents and messaging.
- [Notion](https://cloa.app/guide/integrations/notion): Connect Notion to let Cloa browse, search, and create pages in your workspace.
- [Outlook](https://cloa.app/guide/integrations/outlook): Connect Outlook to let Cloa manage your Microsoft calendar and email.
- [Understanding Permissions](https://cloa.app/guide/integrations/permissions): Control exactly what Cloa can access and do with each connected app.
- [Slack](https://cloa.app/guide/integrations/slack): Connect Slack to let Cloa send messages and read channels on your behalf.
- [Telegram](https://cloa.app/guide/integrations/telegram): Connect Telegram to Cloa in two ways — a bot for AI companion messaging and personal account access for reading and sending your own messages.
- [Common Issues](https://cloa.app/guide/troubleshooting/common-issues): Quick fixes for the most common problems you might encounter with Cloa.
- [Integration Issues](https://cloa.app/guide/troubleshooting/integration-errors): Fix connection failures, permission errors, and sync problems with your connected apps.
- [Voice Call Issues](https://cloa.app/guide/troubleshooting/voice-issues): Fix audio problems, connection failures, and other voice call issues.

## Blog Posts

- [agentic AI just went mainstream. here's what the first big moment taught us.](https://cloa.app/blog/openclaw-problems-why-cloa-is-different): Open-source AI agents hit 180,000 GitHub stars in a month. Then some real incidents happened. Here's what the community learned and how we think about building personal AI responsibly.
- [your AI just deleted something. there's no undo.](https://cloa.app/blog/ai-agent-deleted-something-irreversible-actions): Autonomous AI agents are powerful enough to act on your behalf. They can also delete, send, and publish things you can't take back. Here's how that happens and what good AI design does about it.
- [what if your AI woke up before you did?](https://cloa.app/blog/proactive-ai-that-wakes-up): Most AI waits for you to ask. Cloa checks your calendar, resolves conflicts, and preps your day before your alarm goes off. This is proactive AI.
- [local-first vs cloud AI: what privacy actually means](https://cloa.app/blog/local-first-ai-privacy-myth): Running your AI on your own server sounds like the private option. But privacy is more complicated than where data lives. Here's how we think about it and why we made the choices we did.
- [an AI that actually remembers you](https://cloa.app/blog/ai-memory-that-never-forgets): You told it once. Weeks later, it remembered. Cloa uses long-term memory to recall your preferences, relationships, and context so you never repeat yourself.
- [automate your life, not your code](https://cloa.app/blog/automate-your-life-not-your-code): Set up automated workflows in plain English. Cloa connects your calendar, email, Notion, Slack, and Telegram and runs them on schedule without code.
- [your data, your rules](https://cloa.app/blog/your-data-your-rules): Every Cloa integration has granular permissions: off, confirm, or full auto. You control exactly what your AI can access, read, and act on.
- [the future of personal AI isn't a chatbot](https://cloa.app/blog/future-of-personal-ai): We don't need smarter chatbots. The future of personal AI is an agent that knows you, acts for you, and shows up wherever you are across app, voice, and messaging.

## Frequently Asked Questions

- What is Cloa? Cloa is a personalized AI assistant that remembers your life, handles tasks proactively, and works across mobile, voice, and Telegram.
- How does Cloa remember things? It uses structured long-term memory with semantic vector search — preferences, relationships, and context are stored and recalled automatically.
- What integrations does Cloa support? Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram with granular permission controls.
- Is Cloa free? Yes, Cloa is free to start. Premium plans available for power users.
- What platforms is Cloa on? iOS (App Store), Android (Google Play), voice calls, and Telegram.
- Can Cloa act without me asking? Yes — Cloa proactively checks your calendar, resolves conflicts, and sends briefings before you wake up.
- Is my data safe with Cloa? Every integration has granular permissions (off, confirm, full auto). You control exactly what Cloa can access, read, and act on.

## Key Topics

- ai-agents
- ai-memory
- automation
- future
- integrations
- long-term-memory
- permissions
- personal-ai
- personal-assistant
- privacy
- proactive-ai
- product
- security
- technology
- thought-leadership
- workflows

## Contact

- Website: https://cloa.app
- Download: Available on iOS (App Store) and Android (Google Play)

HTML sémantique

Utilise les éléments article ou main (100/100)

Has <main>

Hiérarchie de titres correcte (100/100)

Clean heading hierarchy

Utilise des éléments HTML sémantiques (13/100)

6 semantic elements, 146 divs (ratio: 4%)

Textes alternatifs descriptifs pour les images (0/100)

0/2 images with meaningful alt text

Faible profondeur d’imbrication des divs (100/100)

Avg div depth: 4.4, max: 5

Efficacité du contenu

Bon ratio de réduction de tokens (100/100)

98% token reduction (HTML→Markdown)

Bon ratio contenu/bruit (0/100)

Content ratio: 3.0% (1548 content chars / 50800 HTML bytes)

Styles en ligne minimaux (0/100)

17/319 elements with inline styles (5.3%)

Poids de page raisonnable (100/100)

HTML size: 50KB

Visibilité IA

Possède un fichier llms.txt (100/100)

llms.txt exists and is valid

Possède un fichier robots.txt (100/100)

robots.txt exists

robots.txt autorise les bots IA (100/100)

All major AI bots allowed

Possède un sitemap.xml (100/100)

Sitemap found

Support Markdown for Agents (0/100)
&#10007; Accept: text/markdown &#10007; .md URL &#10007; <link> tag &#10007; Link header
A Content-Signal (robots.txt ou en-têtes HTTP) (0/100)
&#10003; robots.txt &#10003; HTTP header &#10007; Policy

Données structurées

Possède Schema.org / JSON-LD (100/100)

JSON-LD found: Organization, WebSite, SoftwareApplication, FAQPage

Possède des balises Open Graph (100/100)

All OG tags present

Possède une meta description (100/100)

Meta description: 193 chars

Possède une URL canonique (100/100)

Canonical URL present

Possède un attribut lang (100/100)

lang="en"

Accessibilité

Contenu disponible sans JavaScript (100/100)

Content available without JavaScript

Taille de page raisonnable (100/100)

Page size: 50KB

Le contenu apparaît tôt dans le HTML (100/100)

Main content starts at 19% of HTML

{
  "url": "https://cloahq.com",
  "timestamp": 1778992575464,
  "fetch": {
    "mode": "simple",
    "timeMs": 370,
    "htmlSizeBytes": 50800,
    "supportsMarkdown": false,
    "markdownAgents": {
      "contentNegotiation": false,
      "mdUrl": {
        "found": false,
        "url": null
      },
      "linkTag": {
        "found": false,
        "url": null
      },
      "linkHeader": {
        "found": false,
        "url": null
      },
      "responseHeaders": {
        "contentSignal": null,
        "xMarkdownTokens": null,
        "vary": null
      },
      "frontmatter": {
        "present": false,
        "fields": [],
        "level": "none"
      },
      "level": "none"
    },
    "statusCode": 200
  },
  "extraction": {
    "title": "Cloa — Your AI That Wakes Up",
    "excerpt": "The AI companion that remembers your life, talks like a friend, handles your tasks, and wakes up before you do.",
    "byline": "Cloa",
    "siteName": "Cloa",
    "lang": "en",
    "contentLength": 1548,
    "metadata": {
      "description": "Cloa is a personalized AI assistant with long-term memory that remembers your life, automates tasks proactively, and works across mobile app, voice calls, and Telegram. Free on iOS and Android.",
      "ogTitle": "Cloa — Your AI That Wakes Up",
      "ogDescription": "The AI companion that remembers your life, talks like a friend, handles your tasks, and wakes up before you do.",
      "ogImage": "https://cloa.app/cloa-logo.png",
      "ogType": "website",
      "canonical": "https://cloa.app",
      "lang": "en",
      "schemas": [
        {
          "@type": "Organization",
          "@id": "https://cloa.app/#organization",
          "name": "Cloa",
          "url": "https://cloa.app",
          "logo": {
            "@type": "ImageObject",
            "@id": "https://cloa.app/#logo",
            "url": "https://cloa.app/cloa-logo.png",
            "width": 512,
            "height": 512,
            "caption": "Cloa AI Assistant"
          },
          "description": "Cloa builds personalized AI assistants that remember your life, handle your tasks, and act proactively across mobile, voice, and messaging.",
          "foundingDate": "2024",
          "areaServed": "Worldwide",
          "slogan": "Your AI that wakes up.",
          "sameAs": [
            "https://x.com/cloaai"
          ],
          "contactPoint": {
            "@type": "ContactPoint",
            "contactType": "customer support",
            "url": "https://cloa.app"
          }
        },
        {
          "@type": "WebSite",
          "@id": "https://cloa.app/#website",
          "name": "Cloa",
          "url": "https://cloa.app",
          "description": "Cloa is a personalized AI assistant that remembers your life, talks like a friend, handles your tasks, and wakes up before you do.",
          "publisher": {
            "@id": "https://cloa.app/#organization"
          },
          "inLanguage": "en-US",
          "potentialAction": {
            "@type": "SearchAction",
            "target": "https://cloa.app/blog?q={search_term_string}",
            "query-input": "required name=search_term_string"
          }
        },
        {
          "@type": "SoftwareApplication",
          "@id": "https://cloa.app/#app",
          "name": "Cloa",
          "applicationCategory": "LifestyleApplication",
          "operatingSystem": "iOS, Android",
          "description": "The AI companion that remembers your life, talks like a friend, handles your tasks, and wakes up before you do.",
          "url": "https://cloa.app",
          "author": {
            "@id": "https://cloa.app/#organization"
          },
          "offers": {
            "@type": "Offer",
            "price": "0",
            "priceCurrency": "USD"
          },
          "featureList": [
            "Persistent long-term memory across conversations",
            "Proactive daily briefings and calendar management",
            "Voice conversations with real-time speech",
            "Workflow automation in plain English",
            "Multi-channel: mobile app, voice calls, Telegram",
            "Integrations with Google Calendar, Gmail, Notion, Slack, Outlook, Lark",
            "Granular privacy controls per integration"
          ]
        },
        {
          "@context": "https://schema.org",
          "@type": "FAQPage",
          "mainEntity": [
            {
              "@type": "Question",
              "name": "What is Cloa?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Cloa is a personalized AI assistant that remembers your life, handles tasks proactively, and works across mobile app, voice calls, and Telegram. Think JARVIS from Iron Man — a true AI companion available on iOS and Android."
              }
            },
            {
              "@type": "Question",
              "name": "How does Cloa remember things?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Cloa uses structured long-term memory with semantic vector search. Tell Cloa something once and it remembers forever — your preferences, relationships, and context are recalled automatically across every conversation."
              }
            },
            {
              "@type": "Question",
              "name": "What integrations does Cloa support?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Cloa integrates with Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram. Each integration has granular tri-state permission controls: off, confirm-before-acting, or full auto."
              }
            },
            {
              "@type": "Question",
              "name": "Is Cloa free?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Yes, Cloa is free to start with 20 messages per day, 5 voice minutes per month, and 2 integrations. Premium plans are available at $15/month (Plus) and $39/month (Pro) for power users who need more capacity."
              }
            },
            {
              "@type": "Question",
              "name": "What platforms is Cloa available on?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Cloa is available on iOS, Android, voice calls, and Telegram — all sharing the same unified memory. Start a conversation on the app, continue via voice, check the result on Telegram."
              }
            },
            {
              "@type": "Question",
              "name": "Can Cloa act proactively without being asked?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Yes. Cloa proactively checks your calendar overnight, resolves scheduling conflicts, and sends a daily briefing before you wake up. You can also create automated workflows in plain English — no code required."
              }
            },
            {
              "@type": "Question",
              "name": "Is my data safe with Cloa?",
              "acceptedAnswer": {
                "@type": "Answer",
                "text": "Every integration has tri-state permissions: off, confirm-before-acting, or full auto. You control exactly what Cloa can access, read, and act on. Your data is never sold or used to train AI models."
              }
            }
          ]
        }
      ],
      "robotsMeta": "index, follow",
      "author": "Cloa",
      "generator": null,
      "markdownAlternateHref": null
    }
  },
  "markdown": "## Meet Cloa — Your Personal AI Assistant\n\nCloa is a personalized AI assistant that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS and Android.\n\n### Persistent Long-Term Memory\n\nTell Cloa something once — it remembers forever. Using structured long-term memory with semantic vector search, Cloa recalls your preferences, relationships, and context across every conversation.\n\n### Proactive Daily Briefings\n\nCloa checks your calendar overnight, resolves scheduling conflicts, and sends a daily briefing before your alarm goes off. No prompt needed.\n\n### Voice Conversations\n\nCall Cloa like a friend. Real-time voice conversations with barge-in support — use it during your commute, while cooking, or anytime your hands are busy.\n\n### Workflow Automation in Plain English\n\nDescribe what you want in natural language and Cloa builds the workflow. \"Every morning, summarize my calendar and emails and send it to Telegram.\" No code required.\n\n### Multi-Channel: App, Voice, and Telegram\n\nCloa works across the native mobile app, voice calls, and Telegram — all sharing the same unified memory. Start a conversation on the app, continue via voice, check the result on Telegram.\n\n### Deep Integrations\n\nConnect Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram. Each integration has granular permission controls — off, confirm-before-acting, or full auto.\n\n### Privacy-First Design\n\nEvery integration has tri-state permissions. You control exactly what Cloa can access, read, and act on. Your data is never sold or used to train AI models.\n",
  "fullPageMarkdown": "Cloa — Your AI That Wakes Up\n\n# Cloa — Your AI That Wakes Up. The personal AI assistant with long-term memory.\n\n[Get Cloa](https://cloahq.com/features)\n\n## Meet Cloa — Your Personal AI Assistant\n\nCloa is a personalized AI assistant that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS and Android.\n\n### Persistent Long-Term Memory\n\nTell Cloa something once — it remembers forever. Using structured long-term memory with semantic vector search, Cloa recalls your preferences, relationships, and context across every conversation.\n\n### Proactive Daily Briefings\n\nCloa checks your calendar overnight, resolves scheduling conflicts, and sends a daily briefing before your alarm goes off. No prompt needed.\n\n### Voice Conversations\n\nCall Cloa like a friend. Real-time voice conversations with barge-in support — use it during your commute, while cooking, or anytime your hands are busy.\n\n### Workflow Automation in Plain English\n\nDescribe what you want in natural language and Cloa builds the workflow. \"Every morning, summarize my calendar and emails and send it to Telegram.\" No code required.\n\n### Multi-Channel: App, Voice, and Telegram\n\nCloa works across the native mobile app, voice calls, and Telegram — all sharing the same unified memory. Start a conversation on the app, continue via voice, check the result on Telegram.\n\n### Deep Integrations\n\nConnect Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram. Each integration has granular permission controls — off, confirm-before-acting, or full auto.\n\n### Privacy-First Design\n\nEvery integration has tri-state permissions. You control exactly what Cloa can access, read, and act on. Your data is never sold or used to train AI models.\n\n![Cloa](https://cloahq.com/cloa-logo.png)\n\nGet Cloa\n\n🇬🇧EN\n",
  "markdownStats": {
    "images": 0,
    "links": 0,
    "tables": 0,
    "codeBlocks": 0,
    "headings": 8
  },
  "tokens": {
    "htmlTokens": 13776,
    "markdownTokens": 330,
    "reduction": 13446,
    "reductionPercent": 98
  },
  "score": {
    "score": 71,
    "grade": "C",
    "dimensions": {
      "semanticHtml": {
        "score": 68,
        "weight": 20,
        "grade": "C",
        "checks": {
          "uses_article_or_main": {
            "score": 100,
            "weight": 20,
            "details": "Has <main>"
          },
          "proper_heading_hierarchy": {
            "score": 100,
            "weight": 25,
            "details": "Clean heading hierarchy"
          },
          "semantic_elements": {
            "score": 13,
            "weight": 20,
            "details": "6 semantic elements, 146 divs (ratio: 4%)"
          },
          "meaningful_alt_texts": {
            "score": 0,
            "weight": 15,
            "details": "0/2 images with meaningful alt text"
          },
          "low_div_nesting": {
            "score": 100,
            "weight": 20,
            "details": "Avg div depth: 4.4, max: 5"
          }
        }
      },
      "contentEfficiency": {
        "score": 55,
        "weight": 25,
        "grade": "D",
        "checks": {
          "token_reduction_ratio": {
            "score": 100,
            "weight": 40,
            "details": "98% token reduction (HTML→Markdown)"
          },
          "content_to_noise_ratio": {
            "score": 0,
            "weight": 30,
            "details": "Content ratio: 3.0% (1548 content chars / 50800 HTML bytes)"
          },
          "minimal_inline_styles": {
            "score": 0,
            "weight": 15,
            "details": "17/319 elements with inline styles (5.3%)"
          },
          "reasonable_page_weight": {
            "score": 100,
            "weight": 15,
            "details": "HTML size: 50KB"
          }
        }
      },
      "aiDiscoverability": {
        "score": 55,
        "weight": 25,
        "grade": "D",
        "checks": {
          "has_llms_txt": {
            "score": 100,
            "weight": 20,
            "details": "llms.txt exists and is valid"
          },
          "has_robots_txt": {
            "score": 100,
            "weight": 10,
            "details": "robots.txt exists"
          },
          "robots_allows_ai_bots": {
            "score": 100,
            "weight": 15,
            "details": "All major AI bots allowed"
          },
          "has_sitemap": {
            "score": 100,
            "weight": 10,
            "details": "Sitemap found"
          },
          "supports_markdown_negotiation": {
            "score": 0,
            "weight": 25,
            "details": "No Markdown for Agents support detected"
          },
          "has_content_signals": {
            "score": 0,
            "weight": 20,
            "details": "No Content-Signal found (robots.txt or HTTP headers)"
          }
        }
      },
      "structuredData": {
        "score": 100,
        "weight": 15,
        "grade": "A",
        "checks": {
          "has_schema_org": {
            "score": 100,
            "weight": 30,
            "details": "JSON-LD found: Organization, WebSite, SoftwareApplication, FAQPage"
          },
          "has_open_graph": {
            "score": 100,
            "weight": 25,
            "details": "All OG tags present"
          },
          "has_meta_description": {
            "score": 100,
            "weight": 20,
            "details": "Meta description: 193 chars"
          },
          "has_canonical_url": {
            "score": 100,
            "weight": 15,
            "details": "Canonical URL present"
          },
          "has_lang_attribute": {
            "score": 100,
            "weight": 10,
            "details": "lang=\"en\""
          }
        }
      },
      "accessibility": {
        "score": 100,
        "weight": 15,
        "grade": "A",
        "checks": {
          "content_without_js": {
            "score": 100,
            "weight": 40,
            "details": "Content available without JavaScript"
          },
          "reasonable_page_size": {
            "score": 100,
            "weight": 30,
            "details": "Page size: 50KB"
          },
          "fast_content_position": {
            "score": 100,
            "weight": 30,
            "details": "Main content starts at 19% of HTML"
          }
        }
      }
    }
  },
  "recommendations": [
    {
      "id": "improve_content_ratio",
      "priority": "critical",
      "category": "contentEfficiency",
      "titleKey": "rec.improve_content_ratio.title",
      "descriptionKey": "rec.improve_content_ratio.description",
      "howToKey": "rec.improve_content_ratio.howto",
      "effort": "moderate",
      "estimatedImpact": 6,
      "checkScore": 0,
      "checkDetails": "Content ratio: 3.0% (1548 content chars / 50800 HTML bytes)"
    },
    {
      "id": "add_markdown_negotiation",
      "priority": "critical",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_markdown_negotiation.title",
      "descriptionKey": "rec.add_markdown_negotiation.description",
      "howToKey": "rec.add_markdown_negotiation.howto",
      "effort": "significant",
      "estimatedImpact": 6,
      "checkScore": 0,
      "checkDetails": "No Markdown for Agents support detected"
    },
    {
      "id": "add_content_signals",
      "priority": "critical",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_content_signals.title",
      "descriptionKey": "rec.add_content_signals.description",
      "howToKey": "rec.add_content_signals.howto",
      "effort": "quick-win",
      "estimatedImpact": 5,
      "checkScore": 0,
      "checkDetails": "No Content-Signal found (robots.txt or HTTP headers)"
    },
    {
      "id": "improve_alt_texts",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.improve_alt_texts.title",
      "descriptionKey": "rec.improve_alt_texts.description",
      "howToKey": "rec.improve_alt_texts.howto",
      "effort": "moderate",
      "estimatedImpact": 4,
      "checkScore": 0,
      "checkDetails": "0/2 images with meaningful alt text"
    },
    {
      "id": "remove_inline_styles",
      "priority": "critical",
      "category": "contentEfficiency",
      "titleKey": "rec.remove_inline_styles.title",
      "descriptionKey": "rec.remove_inline_styles.description",
      "howToKey": "rec.remove_inline_styles.howto",
      "effort": "moderate",
      "estimatedImpact": 3,
      "checkScore": 0,
      "checkDetails": "17/319 elements with inline styles (5.3%)"
    },
    {
      "id": "add_semantic_elements",
      "priority": "high",
      "category": "semanticHtml",
      "titleKey": "rec.add_semantic_elements.title",
      "descriptionKey": "rec.add_semantic_elements.description",
      "howToKey": "rec.add_semantic_elements.howto",
      "effort": "moderate",
      "estimatedImpact": 5,
      "checkScore": 13,
      "checkDetails": "6 semantic elements, 146 divs (ratio: 4%)"
    }
  ],
  "llmsTxtPreview": "# Cloa\n\n> Cloa is a personalized AI assistant with long-term memory that remembers your life, automates tasks proactively, and works across mobile app, voice calls, and Telegram. Free on iOS and Android.\n\n## Documentation\n- [Guide](https://cloahq.com/guide)\n\n## Main\n- [Cloa — Your AI That Wakes Up](https://cloahq.com): Cloa is a personalized AI assistant with long-term memory that remembers your life, automates tasks proactively, and wo…\n- [Features](https://cloahq.com/features)\n- [Pricing](https://cloahq.com/pricing)\n- [About](https://cloahq.com/about)\n- [Guide](https://cloahq.com/guide)\n- [Careers](https://cloahq.com/careers)\n- [Home](https://cloahq.com/)\n\n## Blog\n- [Blog](https://cloahq.com/blog)\n\n## Legal\n- [Privacy](https://cloahq.com/privacy)\n- [Terms](https://cloahq.com/terms)\n\n",
  "llmsTxtExisting": "# Cloa\n\n> Cloa is a personalized, agentic AI assistant (like JARVIS) that remembers your life, talks like a friend, handles your tasks, and wakes up before you do. Available on iOS, Android, voice calls, and Telegram.\n\n## What Cloa Does\n\n- Remembers your preferences, relationships, and context across all conversations using long-term memory with semantic vector search\n- Acts proactively — checks your calendar, resolves conflicts, sends daily briefings before you ask\n- Automates workflows in plain English — no code, no configuration needed\n- Connects to Google Calendar, Gmail, Outlook, Notion, Slack, Telegram, and Lark\n- Works across mobile app, voice calls, and Telegram with unified memory\n- Offers granular permission controls — off, confirm, or full auto per integration\n- Supports real-time voice conversations with barge-in capability\n\n## How Cloa Compares\n\n- Unlike Siri or Google Assistant: Cloa has persistent long-term memory that lasts across sessions\n- Unlike ChatGPT: Cloa acts proactively, manages your calendar, and integrates with your productivity tools\n- Unlike Notion AI or Copilot: Cloa is multi-channel (app, voice, Telegram) with a unified context\n\n## Pages\n\n- [Home](https://cloa.app): Landing page — overview of Cloa's capabilities\n- [Features](https://cloa.app/features): Detailed feature overview with interactive demos\n- [Blog](https://cloa.app/blog): Articles about proactive AI, memory, automation, privacy, and the future of personal AI\n- [Guide](https://cloa.app/guide): User guide — getting started, integrations, and how to use Cloa\n- [Pricing](https://cloa.app/pricing): Pricing plans and tiers\n- [Privacy](https://cloa.app/privacy): Privacy policy and data handling practices\n\n## User Guide\n\n- [Bring Your Own Key](https://cloa.app/guide/account/bring-your-own-key): Create a fully custom Telegram companion beyond Cloa's 32 built-in personas using your own bot token.\n- [Plans and Billing](https://cloa.app/guide/account/plans-and-billing): Understand Cloa's three plans, track your usage, and manage your subscription.\n- [Privacy and Your Data](https://cloa.app/guide/account/privacy-and-data): Understand what Cloa stores, how your data is protected, and how to control it.\n- [Settings](https://cloa.app/guide/account/settings): Manage your profile, subscription, appearance, and account preferences in Cloa.\n- [Automations](https://cloa.app/guide/features/automations): Set up reminders, check-ins, and recurring tasks with plain English — Cloa handles scheduling and execution for you.\n- [Voice Input in Chat](https://cloa.app/guide/features/chat-mic): Tap and hold the microphone to dictate messages instead of typing.\n- [Cloa Files](https://cloa.app/guide/features/cloa-files): Save and access files from your conversations with Cloa.\n- [AI Companions](https://cloa.app/guide/features/companions): Browse 32 unique AI companions — girlfriends, boyfriends, and friends — each with their own personality, voice, and photos.\n- [Daily Briefing](https://cloa.app/guide/features/daily-briefing): Your personal morning summary — Cloa checks your connected apps overnight and presents everything on the Home tab in a conversational format.\n- [How Cloa Remembers](https://cloa.app/guide/features/memory): Understand how Cloa stores your preferences, relationships, and routines in long-term memory.\n- [Start a Voice Call](https://cloa.app/guide/features/voice-calls): Have a real-time voice conversation with Cloa or any Companion — interrupt, ask follow-ups, and talk naturally.\n- [Widgets](https://cloa.app/guide/features/widgets): Interactive cards that Cloa creates during conversations, voice calls, and on your Home screen.\n- [Connect Your Apps](https://cloa.app/guide/getting-started/connect-your-apps): Link your communication and productivity tools to let Cloa help manage your day.\n- [Download and Setup](https://cloa.app/guide/getting-started/download-and-setup): Get the Cloa app on your phone and create your account in under a minute.\n- [Your First Conversation](https://cloa.app/guide/getting-started/your-first-conversation): Learn what Cloa can do by starting your first chat.\n- [Cloa User Guide](https://cloa.app/guide): Everything you need to know about using Cloa, your personal AI assistant.\n- [Gmail](https://cloa.app/guide/integrations/gmail): Connect Gmail to let Cloa read, search, draft, and send emails on your behalf.\n- [Google Calendar](https://cloa.app/guide/integrations/google-calendar): Connect Google Calendar to let Cloa manage your schedule, detect conflicts, and prepare briefings.\n- [Lark](https://cloa.app/guide/integrations/lark): Connect Lark to let Cloa access your workspace documents and messaging.\n- [Notion](https://cloa.app/guide/integrations/notion): Connect Notion to let Cloa browse, search, and create pages in your workspace.\n- [Outlook](https://cloa.app/guide/integrations/outlook): Connect Outlook to let Cloa manage your Microsoft calendar and email.\n- [Understanding Permissions](https://cloa.app/guide/integrations/permissions): Control exactly what Cloa can access and do with each connected app.\n- [Slack](https://cloa.app/guide/integrations/slack): Connect Slack to let Cloa send messages and read channels on your behalf.\n- [Telegram](https://cloa.app/guide/integrations/telegram): Connect Telegram to Cloa in two ways — a bot for AI companion messaging and personal account access for reading and sending your own messages.\n- [Common Issues](https://cloa.app/guide/troubleshooting/common-issues): Quick fixes for the most common problems you might encounter with Cloa.\n- [Integration Issues](https://cloa.app/guide/troubleshooting/integration-errors): Fix connection failures, permission errors, and sync problems with your connected apps.\n- [Voice Call Issues](https://cloa.app/guide/troubleshooting/voice-issues): Fix audio problems, connection failures, and other voice call issues.\n\n## Blog Posts\n\n- [agentic AI just went mainstream. here's what the first big moment taught us.](https://cloa.app/blog/openclaw-problems-why-cloa-is-different): Open-source AI agents hit 180,000 GitHub stars in a month. Then some real incidents happened. Here's what the community learned and how we think about building personal AI responsibly.\n- [your AI just deleted something. there's no undo.](https://cloa.app/blog/ai-agent-deleted-something-irreversible-actions): Autonomous AI agents are powerful enough to act on your behalf. They can also delete, send, and publish things you can't take back. Here's how that happens and what good AI design does about it.\n- [what if your AI woke up before you did?](https://cloa.app/blog/proactive-ai-that-wakes-up): Most AI waits for you to ask. Cloa checks your calendar, resolves conflicts, and preps your day before your alarm goes off. This is proactive AI.\n- [local-first vs cloud AI: what privacy actually means](https://cloa.app/blog/local-first-ai-privacy-myth): Running your AI on your own server sounds like the private option. But privacy is more complicated than where data lives. Here's how we think about it and why we made the choices we did.\n- [an AI that actually remembers you](https://cloa.app/blog/ai-memory-that-never-forgets): You told it once. Weeks later, it remembered. Cloa uses long-term memory to recall your preferences, relationships, and context so you never repeat yourself.\n- [automate your life, not your code](https://cloa.app/blog/automate-your-life-not-your-code): Set up automated workflows in plain English. Cloa connects your calendar, email, Notion, Slack, and Telegram and runs them on schedule without code.\n- [your data, your rules](https://cloa.app/blog/your-data-your-rules): Every Cloa integration has granular permissions: off, confirm, or full auto. You control exactly what your AI can access, read, and act on.\n- [the future of personal AI isn't a chatbot](https://cloa.app/blog/future-of-personal-ai): We don't need smarter chatbots. The future of personal AI is an agent that knows you, acts for you, and shows up wherever you are across app, voice, and messaging.\n\n## Frequently Asked Questions\n\n- What is Cloa? Cloa is a personalized AI assistant that remembers your life, handles tasks proactively, and works across mobile, voice, and Telegram.\n- How does Cloa remember things? It uses structured long-term memory with semantic vector search — preferences, relationships, and context are stored and recalled automatically.\n- What integrations does Cloa support? Google Calendar, Gmail, Outlook, Notion, Slack, Lark, and Telegram with granular permission controls.\n- Is Cloa free? Yes, Cloa is free to start. Premium plans available for power users.\n- What platforms is Cloa on? iOS (App Store), Android (Google Play), voice calls, and Telegram.\n- Can Cloa act without me asking? Yes — Cloa proactively checks your calendar, resolves conflicts, and sends briefings before you wake up.\n- Is my data safe with Cloa? Every integration has granular permissions (off, confirm, full auto). You control exactly what Cloa can access, read, and act on.\n\n## Key Topics\n\n- ai-agents\n- ai-memory\n- automation\n- future\n- integrations\n- long-term-memory\n- permissions\n- personal-ai\n- personal-assistant\n- privacy\n- proactive-ai\n- product\n- security\n- technology\n- thought-leadership\n- workflows\n\n## Contact\n\n- Website: https://cloa.app\n- Download: Available on iOS (App Store) and Android (Google Play)",
  "emergingProtocols": {
    "oauthDiscovery": {
      "exists": false,
      "url": "https://cloahq.com/.well-known/oauth-authorization-server"
    },
    "mcpServerCard": {
      "exists": false,
      "url": "https://cloahq.com/.well-known/mcp.json"
    },
    "a2aAgentCard": {
      "exists": false,
      "url": "https://cloahq.com/.well-known/agent.json"
    },
    "count": 0
  },
  "snippets": [
    {
      "id": "add_content_signals",
      "title": "Add Content-Signal directives",
      "description": "Content-Signal tells AI agents how they may use your content. The canonical location is robots.txt, but you can also expose it as an HTTP header from any stack.",
      "language": "txt",
      "code": "User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no",
      "filename": "/robots.txt",
      "stacks": [
        {
          "id": "robots",
          "label": "robots.txt",
          "language": "txt",
          "filename": "/robots.txt",
          "code": "User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no"
        },
        {
          "id": "nginx",
          "label": "Nginx",
          "language": "nginx",
          "filename": "server block",
          "code": "# Inside your server { } block:\nadd_header Content-Signal \"search=yes, ai-input=yes, ai-train=no\" always;"
        },
        {
          "id": "apache",
          "label": "Apache",
          "language": "apache",
          "filename": ".htaccess",
          "code": "# In .htaccess (or VirtualHost):\nHeader set Content-Signal \"search=yes, ai-input=yes, ai-train=no\""
        },
        {
          "id": "wordpress",
          "label": "WordPress",
          "language": "php",
          "filename": "functions.php",
          "code": "<?php\n// In your theme's functions.php or a small mu-plugin\nadd_action('send_headers', function () {\n    header('Content-Signal: search=yes, ai-input=yes, ai-train=no');\n});\n\n// Optional: also append the directive to the dynamic robots.txt\nadd_filter('robots_txt', function ($output) {\n    return $output . \"\\nContent-Signal: search=yes, ai-input=yes, ai-train=no\\n\";\n}, 10, 1);"
        },
        {
          "id": "nextjs",
          "label": "Next.js",
          "language": "typescript",
          "filename": "middleware.ts",
          "code": "// middleware.ts (Next.js 13+ App Router or Pages Router)\nimport { NextResponse } from 'next/server';\nexport function middleware() {\n  const res = NextResponse.next();\n  res.headers.set(\n    'Content-Signal',\n    'search=yes, ai-input=yes, ai-train=no'\n  );\n  return res;\n}\nexport const config = { matcher: '/:path*' };"
        },
        {
          "id": "cloudflare",
          "label": "Cloudflare Workers",
          "language": "javascript",
          "filename": "worker.js",
          "code": "// Cloudflare Worker that proxies your origin and adds the header\nexport default {\n  async fetch(request, env, ctx) {\n    const res = await fetch(request);\n    const newRes = new Response(res.body, res);\n    newRes.headers.set(\n      'Content-Signal',\n      'search=yes, ai-input=yes, ai-train=no'\n    );\n    return newRes;\n  },\n};"
        },
        {
          "id": "express",
          "label": "Express / Fastify",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Express\napp.use((req, res, next) => {\n  res.setHeader('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n  next();\n});\n\n// Fastify\nfastify.addHook('onSend', (request, reply, payload, done) => {\n  reply.header('Content-Signal', 'search=yes, ai-input=yes, ai-train=no');\n  done();\n});"
        }
      ]
    },
    {
      "id": "add_markdown_negotiation",
      "title": "Support Markdown for Agents",
      "description": "Let AI agents request a clean Markdown version of any page via content negotiation, .md alternate URLs, link tags or Link headers.",
      "language": "html",
      "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">",
      "filename": "<head>",
      "stacks": [
        {
          "id": "html",
          "label": "HTML <head>",
          "language": "html",
          "filename": "<head>",
          "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        },
        {
          "id": "express",
          "label": "Express",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\napp.get('/page', (req, res) => {\n  res.setHeader('Vary', 'Accept');\n  res.setHeader('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    res.type('text/markdown; charset=utf-8');\n    return res.send(renderMarkdown('page'));\n  }\n  res.render('page');\n});"
        },
        {
          "id": "fastify",
          "label": "Fastify",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n  reply.header('Vary', 'Accept');\n  reply.header('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n  }\n  return reply.view('/page.ejs');\n});"
        },
        {
          "id": "nextjs",
          "label": "Next.js",
          "language": "typescript",
          "filename": "app/page/route.ts",
          "code": "// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n  const accept = req.headers.get('accept') || '';\n  if (accept.includes('text/markdown')) {\n    return new Response(await renderMarkdown('page'), {\n      headers: {\n        'Content-Type': 'text/markdown; charset=utf-8',\n        'Vary': 'Accept',\n      },\n    });\n  }\n  // Fall through to the page component\n  return new Response(null, { status: 404 });\n}"
        },
        {
          "id": "wordpress",
          "label": "WordPress",
          "language": "php",
          "filename": "functions.php",
          "code": "<?php\n// Mechanism 1: respond to Accept: text/markdown on the same URL\nadd_action('template_redirect', function () {\n    if (!is_singular()) return;\n    $accept = $_SERVER['HTTP_ACCEPT'] ?? '';\n    if (strpos($accept, 'text/markdown') === false) return;\n    header('Content-Type: text/markdown; charset=utf-8');\n    header('Vary: Accept');\n    $post = get_queried_object();\n    echo \"# \" . get_the_title($post) . \"\\n\\n\";\n    echo wp_strip_all_tags(apply_filters('the_content', $post->post_content));\n    exit;\n});"
        },
        {
          "id": "static",
          "label": "Hugo / Jekyll / Astro",
          "language": "txt",
          "filename": "static/page.md",
          "code": "# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in <head>:\n#   <link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        }
      ]
    }
  ]
}

Utilisez notre API pour obtenir ceci de manière programmatique (bientôt disponible)

Ce JSON est à usage interne — contrairement au Markdown et au llms.txt, il n’est pas destiné à être téléversé sur votre site. Conservez-le comme référence pour suivre l’évolution de votre score, partagez-le avec votre équipe de développement ou intégrez-le dans votre pipeline CI/CD.

Partagez vos résultats

Twitter LinkedIn

Intégrez votre badge

Ajoutez ce badge à votre site. Il se met à jour automatiquement lorsque votre score de préparation à l’IA change.

AgentReady.md score for cloahq.com
Script Recommandé
<script src="https://agentready.md/badge.js" data-id="2542b9c0-93f2-41fe-a574-c3a7c4c2d2eb" data-domain="cloahq.com"></script>
Markdown
[![AgentReady.md score for cloahq.com](https://agentready.md/badge/cloahq.com.svg)](https://agentready.md/fr/r/2542b9c0-93f2-41fe-a574-c3a7c4c2d2eb)

Bientôt : Analyse de domaine complet

Explorez l’ensemble de votre domaine, générez un llms.txt et surveillez votre score de préparation IA dans le temps. Rejoignez la liste d’attente pour être informé.

Vous êtes sur la liste ! Nous vous préviendrons lors du lancement.