<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Antonia Navarrete</title>
    <description>The latest articles on Forem by Antonia Navarrete (@antitopy).</description>
    <link>https://forem.com/antitopy</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3901131%2F11efb08f-32fc-4b00-aa14-6250ff552728.jpg</url>
      <title>Forem: Antonia Navarrete</title>
      <link>https://forem.com/antitopy</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/antitopy"/>
    <language>en</language>
    <item>
      <title>Hooks en Kiro: cómo automatizar tareas repetitivas con triggers inteligentes</title>
      <dc:creator>Antonia Navarrete</dc:creator>
      <pubDate>Fri, 08 May 2026 05:35:34 +0000</pubDate>
      <link>https://forem.com/antitopy/hooks-en-kiro-como-automatizar-tareas-repetitivas-con-triggers-inteligentes-4cbm</link>
      <guid>https://forem.com/antitopy/hooks-en-kiro-como-automatizar-tareas-repetitivas-con-triggers-inteligentes-4cbm</guid>
      <description>&lt;h1&gt;
  
  
  Hooks en Kiro: cómo automatizar tareas repetitivas con triggers inteligentes
&lt;/h1&gt;

&lt;p&gt;¿Cuántas veces al día le pides al agente que revise el linting, que genere tests o que actualice la documentación? Si la respuesta es "muchas", los &lt;strong&gt;agent hooks&lt;/strong&gt; de Kiro son para ti. En lugar de repetir esas solicitudes manualmente, configuras una regla una sola vez y Kiro se encarga del resto, de forma automática y consistente.&lt;/p&gt;

&lt;p&gt;En este post vamos a recorrer qué son los hooks, cómo funcionan, qué tipos de triggers tienes disponibles y cómo crear los tuyos desde cero.&lt;/p&gt;




&lt;h2&gt;
  
  
  ¿Qué son los agent hooks?
&lt;/h2&gt;

&lt;p&gt;Los agent hooks son disparadores automáticos que ejecutan una acción predefinida —ya sea un prompt al agente o un comando de shell— cuando ocurre un evento específico en tu IDE.&lt;/p&gt;

&lt;p&gt;El sistema funciona en dos pasos:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Detección del evento:&lt;/strong&gt; Kiro monitorea constantemente eventos como guardar un archivo, terminar una tarea o invocar una herramienta.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Ejecución de la acción:&lt;/strong&gt; Cuando el evento ocurre, se dispara automáticamente la acción configurada.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Esto transforma la forma en que trabajas. Con hooks bien configurados puedes:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Mantener calidad de código consistente sin esfuerzo manual&lt;/li&gt;
&lt;li&gt;Prevenir vulnerabilidades de seguridad desde el momento en que escribes&lt;/li&gt;
&lt;li&gt;Reducir la carga cognitiva del equipo&lt;/li&gt;
&lt;li&gt;Estandarizar procesos sin depender de que cada persona los recuerde&lt;/li&gt;
&lt;li&gt;Crear ciclos de desarrollo más rápidos y predecibles&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Los dos tipos de acción
&lt;/h2&gt;

&lt;p&gt;Antes de ver los triggers, es importante entender qué puede hacer un hook cuando se dispara. Hay dos tipos de acción:&lt;/p&gt;

&lt;h3&gt;
  
  
  Agent Prompt (Ask Kiro)
&lt;/h3&gt;

&lt;p&gt;Defines un prompt en lenguaje natural que se envía al agente cada vez que el hook se activa. El agente responde y actúa sobre él igual que lo haría con cualquier mensaje en el panel de chat. Es la opción correcta cuando la tarea depende del contexto actual del código.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Nota:&lt;/strong&gt; Las acciones de tipo Agent Prompt consumen créditos, ya que inician un nuevo ciclo del agente.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3&gt;
  
  
  Shell Command (Run Command)
&lt;/h3&gt;

&lt;p&gt;Defines un comando de shell que se ejecuta localmente en tu máquina. Si el comando termina con exit code &lt;code&gt;0&lt;/code&gt;, su salida (&lt;code&gt;stdout&lt;/code&gt;) se agrega al contexto del agente. Si falla, el error (&lt;code&gt;stderr&lt;/code&gt;) se envía al agente como notificación. En los triggers &lt;code&gt;Pre Tool Use&lt;/code&gt; y &lt;code&gt;Prompt Submit&lt;/code&gt;, un fallo también bloquea la operación.&lt;/p&gt;

&lt;p&gt;Los Shell Commands son más rápidos (se ejecutan localmente, sin LLM) y no consumen créditos. Son la opción correcta para tareas determinísticas que no dependen del contexto del agente.&lt;/p&gt;




&lt;h2&gt;
  
  
  Los 10 tipos de trigger disponibles
&lt;/h2&gt;

&lt;p&gt;Kiro ofrece una variedad de triggers para cubrir prácticamente cualquier momento del ciclo de desarrollo.&lt;/p&gt;

&lt;h3&gt;
  
  
  Prompt Submit
