<?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>DEV Community: haskdev</title>
    <description>The latest articles on DEV Community by haskdev (@williamdelaespriella).</description>
    <link>https://dev.to/williamdelaespriella</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%2F634686%2Ff10d551a-58b9-47d2-bc1a-52c728f21c9e.jpeg</url>
      <title>DEV Community: haskdev</title>
      <link>https://dev.to/williamdelaespriella</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/williamdelaespriella"/>
    <language>en</language>
    <item>
      <title>Redoc, documentación ágil libre de dependencias</title>
      <dc:creator>haskdev</dc:creator>
      <pubDate>Thu, 21 Oct 2021 02:05:32 +0000</pubDate>
      <link>https://dev.to/williamdelaespriella/redoc-documentacion-agil-libre-de-dependencias-1jhk</link>
      <guid>https://dev.to/williamdelaespriella/redoc-documentacion-agil-libre-de-dependencias-1jhk</guid>
      <description>&lt;h2&gt;
  
  
  Resumen
&lt;/h2&gt;

&lt;p&gt;Sabemos la importancia que tiene la documentación en los sistemas de información y como desarrolladores debemos aprender a ser asertivos a la hora de hacerlo, debido a que el exceso o la falta de documentación puede llegar a ser una carga inútil para un equipo de trabajo si este no es muy maduro. &lt;br&gt;
La documentación de APIs es algo bastante poderoso y útil, que lamentablemente muy pocas veces hacemos. Si escalamos  un poco el uso de esta para analizar el impacto que tiene en los equipos de trabajo, veremos beneficios como, ayudar a los nuevos integrantes del equipo a tener una mejor transición y un mayor entendimiento de un proyecto, incluso a aquellos integrantes con más experiencia les permite recordar funcionalidades implementadas hace algún tiempo.&lt;/p&gt;
&lt;h2&gt;
  
  
  Documentar Asertivamente
&lt;/h2&gt;

&lt;p&gt;Documentar puede llegar a ser una tarea engorrosa y en la mayoría de los casos amerita implementar dependencias externas a nuestros proyectos. esto último tiende a evitarse por la preocupación de sumar cargas a la ejecución. Entonces, si sabemos que es importante documentar, pero no queremos agregar herramientas que afecten nuestro código, ¿Qué deberíamos usar?&lt;br&gt;
Swagger ofrece una solución bastante completa, basada en la especificación de Openapi, sin embargo es necesario agregar algunas dependencias, por lo que la nueva especificación Redoc es una mejor opción para lograr una documentación ágil, sin usar dependencias de terceros en tu proyecto.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Openapi:&lt;/strong&gt; es un estándar creado para describir APIs, se centra en la evolución y promoción de un formato de descripción neutral para el proveedor, basado inicialmente en la especificación de swagger.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Redoc:&lt;/strong&gt; es un software para la documentación de APIs. Conformado por una interfaz interactiva y ordenada con objetos anidados basado en un marco responsive de 3 paneles (&lt;a href="http://redocly.github.io/redoc/" rel="noopener noreferrer"&gt;ejemplo&lt;/a&gt;).&lt;/p&gt;

&lt;p&gt;En este artículo no se abordarán conceptos a profundidad, por lo que recomendamos leer antes &lt;a href="https://medium.com/condorlabs-engineering/automating-api-documentation-c8f48f2bc30e" rel="noopener noreferrer"&gt;este artículo&lt;/a&gt; bastante completo acerca del tema. Abordaremos las funcionalidades más importantes de Redoc para documentar sus APIs de manera asertiva y organizada.&lt;/p&gt;
&lt;h2&gt;
  
  
  Configuración redoc-cli
&lt;/h2&gt;

