using MongoDB.Driver; using RouteGuideContracts.BindingModels; using RouteGuideContracts.SearchModels; using RouteGuideContracts.StoragesContracts; using RouteGuideContracts.ViewModels; using RouteGuideMongoDBImplement.Models; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace RouteGuideMongoDBImplement.Implements { /// /// Хранилище для сущности "Маршрут" /// public class RouteStorage : IRouteStorage { /// /// Получение полного списка /// /// public List GetFullList() { using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; return context.Routes .Find(filter) .ToList() .Select(x => x.GetViewModel) .ToList(); } /// /// Получение фильтрованного списка /// /// /// public List GetFilteredList(RouteSearchModel model) { if (string.IsNullOrEmpty(model.Name)) { return new(); } using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Eq(x => x.Name, model.Name); return context.Routes .Find(filter) .ToList() .Select(x => x.GetViewModel) .ToList(); } /// /// Получить список из заданного количества элементов /// /// /// public List GetList(int count) { if (count <= 0) { return new(); } using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; return context.Routes .Find(filter) .Limit(count) .ToList() .Select(x => x.GetViewModel) .ToList(); } /// /// Получение элемента /// /// /// public RouteViewModel? GetElement(RouteSearchModel model) { if (string.IsNullOrEmpty(model.Id?.ToString()) && string.IsNullOrEmpty(model.Name)) { return null; } using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; if (!string.IsNullOrEmpty(model.Name)) { filter &= filterBuilder.Eq(x => x.Name, model.Name); } if (!string.IsNullOrEmpty(model.Id?.ToString())) { filter &= filterBuilder.Eq(x => x.Id, model.Id); } return context.Routes .Find(filter) .FirstOrDefault() ?.GetViewModel; } /// /// Добавление элемента /// /// /// public RouteViewModel? Insert(RouteBindingModel model) { using var context = new RouteGuideDatabase(); var newRoute = Route.Create(context, model); if (newRoute == null) { return null; } context.Routes.InsertOne(newRoute); return newRoute.GetViewModel; } /// /// Редактирование элемента /// /// /// public RouteViewModel? Update(RouteBindingModel model) { using var context = new RouteGuideDatabase(); using var session = context._client.StartSession(); try { var filterBuilder = Builders.Filter; var filter = filterBuilder.Eq(x => x.Id, model.Id); var route = context.Routes.Find(filter).FirstOrDefault(); if (route == null) { return null; } route.Update(model); route.UpdateStops(context, model); context.Routes.ReplaceOne(filter, route); session.CommitTransaction(); return route.GetViewModel; } catch { session.AbortTransaction(); throw; } } /// /// Удаление элемента /// /// /// public RouteViewModel? Delete(RouteBindingModel model) { using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Eq(x => x.Id, model.Id); var route = context.Routes.Find(filter).FirstOrDefault(); if (route == null) { return null; } context.Routes.FindOneAndDelete(filter); return route.GetViewModel; } /// /// Удаление записи /// /// public RouteViewModel? Delete() { if (!GetFullList().Any()) { return null; } using var context = new RouteGuideDatabase(); var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; var element = context.Routes.FindOneAndDelete(filter); return element.GetViewModel; } /// /// Удаление всех элементов /// /// public int Clear() { using var context = new RouteGuideDatabase(); int count = GetFullList().Count; if (count <= 0) { return 0; } var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; context.Routes.DeleteMany(filter); return count; } } }