&lt;/h3&gt;

&lt;p&gt;Se activa cuando el usuario envía un prompt al agente. En modo Shell Command, el contenido del prompt es accesible mediante la variable de entorno &lt;code&gt;USER_PROMPT&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Agregar contexto adicional relevante al prompt&lt;/li&gt;
&lt;li&gt;Bloquear ciertos tipos de solicitudes según su contenido&lt;/li&gt;
&lt;li&gt;Registrar todos los prompts en una ubicación central&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Agent Stop
&lt;/h3&gt;

&lt;p&gt;Se dispara cuando el agente ha completado su turno y terminó de responder.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Compilar el código generado y reportar fallos al agente&lt;/li&gt;
&lt;li&gt;Formatear o revisar el código producido por el agente&lt;/li&gt;
&lt;li&gt;Revisar los cambios realizados y dar instrucciones adicionales&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Pre Tool Use
&lt;/h3&gt;

&lt;p&gt;Se ejecuta justo antes de que el agente invoque una herramienta. En el campo &lt;strong&gt;Tool name&lt;/strong&gt; puedes especificar herramientas concretas o usar categorías predefinidas:&lt;/p&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Categoría&lt;/th&gt;
&lt;th&gt;Descripción&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;read&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas de lectura de archivos&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;write&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas de escritura de archivos&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;shell&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas relacionadas con comandos de shell&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;web&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas web&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;spec&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas de spec&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;*&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Todas las herramientas (built-in y MCP)&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;p&gt;También puedes usar prefijos como &lt;code&gt;@mcp&lt;/code&gt;, &lt;code&gt;@powers&lt;/code&gt; o &lt;code&gt;@builtin&lt;/code&gt; para filtrar por origen, e incluso patrones regex como &lt;code&gt;@mcp.*sql.*&lt;/code&gt; para herramientas MCP específicas.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Bloquear invocaciones de herramientas no autorizadas&lt;/li&gt;
&lt;li&gt;Agregar instrucciones adicionales antes de que el agente actúe&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Post Tool Use
&lt;/h3&gt;

&lt;p&gt;Se activa después de que el agente invoca una herramienta. Aplica la misma lógica de filtrado que Pre Tool Use.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Registrar invocaciones para auditoría&lt;/li&gt;
&lt;li&gt;Formatear archivos actualizados después de una escritura&lt;/li&gt;
&lt;li&gt;Dar instrucciones adicionales sobre el resultado de la herramienta&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  File Create
&lt;/h3&gt;

&lt;p&gt;Se dispara cuando se crean archivos nuevos que coinciden con un patrón específico en tu workspace.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Generar boilerplate automáticamente para nuevos componentes&lt;/li&gt;
&lt;li&gt;Agregar headers de licencia a archivos nuevos&lt;/li&gt;
&lt;li&gt;Crear archivos de test en paralelo al crear archivos de implementación&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  File Save
&lt;/h3&gt;

&lt;p&gt;Se activa cada vez que guardas un archivo que coincide con el patrón configurado. Es el trigger más usado en el día a día.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Ejecutar linting y formateo automático&lt;/li&gt;
&lt;li&gt;Actualizar archivos relacionados&lt;/li&gt;
&lt;li&gt;Generar o actualizar documentación&lt;/li&gt;
&lt;li&gt;Correr tests para los archivos modificados&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  File Delete
&lt;/h3&gt;

&lt;p&gt;Se dispara al eliminar archivos que coinciden con el patrón.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Limpiar archivos relacionados automáticamente&lt;/li&gt;
&lt;li&gt;Actualizar referencias de imports en otros archivos&lt;/li&gt;
&lt;li&gt;Mantener la integridad del proyecto&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Pre Task Execution
&lt;/h3&gt;

&lt;p&gt;Se ejecuta antes de que una tarea de spec comience su ejecución (cuando su estado cambia a &lt;code&gt;in_progress&lt;/code&gt;).&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Correr scripts de preparación o configuración del entorno&lt;/li&gt;
&lt;li&gt;Validar que los prerequisitos estén cumplidos antes de iniciar&lt;/li&gt;
&lt;li&gt;Registrar el inicio de la tarea para tracking&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Post Task Execution
&lt;/h3&gt;

&lt;p&gt;Se activa cuando una tarea de spec completa su ejecución (cuando su estado cambia a &lt;code&gt;completed&lt;/code&gt;).&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Correr tests para verificar la corrección de la tarea&lt;/li&gt;
&lt;li&gt;Aplicar linting o formateo sobre los archivos modificados&lt;/li&gt;
&lt;li&gt;Generar documentación del trabajo completado&lt;/li&gt;
&lt;li&gt;Notificar sistemas externos sobre la finalización&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  Manual Trigger
&lt;/h3&gt;

