/
FilterExpressionExtension.cs
52 lines (43 loc) · 2.17 KB
/
FilterExpressionExtension.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
using System;
using System.Linq;
using System.Linq.Expressions;
using EntityGraphQL.Compiler;
using EntityGraphQL.Compiler.Util;
using EntityGraphQL.Extensions;
namespace EntityGraphQL.Schema.FieldExtensions
{
public class FilterExpressionExtension : BaseFieldExtension
{
private bool isQueryable;
private Type? listType;
/// <summary>
/// Configure the field for a filter argument. Do as much as we can here as it is only executed once.
/// </summary>
/// <param name="schema"></param>
/// <param name="field"></param>
public override void Configure(ISchemaProvider schema, IField field)
{
if (field.ResolveExpression == null)
throw new EntityGraphQLCompilerException($"FilterExpressionExtension requires a Resolve function set on the field");
if (!field.ResolveExpression.Type.IsEnumerableOrArray())
throw new ArgumentException($"Expression for field {field.Name} must be a collection to use FilterExpressionExtension. Found type {field.ReturnType.TypeDotnet}");
listType = field.ReturnType.TypeDotnet.GetEnumerableOrArrayType()!;
// Update field arguments
var args = Activator.CreateInstance(typeof(FilterArgs<>).MakeGenericType(listType))!;
field.AddArguments(args);
isQueryable = typeof(IQueryable).IsAssignableFrom(field.ResolveExpression.Type);
}
public override Expression? GetExpression(IField field, Expression expression, ParameterExpression? argumentParam, dynamic? arguments, Expression context, IGraphQLNode? parentNode, bool servicesPass, ParameterReplacer parameterReplacer)
{
// data is already filtered
if (servicesPass)
return expression;
// we have current context update Items field
if (arguments != null && arguments?.Filter != null && arguments?.Filter.HasValue)
{
expression = Expression.Call(isQueryable ? typeof(Queryable) : typeof(Enumerable), "Where", new Type[] { listType! }, expression, arguments!.Filter.Query);
}
return expression;
}
}
}