0.1.2 • Published 1 year ago

md-links-aemunozp v0.1.2

Weekly downloads
-
License
ISC
Repository
github
Last release
1 year ago

Markdown Links

Comando md-links-here

Índice


1. Preámbulo

Markdown es un lenguaje de marcado ligero muy popular entre developers. Es usado en muchísimas plataformas que manejan texto plano (GitHub, foros, blogs, ...) y es muy común encontrar varios archivos en ese formato en cualquier tipo de repositorio (empezando por el tradicional README.md).

Estos archivos Markdown normalmente contienen links (vínculos/ligas) que muchas veces están rotos o ya no son válidos y eso perjudica mucho el valor de la información que se quiere compartir.

Dentro de una comunidad de código abierto, nos han propuesto crear una herramienta usando Node.js, que lea y analice archivos en formato Markdown, para verificar los links que contengan y reportar algunas estadísticas.

2. Instalacion

Instale con una dependicia de desarrollo a su proyecto

npm i md-links-aemunozp

Ahora deberia poder ejecurtarlo con # md-Links-here y mostrara una breve descripción de isntrucciones.

$ md-links-here 
Welcome!
Here are the instructions to use md-Links-here
  1-If you want only links information like href,text,file put only the path.
  2-If you want information and validation of links such as href, text, file, status put path and the --validate command.
  3-If you want to know the total and unique links put the command --stats.
  4-If you want to know the total, single links and broken links put the command --validate --stats.

3. Uso

Despues de instalar globalmente el comando podra utilizar los siguientes comandos:

md-Links-here [path][options]
md-Links-here 
md-Links-here --validate
md-Links-here --stats
md-Links-here --validate stats

4. Ejemplos

Si desea saber que links estan en sus archivos, ingrese la ruta de su archivo o directorio :Por ejemplo:"C:/Users/Estefania/Desktop/mdLinks/DEV003-md-links/prueba.md"

Informacion de los links como href,text y file.

$ md-links-here prueba.md
href:https://developer.mozilla.org/es/docs/Learn/JavaScript/Building_blocks/ Functions
text:Funciones — bloques de código reutilizables - MDN
file:C:\Users\Estefania\Desktop\mdLinks\DEV003-md-links\prueba.md
--

Informacion de los links como href,text, file, status,message usar --validate.

$ md-links-here prueba.md --validate
href:https://developer.mozilla.org/es/docs/Learn/JavaScript/Building_blocks/ Functions
text:Funciones — bloques de código reutilizables - MDN
file:C:\Users\Estefania\Desktop\mdLinks\DEV003-md-links\prueba.md
status:404
message:Fail
--

Estadísticas de los links como total y unicos usar --stats.

$ md-links-here prueba.md --stats
Total: 1
Unique: 1

Validar y estadisticas de los links rotos usar --validate --stats.

$ md-links-here prueba.md --validate --stats
Total: 1
Unique: 1
Broken: 1

Explicacion tecnica

1) JavaScript API

El módulo debe poder importarse en otros scripts de Node.js y debe ofrecer la siguiente interfaz:

mdLinks(path, options)

Argumentos
  • path: Ruta absoluta o relativa al archivo o directorio. Si la ruta pasada es relativa, debe resolverse como relativa al directorio desde donde se invoca node - current working directory).
  • options: Un objeto con únicamente la siguiente propiedad:
    • validate: Booleano que determina si se desea validar los links encontrados.
Valor de retorno

La función debe retornar una promesa (Promise) que resuelva a un arreglo (Array) de objetos (Object), donde cada objeto representa un link y contiene las siguientes propiedades

Con validate:false :

  • href: URL encontrada.
  • text: Texto que aparecía dentro del link (<a>).
  • file: Ruta del archivo donde se encontró el link.

Con validate:true :

  • href: URL encontrada.
  • text: Texto que aparecía dentro del link (<a>).
  • file: Ruta del archivo donde se encontró el link.
  • status: Código de respuesta HTTP.
  • ok: Mensaje fail en caso de fallo u ok en caso de éxito.

Ejemplo (resultados como comentarios)

const mdLinks = require("md-links");

mdLinks("./some/example.md")
  .then(links => {
    // => [{ href, text, file }, ...]
  })
  .catch(console.error);

mdLinks("./some/example.md", { validate: true })
  .then(links => {
    // => [{ href, text, file, status, ok }, ...]
  })
  .catch(console.error);

mdLinks("./some/dir")
  .then(links => {
    // => [{ href, text, file }, ...]
  })
  .catch(console.error);

2) CLI (Command Line Interface - Interfaz de Línea de Comando)

El ejecutable de nuestra aplicación debe poder ejecutarse de la siguiente manera a través de la terminal:

md-links <path-to-file> [options]

Por ejemplo:

$ md-links ./some/example.md
./some/example.md http://algo.com/2/3/ Link a algo
./some/example.md https://otra-cosa.net/algun-doc.html algún doc
./some/example.md http://google.com/ Google

El comportamiento por defecto no debe validar si las URLs responden ok o no, solo debe identificar el archivo markdown (a partir de la ruta que recibe como argumento), analizar el archivo Markdown e imprimir los links que vaya encontrando, junto con la ruta del archivo donde aparece y el texto que hay dentro del link (truncado a 50 caracteres).

Options

--validate

Si pasamos la opción --validate, el módulo debe hacer una petición HTTP para averiguar si el link funciona o no. Si el link resulta en una redirección a una URL que responde ok, entonces consideraremos el link como ok.

Por ejemplo:

$ md-links ./some/example.md --validate
./some/example.md http://algo.com/2/3/ ok 200 Link a algo
./some/example.md https://otra-cosa.net/algun-doc.html fail 404 algún doc
./some/example.md http://google.com/ ok 301 Google

Vemos que el output en este caso incluye la palabra ok o fail después de la URL, así como el status de la respuesta recibida a la petición HTTP a dicha URL.

--stats

Si pasamos la opción --stats el output (salida) será un texto con estadísticas básicas sobre los links.

$ md-links ./some/example.md --stats
Total: 3
Unique: 3

También podemos combinar --stats y --validate para obtener estadísticas que necesiten de los resultados de la validación.

$ md-links ./some/example.md --stats --validate
Total: 3
Unique: 3
Broken: 1

6. Checklist

General

  • [] Puede instalarse via npm install --global <github-user>/md-links

README.md

  • Un board con el backlog para la implementación de la librería.
  • Documentación técnica de la librería.
  • Guía de uso e instalación de la librería

API mdLinks(path, opts)

  • El módulo exporta una función con la interfaz (API) esperada.
  • Implementa soporte para archivo individual
  • Implementa soporte para directorios
  • Implementa options.validate

CLI

  • Expone ejecutable md-links en el path (configurado en package.json)
  • [] Se ejecuta sin errores / output esperado
  • Implementa --validate
  • Implementa --stats

Pruebas / tests

  • Pruebas unitarias cubren un mínimo del 70% de statements, functions, lines, y branches.
  • Pasa tests (y linters) (npm test).
0.1.2

1 year ago

1.1.2

1 year ago

1.1.1

1 year ago

1.1.0

1 year ago

0.1.0

1 year ago