&lt;p&gt;Se ejecuta a demanda, cuando tú lo decides, mediante un clic en el panel de Kiro.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Casos de uso:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Code reviews puntuales&lt;/li&gt;
&lt;li&gt;Generación de documentación bajo pedido&lt;/li&gt;
&lt;li&gt;Escaneos de seguridad&lt;/li&gt;
&lt;li&gt;Optimización de performance&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Tres casos de uso reales
&lt;/h2&gt;

&lt;h3&gt;
  
  
  1. Sincronización automática de traducciones
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;Trigger:&lt;/strong&gt; File Save | &lt;strong&gt;Archivos:&lt;/strong&gt; &lt;code&gt;locales/en.json&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;Cada vez que guardas el archivo de traducciones en inglés, el hook detecta qué claves se añadieron o modificaron, revisa todos los demás archivos de idioma, marca las claves ausentes con &lt;code&gt;NEEDS_TRANSLATION&lt;/code&gt; y las modificadas con &lt;code&gt;NEEDS_REVIEW&lt;/code&gt;, y genera un resumen de los cambios pendientes. El equipo de localización siempre sabe exactamente qué falta.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Instrucciones al agente:
1. Identify which string keys were added or modified
2. Check all other language files for these keys
3. For missing keys, add them with a "NEEDS_TRANSLATION" marker
4. For modified keys, mark them as "NEEDS_REVIEW"
5. Generate a summary of changes needed across all languages
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  2. Mantenedor de cobertura de tests
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;Trigger:&lt;/strong&gt; File Save | &lt;strong&gt;Archivos:&lt;/strong&gt; &lt;code&gt;src/**/*.{js,ts,jsx,tsx}&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;Al modificar cualquier archivo fuente, el agente identifica las funciones nuevas o cambiadas, verifica si existen tests correspondientes, genera casos de prueba para el código sin cobertura, los ejecuta y actualiza los reportes. La cobertura de tests nunca cae.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Instrucciones al agente:
1. Identify new or modified functions and methods
2. Check if corresponding tests exist and cover the changes
3. If coverage is missing, generate test cases for the new code
4. Run the tests to verify they pass
5. Update coverage reports
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  3. Generador de documentación bajo demanda
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;Trigger:&lt;/strong&gt; Manual Trigger&lt;/p&gt;

&lt;p&gt;Con un clic, el agente genera documentación completa del archivo actual: extrae firmas de funciones y clases, documenta parámetros y tipos de retorno, incluye ejemplos de uso basados en el código existente, actualiza el &lt;code&gt;README.md&lt;/code&gt; con los nuevos exports y verifica que todo siga los estándares del proyecto.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Instrucciones al agente:
1. Extract function and class signatures
2. Document parameters and return types
3. Provide usage examples based on existing code
4. Update the README.md with any new exports
5. Ensure documentation follows project standards
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h2&gt;
  
  
  Cómo crear tu primer hook
&lt;/h2&gt;

&lt;p&gt;Puedes crear hooks de dos maneras desde la sección &lt;strong&gt;Agent Hooks&lt;/strong&gt; del panel de Kiro.&lt;/p&gt;

&lt;h3&gt;
  
  
  Opción A: con lenguaje natural (recomendado para empezar)
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;Navega a la sección &lt;strong&gt;Agent Hooks&lt;/strong&gt; en el panel de Kiro&lt;/li&gt;
&lt;li&gt;Haz clic en el botón &lt;strong&gt;+&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;Selecciona &lt;strong&gt;Ask Kiro to create a hook&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;Describe en lenguaje natural lo que quieres que haga el hook&lt;/li&gt;
&lt;li&gt;Presiona &lt;strong&gt;Enter&lt;/strong&gt; o haz clic en &lt;strong&gt;Submit&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;Revisa la configuración generada, ajusta si es necesario y haz clic en &lt;strong&gt;Save Hook&lt;/strong&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Opción B: configuración manual
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;Navega a la sección &lt;strong&gt;Agent Hooks&lt;/strong&gt; en el panel de Kiro&lt;/li&gt;
&lt;li&gt;Haz clic en el botón &lt;strong&gt;+&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;Selecciona &lt;strong&gt;Manually create a hook&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;Completa los campos del formulario:

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Title:&lt;/strong&gt; nombre corto del hook&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Description:&lt;/strong&gt; qué hace el hook&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Event:&lt;/strong&gt; tipo de trigger (File Save, Post Tool Use, Pre Task Execution, etc.)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Tool name:&lt;/strong&gt; para hooks Pre/Post Tool Use, qué herramientas aplican&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;File pattern:&lt;/strong&gt; para hooks de archivo, qué archivos monitorear&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Action:&lt;/strong&gt; &lt;em&gt;Ask Kiro&lt;/em&gt; (prompt al agente) o &lt;em&gt;Run Command&lt;/em&gt; (shell)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Instructions / Command:&lt;/strong&gt; el prompt o comando a ejecutar&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Haz clic en &lt;strong&gt;Create Hook&lt;/strong&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Atajo útil:&lt;/strong&gt; También puedes abrir el Hook UI desde el Command Palette con &lt;code&gt;Cmd+Shift+P&lt;/code&gt; (Mac) o &lt;code&gt;Ctrl+Shift+P&lt;/code&gt; (Windows/Linux) y escribiendo &lt;code&gt;Kiro: Open Kiro Hook UI&lt;/code&gt;.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  Gestión de hooks
&lt;/h2&gt;