&lt;p&gt;Para usar &lt;strong&gt;Redoc&lt;/strong&gt; utilizaremos una dependencia de desarrollo llamada &lt;strong&gt;redoc-cli.&lt;/strong&gt; estas la agregamos a nuestro proyecto de la siguiente forma:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;npm install --save-dev redoc-cli
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Importante observar que usamos el flag &lt;code&gt;--save-dev&lt;/code&gt; para incluirla en las dependencias de desarrollo. Además, para su configuración explicaremos los sientes flags, que nos permitirán usar redoc-cli para generar nuestra documentación.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;bundler:&lt;/strong&gt; permite crear un archivo html con la documentación para su posterior renderización desde el servidor, sin necesidad de dependencias.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;serve:&lt;/strong&gt; permite ejecutar un servidor local que te permita visualizar los cambios locales en tu documentación.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;--watch:&lt;/strong&gt; permite reiniciar automáticamente la aplicación cuando se detectan cambios de archivo en el yml.&lt;/li&gt;
&lt;/ul&gt;

&lt;blockquote&gt;
&lt;p&gt;Para conocer más flags que puede utilizar en &lt;strong&gt;redoc-cli&lt;/strong&gt; mirar esta &lt;a href="https://github.com/Redocly/redoc/blob/master/cli/README.md" rel="noopener noreferrer"&gt;doc&lt;/a&gt;.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Para iniciar con nuestro ejemplo este &lt;a href="https://github.com/WilliamDeLaEspriella/redoc-todo-list/tree/template!" rel="noopener noreferrer"&gt;repositorio&lt;/a&gt; se ha preparado para ti. En él tendremos un template para trabajar todo el ejemplo. Ahora, para poder empezar necesitamos agregar los scripts que nos permitirán ejecutar nuestra documentación en local y también crear un bundler para producción. Usando los flags que ya se explicaron arriba a la parte de script de su package.json. Agregamos a este las siguientes instrucciones:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fpln2em2t9it96q0uflna.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fpln2em2t9it96q0uflna.png" alt="redoc cofiguration in package json"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Usamos &lt;strong&gt;concurrently&lt;/strong&gt; para ejecutar dos instrucciones importantes de forma simultanea; la primera nos permite ejecutar nuestra documentación y visualizar los cambios de manera local, la segunda nos ayuda a actualizar nuestro bundler localizado en index.html de esta manera podremos visualizar nuestra documentación usando el comando &lt;code&gt;npm start&lt;/code&gt;.&lt;/p&gt;
&lt;h2&gt;
  
  
  Configuración inicial
&lt;/h2&gt;

&lt;p&gt;Para agregar las configuraciones y datos de nuestra documentación usaremos &lt;strong&gt;un archivo openapi.yml que colocaremos en una carpeta llamada docs&lt;/strong&gt;, el cual podemos visualizar en las ejecuciones de los comandos mostrados en la parte de arriba. Dentro este archivo colocamos una configuración básica de openapi que explicaremos posteriormente.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fjknago5nd83iwd9gp145.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fjknago5nd83iwd9gp145.png" alt="redoc basic configuration"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ejecute &lt;strong&gt;npm run docs&lt;/strong&gt; en su consola situada en la raíz de tu proyecto. Luego entre a su navegador en la ruta &lt;code&gt;http://localhost:8080&lt;/code&gt;.  deberías ver una pantalla como esta:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fg6oa0hd12k6fapi55wdm.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fg6oa0hd12k6fapi55wdm.png" alt="redoc pages"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Si usted no tiene el mismo resultado puede usar el código mostrado &lt;a href="https://github.com/WilliamDeLaEspriella/redoc-todo-list/tree/basic-configuration" rel="noopener noreferrer"&gt;aquí&lt;/a&gt;.&lt;/p&gt;
&lt;/blockquote&gt;
&lt;h2&gt;
  
  
  Documentando nuestra API
&lt;/h2&gt;

