Esta es una libreria de NodeJS que contiene un extractor de links, recibe una ruta de archivo en formato “.md” y retorna por medio de la consola un listado de todos los enlaces que contiene el proyecto, así como la línea del archivo donde se encuentra alojado. Además si se añade la opción de validar, puede comprobar que los enlaces están funcionando o de lo contrario están “rotos”.
Este proyecto se encuentra en su versión 2.4.0 en la cual se añadió la validación de links, por el momento estamos trabajando en una mejor implementación y más opciones de validación como obtener un promedio de links con status ok. Por el momento solo es posible analizar archivos de tipo “.md” y solo es posible ver los resultados en la consola, si el archivo no contiene links no retorna nada.
Debes tener instalado npm (sudo) npm install -g Para usarlo en la terminal (git Bash) Debes instalar de forma global las siguientes librerías con las que trabaja este markdown extractor (de forma global para que esté disponible en cualquiera de tus proyectos, de lo contrario en lugar de "-g" debes escribir "--save"):
$npm install marked -g
$npm install marked-terminal -g
$npm install chalk -g
$npm install node-fetch -g
Pasos para instalar esta librería
$npm install marielk-mdlinks -g
A continuación debes ejecutar el comando
$ mdlinks <nombre-de-tu-archivo.md>
Esto devolverá un listado con los links encontrados en tu archivo con su título y la linea de codigo donde se encuentra.
La siguiente opción es
$mdlinks <nombre-de-tu-archivo.md> -validate
Esto te devolverá lo mismo que el comando anterior además de un status de cada link, 200 si esta funcionando, y 404 si no existe el enlace.
Usa la librería como un paquete completo, instalando con npm, se guardará el fichero en la carpeta node_modules, marielk-mdlinks. Luego en tu archivo js puedes usarlo directamente con "require", ejemplo:
```
const links = require('./node_modules/marielk-mdlinks/lib/md-links').mdlinks(nombreDeTuArchivo.md, -validate);
```
CLI https://medium.freecodecamp.org/writing-command-line-applications-in-nodejs-2cf8327eee2 https://www.youtube.com/watch?v=C9xGEJ80jjs https://www.youtube.com/watch?v=oKinLQXxE38
Leer archivos https://nodejs.org/api/fs.html#fs_fs_readdir_path_options_callback https://www.w3schools.com/nodejs/nodejs_filesystem.asp https://nodejs.org/api/path.html#path_path_resolve_paths
Marked https://www.npmjs.com/package/marked-terminal https://github.com/markedjs/marked https://marked.js.org/#/USING_ADVANCED.md#options https://www.npmjs.com/package/chalk
Debug nodejs https://medium.com/@paul_irish/debugging-node-js-nightlies-with-chrome-devtools-7c4a1b95ae27
Error con el modulo de Marked-terminal Durante la ejecución del proyecto arrojó un error recurrente con la libreria de Marked, por lo que el fallo fue reportado en su cuenta de github, este Issue tuvo una respuesta positiva por parte de un miembro del equipo y fue incluido en las mejoras que se lanzaran en la próxima versión de esta librería.
La organización de este trabajo se detalla en el siguiente enlace
- Trello - Organizador de tareas
Proyecto realizado para Laboratoria Chile, proceso de Bootcamp 2018
- Mariel Quezada - Developer - Marielk
También puedes mirar el repositorio original de este proyecto Laboratoria-Markdown quíenes han creado este desafío para las estudiantes de este curso :woman: :computer:.