&lt;p&gt;Todos tus hooks están accesibles desde la sección &lt;strong&gt;Agent Hooks&lt;/strong&gt; del panel de Kiro.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Activar / desactivar:&lt;/strong&gt; Haz clic en el ícono de ojo junto al hook, o usa el switch &lt;em&gt;Hook Enabled&lt;/em&gt; en la vista de detalle. No necesitas eliminar un hook para pausarlo.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Editar:&lt;/strong&gt; Selecciona el hook y modifica cualquier campo. Los cambios aplican de inmediato.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Eliminar:&lt;/strong&gt; Selecciona el hook, haz clic en &lt;em&gt;Delete Hook&lt;/em&gt; y confirma. Esta acción no se puede deshacer.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Ejecutar manualmente:&lt;/strong&gt; Para hooks de tipo Manual Trigger, usa el botón ▷ junto al nombre o el botón &lt;em&gt;Start Hook&lt;/em&gt; en la vista de detalle.&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Buenas prácticas
&lt;/h2&gt;

&lt;h3&gt;
  
  
  Diseño de hooks
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Un hook, una responsabilidad.&lt;/strong&gt; Enfoca cada hook en una sola tarea. Son más predecibles y fáciles de depurar.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Instrucciones claras y sin ambigüedad.&lt;/strong&gt; Cuando uses Agent Prompt, escribe pasos numerados para operaciones complejas.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Empieza con alcance limitado.&lt;/strong&gt; Para hooks de archivo, comienza con patrones restrictivos antes de ampliarlos.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Prueba con casos límite.&lt;/strong&gt; Verifica que el hook maneje contenido inesperado o malformado sin fallar.&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Rendimiento
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Considera la frecuencia del trigger: hooks que se disparan muy seguido en archivos grandes pueden impactar tu flujo.&lt;/li&gt;
&lt;li&gt;Usa patrones de archivo precisos para evitar ejecuciones innecesarias.&lt;/li&gt;
&lt;li&gt;Para tareas determinísticas, prefiere Shell Command sobre Agent Prompt: es más rápido y no consume créditos.&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Trabajo en equipo
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Guarda las configuraciones de hooks en &lt;strong&gt;control de versiones&lt;/strong&gt; para compartirlas con todo el equipo.&lt;/li&gt;
&lt;li&gt;Documenta el propósito de cada hook y sus limitaciones conocidas.&lt;/li&gt;
&lt;li&gt;Revisa y actualiza los hooks a medida que el proyecto evoluciona.&lt;/li&gt;
&lt;li&gt;Elimina hooks que ya no sean necesarios para mantener el flujo limpio.&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Hooks + MCP: el siguiente nivel
&lt;/h2&gt;

&lt;p&gt;Los agent hooks se potencian aún más cuando se combinan con servidores &lt;strong&gt;MCP (Model Context Protocol)&lt;/strong&gt;. Al integrar MCP, los hooks pueden acceder a herramientas externas y APIs especializadas durante su ejecución.&lt;/p&gt;

&lt;p&gt;Algunos ejemplos de lo que puedes lograr:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Verificar que el código respete el design system de Figma al guardar archivos CSS o HTML&lt;/li&gt;
&lt;li&gt;Actualizar el estado de tickets en Jira o Asana cuando una tarea de spec se completa&lt;/li&gt;
&lt;li&gt;Sincronizar una base de datos a partir de archivos de muestra en el proyecto&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Para usarlos, configura los servidores MCP en Kiro y referencia sus herramientas directamente en las instrucciones del hook.&lt;/p&gt;




&lt;h2&gt;
  
  
  Próximos pasos
&lt;/h2&gt;

&lt;p&gt;Los agent hooks son una de las funcionalidades más poderosas de Kiro para eliminar trabajo repetitivo del día a día. La clave está en identificar qué tareas haces manualmente con más frecuencia y automatizarlas una a una.&lt;/p&gt;

