Это зависит.:)
Мое мнение:
Мне нравится держать свой сервис свободным, чтобы минимизировать дублирующийся код.Я также фанат труб и фильтров.
Вот что я бы сделал (и СДЕЛАЛ).
Сервис
public ICollection<Item> GetHandledItems<TKey>(OrderingOptions<Item, TKey> orderingOptions)
{
return repository
.Query()
.WhereHandled()
.WithOrdering(orderingOptions)
.ToList();
}
ItemFilters.cs
public static IQueryable<Item> WhereHandled(this IQueryable<Item> source)
{
return source.Where(it => it.IsHandled);
}
public static IOrderedQueryable<T> WithOrdering<T, TKey>(
this IQueryable<T> source,
OrderingOptions<T, TKey> orderingOptions)
{
return orderingOptions.SortDescending
? source.OrderByDescending(orderingOptions.OrderingKey) :
source.OrderBy(orderingOptions.OrderingKey);
}
OrderingOptions.cs
public class OrderingOptions<T,TKey>
{
public OrderingOptions(Expression<Func<T,TKey>> orderingKey, bool sortDescending = false)
{
OrderingKey = orderingKey;
SortDescending = sortDescending;
}
public Expression<Func<T,TKey>> OrderingKey { get; private set; }
public bool SortDescending { get; private set; }
}
Таким образом, вы можете указать порядок в контроллере:
var items = service.GetHandledItems(new OrderingOptions(it => it.Id));
Различия между вышеперечисленным и опциями 3:
- Вышеизложенное материализует последовательность перед возвратом в контроллер.Вариант 3 не делает, что опасно (вы можете в конечном итоге вернуть запрос в View и нарушить шаблон MVC).
- Универсальный POCO «Упорядочивание», может использоваться где угодно и сохраняет ваши запросы СУХИМ.* Служба становится тупой , и просто смягчает между хранилищем и контроллером (что все, что он должен делать, IMO).Логика (например, фильтры) отводится в одно место.