protected Expression BuildFindEntityQuery(IEntityType entityType, IQueryProviderProvider queryProvider, JObject jObject, IDictionary <IProperty, object> keyPairs) { var query = queryProvider.GetQuery(entityType.ClrType); var keyPredicateLambdaExpression = GetKeyFilterExpression(jObject, entityType, keyPairs); var whereCallExpression = Expression.Call(null, WhereMethodInfo.MakeGenericMethod(entityType.ClrType), query.Expression, keyPredicateLambdaExpression); return(whereCallExpression); }
public MutationContext(PermissionEntityTypeBuilder permissionEntityTypeBuilder, IEnumerable <IRuleMap> ruleMaps, object securityContext, IQueryProviderProvider queryProviderProvider, JsonSerializer jsonSerializer) { PermissionEntityTypeBuilder = permissionEntityTypeBuilder; RuleMaps = ruleMaps; SecurityContext = securityContext; QueryProviderProvider = queryProviderProvider; JsonSerializer = jsonSerializer; }
public JObjectMutationHelper( IEnumerable <IRuleMap> ruleMaps, IQueryProviderProvider queryProviderProvider, IModelProvider modelProvider, PermissionResolverExpressionBuilderProvider permissionResolverExpressionBuilderProvider, PermissionEntityTypeBuilder permissionEntityTypeBuilder ) { RuleMaps = ruleMaps; QueryProviderProvider = queryProviderProvider; Model = modelProvider.Model; PermissionResolverExpressionBuilderProvider = permissionResolverExpressionBuilderProvider; PermissionEntityTypeBuilder = permissionEntityTypeBuilder; }
public async Task <Task> InvokeAsync(HttpContext httpContext, ExpressionConverterResolver expressionConverterResolver, IEnumerable <IExtensionMethodsProvider> extensionMethodsProviders, IEnumerable <IStaticMethodsProvider> staticMethodsProviders, IQueryProviderProvider queryProviderProvider, IEnumerable <IIdentifier> Identifiers, IEnumerable <IIdentifierProvider> identifierProviders, JsonSerializer jsonSerializer, IEnumerable <IRuleMapsProvider> ruleMapsProviders, IEnumerable <IRuleMap> ruleMaps, IEnumerable <ICustomMethodCallExpressionConverter> customMethodCallExpressionConverters, IIdentityProvider identityProvider, System.Text.Json.JsonSerializerOptions jsonSerializerOptions) { Esprima.Ast.Expression jsExpression = null; string payload = null; using (var reader = new StreamReader(httpContext.Request.Body)) { payload = await reader.ReadToEndAsync(); var parser = new JavaScriptParser(payload, new ParserOptions() { Range = true }); jsExpression = parser.ParseExpression(); } // The context holds the converters // Building the expression var currentUser = identityProvider.GetIdentity().User; // The context olds the factories ruleMaps = ruleMaps.Union(ruleMapsProviders.SelectMany(rmp => rmp.RuleMaps)); var expressionConvertersContext = new ExpressionConverterContext() { ExpressionConverterResolver = expressionConverterResolver, ExtensionMethods = extensionMethodsProviders.SelectMany(emp => emp.Methods), StaticMethods = staticMethodsProviders.SelectMany(emp => emp.Methods), RuleMapRegistry = new RuleMapRegistry(ruleMaps, Enumerable.Empty <IRuleMapsProvider>()), RuleMaps = ruleMaps, CustomMethodCallExpressionConverters = customMethodCallExpressionConverters, securityContext = new Context() { User = currentUser }, Source = payload }; var identifiers = new Dictionary <string, System.Linq.Expressions.Expression>(); foreach (var identifierProvider in identifierProviders) { foreach (var identifier in identifierProvider.Identifiers) { identifiers[identifier.Key] = identifier.Value; } } foreach (var identifier in Identifiers) { identifiers[identifier.Name] = identifier.Expression; } // The scope olds the target type, the generic parameter map and varibales set. // Note that the target type is null since we cannot predict it at this stage. // Note that the generic parameter map is null since we cannot predict it at this stage var expressionConvertersScope = new ExpressionConverterScope(null, null) { Variables = identifiers }; var expression = expressionConverterResolver.Convert(jsExpression, expressionConvertersContext, expressionConvertersScope, false); if (expression.Type != typeof(void) && expression.Type != typeof(Task)) { Func <Task <object> > asyncFunction = null; if (expression.Type.IsGenericType && expression.Type.GetGenericTypeDefinition() == typeof(Task <>)) { var f = System.Linq.Expressions.Expression.Lambda <Func <Task> >(expression).Compile(); asyncFunction = async() => { var task = f(); await task; return((object)((dynamic)task).Result); }; } else { var function = System.Linq.Expressions.Expression.Lambda <Func <object> >(System.Linq.Expressions.Expression.Convert(expression, typeof(object))).Compile(); asyncFunction = new Func <Task <object> >(() => Task.FromResult(function())); } var result = await asyncFunction(); httpContext.Response.Headers.Add("Content-Type", "application/json"); httpContext.Response.Headers.Add("charset", "utf8"); var queryable = result as IQueryable <object>; if (queryable != null) { result = queryable.ToArray(); } using (var streamWriter = new StreamWriter(httpContext.Response.Body)) { using (var jsonWriter = new JsonTextWriter(streamWriter)) { jsonSerializer.Serialize(jsonWriter, result); } } } else { Func <Task> asyncAction = null; if (expression.Type == typeof(Task)) { asyncAction = System.Linq.Expressions.Expression.Lambda <Func <Task> >(expression).Compile(); } else { var a = System.Linq.Expressions.Expression.Lambda <Action>(expression).Compile(); asyncAction = new Func <Task>(() => { a(); return(Task.CompletedTask); }); } await asyncAction(); } return(Task.CompletedTask); }