Para iniciar veamos cómo quedará la estructura de nuestro repositorio de MongoDB para cuando lo hayamos terminado:
Como podemos ver tiene la misma estructura que nuestro repositorio de Sql Server del artículo anterior, a diferencia que en este repo utilizamos la entidad Articulo
Ahora observemos el código de nuestro repositorio base para MongoDB
public class BaseRepository<T> where T : class { private readonly string _nombreColeccion; private MongoDatabase database; public BaseRepository(string nombreColeccion) { _nombreColeccion = nombreColeccion; } public void ConectarDb() { const string connectionString = "mongodb://localhost"; var client = new MongoClient(connectionString); MongoServer server = client.GetServer(); database = server.GetDatabase("RepositoryPatternDemo"); } public void Insertar(T entidad) { var coleccion = database.GetCollection<T>(_nombreColeccion); coleccion.Insert(entidad); } public IQueryable<T> ObtenerTodos() { var coleccion = database.GetCollection<T>(_nombreColeccion); return coleccion.FindAll().AsQueryable(); } }
Nuestro repo base nos permite conectarnos a una base de datos MongoDB usando el string de conexión y base de datos que vemos en el código
Ahora veamos la entidad Artículo la cual se almacena directamente en MongoDB como un documento de tipo Json:
public class Articulo { public ObjectId Id { get; set; } public string Titulo { get; set; } public string ContenidoHtml { get; set; } public List<string> Etiquetas { get; set; } public string IdEmpleado { get; set; } }
Como podemos ver tenemos una propiedad de tipo ObjectId, el cual se generará al guardar el documento en MongoDB, recordemos que todos los documentos en Mongo deben tener este ObjectId por lo tanto aquí lo tenemos en esta entidad y recordemos también que esta entidad será mapeado por Automapper a nuestra entidad de dominio Articulo que es la que en realidad van a conocer los clientes que usen este repositorio.
Y para finalizar con el repositorio de MongoDB observemos el repo específico:
public class ArticuloRepository : BaseRepository<Articulo>, IArticuloRepository { public ArticuloRepository(string nombreColeccion = "Articulos") : base(nombreColeccion) { } public List<Dominio.Articulo> ObtenerArticulos() { AutoMapper.Mapper.CreateMap<Articulo, Dominio.Articulo>(); ConectarDb(); return new List<Dominio.Articulo>(ObtenerTodos().Select(c => AutoMapper.Mapper.Map<Dominio.Articulo>(c) )); } public void GuardarArticulo(Dominio.Articulo articulo) { AutoMapper.Mapper.CreateMap<Dominio.Articulo, Articulo>(); var art = AutoMapper.Mapper.Map<Articulo>(articulo); ConectarDb(); Insertar(art); } }
Como podemos observar es un repo bastante sencillo con tan solo dos operaciones, podríamos implementar las que fueran necesarias, y podemos ver que se trabaja de igual forma que el repo de Sql Server del artículo anterior usando automapper para mapear la entidad usada por el repo a la entidad de dominio en este caso la entidad de dominio Articulo.
Y para finalizar el artículo implementaremos el último repositorio del ejemplo, el cual nos permite obtener los datos de contacto de un empleado a través de un servicio Asp.net Web Api. Si quieres obtener más información acerca de Web Api, te invito a visitar el blog de mi amigo y Crack Hernan Guzman.
En este repo usaremos directamente la entidad de dominio DatosContacto, por lo que no necesitaremos del uso de automapper, y tendremos como siempre un repositorio base el cual encapsulará la conexión a nuestra Api y tendremos un repo específico que heredará del repo base. Ahora veamos como es el código del repositorio base:
public class BaseRepository<T> where T : class { public string UrlApi { get; set; } public T ObtenerPorId(string id) { var client = new HttpClient { BaseAddress = new Uri("http://localhost:38417/") }; client.DefaultRequestHeaders.Accept.Add( new MediaTypeWithQualityHeaderValue("application/json")); HttpResponseMessage response = client.GetAsync(string.Format("api/DatosContacto/{0}", id)).Result; if (response.IsSuccessStatusCode) { var datosContacto = response.Content.ReadAsStringAsync(); return JsonConvert.DeserializeObject<T>(datosContacto.Result); } else { return null; } } }
Nuestro repositorio base se encarga de consumir el servicio Web Api, enviando el id del empleado para obtener en formato Json su información de contacto, posteriormente deserializa los datos de contacto en la entidad de dominio DatosContacto y la retorna. (El código de ejemplo del Api lo puedes encontrar en el repositorio en GitHub correspondiente a esta serie de artículos).
Ahora para finalizar observemos como es el código de nuestro repositorio específico para DatosContacto:
public class DatosContactoRepository : BaseRepository<Dominio.DatosContacto>, IDatosContactoRepository { public Dominio.DatosContacto ObtenerDatosContactoEmpleado(string idEmpleado) { return ObtenerPorId(idEmpleado); } }
Es bastante simple, dado que solo tiene una operación.
Y bueno eso es todo por este artículo, en el cual implementamos los repositorios para acceso a MongoDB y para acceso a Web Api, en el próximo artículo terminaremos esta pequeña serie sobre el patrón repositorio o repositoy pattern observando como consumir los repositorios que hemos creado desde algún cliente, como por ejemplo una aplicación Asp.Net Mvc. Espero sea de utilidad y de interés para ustedes.
Continua en: Implementando patrón repositorio - Repository pattern en C# Parte IV
Este ejemplo lo puedes descargar de mi repositorio en GitHub
No olvides visitar mi página en Facebook para mantenerte actualizado de lo que pasa en el Tavo.Net https://www.facebook.com/eltavo.net
Saludos, y buena suerte!