&lt;p&gt;Cualquier configuración de openapi consta de ciertos  ítems que nos permitirán agregar un tipo de información especifica a nuestra documentación.&lt;br&gt;
Primero empezamos explicando cada uno de los  ítems que nos ofrece la especificación de openapi para construir paso a paso la documentación de nuestra API.&lt;br&gt;
&lt;strong&gt;Open api version:&lt;/strong&gt; Aquí colocaremos la versión de openapi con la que se va a trabajar. Como pudimos ver en el ejemplo, usaremos la versión 3.&lt;br&gt;
&lt;strong&gt;&lt;a href="https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#infoObject" rel="noopener noreferrer"&gt;Info&lt;/a&gt;: Esta etiqueta sirve par colocar un objeto con toda la información relevante de la documentación&lt;/strong&gt; como título, logo, descripción, etc. En nuestro archivo la configuraremos de la siguiente forma.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fx82b7nd6nco10ei4ocus.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fx82b7nd6nco10ei4ocus.png" alt="info configuration redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Servers: Aquí agruparemos los dominios que posea nuestra API.&lt;/strong&gt; es bien sabido que dentro de algunos equipos de trabajo la construcción de una API puede ser manipulada desde diferentes entornos como test, staging, demo o producción. En esta sección colocaremos todos esos puntos de acceso a nuestro servidor.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fggeiac0sef6s6qzyhtbu.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fggeiac0sef6s6qzyhtbu.png" alt="servers configuration redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Security:&lt;/strong&gt; Lista de valores que incluyen objetos con requisitos de seguridad alternativos. Solo se debe satisfacer uno de los objetos de requisito de seguridad para autorizar una solicitud. &lt;br&gt;
Para el ejemplo usaremos 3 tipos de autenticación: basic, Jwt y api key. &lt;strong&gt;Para más información de como implementar autenticación visite este &lt;a href="https://swagger.io/docs/specification/authentication/" rel="noopener noreferrer"&gt;enlace&lt;/a&gt;&lt;/strong&gt;. Nuestro ejemplo quedaría de esta manera:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7jactxyp1c5r828o3mol.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7jactxyp1c5r828o3mol.png" alt="Authentication define for redoc and openapi"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Tags: Con ayuda de los tags podremos agrupar endpoints de una manera más visual en su documentación.&lt;/strong&gt; para nuestro ejemplo usaremos dos,  tag1 y tag2, solo para lograr una mayor visualización de su funcionamiento. se colocan de esta manera:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ft9ni97mq2v5kjshnexjw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ft9ni97mq2v5kjshnexjw.png" alt="Tags Configuration for openapi and redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;a href="https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#componentsObject" rel="noopener noreferrer"&gt;Components&lt;/a&gt;:&lt;/strong&gt; Esta sección nos sirve para hacer una abstracción de los schemas, responses, parameters, etc. que se usan principalmente en la sección de &lt;strong&gt;path.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Usando este enfoque podemos lograr un código más organizado y reutilizable. Para nuestro ejemplo crearemos las especificaciones para los componentes de seguridad mencionados en la anterior sección utilizando la etiqueta securitySchemes, además crearemos unos schemas y responses que se usarán en el path de la siguiente sección.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Consulte &lt;a href="https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#schema-object" rel="noopener noreferrer"&gt;aquí&lt;/a&gt; para más validaciones en los schemas&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fh25ryw4cmsjqnkl4gqbk.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fh25ryw4cmsjqnkl4gqbk.png" alt="Example configuration components in redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;a href="https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#pathsObject" rel="noopener noreferrer"&gt;Paths&lt;/a&gt;: En esta sección documentaremos los endpoint de nuestra API y los tipos de consultas que se harán en estos&lt;/strong&gt;, incluyendo todos los datos internos que posee un endpoint como las diferentes respuestas o cuántos y dónde se reciben los parámetros.&lt;br&gt;
Debido a que esta sección define las características del endpoint es bastante importante llamar a estos desde la etiqueta components y &lt;strong&gt;no declarar los schemas y parámetros en el mismo path.&lt;/strong&gt; de esta manera logrará tener un archivo de documentación más organizado.&lt;br&gt;
Para nuestro ejemplo definimos una ruta /todo_list, con dos tipos de consulta, un get y un post. Usando los componentes que definimos en la anterior sección podemos crear la definición de la siguiente manera:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F41e18f7qeygocnbakz6l.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F41e18f7qeygocnbakz6l.png" alt="configuration path in redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Llegado este punto podemos ejecutar el servidor y visualizar todas las configuraciones, ya sea ejecutando el &lt;code&gt;npm run docs&lt;/code&gt; para lanzar &lt;strong&gt;redoc-cli&lt;/strong&gt; o de la misma manera ya ejecutar el servidor con &lt;code&gt;npm start&lt;/code&gt;. Debería ver una imagen como esta:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fikab0s4iah2fnfytyztz.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fikab0s4iah2fnfytyztz.png" alt="dashboard redoc"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Si por alguna razón no puede visualizar los cambios, ejecute nuevamente &lt;strong&gt;npm run docs&lt;/strong&gt; o verifique que tenga todo de la manera correcta en este &lt;a href="https://github.com/WilliamDeLaEspriella/redoc-todo-list/tree/avanzada-configuration" rel="noopener noreferrer"&gt;link&lt;/a&gt;.&lt;/p&gt;
&lt;h2&gt;
  
  
  Refactorizando sus yml