&lt;p&gt;Un buen punto de partida: agrega un hook de &lt;strong&gt;File Save&lt;/strong&gt; sobre tus archivos fuente principales con linting automático. Con eso solo ya notarás la diferencia.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://kiro.dev/docs/hooks" rel="noopener noreferrer"&gt;Documentación de hooks&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://kiro.dev/docs/hooks/types" rel="noopener noreferrer"&gt;Tipos de trigger&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://kiro.dev/docs/hooks/actions" rel="noopener noreferrer"&gt;Acciones disponibles&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://kiro.dev/docs/hooks/examples" rel="noopener noreferrer"&gt;Ejemplos y templates&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://kiro.dev/docs/hooks/best-practices" rel="noopener noreferrer"&gt;Buenas prácticas&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>ai</category>
      <category>kiro</category>
      <category>agents</category>
    </item>
    <item>
      <title>[Boost]</title>
      <dc:creator>Antonia Navarrete</dc:creator>
      <pubDate>Tue, 28 Apr 2026 21:20:28 +0000</pubDate>
      <link>https://forem.com/antitopy/-4km0</link>
      <guid>https://forem.com/antitopy/-4km0</guid>
      <description>&lt;div class="ltag__link--embedded"&gt;
  &lt;div class="crayons-story "&gt;
  &lt;a href="https://dev.to/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf" class="crayons-story__hidden-navigation-link"&gt;Kiro Specs: Deja de Improvisar y Empieza a Planificar Features con IA&lt;/a&gt;


  &lt;div class="crayons-story__body crayons-story__body-full_post"&gt;
    &lt;div class="crayons-story__top"&gt;
      &lt;div class="crayons-story__meta"&gt;
        &lt;div class="crayons-story__author-pic"&gt;

          &lt;a href="/antitopy" class="crayons-avatar  crayons-avatar--l  "&gt;
            &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3901131%2F11efb08f-32fc-4b00-aa14-6250ff552728.jpg" alt="antitopy profile" class="crayons-avatar__image"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
        &lt;div&gt;
          &lt;div&gt;
            &lt;a href="/antitopy" class="crayons-story__secondary fw-medium m:hidden"&gt;
              Antonia Navarrete
            &lt;/a&gt;
            &lt;div class="profile-preview-card relative mb-4 s:mb-0 fw-medium hidden m:inline-block"&gt;
              
                Antonia Navarrete
                
              
              &lt;div id="story-author-preview-content-3582873" class="profile-preview-card__content crayons-dropdown branded-7 p-4 pt-0"&gt;
                &lt;div class="gap-4 grid"&gt;
                  &lt;div class="-mt-4"&gt;
                    &lt;a href="/antitopy" class="flex"&gt;
                      &lt;span class="crayons-avatar crayons-avatar--xl mr-2 shrink-0"&gt;
                        &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3901131%2F11efb08f-32fc-4b00-aa14-6250ff552728.jpg" class="crayons-avatar__image" alt=""&gt;
                      &lt;/span&gt;
                      &lt;span class="crayons-link crayons-subtitle-2 mt-5"&gt;Antonia Navarrete&lt;/span&gt;
                    &lt;/a&gt;
                  &lt;/div&gt;
                  &lt;div class="print-hidden"&gt;
                    
                      Follow
                    
                  &lt;/div&gt;
                  &lt;div class="author-preview-metadata-container"&gt;&lt;/div&gt;
                &lt;/div&gt;
              &lt;/div&gt;
            &lt;/div&gt;

          &lt;/div&gt;
          &lt;a href="https://dev.to/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf" class="crayons-story__tertiary fs-xs"&gt;&lt;time&gt;Apr 28&lt;/time&gt;&lt;span class="time-ago-indicator-initial-placeholder"&gt;&lt;/span&gt;&lt;/a&gt;
        &lt;/div&gt;
      &lt;/div&gt;

    &lt;/div&gt;

    &lt;div class="crayons-story__indention"&gt;
      &lt;h2 class="crayons-story__title crayons-story__title-full_post"&gt;
        &lt;a href="https://dev.to/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf" id="article-link-3582873"&gt;
          Kiro Specs: Deja de Improvisar y Empieza a Planificar Features con IA
        &lt;/a&gt;
      &lt;/h2&gt;
        &lt;div class="crayons-story__tags"&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/ai"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;ai&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/beginners"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;beginners&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/kiro"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;kiro&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/tutorial"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;tutorial&lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="crayons-story__bottom"&gt;
        &lt;div class="crayons-story__details"&gt;
          &lt;a href="https://dev.to/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left"&gt;
            &lt;div class="multiple_reactions_aggregate"&gt;
              &lt;span class="multiple_reactions_icons_container"&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/sparkle-heart-5f9bee3767e18deb1bb725290cb151c25234768a0e9a2bd39370c382d02920cf.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
              &lt;/span&gt;
              &lt;span class="aggregate_reactions_counter"&gt;2&lt;span class="hidden s:inline"&gt; reactions&lt;/span&gt;&lt;/span&gt;
            &lt;/div&gt;
          &lt;/a&gt;
            &lt;a href="https://dev.to/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf#comments" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left flex items-center"&gt;
              Comments


              2&lt;span class="hidden s:inline"&gt; comments&lt;/span&gt;
            &lt;/a&gt;
        &lt;/div&gt;
        &lt;div class="crayons-story__save"&gt;
          &lt;small class="crayons-story__tertiary fs-xs mr-2"&gt;
            5 min read
          &lt;/small&gt;
            
              &lt;span class="bm-initial"&gt;
                

              &lt;/span&gt;
              &lt;span class="bm-success"&gt;
                

              &lt;/span&gt;
            
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;

&lt;/div&gt;


