URL analizada
https://docs.dappbooster.dev
Puntuación AI-Ready
Deficiente
de 100
Ahorro de tokens
Desglose de la puntuación
Protocolos emergentes
0 de 3 detectadosEndpoints well-known que los AI agents buscan. Detectados significa que un agente puede descubrir y conectar con tu servicio automáticamente.
-
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
Tu sitio no soporta Markdown for Agents. Este estándar de Cloudflare permite a los agentes IA solicitar contenido en formato markdown, reduciendo el uso de tokens en ~80%.
Cómo implementarlo
Implementa uno o más: (1) Responder a Accept: text/markdown con contenido markdown. (2) Servir URLs .md (ej: /pagina.md). (3) Añadir etiquetas <link rel="alternate" type="text/markdown">. (4) Añadir cabeceras HTTP Link para descubrimiento markdown.
No se encontró un sitemap. Un sitemap ayuda a los AI agents a descubrir todas las páginas de tu sitio.
Cómo implementarlo
Crea un /sitemap.xml con todas tus páginas públicas. La mayoría de los CMS pueden generarlo automáticamente.
No se encontraron directivas Content-Signal. Estas indican a los agentes IA cómo pueden usar tu contenido (indexación, entrada IA, datos de entrenamiento). La ubicación recomendada es robots.txt.
Cómo implementarlo
Añade Content-Signal a tu robots.txt: User-agent: *\nContent-Signal: search=yes, ai-input=yes, ai-train=no. También puedes añadirlo como cabecera HTTP en respuestas markdown.
Muchos elementos tienen atributos de estilo en línea. Estos añaden ruido para los AI agents al extraer contenido.
Cómo implementarlo
Mueve todos los estilos en línea a clases CSS en tu hoja de estilos. Usa frameworks de CSS utilitario como Tailwind si necesitas muchos estilos únicos.
Tu página tiene un bajo ratio de contenido real respecto al HTML total. Gran parte del peso de la página es marcado, scripts o estilos en lugar de contenido.
Cómo implementarlo
Mueve el CSS a hojas de estilo externas, elimina los estilos en línea, minimiza el JavaScript y asegúrate de que el HTML se centre en la estructura del contenido.
No se encontraron datos estructurados de Schema.org. JSON-LD ayuda a los AI agents a extraer información factual y estructurada de tus páginas.
Cómo implementarlo
Añade un bloque <script type="application/ld+json"> con marcado Schema.org. Usa los tipos apropiados: Article para entradas de blog, Product para productos, Organization para la página de tu empresa.
Faltan etiquetas Open Graph o están incompletas. Las etiquetas OG ayudan a los AI agents (y plataformas sociales) a comprender el título, la descripción y la imagen de tu página.
Cómo implementarlo
Añade las meta etiquetas og:title, og:description y og:image en el <head> de tu página.
No se encontró meta description. Esta etiqueta proporciona un resumen conciso de la página para AI agents y motores de búsqueda.
Cómo implementarlo
Añade una etiqueta <meta name="description" content="..."> con una descripción de 150-160 caracteres sobre el contenido de la página.
Algunas imágenes carecen de texto alternativo descriptivo. Un buen texto alternativo ayuda a los AI agents a comprender el contenido y contexto de las imágenes.
Cómo implementarlo
Añade atributos alt descriptivos a todas las imágenes. Describe lo que muestra la imagen, no solo 'imagen' o 'foto'. Para imágenes decorativas, usa alt="" (vacío).
El contenido principal aparece tarde en el documento HTML. Los AI agents pueden dar más peso al contenido que aparece antes.
Cómo implementarlo
Reestructura tu HTML para que el contenido <main> o <article> aparezca antes que las barras laterales y el contenido suplementario.
 dAppBooster is a [repository template](https://github.com/BootNodeDev/dAppBooster), a starter-kit for boosting the development of decentralized applications (dApps). It is built onto the last tools available such us [React](https://react.dev/), [Typescript](https://www.typescriptlang.org/), [Wagmi](https://wagmi.sh/), [viem](https://viem.sh/), [@tanstank-query](https://tanstack.com/query/latest), [@tanstank-query](https://tanstack.com/router/latest), [vite](https://vitejs.dev/). Learn more about the [stack](https://docs.dappbooster.dev/advanced/stack). This template provides developers with a solid foundation, including essential configurations and tools for integrating with blockchain networks. By using [dAppBooster](https://demo.dappbooster.dev/), developers can quickly scaffold new dApps with a standardized setup, ensuring best practices for security, scalability, and efficiency are embedded from the start. It includes a ready-to-use development environment and whether you're building DeFi apps, or other blockchain solutions, dAppBooster saves time making it easier to launch robust blockchain-based applications. Whether you're a beginner or an experienced blockchain developer, dAppBooster provides a reliable, scalable starting point that takes care of much of the initial setup, letting you focus on building unique features for your dApp. Its flexibility makes it suitable for a wide range of blockchain-based applications, from simple token systems to complex decentralized ecosystems. After more than five years of making decentralized apps, our team at [BootNode](https://bootnode.dev/) has put together a simple yet powerful toolkit. This toolkit is designed to tackle the common hurdles and big decisions that come up when building dApps. It makes starting a new dApp smoother, cutting down on both time and complexity while focusing on developer experience, stability, bundle size, and performance. Here are some main features this starter-kit provides: - **Structure:** a flexible structure to handle contracts, ABIS, subgraphs and common decentralized components. - **Multi-chain:** native support and configuration to work with multiple chains with automatic type safe and super intuitive. - **Wallets connectivity:** native support to work with [connectkit](https://docs.family.co/connectkit), [rainbowkit](https://www.rainbowkit.com/), [web3modal](https://github.com/WalletConnect/web3modal); including [porto](https://porto.sh/sdk) SDK integration . - **Decentralized components:** Tree-shakable components that any dApp needs. - **Subgraphs:** multi-chain subgraphs support with auto generated typed hooks to query data.
dAppBooster Are you an LLM? Read [llms.txt](https://docs.dappbooster.dev/llms.txt) for a summary of the docs, or [llms-full.txt](https://docs.dappbooster.dev/llms-full.txt) for the full context. [Skip to content](https://docs.dappbooster.dev/#vocs-content) [](https://docs.dappbooster.dev/) [ ](https://x.com/bootnodedev) [ ](https://github.com/BootNodeDev/dAppBooster) [ ](https://t.me/dAppBooster) Search... [](https://docs.dappbooster.dev/) [](https://docs.dappbooster.dev/) Menu Introduction On this page [ Ask in ChatGPT](https://chatgpt.com/?hints=search&q=) # dAppBooster[ ](https://docs.dappbooster.dev/#dappbooster)  ## Why dAppBooster[ ](https://docs.dappbooster.dev/#why-dappbooster) dAppBooster is a [repository template](https://github.com/BootNodeDev/dAppBooster), a starter-kit for boosting the development of decentralized applications (dApps). It is built onto the last tools available such us [React](https://react.dev/), [Typescript](https://www.typescriptlang.org/), [Wagmi](https://wagmi.sh/), [viem](https://viem.sh/), [@tanstank-query](https://tanstack.com/query/latest), [@tanstank-query](https://tanstack.com/router/latest), [vite](https://vitejs.dev/). Learn more about the [stack](https://docs.dappbooster.dev/advanced/stack). This template provides developers with a solid foundation, including essential configurations and tools for integrating with blockchain networks. By using [dAppBooster](https://demo.dappbooster.dev/), developers can quickly scaffold new dApps with a standardized setup, ensuring best practices for security, scalability, and efficiency are embedded from the start. **Component technical docs** You can find the components' technical documentation and examples [here](https://components.dappbooster.dev/) It includes a ready-to-use development environment and whether you're building DeFi apps, or other blockchain solutions, dAppBooster saves time making it easier to launch robust blockchain-based applications. Whether you're a beginner or an experienced blockchain developer, dAppBooster provides a reliable, scalable starting point that takes care of much of the initial setup, letting you focus on building unique features for your dApp. Its flexibility makes it suitable for a wide range of blockchain-based applications, from simple token systems to complex decentralized ecosystems. After more than five years of making decentralized apps, our team at [BootNode](https://bootnode.dev/) has put together a simple yet powerful toolkit. This toolkit is designed to tackle the common hurdles and big decisions that come up when building dApps. It makes starting a new dApp smoother, cutting down on both time and complexity while focusing on developer experience, stability, bundle size, and performance. Here are some main features this starter-kit provides: - **Structure:** a flexible structure to handle contracts, ABIS, subgraphs and common decentralized components. - **Multi-chain:** native support and configuration to work with multiple chains with automatic type safe and super intuitive. - **Wallets connectivity:** native support to work with [connectkit](https://docs.family.co/connectkit), [rainbowkit](https://www.rainbowkit.com/), [web3modal](https://github.com/WalletConnect/web3modal); including [porto](https://porto.sh/sdk) SDK integration . - **Decentralized components:** Tree-shakable components that any dApp needs. - **Subgraphs:** multi-chain subgraphs support with auto generated typed hooks to query data.
Sube este archivo como /index.md en tu servidor para que los AI agents puedan acceder a una versión limpia de tu página. También puedes configurar la negociación de contenido Accept: text/markdown para servirlo automáticamente.
Nuestra recomendación
# docs.dappbooster.dev ## Documentation - [llms.txt](https://docs.dappbooster.dev/llms.txt) - [llms-full.txt](https://docs.dappbooster.dev/llms-full.txt) - [Skip to content](https://docs.dappbooster.dev/) - [Installation](https://docs.dappbooster.dev/introduction/installation) - [Introduction](https://docs.dappbooster.dev/components/introduction) - [My First dapp](https://docs.dappbooster.dev/recipes/my-first-dapp) - [Subgraphs](https://docs.dappbooster.dev/recipes/subgraphs) - [Subgraph plugin](https://docs.dappbooster.dev/advanced/subgraph-plugin) - [Networks](https://docs.dappbooster.dev/advanced/networks) - [Manual installation](https://docs.dappbooster.dev/advanced/manual-installation) - [Tech Stack](https://docs.dappbooster.dev/advanced/stack) ## Main - [dAppBooster](https://docs.dappbooster.dev) - [Introduction](https://docs.dappbooster.dev/) - [Installation](https://docs.dappbooster.dev/introduction/installation) - [Introduction](https://docs.dappbooster.dev/components/introduction) - [My First dapp](https://docs.dappbooster.dev/recipes/my-first-dapp) - [Subgraphs](https://docs.dappbooster.dev/recipes/subgraphs) - [Subgraph plugin](https://docs.dappbooster.dev/advanced/subgraph-plugin) - [Networks](https://docs.dappbooster.dev/advanced/networks) - [Manual installation](https://docs.dappbooster.dev/advanced/manual-installation)
El llms.txt completo requiere un análisis de todo el dominio (próximamente)
Sube este archivo a https://docs.dappbooster.dev/llms.txt en la raíz de tu dominio. Los AI agents como ChatGPT, Claude y Perplexity consultan este archivo para comprender la estructura de tu sitio.
Este sitio ya tiene un archivo llms.txt.
Formato válido# dAppBooster > A modern starter kit built with React to quickly get started with your next web3 project. ## Docs - [Building your first dApp](/recipes/my-first-dapp): Wrapping and Unwrapping WETH - [Subgraphs](/recipes/subgraphs): **Initial setup** - [Installation](/introduction/installation): Getting started with dAppBooster in just a few minutes - [Introduction](/components/introduction): This section is a work in progress - [Manual Installation](/advanced/manual-installation): In case the installation script doesn't fit your needs these are the steps to perform a manual installation. - [Networks](/advanced/networks): To add / remove / edit a network supported by the dApp you can do it directly in the `networks.config.ts` file. - [Tech Stack](/advanced/stack): **Overview** - [dAppBooster Subgraph Plugin](/advanced/subgraph-plugin): This package provides a flexible and reusable solution for generating [GraphQL](https://graphql.org/) clients using `@graphql-codegen/cli`, integrated with `@tanstack/react-query`.
HTML semántico
Has <article>
Clean heading hierarchy
13 semantic elements, 73 divs (ratio: 15%)
2/5 images with meaningful alt text
Avg div depth: 4.2, max: 7
Eficiencia del contenido
94% token reduction (HTML→Markdown)
Content ratio: 8.4% (2151 content chars / 25648 HTML bytes)
45/212 elements with inline styles (21.2%)
HTML size: 25KB
Visibilidad para IA
llms.txt exists and is valid
robots.txt exists
All major AI bots allowed
No sitemap found
Datos estructurados
No JSON-LD / Schema.org found
1/3 OG tags present
No meta description
No canonical URL
lang="en"
Accesibilidad
Content available without JavaScript
Page size: 25KB
Main content starts at 68% of HTML
{
"url": "https://docs.dappbooster.dev",
"timestamp": 1779112518813,
"fetch": {
"mode": "simple",
"timeMs": 77,
"htmlSizeBytes": 25648,
"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": "dAppBooster",
"excerpt": "",
"byline": null,
"siteName": null,
"lang": "en",
"contentLength": 2151,
"metadata": {
"description": null,
"ogTitle": "dAppBooster",
"ogDescription": null,
"ogImage": null,
"ogType": "website",
"canonical": null,
"lang": "en",
"schemas": [],
"robotsMeta": null,
"author": null,
"generator": null,
"markdownAlternateHref": null
}
},
"markdown": "\n\ndAppBooster is a [repository template](https://github.com/BootNodeDev/dAppBooster), a starter-kit for boosting the development of decentralized applications (dApps). It is built onto the last tools available such us [React](https://react.dev/), [Typescript](https://www.typescriptlang.org/), [Wagmi](https://wagmi.sh/), [viem](https://viem.sh/), [@tanstank-query](https://tanstack.com/query/latest), [@tanstank-query](https://tanstack.com/router/latest), [vite](https://vitejs.dev/). Learn more about the [stack](https://docs.dappbooster.dev/advanced/stack).\n\nThis template provides developers with a solid foundation, including essential configurations and tools for integrating with blockchain networks. By using [dAppBooster](https://demo.dappbooster.dev/), developers can quickly scaffold new dApps with a standardized setup, ensuring best practices for security, scalability, and efficiency are embedded from the start.\n\nIt includes a ready-to-use development environment and whether you're building DeFi apps, or other blockchain solutions, dAppBooster saves time making it easier to launch robust blockchain-based applications.\n\nWhether you're a beginner or an experienced blockchain developer, dAppBooster provides a reliable, scalable starting point that takes care of much of the initial setup, letting you focus on building unique features for your dApp. Its flexibility makes it suitable for a wide range of blockchain-based applications, from simple token systems to complex decentralized ecosystems.\n\nAfter more than five years of making decentralized apps, our team at [BootNode](https://bootnode.dev/) has put together a simple yet powerful toolkit. This toolkit is designed to tackle the common hurdles and big decisions that come up when building dApps. It makes starting a new dApp smoother, cutting down on both time and complexity while focusing on developer experience, stability, bundle size, and performance. Here are some main features this starter-kit provides:\n\n- **Structure:** a flexible structure to handle contracts, ABIS, subgraphs and common decentralized components.\n- **Multi-chain:** native support and configuration to work with multiple chains with automatic type safe and super intuitive.\n- **Wallets connectivity:** native support to work with [connectkit](https://docs.family.co/connectkit), [rainbowkit](https://www.rainbowkit.com/), [web3modal](https://github.com/WalletConnect/web3modal); including [porto](https://porto.sh/sdk) SDK integration .\n- **Decentralized components:** Tree-shakable components that any dApp needs.\n- **Subgraphs:** multi-chain subgraphs support with auto generated typed hooks to query data.\n",
"fullPageMarkdown": "dAppBooster Are you an LLM? Read [llms.txt](https://docs.dappbooster.dev/llms.txt) for a summary of the docs, or [llms-full.txt](https://docs.dappbooster.dev/llms-full.txt) for the full context.\n\n[Skip to content](https://docs.dappbooster.dev/#vocs-content)\n\n[](https://docs.dappbooster.dev/)\n\n[\n\n](https://x.com/bootnodedev)\n\n[\n\n](https://github.com/BootNodeDev/dAppBooster)\n\n[\n\n](https://t.me/dAppBooster)\n\nSearch...\n\n[](https://docs.dappbooster.dev/)\n\n[](https://docs.dappbooster.dev/)\n\nMenu\n\nIntroduction\n\nOn this page\n\n[\n\nAsk in ChatGPT](https://chatgpt.com/?hints=search&q=)\n\n# dAppBooster[\n\n](https://docs.dappbooster.dev/#dappbooster)\n\n\n\n## Why dAppBooster[\n\n](https://docs.dappbooster.dev/#why-dappbooster)\n\ndAppBooster is a [repository template](https://github.com/BootNodeDev/dAppBooster), a starter-kit for boosting the development of decentralized applications (dApps). It is built onto the last tools available such us [React](https://react.dev/), [Typescript](https://www.typescriptlang.org/), [Wagmi](https://wagmi.sh/), [viem](https://viem.sh/), [@tanstank-query](https://tanstack.com/query/latest), [@tanstank-query](https://tanstack.com/router/latest), [vite](https://vitejs.dev/). Learn more about the [stack](https://docs.dappbooster.dev/advanced/stack).\n\nThis template provides developers with a solid foundation, including essential configurations and tools for integrating with blockchain networks. By using [dAppBooster](https://demo.dappbooster.dev/), developers can quickly scaffold new dApps with a standardized setup, ensuring best practices for security, scalability, and efficiency are embedded from the start.\n\n**Component technical docs**\n\nYou can find the components' technical documentation and examples [here](https://components.dappbooster.dev/)\n\nIt includes a ready-to-use development environment and whether you're building DeFi apps, or other blockchain solutions, dAppBooster saves time making it easier to launch robust blockchain-based applications.\n\nWhether you're a beginner or an experienced blockchain developer, dAppBooster provides a reliable, scalable starting point that takes care of much of the initial setup, letting you focus on building unique features for your dApp. Its flexibility makes it suitable for a wide range of blockchain-based applications, from simple token systems to complex decentralized ecosystems.\n\nAfter more than five years of making decentralized apps, our team at [BootNode](https://bootnode.dev/) has put together a simple yet powerful toolkit. This toolkit is designed to tackle the common hurdles and big decisions that come up when building dApps. It makes starting a new dApp smoother, cutting down on both time and complexity while focusing on developer experience, stability, bundle size, and performance. Here are some main features this starter-kit provides:\n\n- **Structure:** a flexible structure to handle contracts, ABIS, subgraphs and common decentralized components.\n- **Multi-chain:** native support and configuration to work with multiple chains with automatic type safe and super intuitive.\n- **Wallets connectivity:** native support to work with [connectkit](https://docs.family.co/connectkit), [rainbowkit](https://www.rainbowkit.com/), [web3modal](https://github.com/WalletConnect/web3modal); including [porto](https://porto.sh/sdk) SDK integration .\n- **Decentralized components:** Tree-shakable components that any dApp needs.\n- **Subgraphs:** multi-chain subgraphs support with auto generated typed hooks to query data.\n",
"markdownStats": {
"images": 1,
"links": 15,
"tables": 0,
"codeBlocks": 0,
"headings": 0
},
"tokens": {
"htmlTokens": 9422,
"markdownTokens": 588,
"reduction": 8834,
"reductionPercent": 94
},
"score": {
"score": 58,
"grade": "D",
"dimensions": {
"semanticHtml": {
"score": 81,
"weight": 20,
"grade": "B",
"checks": {
"uses_article_or_main": {
"score": 100,
"weight": 20,
"details": "Has <article>"
},
"proper_heading_hierarchy": {
"score": 100,
"weight": 25,
"details": "Clean heading hierarchy"
},
"semantic_elements": {
"score": 50,
"weight": 20,
"details": "13 semantic elements, 73 divs (ratio: 15%)"
},
"meaningful_alt_texts": {
"score": 40,
"weight": 15,
"details": "2/5 images with meaningful alt text"
},
"low_div_nesting": {
"score": 100,
"weight": 20,
"details": "Avg div depth: 4.2, max: 7"
}
}
},
"contentEfficiency": {
"score": 63,
"weight": 25,
"grade": "C",
"checks": {
"token_reduction_ratio": {
"score": 100,
"weight": 40,
"details": "94% token reduction (HTML→Markdown)"
},
"content_to_noise_ratio": {
"score": 25,
"weight": 30,
"details": "Content ratio: 8.4% (2151 content chars / 25648 HTML bytes)"
},
"minimal_inline_styles": {
"score": 0,
"weight": 15,
"details": "45/212 elements with inline styles (21.2%)"
},
"reasonable_page_weight": {
"score": 100,
"weight": 15,
"details": "HTML size: 25KB"
}
}
},
"aiDiscoverability": {
"score": 45,
"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": 0,
"weight": 10,
"details": "No 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": 18,
"weight": 15,
"grade": "F",
"checks": {
"has_schema_org": {
"score": 0,
"weight": 30,
"details": "No JSON-LD / Schema.org found"
},
"has_open_graph": {
"score": 33,
"weight": 25,
"details": "1/3 OG tags present"
},
"has_meta_description": {
"score": 0,
"weight": 20,
"details": "No meta description"
},
"has_canonical_url": {
"score": 0,
"weight": 15,
"details": "No canonical URL"
},
"has_lang_attribute": {
"score": 100,
"weight": 10,
"details": "lang=\"en\""
}
}
},
"accessibility": {
"score": 78,
"weight": 15,
"grade": "B",
"checks": {
"content_without_js": {
"score": 100,
"weight": 40,
"details": "Content available without JavaScript"
},
"reasonable_page_size": {
"score": 100,
"weight": 30,
"details": "Page size: 25KB"
},
"fast_content_position": {
"score": 25,
"weight": 30,
"details": "Main content starts at 68% of HTML"
}
}
}
}
},
"recommendations": [
{
"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_sitemap",
"priority": "critical",
"category": "aiDiscoverability",
"titleKey": "rec.add_sitemap.title",
"descriptionKey": "rec.add_sitemap.description",
"howToKey": "rec.add_sitemap.howto",
"effort": "quick-win",
"estimatedImpact": 5,
"checkScore": 0,
"checkDetails": "No sitemap found"
},
{
"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": "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": "45/212 elements with inline styles (21.2%)"
},
{
"id": "improve_content_ratio",
"priority": "high",
"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": 25,
"checkDetails": "Content ratio: 8.4% (2151 content chars / 25648 HTML bytes)"
},
{
"id": "add_schema_org",
"priority": "high",
"category": "structuredData",
"titleKey": "rec.add_schema_org.title",
"descriptionKey": "rec.add_schema_org.description",
"howToKey": "rec.add_schema_org.howto",
"effort": "moderate",
"estimatedImpact": 6,
"checkScore": 0,
"checkDetails": "No JSON-LD / Schema.org found"
},
{
"id": "add_open_graph",
"priority": "high",
"category": "structuredData",
"titleKey": "rec.add_open_graph.title",
"descriptionKey": "rec.add_open_graph.description",
"howToKey": "rec.add_open_graph.howto",
"effort": "quick-win",
"estimatedImpact": 4,
"checkScore": 33,
"checkDetails": "1/3 OG tags present"
},
{
"id": "add_meta_description",
"priority": "high",
"category": "structuredData",
"titleKey": "rec.add_meta_description.title",
"descriptionKey": "rec.add_meta_description.description",
"howToKey": "rec.add_meta_description.howto",
"effort": "quick-win",
"estimatedImpact": 4,
"checkScore": 0,
"checkDetails": "No meta description"
},
{
"id": "improve_alt_texts",
"priority": "high",
"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": 40,
"checkDetails": "2/5 images with meaningful alt text"
},
{
"id": "move_content_earlier",
"priority": "high",
"category": "accessibility",
"titleKey": "rec.move_content_earlier.title",
"descriptionKey": "rec.move_content_earlier.description",
"howToKey": "rec.move_content_earlier.howto",
"effort": "moderate",
"estimatedImpact": 4,
"checkScore": 25,
"checkDetails": "Main content starts at 68% of HTML"
}
],
"llmsTxtPreview": "# docs.dappbooster.dev\n\n## Documentation\n- [llms.txt](https://docs.dappbooster.dev/llms.txt)\n- [llms-full.txt](https://docs.dappbooster.dev/llms-full.txt)\n- [Skip to content](https://docs.dappbooster.dev/)\n- [Installation](https://docs.dappbooster.dev/introduction/installation)\n- [Introduction](https://docs.dappbooster.dev/components/introduction)\n- [My First dapp](https://docs.dappbooster.dev/recipes/my-first-dapp)\n- [Subgraphs](https://docs.dappbooster.dev/recipes/subgraphs)\n- [Subgraph plugin](https://docs.dappbooster.dev/advanced/subgraph-plugin)\n- [Networks](https://docs.dappbooster.dev/advanced/networks)\n- [Manual installation](https://docs.dappbooster.dev/advanced/manual-installation)\n- [Tech Stack](https://docs.dappbooster.dev/advanced/stack)\n\n## Main\n- [dAppBooster](https://docs.dappbooster.dev)\n- [Introduction](https://docs.dappbooster.dev/)\n- [Installation](https://docs.dappbooster.dev/introduction/installation)\n- [Introduction](https://docs.dappbooster.dev/components/introduction)\n- [My First dapp](https://docs.dappbooster.dev/recipes/my-first-dapp)\n- [Subgraphs](https://docs.dappbooster.dev/recipes/subgraphs)\n- [Subgraph plugin](https://docs.dappbooster.dev/advanced/subgraph-plugin)\n- [Networks](https://docs.dappbooster.dev/advanced/networks)\n- [Manual installation](https://docs.dappbooster.dev/advanced/manual-installation)\n\n",
"llmsTxtExisting": "# dAppBooster\n\n> A modern starter kit built with React to quickly get started with your next web3 project.\n\n## Docs\n\n- [Building your first dApp](/recipes/my-first-dapp): Wrapping and Unwrapping WETH\n- [Subgraphs](/recipes/subgraphs): **Initial setup**\n- [Installation](/introduction/installation): Getting started with dAppBooster in just a few minutes\n- [Introduction](/components/introduction): This section is a work in progress\n- [Manual Installation](/advanced/manual-installation): In case the installation script doesn't fit your needs these are the steps to perform a manual installation.\n- [Networks](/advanced/networks): To add / remove / edit a network supported by the dApp you can do it directly in the `networks.config.ts` file.\n- [Tech Stack](/advanced/stack): **Overview**\n- [dAppBooster Subgraph Plugin](/advanced/subgraph-plugin): This package provides a flexible and reusable solution for generating [GraphQL](https://graphql.org/) clients using `@graphql-codegen/cli`, integrated with `@tanstack/react-query`.",
"emergingProtocols": {
"oauthDiscovery": {
"exists": false,
"url": "https://docs.dappbooster.dev/.well-known/oauth-authorization-server"
},
"mcpServerCard": {
"exists": false,
"url": "https://docs.dappbooster.dev/.well-known/mcp.json"
},
"a2aAgentCard": {
"exists": false,
"url": "https://docs.dappbooster.dev/.well-known/agent.json"
},
"count": 0
},
"snippets": [
{
"id": "add_open_graph",
"title": "Add missing Open Graph tags",
"description": "Open Graph tags control how your page looks when shared on social media and how AI platforms preview your URL in answers.",
"language": "html",
"code": "<meta property=\"og:description\" content=\"Page description.\">\n<meta property=\"og:image\" content=\"https://yoursite.com/og-image.jpg\">\n<meta property=\"og:url\" content=\"https://docs.dappbooster.dev\">\n<meta property=\"og:type\" content=\"website\">",
"filename": "<head>",
"stacks": [
{
"id": "html",
"label": "HTML <head>",
"language": "html",
"filename": "<head>",
"code": "<meta property=\"og:description\" content=\"Page description.\">\n<meta property=\"og:image\" content=\"https://yoursite.com/og-image.jpg\">\n<meta property=\"og:url\" content=\"https://docs.dappbooster.dev\">\n<meta property=\"og:type\" content=\"website\">"
},
{
"id": "wordpress",
"label": "WordPress",
"language": "php",
"filename": "functions.php",
"code": "<?php\n// Quick Open Graph tags without a plugin (skip if Yoast / Rank Math is active)\nadd_action('wp_head', function () {\n if (!is_singular()) return;\n $post = get_queried_object();\n $title = get_the_title($post);\n $desc = get_the_excerpt($post) ?: wp_trim_words(strip_tags($post->post_content), 30);\n $image = get_the_post_thumbnail_url($post, 'large') ?: 'https://yoursite.com/og-image.jpg';\n $url = get_permalink($post);\n printf('<meta property=\"og:title\" content=\"%s\">' . \"\\n\", esc_attr($title));\n printf('<meta property=\"og:description\" content=\"%s\">' . \"\\n\", esc_attr($desc));\n printf('<meta property=\"og:image\" content=\"%s\">' . \"\\n\", esc_url($image));\n printf('<meta property=\"og:url\" content=\"%s\">' . \"\\n\", esc_url($url));\n echo '<meta property=\"og:type\" content=\"article\">' . \"\\n\";\n}, 5);"
},
{
"id": "nextjs",
"label": "Next.js",
"language": "typescript",
"filename": "app/page.tsx",
"code": "// Next.js App Router — Metadata API\nimport type { Metadata } from 'next';\n\nexport const metadata: Metadata = {\n title: \"dAppBooster\",\n description: \"Page description.\",\n openGraph: {\n title: \"dAppBooster\",\n description: \"Page description.\",\n url: \"https://docs.dappbooster.dev\",\n images: [\"https://yoursite.com/og-image.jpg\"],\n type: 'website',\n },\n};"
}
]
},
{
"id": "add_meta_description",
"title": "Add meta description",
"description": "A good meta description (50-160 characters) helps AI agents understand your page quickly.",
"language": "html",
"code": "<meta name=\"description\" content=\"dAppBooster\">",
"filename": "<head>"
},
{
"id": "add_schema_org",
"title": "Add Schema.org JSON-LD",
"description": "Structured data helps AI agents understand the type, author, and purpose of your content.",
"language": "html",
"code": "<script type=\"application/ld+json\">\n{\n \"@context\": \"https://schema.org\",\n \"@type\": \"WebPage\",\n \"name\": \"dAppBooster\",\n \"description\": \"Page description.\",\n \"url\": \"https://docs.dappbooster.dev\",\n \"inLanguage\": \"en\"\n}\n</script>",
"filename": "<head>"
},
{
"id": "add_sitemap",
"title": "Create /sitemap.xml",
"description": "A sitemap helps AI agents discover all your pages. Most CMS platforms generate one automatically.",
"language": "xml",
"code": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<urlset xmlns=\"http://www.sitemaps.org/schemas/sitemap/0.9\">\n <url>\n <loc>https://docs.dappbooster.dev</loc>\n <lastmod>2026-05-18</lastmod>\n </url>\n</urlset>",
"filename": "/sitemap.xml"
},
{
"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\">"
}
]
}
]
}
Usa nuestra API para obtener esto de forma programática (próximamente)
Este JSON es para uso interno — a diferencia del Markdown y llms.txt, no está pensado para subirse a tu web. Guárdalo como referencia para seguir la evolución de tu puntuación, compártelo con tu equipo de desarrollo o intégralo en tu pipeline CI/CD.
Incrusta tu badge
Añade este badge a tu sitio. Se actualiza automáticamente cuando cambie tu puntuación.
<script src="https://agentready.md/badge.js" data-id="9d1c2f24-52cf-4413-9bd6-06f75066a06e" data-domain="docs.dappbooster.dev"></script>
[](https://agentready.md/es/r/9d1c2f24-52cf-4413-9bd6-06f75066a06e)
Próximamente: Análisis de dominio completo
Rastrea todo tu dominio, genera llms.txt y monitoriza tu puntuación de preparación para IA a lo largo del tiempo. Únete a la lista de espera para recibir notificaciones.