Я пытаюсь реализовать класс, который определяет фильтр, чтобы сделать его более явным, когда он будет передан в качестве аргумента методам в моем классе репозитория (EF).
И у меня есть проблема с определением неявный оператор из Expression в мой класс. Можно ли сделать реализацию для синтаксиса рядом с переменной fd4?
public class FilterDefinition<TEntity>
where TEntity : class
{
public FilterDefinition() { }
public FilterDefinition(Expression<Func<TEntity, bool>> filter)
{
this.Filter = filter;
}
public virtual Expression<Func<TEntity, bool>> Filter { get; set; }
public static implicit operator FilterDefinition<TEntity>(Expression<Func<TEntity, bool>> filter) => new FilterDefinition<TEntity>(filter);
}
public class SomeEntity
{
public bool SomeBool { get; set; }
}
class Program
{
static void Main()
{
FilterDefinition<SomeEntity> fd1 = new FilterDefinition<SomeEntity>(x => x.SomeBool);
FilterDefinition<SomeEntity> fd2 = new FilterDefinition<SomeEntity> { Filter = x => x.SomeBool };
FilterDefinition<SomeEntity> fd3 = (Expression<Func<SomeEntity, bool>>)(x => x.SomeBool);
//FilterDefinition<SomeEntity> fd4 = x => x.SomeBool;
Console.ReadKey();
}
}
Цель класса FilterDefinition - передать в качестве аргумента хранилище запросов generi c. А с помощью наследования определяют часто используемые фильтры.
public class Repository<TEntity> : IRepository<TEntity>
where TEntity : class
{
private readonly DbSet<TEntity> dbSet;
public Repository(DbContext context)
{
this.dbSet = context.Set<TEntity>();
}
public async Task<IEnumerable<TEntity>> GetAsync(
FilterDefinition<TEntity> filter = null,
OrderDefinition<TEntity> order = null,
PagingDefinition paging = null)
{
return await new QueryBuilder<TEntity>(this.dbSet)
.ApplyFilter(filter)
.ApplyOrder(order)
.ApplyPaging(paging)
.ToQuery()
.ToListAsync();
}