</description>
    </item>
    <item>
      <title>Kiro Specs: Deja de Improvisar y Empieza a Planificar Features con IA</title>
      <dc:creator>Antonia Navarrete</dc:creator>
      <pubDate>Tue, 28 Apr 2026 21:15:37 +0000</pubDate>
      <link>https://forem.com/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf</link>
      <guid>https://forem.com/antitopy/kiro-specs-deja-de-improvisar-y-empieza-a-planificar-features-con-ia-41mf</guid>
      <description>&lt;p&gt;Si alguna vez arrancaste a codear una feature "porque ya sabes lo que hay que hacer" y terminaste reescribiendo todo a mitad del camino... este post es para ti.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Kiro Specs&lt;/strong&gt; es una de las funcionalidades más poderosas del IDE Kiro, y la mayoría de los devs la ignora porque suena a burocracia. Spoiler: no lo es. Es la diferencia entre vibe coding y desarrollo estructurado con IA.&lt;/p&gt;




&lt;h2&gt;
  
  
  ¿Qué es un Spec en Kiro?
&lt;/h2&gt;

&lt;p&gt;Un Spec (especificación) es un artefacto estructurado que convierte una idea de alto nivel en un plan de implementación detallado, con trazabilidad desde el requisito hasta el código.&lt;/p&gt;

&lt;p&gt;Cada vez que creas un Spec, Kiro genera automáticamente &lt;strong&gt;tres archivos&lt;/strong&gt;:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;.kiro/specs/mi-feature/
├── requirements.md   → Qué debe hacer el sistema
├── design.md         → Cómo lo va a hacer
└── tasks.md          → Lista de tareas ejecutables
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;No son documentos para guardar en un cajón. Son artefactos vivos que la IA usa para generar código coherente y trazable.&lt;/p&gt;




&lt;h2&gt;
  
  
  Los Dos Workflows: ¿Por Dónde Empiezas?
&lt;/h2&gt;

&lt;p&gt;Kiro ofrece dos flujos según tu punto de partida:&lt;/p&gt;

&lt;h3&gt;
  
  
  🔹 Requirements-First (Requisitos primero)
&lt;/h3&gt;

&lt;p&gt;El flujo más común. Lo usas cuando sabes &lt;strong&gt;qué&lt;/strong&gt; quieres construir pero el &lt;strong&gt;cómo&lt;/strong&gt; es flexible.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Requisitos → Diseño → Tareas → Código
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Cuándo usarlo:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Estás construyendo una feature desde cero&lt;/li&gt;
&lt;li&gt;El producto manda (customer feedback, historias de usuario)&lt;/li&gt;
&lt;li&gt;La arquitectura puede adaptarse a los requisitos&lt;/li&gt;
&lt;li&gt;Proyecto greenfield&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  🔹 Design-First (Diseño primero)
&lt;/h3&gt;

&lt;p&gt;Lo usas cuando ya tienes una arquitectura en mente o restricciones técnicas no negociables.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Diseño → Requisitos → Tareas → Código
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Cuándo usarlo:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Tienes un diagrama de arquitectura existente&lt;/li&gt;
&lt;li&gt;Hay requisitos no funcionales estrictos (latencia, compliance)&lt;/li&gt;
&lt;li&gt;Estás portando diseños desde otra herramienta&lt;/li&gt;
&lt;li&gt;Necesitas validar factibilidad técnica antes de comprometerte&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  La Notación EARS: Requisitos que la IA Entiende (y tú también)
&lt;/h2&gt;

&lt;p&gt;El &lt;code&gt;requirements.md&lt;/code&gt; usa &lt;strong&gt;EARS (Easy Approach to Requirements Syntax)&lt;/strong&gt;, un estándar de la industria para escribir requisitos sin ambigüedad.&lt;/p&gt;

&lt;p&gt;El patrón es simple:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;WHEN [condición o evento]
THE SYSTEM SHALL [comportamiento esperado]
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Ejemplo: Sistema de autenticación
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight markdown"&gt;&lt;code&gt;&lt;span class="gu"&gt;## Requisito 1: Registro de usuario&lt;/span&gt;
WHEN a user submits the registration form with valid email and password
THE SYSTEM SHALL create a new account and send a verification email

&lt;span class="gu"&gt;## Requisito 2: Validación de formulario&lt;/span&gt;
WHEN a user submits the registration form with an already-registered email
THE SYSTEM SHALL display an error message without creating a duplicate account

&lt;span class="gu"&gt;## Requisito 3: Bloqueo por intentos fallidos&lt;/span&gt;
WHEN a user fails to login 5 consecutive times
THE SYSTEM SHALL temporarily block the account for 15 minutes and notify the user
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;¿Por qué esto importa? Porque cada requisito en formato EARS es:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Inequívoco&lt;/strong&gt;: no hay lugar para interpretaciones&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Testeable&lt;/strong&gt;: cada uno se convierte directamente en un caso de prueba&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Trazable&lt;/strong&gt;: puedes rastrear cada línea de código hasta el requisito que la originó&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  El design.md: Arquitectura Generada Automáticamente
&lt;/h2&gt;

