From 8f488274a78e92a6d02ce8354c99b3b91f8cc872 Mon Sep 17 00:00:00 2001 From: NazarovMikhail Date: Fri, 12 Jan 2024 18:03:54 +0500 Subject: [PATCH] =?UTF-8?q?=F0=9F=94=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Extensions/QueryableExtensions.cs | 90 ++++++++----------- 1 file changed, 38 insertions(+), 52 deletions(-) diff --git a/src/Monq.Core.Paging/Extensions/QueryableExtensions.cs b/src/Monq.Core.Paging/Extensions/QueryableExtensions.cs index 6b96f23..52a5595 100644 --- a/src/Monq.Core.Paging/Extensions/QueryableExtensions.cs +++ b/src/Monq.Core.Paging/Extensions/QueryableExtensions.cs @@ -9,22 +9,17 @@ namespace Monq.Core.Paging.Extensions { public static class QueryableExtensions { - // if it needs checking search value - method TryParse else - null - static readonly Dictionary _supportedTypes = new() + static readonly HashSet _supportSearchByStringPropertyTypes = new() { - [typeof(int)] = typeof(int).GetMethod( - nameof(int.TryParse), - new Type[] { typeof(string), typeof(int).MakeByRefType() })!, - [typeof(long)] = typeof(int).GetMethod( - nameof(int.TryParse), - new Type[] { typeof(string), typeof(int).MakeByRefType() })!, - [typeof(Guid)] = null, + typeof(string), + typeof(Guid), + }; + static readonly HashSet _supportSearchByIntNumberPropertyTypes = new() + { + typeof(int), + typeof(long), + typeof(Guid), }; - - static readonly MethodInfo _methodContains = typeof(string).GetMethod(nameof(string.Contains), new[] { typeof(string) })!; - static readonly MethodInfo _methodToString = typeof(object).GetMethod(nameof(ToString))!; - static readonly MethodInfo _methodToLower = typeof(string).GetMethod(nameof(string.ToLower), Type.EmptyTypes)!; - static readonly MethodInfo _methodIsNullOrEmpty = typeof(string).GetMethod(nameof(string.IsNullOrEmpty), new[] { typeof(string) })!; /// /// Orderings the by. @@ -73,33 +68,51 @@ public static IQueryable OrderByProperty(this IQueryable p.Property.PropertyType == typeof(string)).ToList(); + var searchByStringProperties = props.Where(p => _supportSearchByStringPropertyTypes.Contains(p.Property.PropertyType)) + .ToList(); if (!props.Any()) return null; var parameter = Expression.Parameter(typeof(TSource), "t"); + var methodContains = typeof(string).GetMethod(nameof(string.Contains), new[] { typeof(string) }); + var methodToLower = typeof(string).GetMethod(nameof(string.ToLower), Type.EmptyTypes); + var methodToString = typeof(object).GetMethod(nameof(ToString)); + var methodIsNullOrEmpty = typeof(string).GetMethod(nameof(string.IsNullOrEmpty), new[] { typeof(string) }); + var value = Expression.Constant(search.ToLower(), typeof(string)); + var expList = new List(); - foreach (var (fullName, _) in stringProperties) + foreach (var (fullName, prop) in searchByStringProperties) { var expMember = parameter.GetPropertyExpressionUnSafe(fullName); - var extIsNullOrEmpty = Expression.Not(Expression.Call(_methodIsNullOrEmpty, expMember.AddNullConditions())); + if (prop.PropertyType != typeof(string)) + expMember = Expression.Call(expMember, methodToString); + + var extIsNullOrEmpty = Expression.Not(Expression.Call(methodIsNullOrEmpty, expMember.AddNullConditions())); - var expLower = Expression.Call(expMember, _methodToLower); - var expContains = Expression.Call(expLower, _methodContains, value); + var expLower = Expression.Call(expMember, methodToLower); + var expContains = Expression.Call(expLower, methodContains, value); var extAnd = Expression.AndAlso(extIsNullOrEmpty, expContains); expList.Add(extAnd); } - var valueExpressions = FormExpressionsForSupportedTypes( - props, - parameter, - search); - - expList.AddRange(valueExpressions); + if (long.TryParse(search, out _)) + { + var searchByIntProperties = props.Where(p => _supportSearchByIntNumberPropertyTypes.Contains(p.Property.PropertyType)) + .ToList(); + var expression = Expression.Constant(true); + foreach (var (fullName, _) in searchByIntProperties) + { + var expMember = parameter.GetPropertyExpression(fullName); + var ext = Expression.Call(expMember, methodToString); + var extContains = Expression.Call(ext, methodContains, value); + var extAnd = Expression.Equal(extContains, expression); + expList.Add(extAnd); + } + } if (expList.Count == 0) return null; @@ -107,32 +120,5 @@ public static IQueryable OrderByProperty(this IQueryable>(body, parameter); } - - private static IEnumerable FormExpressionsForSupportedTypes( - IEnumerable<(string FullName, PropertyInfo Property)> targetProps, - ParameterExpression parameter, - string searchValue) - { - var result = new List(); - var valueExpr = Expression.Constant(searchValue.ToLower(), typeof(string)); - var expression = Expression.Constant(true); - - foreach (var (fullName, prop) in targetProps) - { - if (!_supportedTypes.TryGetValue(prop.PropertyType, out var tryParseMethod)) - continue; - - if (tryParseMethod != null - && (bool)tryParseMethod.Invoke(null, new object?[] { searchValue, null })! == false) - continue; - - var expMember = parameter.GetPropertyExpression(fullName); - var ext = Expression.Call(expMember, _methodToString); - var extContains = Expression.Call(ext, _methodContains, valueExpr); - var extAnd = Expression.Equal(extContains, expression); - result.Add(extAnd); - } - return result; - } } } \ No newline at end of file