En este cuarto artículo de Spectral aprenderemos a implementar la herramienta como una guía de estilos de APIs con diferentes enfoques.
A modo de recordatorio pongo los enlaces a los artículos :
- Primeros pasos con Spectral (Parte 1) : Artículo de introducción a la herramienta Spectral que hace uso de diferentes ejemplos y que explica diferentes enfoques de diseño.
- Primeros pasos con Spectral (Parte 2): Implementar una Regla Custom: Artículo que enseñará la forma de crear una regla customizada y usarla mediante una propuesta de procedimiento sobre la forma de hacerse.
- Primeros pasos con Spectral (Parte 3): Desarrollando APIs: Artículo que enseñará a como enfocar Spectral al desarrollo de APIs.
Este es el índice que se va a utilizar para estructurar este artículo
- Spectral para implementar Guías de Estilo para APIs
- Guías de Estilo de Desarrollo de las Empresas
- Ejemplo de Uso
- Conclusiones
Spectral para implementar Guías de Estilo para APIs
Disponer de una guía de estilo para el diseño / desarrollo de APIs dentro de una compañía permite que se diseñen las API de forma estándar, normalizada, homogénea y con aplicación de buenas prácticas. Hay que tener en cuenta que todo lo anterior se corresponde con la forma de hacerlo dentro de esa compañía en particular, de esta forma las APIs adquirirán cierta calidad y seguridad a la hora de desarrollar cualquier funcionalidad.
Ayuda
Se conseja volver a leer lo explicado en el tercer artículo:
- Primeros pasos con Spectral (Parte 3): Desarrollando APIs: Artículo que enseñará a como enfocar Spectral al desarrollo de APIs.
En este tipo de documentación se suelen explicar muchas cosas:
- Relaciones entre recursos
- Tipos de endpoints: recursos y/o funcionalidad
- Nomenclatura
- Uso de verbos HTTP
- Códigos de estado
- Uso de paginación
- Uso de internacionalización
- Gestión de errores
- Cabeceras
- Versionado
- Respuestas
- Testing
- Seguridad
- Documentación
- …
Importante: Hay que tener en cuenta que sobre cada uno de los puntos anteriores se pueden trabajar sus propias buenas prácticas.
Conjuntos de Reglas Corporativas y sus enfoques
Importante
Este apartado aplica sobre cualquier guía de estilo que se quiera desarrollar, aunque posteriormente en el ejemplo lo aplicaremos sobre una guía de estilo de APIs
Asi que antentos a apartado de enfoques
Disponer de conjuntos de reglas corporativos adaptados a las guías de estilos es uno de los aspectos que hace que una compañía se diferencie de otra aun haciendo lo mismo.
Esto significa varias cosas:
- Se tiene claro que se quiere
- Se tiene claro que se tiene
- Se tiene claro que NO se permite
Aprovechando la características de personalización de reglas de Spectral podremos implementar su definición y uso de forma particular.
Se pueden establecer diferentes enfoques:
- Enfoque de implementación de las reglas
- Enfoque del ámbito del conjunto de reglas específico
- Enfoque de definir un conjunto de reglas base
- Enfoque de distribución de las reglas
Enfoque de implementación de las reglas
Existen diferentes maneras sobre la forma de implementar una regla
- "single-file": Cada regla se implementa en un fichero independiente
- Cumplimiento del patrón PSR
- El fichero debería de llevar el nombre de la regla como ayuda a localizarlo
- El fichero se podrá almacenar en una estructura definida para ello
- Global al proyecto
- Local al proyecto
- Referenciado desde el fichero de Ruleset utilizado
- "group": Se implementan varias reglas en un mismo fichero
- Agrupación por funcionalidad o contexto (Ejemplo: trabajar con https, trabajar con números, trabajar con paginación, etc.)
- El fichero debería de llevar el nombre de la funcionalidad o contexto referido
- El fichero se podrá almacenar en una estructura definida para ello
- Global al proyecto
- Local al proyecto
- Referenciado desde el fichero de Ruleset utilizado
- "ad-hoc": Cada regla se implementa de forma directa sobre el propio fichero de Ruleset
Enfoque del ámbito del conjunto de reglas específico
Existe la posibilidad de disponer diferentes conjuntos de reglas con diferentes criterios de aplicación de reglas
Por ejemplo:
- Tipología de API
- APIs de sistemas críticos
- APIs de arquitecturas Event-Driven
- APIs de sistemas legacy
- …
- Contexto de uso
- Aplicaciones legacy
- Nuevos desarrollos
- Productos
- …
- Sector sobre el que aplica
- Tecnología sobre la que aplica
- Para APIs definidas por OAS v3
- Para ficheros de configuración YAML de Spring-Boot
- …
- …
Enfoque de definir un conjunto de reglas base
Se aconseja disponer de un conjunto de reglas que sea aprobado de forma corporativa para uso dentro de la compañía.
Para ello se aconseja definir uno o varios conjuntos de reglas base que pueda aplicar de forma común a todos los proyectos tipo implicados.
Estos conjuntos de reglas requerirán un tratamiento de proyecto de desarrollo como cualquier otro, es decir, van a requerir mantenimiento, testing, versionado, documentación, formación etc.
Ventajas:
- Disponer de un mismo conjunto de reglas centralizados
- Uso total o parcial de las reglas -> Uso
- Extensión de reglas
- Activación o desactivación de reglas
- Composición de reglas
- …
- Facilita que cada uno se pueda montar su batería de reglas de validación
- Uso total o parcial de las reglas -> Uso
- Evitando que se tenga que re implementar algo 1000 veces
- Compartir su uso entre proyectos
- Todo el mundo se evaluaría por las mismas reglas
- Reducción de tiempos de desarrollo
- …
Desventajas:
- Requiere invertir recursos en este punto :
- Nunca dejará de evolucionar, por lo tanto, se trata como un proyecto orgánico
- Requiere un análisis previo para no añadir errores de inicio
- Un fallo en una de estas guías tras su implementación requerirá mucho mantenimiento correctivo
- …
Enfoque de distribución de las reglas
Existen diferentes formas de distribuir las reglas y por lo tanto, hay que te tener definido todo lo necesario para su uso.
Nota
Este es un tema tan importante que el propio fabricante proporciona un enlace de documentación
Algunas impementaciones de la distribución de reglas son:
- Proporcionar una copia del fichero de configuración y las reglas
- Proporcionar el fichero de configuración y las reglas de forma centralizada
Proporcionar una copia del fichero de configuración y las reglas
Se proporcionarán de forma sencilla los ficheros necesarios para que cada proyecto lo implemente y lo utilice como quiera.
No se podrá tener el control de quién lo utiliza y quien no.
No se podrá tener el control
Proporcionar el fichero de configuración y las reglas de forma centralizada
Se proporcionarán desde una ubicación central
Existen diferentes formas de implementarse:
- Incorporar los ficheros como funcionalidad desde una librería de arquitectura del framework de desarrollo
- Incorporar los ficheros en el arquetipo del proyecto
- Directorio de configuración: spectral/
- Fichero por defecto : .spectral.yml
- Publicar los endpoints de acceso al fichero de configuración y de reglas
- En la documentación se referencia como "HTTP Server" e indica que se puede hacer uso
Ejemplos de ficheros de Spectral
En este a partado se proporcionarán algunos ejemplos de uso
Ejemplo de fichero Ruleset con reglas base como fichero con enfoque de "extensión"
extends:
# Usar las reglas predefinidas para OpenAPI
- spectral:oas
# Extender las reglas con una regla específica definida de forma local
- ./spectral/rules/open-api-version-3.yaml
# Extender las reglas con un conjunto de reglas corporativo
- ./global/organization-rules.yaml
rules: {
operation-tags-alphabetical: false
}
Ejemplo de fichero Ruleset con reglas base como fichero con enfoque de "único uso"
extends:
# Extender las reglas con un conjunto de reglas corporativo
- ./global/organization-rules.yaml
rules: {
operation-tags-alphabetical: false
}
Ejemplo de fichero Ruleset con reglas base referenciado desde una URL
extends:
- https://raw.githubusercontent.com/vjmadrid/enmilocalfunciona-spectral/main/style-guide/spectral/rulesets/company-rules.yaml
Guías de Estilo de Desarrollo de APIs de las Empresas
Cada compañía / equipo / desarrollador tiene su propia forma de hacer las cosas y muchas veces se publican sus guías de estilo de APIs como muestra de transparencia.
Pero esto no se pueden confirmar del todo …jejeje
Recursos
Spectral proporciona un portal para ayudar con el tema de las guías de estilo
Algunos ejemplos de guías de estilo públicas son:
- OpenAPI Community Style Guide
- Collection of custom rulesets including APIs You Won’t Hate, ruleset of "super opinionated HTTP API advice".
- Nexmo
- Box
- DigitalOcean
- Azure
- Adidas
- Transcom
- Team Digitale
- Zalando
- Red HaT
Ejemplo de Uso
Para enseñar a utilizarlo y así practicar se ha habilitado un repositorio, este repositorio se reutilizará para otros artículos con Spectral.
La parte de que tiene que ver con este artículo se encuentra en el apartado de style-guide/
Conclusiones
Continuamos avanzando en nuestro conocimiento sobre Spectral y cada vez le vamos encontrando más utilidades o bien vamos complicando los casos de uso para sacarle más provecho.
A la vez que hacemos lo anterior y casi sin darnos cuentas estamos mejorando la forma de trabajar a nivel de empresa. Además, estamos consiguiendo una de las cosas más interesante que buscan las empresas … la industrialización de procesos. Estamos incluyendo entonces el proceso lintado como automatismo para diferentes casos de uso.
Además este proceso no sólo ayuda al desarrollo sino que también ayudamos a
- QA: Añadiendo una capa de validaciones extra sobre el proyecto y su desarrollo que podrá ser medido como un nuevo aspecto de calidad como puede ser la ejecución de test unitarios
- DevOps: Añadiendo una fase extra dentro del ciclo de CI/CD para evitar propagar errores en producción
Asi que seguiremos mejorando todo esto con los siguientes artículos. 😉
Continuamos dando pasitos…