&lt;p&gt;Una vez confirmados los requisitos, Kiro genera el &lt;code&gt;design.md&lt;/code&gt; con:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Arquitectura del sistema y sus componentes&lt;/li&gt;
&lt;li&gt;Diagramas de secuencia&lt;/li&gt;
&lt;li&gt;Modelos de datos e interfaces&lt;/li&gt;
&lt;li&gt;Stack tecnológico recomendado&lt;/li&gt;
&lt;li&gt;Estrategia de manejo de errores&lt;/li&gt;
&lt;li&gt;Enfoque de testing&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Fragmento de ejemplo:
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight markdown"&gt;&lt;code&gt;&lt;span class="gu"&gt;## Arquitectura del Sistema de Autenticación&lt;/span&gt;

&lt;span class="gu"&gt;### Componentes&lt;/span&gt;
&lt;span class="p"&gt;-&lt;/span&gt; &lt;span class="gs"&gt;**AuthController**&lt;/span&gt;: Maneja las rutas HTTP de autenticación
&lt;span class="p"&gt;-&lt;/span&gt; &lt;span class="gs"&gt;**UserService**&lt;/span&gt;: Lógica de negocio para gestión de usuarios
&lt;span class="p"&gt;-&lt;/span&gt; &lt;span class="gs"&gt;**TokenService**&lt;/span&gt;: Generación y validación de JWT
&lt;span class="p"&gt;-&lt;/span&gt; &lt;span class="gs"&gt;**EmailService**&lt;/span&gt;: Envío de correos transaccionales

&lt;span class="gu"&gt;### Diagrama de Secuencia: Login&lt;/span&gt;

User → AuthController: POST /auth/login
AuthController → UserService: validateCredentials(email, password)
UserService → DB: findUserByEmail(email)
DB → UserService: user record
UserService → UserService: comparePassword(hash)
UserService → TokenService: generateJWT(userId)
TokenService → AuthController: { accessToken, refreshToken }
AuthController → User: 200 OK + tokens
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h2&gt;
  
  
  El tasks.md: Tu Roadmap de Implementación
&lt;/h2&gt;

&lt;p&gt;El último archivo que genera Kiro es el más concreto: una lista de tareas ejecutables, con dependencias y estado en tiempo real.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight markdown"&gt;&lt;code&gt;&lt;span class="gu"&gt;## Tareas de Implementación&lt;/span&gt;
&lt;span class="p"&gt;
-&lt;/span&gt; [ ] 1. Configurar la base de datos de usuarios
&lt;span class="p"&gt;  -&lt;/span&gt; Crear migración para tabla &lt;span class="sb"&gt;`users`&lt;/span&gt;
&lt;span class="p"&gt;  -&lt;/span&gt; Definir índices para email (unique)
&lt;span class="p"&gt;  -&lt;/span&gt; Agregar campos: id, email, password_hash, created_at, is_verified
&lt;span class="p"&gt;
-&lt;/span&gt; [ ] 2. Implementar UserService
&lt;span class="p"&gt;  -&lt;/span&gt; Método &lt;span class="sb"&gt;`createUser(email, password)`&lt;/span&gt;
&lt;span class="p"&gt;  -&lt;/span&gt; Método &lt;span class="sb"&gt;`validateCredentials(email, password)`&lt;/span&gt;
&lt;span class="p"&gt;  -&lt;/span&gt; Manejo de errores: DuplicateEmailError, InvalidCredentialsError
&lt;span class="p"&gt;
-&lt;/span&gt; [ ] 3. Implementar TokenService  
&lt;span class="p"&gt;  -&lt;/span&gt; Generación de JWT con expiración configurable
&lt;span class="p"&gt;  -&lt;/span&gt; Refresh token con rotación automática
&lt;span class="p"&gt;  -&lt;/span&gt; Blacklist para tokens revocados
&lt;span class="p"&gt;
-&lt;/span&gt; [ ] 4. Crear AuthController
&lt;span class="p"&gt;  -&lt;/span&gt; POST /auth/register
&lt;span class="p"&gt;  -&lt;/span&gt; POST /auth/login
&lt;span class="p"&gt;  -&lt;/span&gt; POST /auth/logout
&lt;span class="p"&gt;  -&lt;/span&gt; POST /auth/refresh
&lt;span class="p"&gt;
-&lt;/span&gt; [ ] 5. Tests de integración
&lt;span class="p"&gt;  -&lt;/span&gt; Happy path: registro → verificación → login
&lt;span class="p"&gt;  -&lt;/span&gt; Error cases: email duplicado, credenciales inválidas
&lt;span class="p"&gt;  -&lt;/span&gt; Rate limiting: 5 intentos fallidos → bloqueo
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Puedes ejecutar cada tarea individualmente o todas a la vez. Kiro actualiza el estado en tiempo real mientras implementa.&lt;/p&gt;




