Al planificar la arquitectura para una aplicación web MVC de mediana y gran escala, ¿cómo implementa las capas para que estén tan desacopladas como sea posible y fáciles de probar? (básicamente siga las mejores prácticas) Digamos que estoy usando el código primero como mi acceso a datos.
Lucho con qué definir como "lógica de negocios" y cómo se supone que interactúa con la capa de datos. Tomando una aplicación de venta de vehículos como ejemplo, ¿sería la lógica de negocios clases que realizaran tareas como calcular la banda de impuestos para vehículos dados, comparar estadísticas de millas por galón, etc.? En cuanto a las entidades comerciales (por ejemplo, automóviles, furgonetas, motocicletas), las incluiría en la capa de datos junto con mi DataContext
clase.
Además, ¿qué constituiría la lógica de la aplicación en lugar de la empresa? Supongo que cosas como validaciones de entrada de sesión / usuario?
Entonces, por ejemplo, un controlador de automóvil podría devolver un resultado de acción / vista que enumera los diez automóviles principales filtrados por tipo y mejor mpg. Entonces, digamos que tengo un ICarRepository
'carRepo' inyectado en mi controlador (usando el patrón de repositorio / DI), filtro mis autos desde un parámetro del método de acción, por ejemplovar cars = carRepo.getCarsByType("hatchback");
Así que mantuve el conocimiento de acceso a datos fuera de mi controlador usando un repositorio, ahora para mantener la lógica de negocios fuera del controlador usando un modelo de dominio - var result = new MpgCalculator (cars); - Digamos que necesito la clase de calculadora porque necesita realizar una lógica adicional para calcular la mejor eficiencia de combustible, más que solo cargar / filtrar entidades del DB. Entonces, ahora tengo un conjunto de datos para mi vista que representa que utilizó un repositorio para recuperar de la capa de acceso a datos y un objeto específico de dominio para procesar y realizar tareas relacionadas con el negocio en esos datos.
¿Estoy cometiendo errores aquí? ¿todavía necesitamos usar el patrón de repositorio o puedo simplemente codificar contra una interfaz para desacoplar el ORM y probar? Sobre este tema, dado que mis clases concretas de acceso a datos dbcontext están en la capa de datos, ¿deberían las definiciones de interfaz entrar en la capa de dominio / negocio, lo que significa que si la tecnología de acceso a datos cambia alguna vez, mis otras capas no se verán afectadas?
Por lo que he estudiado hasta ahora, mi estructura se ve así:
Aplicación de Internet MVC -> El proyecto estándar de Internet - los modelos aquí son ViewModels
Capa de dominio / negocio -> clases / modelos específicos de negocio que los controladores pueden usar para procesar entidades de dominio desde la capa de datos antes de pasar a las vistas relevantes
¿Es necesaria la abstracción del repositorio? -> Escucho mucho debate sobre esto, especialmente cuando uso un ORM
Capa de datos -> Clases de entidad (automóvil, furgoneta, motocicleta), DbContext - Capa de tecnología de acceso a datos concretos