You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Hasta ahora hemos hablado de las opiniones de un framework, pero estas suelen ser bypasseadas cuando se aplica arquitectura limpia. Poco importa que tu framework incluya un contrato para el envío de notificaciones si tu capa aplicación no depende de él y por lo tanto no lo puede utilizar directamente. Poco importa la forma en la que el framework valide los datos de entrada si tu capa de aplicación va a hacerlo de otra forma diferente.
Cuando se aplica arquitectura limpia, en las capas de aplicación y dominio se proporcionan una serie de interfaces que luego desde la capa de infraestructura llamarán a los servicios del framework.
Veamos esto con un ejemplo.
Creamos un caso de uso que se encarga crear un cliente, guardarlo en un medio de persistencia y luego enviar un correo electrónico a este cliente.
Como se puede observar, estos métodos estáticos son simples fachadas hacía una interfaz que proveé nuestra aplicación, pero que tendrá que ser implementada en la capa de aplicación utilizando el mecanismo que el framework provea. Ahora pongamos como ejemplo la implementación de la interfaz IEmailSender en la capa de infraestructura utilizando un framework que proveé su contrato para enviar emails e inyección de dependencias como forma de resolverlos.
Generalmente porque este enfoque permite adaptar estos servicios al dominio concreto de la aplicación. Es posible que un email no sea exactamente lo mismo en un tipo de aplicación que en otro ni tampoco las operaciones sobre el mismo.
¿Qué problema hay con esto?
El principal problema de este enfoque es que requiere un aburrido y repetitivo trabajo de escribir una serie de interfaces y valueobjects/estructuras (como la clase Email en este caso) similares por cada proyecto que se inicie.
Conclusión
En mi opinión esa flexibilidad no componsa ya que un email en casi cualquier aplicación será un mensaje compuesto de texto plano y/o HTML, una dirección de origen, una de destino, direcciones en copia y copia oculta y archivos adjuntos.
Esto supone repetir las clases e interfaces para cada uno de los proyectos que inicias, tarea que puede ser especialmente pesada, sobretodo para aquellas clases que tienen que mantener sus invariantes.
En el supuesto caso de que tu aplicación muy especifica entienda otra cosa por email, siempre puedes crear tu clase de dominio y obviar la clase proporcionada.
IOKode.OpinionatedFramework
Yo tengo una opinión de como debería de ser un proyecto de dominio y aplicación y he querido hacer un framework que la reespalde. Este dispone de una librería de validación, un contenedor de dependencias para la capa de dominio aislado del contenedor de Microsoft, una serie de contratos para servicios comunes así como fachadas para acceder directamente a ellos.
El framework está aún en fase muy temprano de desarrollo y por lo tanto aún no está disponible en NuGet, pero el repositorio de desarrollo es público en GitHub.
archEntrada relacionada con la arquitectura de softwareopiniónEntrada que contiene una opinión personal
1 participant
Heading
Bold
Italic
Quote
Code
Link
Numbered list
Unordered list
Task list
Attach files
Mention
Reference
Menu
reacted with thumbs up emoji reacted with thumbs down emoji reacted with laugh emoji reacted with hooray emoji reacted with confused emoji reacted with heart emoji reacted with rocket emoji reacted with eyes emoji
-
Esta entrada forma parte de una serie:
Hasta ahora hemos hablado de las opiniones de un framework, pero estas suelen ser bypasseadas cuando se aplica arquitectura limpia. Poco importa que tu framework incluya un contrato para el envío de notificaciones si tu capa aplicación no depende de él y por lo tanto no lo puede utilizar directamente. Poco importa la forma en la que el framework valide los datos de entrada si tu capa de aplicación va a hacerlo de otra forma diferente.
Cuando se aplica arquitectura limpia, en las capas de aplicación y dominio se proporcionan una serie de interfaces que luego desde la capa de infraestructura llamarán a los servicios del framework.
Veamos esto con un ejemplo.
Creamos un caso de uso que se encarga crear un cliente, guardarlo en un medio de persistencia y luego enviar un correo electrónico a este cliente.
Ahora véamos que es lo que hacen los métodos
Save
ySend
:Como se puede observar, estos métodos estáticos son simples fachadas hacía una interfaz que proveé nuestra aplicación, pero que tendrá que ser implementada en la capa de aplicación utilizando el mecanismo que el framework provea. Ahora pongamos como ejemplo la implementación de la interfaz IEmailSender en la capa de infraestructura utilizando un framework que proveé su contrato para enviar emails e inyección de dependencias como forma de resolverlos.
¿Por qué no se usan unas interfaces comunes?
Generalmente porque este enfoque permite adaptar estos servicios al dominio concreto de la aplicación. Es posible que un email no sea exactamente lo mismo en un tipo de aplicación que en otro ni tampoco las operaciones sobre el mismo.
¿Qué problema hay con esto?
El principal problema de este enfoque es que requiere un aburrido y repetitivo trabajo de escribir una serie de interfaces y valueobjects/estructuras (como la clase Email en este caso) similares por cada proyecto que se inicie.
Conclusión
En mi opinión esa flexibilidad no componsa ya que un email en casi cualquier aplicación será un mensaje compuesto de texto plano y/o HTML, una dirección de origen, una de destino, direcciones en copia y copia oculta y archivos adjuntos.
Esto supone repetir las clases e interfaces para cada uno de los proyectos que inicias, tarea que puede ser especialmente pesada, sobretodo para aquellas clases que tienen que mantener sus invariantes.
En el supuesto caso de que tu aplicación muy especifica entienda otra cosa por email, siempre puedes crear tu clase de dominio y obviar la clase proporcionada.
IOKode.OpinionatedFramework
Yo tengo una opinión de como debería de ser un proyecto de dominio y aplicación y he querido hacer un framework que la reespalde. Este dispone de una librería de validación, un contenedor de dependencias para la capa de dominio aislado del contenedor de Microsoft, una serie de contratos para servicios comunes así como fachadas para acceder directamente a ellos.
El framework está aún en fase muy temprano de desarrollo y por lo tanto aún no está disponible en NuGet, pero el repositorio de desarrollo es público en GitHub.
OpenSoruce y licencia abierta
El código fuente está disponible en GitHub y la licencia es BSD de 2 cláusulas, lo que permite su uso ilimitado en proyectos tanto cerrados como abiertos.
¿Quieres colaborar?
OpinionatedFramework es un proyecto open source alojado en GitHub. Si quieres colaborar en el desarrollo, puedes enviar una pull request.
Beta Was this translation helpful? Give feedback.
All reactions