&lt;h2&gt;
  
  
  Flujo Completo: Del Prompt al Código
&lt;/h2&gt;

&lt;p&gt;Así se ve el proceso desde cero:&lt;/p&gt;

&lt;h3&gt;
  
  
  Paso 1: Crear el Spec
&lt;/h3&gt;

&lt;p&gt;En el panel de Kiro, haz clic en &lt;code&gt;+&lt;/code&gt; bajo la sección &lt;strong&gt;Specs&lt;/strong&gt;, o escribe en el chat:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Spec: sistema de autenticación con registro por email,
login, logout y reset de contraseña. Debe proteger
contra fuerza bruta y validar formatos de email.
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Paso 2: Elegir el workflow
&lt;/h3&gt;

&lt;p&gt;Kiro te pregunta: ¿Feature o Bug fix? Selecciona &lt;strong&gt;Feature&lt;/strong&gt;, luego elige &lt;strong&gt;Requirements-First&lt;/strong&gt;.&lt;/p&gt;

&lt;h3&gt;
  
  
  Paso 3: Iterar sobre requisitos
&lt;/h3&gt;

&lt;p&gt;Kiro genera el primer borrador de &lt;code&gt;requirements.md&lt;/code&gt;. Puedes refinarlo:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Agrega un requisito para que el sistema soporte 
autenticación con Google OAuth como alternativa
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Paso 4: Revisar el diseño
&lt;/h3&gt;

&lt;p&gt;Kiro genera &lt;code&gt;design.md&lt;/code&gt;. Aquí validas que la arquitectura sea correcta antes de que empiece a generar código. Puedes pedir cambios:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Cambia el storage de sesiones de memoria a Redis
para soportar múltiples instancias del servidor
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Paso 5: Ejecutar tareas
&lt;/h3&gt;

&lt;p&gt;Una vez aprobado el diseño, abres &lt;code&gt;tasks.md&lt;/code&gt; y ejecutas las tareas. Kiro implementa, y tú revisas.&lt;/p&gt;




&lt;h2&gt;
  
  
  Cuándo Usar Specs vs. Vibe Coding
&lt;/h2&gt;

&lt;p&gt;No siempre necesitas un Spec. Aquí la guía rápida:&lt;/p&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Situación&lt;/th&gt;
&lt;th&gt;Usa&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;Feature compleja con múltiples componentes&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Specs&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Bug donde las regresiones son costosas&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Specs&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Necesitas documentación para el equipo&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Specs&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Prototipo rápido sin objetivos claros&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Vibe&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Exploración técnica sin entregables&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Vibe&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Cambio menor de una sola línea&lt;/td&gt;
&lt;td&gt;&lt;strong&gt;Vibe&lt;/strong&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;




&lt;h2&gt;
  
  
  Tips para Sacarle el Máximo
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;1. Itera en los requisitos ANTES de pasar al diseño.&lt;/strong&gt; El poder de Requirements-First está en definir bien el "qué" antes de comprometerte con el "cómo".&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2. Importa requisitos existentes.&lt;/strong&gt; Si tienes un PRD en Confluence o tickets en Jira, puedes copiar el contenido a un archivo y pedirle a Kiro que genere el Spec desde él:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight markdown"&gt;&lt;code&gt;&lt;span class="gh"&gt;#mi-prd.md Genera un spec a partir de este documento&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;3. Usa imágenes de arquitectura.&lt;/strong&gt; Si tienes un diagrama en draw.io o una foto de la pizarra, puedes incluirlo en tu prompt al usar Design-First. Kiro lo interpreta.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;4. Los Specs son vivos.&lt;/strong&gt; Si cambian los requisitos, no empieces de cero: edita &lt;code&gt;requirements.md&lt;/code&gt; y haz clic en &lt;strong&gt;Refine&lt;/strong&gt; en el &lt;code&gt;design.md&lt;/code&gt;. Kiro actualiza todo en cascada.&lt;/p&gt;




&lt;h2&gt;
  
  
  Conclusión
&lt;/h2&gt;

&lt;p&gt;Los Specs de Kiro no son burocracia: son la forma de hacer que la IA trabaje de manera &lt;strong&gt;predecible y trazable&lt;/strong&gt; en features complejas. En lugar de tener un agente que improvisa, tienes uno que sigue un plan que tú aprobaste.&lt;/p&gt;

&lt;p&gt;La próxima vez que vayas a arrancar una feature no trivial, antes de escribir la primera línea de código, prueba crear un Spec. El tiempo que "perdés" planificando te lo devuelve duplicado en debugging evitado.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;¿Te resultó útil? En el próximo post voy a cubrir **Hooks&lt;/em&gt;&lt;em&gt;: cómo automatizar tareas repetitivas con triggers inteligentes en Kiro.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>ai</category>
      <category>beginners</category>
      <category>kiro</category>
      <category>tutorial</category>
    </item>
  </channel>
</rss>