&lt;/h2&gt;

&lt;p&gt;Para este ejemplo se definió una sola ruta para documentar con dos tipos de consulta, pero &lt;strong&gt;debe tener en cuenta que las APIs o servidores pueden contar con decenas de rutas y estas tener diferentes tipos de consulta.&lt;/strong&gt; La etiqueta &lt;strong&gt;components&lt;/strong&gt; le puede ayudar a agrupar configuraciones en común, pero aún le puede quedar una archivo bastante extenso y difícil de actualizar muchas veces. Una solución a esto es dividir el código en archivos más pequeños y luego referenciarlos en el archivo principal. La forma en la que referenciarmos en yml es:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;$ref: [ruta]#/[components]
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ejemplo:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;$ref: ../componets/schemas.yml#/tolistResponse
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;&lt;a href="https://github.com/WilliamDeLaEspriella/redoc-todo-list/tree/refactor-code" rel="noopener noreferrer"&gt;Aquí&lt;/a&gt;&lt;/strong&gt; puede visualizar todo el proyecto ya refactorizado y organizado en módulos, de manera que todo el código es más legible y organizado.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conclusiones
&lt;/h2&gt;

&lt;p&gt;Para el contexto del ejemplo usamos una app básica en node que permite renderizar un único archivo html para visualizar los beneficios de documentar APIs con &lt;strong&gt;Redoc&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;En este post pudimos visualizar:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Lo fácil que es documentar las especificaciones de nuestra API usando un lenguaje clave-valor como yaml.&lt;/li&gt;
&lt;li&gt;Los beneficios que nos trae usar las características definidas por openapi.&lt;/li&gt;
&lt;li&gt;El poder que nos da redoc-cli al permitirnos ejecutar y crear un bundler de nuestra documentación de manera ágil.&lt;/li&gt;
&lt;li&gt;La facilidad de poder tener las especificaciones de su documentación en un solo html y libre de dependencias extra para su proyecto.&lt;/li&gt;
&lt;li&gt;Los beneficios de que el resultado del bundler sea un html, es que se puede visualizar en casi cualquier entorno o framework que soporte este formato.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Es importante otorgar el tiempo y la importancia que necesita el proceso de documentación de APIs en nuestro equipo. Debemos apropiarnos del impacto que este posee para un proceso de desarrollo de software mas saludable.&lt;/p&gt;

</description>
      <category>redoc</category>
      <category>javascript</category>
      <category>node</category>
      <category>spanish</category>
    </item>
  </channel>
</rss>
