Compare commits
8 Commits
10.1.1-rc3
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 55f1324286 | |||
|
|
b34bf874b4 | ||
|
|
c6de10b98b | ||
|
|
3945c1a158 | ||
| 7614f68512 | |||
|
|
fdee02c960 | ||
|
|
a4525bad6a | ||
|
|
3df094b9e7 |
@ -1,50 +0,0 @@
|
|||||||
{
|
|
||||||
"permissions": {
|
|
||||||
"allow": [
|
|
||||||
"Bash(dotnet clean:*)",
|
|
||||||
"Bash(dotnet run)",
|
|
||||||
"Bash(dotnet add:*)",
|
|
||||||
"Bash(timeout 5 dotnet run:*)",
|
|
||||||
"Bash(dotnet remove:*)",
|
|
||||||
"Bash(netstat:*)",
|
|
||||||
"Bash(findstr:*)",
|
|
||||||
"Bash(cat:*)",
|
|
||||||
"Bash(taskkill:*)",
|
|
||||||
"WebSearch",
|
|
||||||
"Bash(dotnet tool install:*)",
|
|
||||||
"Bash(protogen:*)",
|
|
||||||
"Bash(timeout 15 dotnet run:*)",
|
|
||||||
"Bash(where:*)",
|
|
||||||
"Bash(timeout 30 dotnet run:*)",
|
|
||||||
"Bash(timeout 60 dotnet run:*)",
|
|
||||||
"Bash(timeout 120 dotnet run:*)",
|
|
||||||
"Bash(git add:*)",
|
|
||||||
"Bash(curl:*)",
|
|
||||||
"Bash(timeout 3 cmd:*)",
|
|
||||||
"Bash(timeout:*)",
|
|
||||||
"Bash(tasklist:*)",
|
|
||||||
"Bash(dotnet build:*)",
|
|
||||||
"Bash(dotnet --list-sdks:*)",
|
|
||||||
"Bash(dotnet sln:*)",
|
|
||||||
"Bash(pkill:*)",
|
|
||||||
"Bash(python3:*)",
|
|
||||||
"Bash(grpcurl:*)",
|
|
||||||
"Bash(lsof:*)",
|
|
||||||
"Bash(xargs kill -9)",
|
|
||||||
"Bash(dotnet run:*)",
|
|
||||||
"Bash(find:*)",
|
|
||||||
"Bash(dotnet pack:*)",
|
|
||||||
"Bash(unzip:*)",
|
|
||||||
"WebFetch(domain:andrewlock.net)",
|
|
||||||
"WebFetch(domain:github.com)",
|
|
||||||
"WebFetch(domain:stackoverflow.com)",
|
|
||||||
"WebFetch(domain:www.kenmuse.com)",
|
|
||||||
"WebFetch(domain:blog.rsuter.com)",
|
|
||||||
"WebFetch(domain:natemcmaster.com)",
|
|
||||||
"WebFetch(domain:www.nuget.org)",
|
|
||||||
"Bash(mkdir:*)"
|
|
||||||
],
|
|
||||||
"deny": [],
|
|
||||||
"ask": []
|
|
||||||
}
|
|
||||||
}
|
|
||||||
96
.editorconfig
Normal file
96
.editorconfig
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 4
|
||||||
|
end_of_line = lf
|
||||||
|
charset = utf-8
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
insert_final_newline = true
|
||||||
|
|
||||||
|
[*.{csproj,props,targets,xml}]
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
[*.{json,yml,yaml}]
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
[*.proto]
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
[*.cs]
|
||||||
|
# Namespace
|
||||||
|
csharp_style_namespace_declarations = file_scoped:warning
|
||||||
|
|
||||||
|
# Braces — Allman style
|
||||||
|
csharp_new_line_before_open_brace = all
|
||||||
|
|
||||||
|
# Usings
|
||||||
|
dotnet_sort_system_directives_first = true
|
||||||
|
csharp_using_directive_placement = outside_namespace:warning
|
||||||
|
|
||||||
|
# var preferences — use var when type is apparent
|
||||||
|
csharp_style_var_for_built_in_types = true:suggestion
|
||||||
|
csharp_style_var_when_type_is_apparent = true:suggestion
|
||||||
|
csharp_style_var_elsewhere = true:suggestion
|
||||||
|
|
||||||
|
# Expression bodies — prefer for simple members
|
||||||
|
csharp_style_expression_bodied_methods = when_on_single_line:suggestion
|
||||||
|
csharp_style_expression_bodied_constructors = false:suggestion
|
||||||
|
csharp_style_expression_bodied_operators = when_on_single_line:suggestion
|
||||||
|
csharp_style_expression_bodied_properties = true:suggestion
|
||||||
|
csharp_style_expression_bodied_accessors = true:suggestion
|
||||||
|
csharp_style_expression_bodied_lambdas = true:suggestion
|
||||||
|
|
||||||
|
# Pattern matching
|
||||||
|
csharp_style_pattern_matching_over_is_with_cast_check = true:suggestion
|
||||||
|
csharp_style_pattern_matching_over_as_with_null_check = true:suggestion
|
||||||
|
|
||||||
|
# Null checking
|
||||||
|
csharp_style_throw_expression = true:suggestion
|
||||||
|
csharp_style_conditional_delegate_call = true:suggestion
|
||||||
|
|
||||||
|
# Modifier preferences — exclude interface members (netstandard2.1 compat)
|
||||||
|
dotnet_style_require_accessibility_modifiers = for_non_interface_members:warning
|
||||||
|
|
||||||
|
# Field naming — _camelCase for private fields
|
||||||
|
dotnet_naming_rule.private_fields_should_be_camel_case.severity = warning
|
||||||
|
dotnet_naming_rule.private_fields_should_be_camel_case.symbols = private_fields
|
||||||
|
dotnet_naming_rule.private_fields_should_be_camel_case.style = camel_case_underscore
|
||||||
|
|
||||||
|
dotnet_naming_symbols.private_fields.applicable_kinds = field
|
||||||
|
dotnet_naming_symbols.private_fields.applicable_accessibilities = private, protected, private_protected
|
||||||
|
dotnet_naming_symbols.private_fields.required_modifiers =
|
||||||
|
|
||||||
|
dotnet_naming_style.camel_case_underscore.required_prefix = _
|
||||||
|
dotnet_naming_style.camel_case_underscore.capitalization = camel_case
|
||||||
|
|
||||||
|
# Constants — PascalCase
|
||||||
|
dotnet_naming_rule.constants_should_be_pascal_case.severity = suggestion
|
||||||
|
dotnet_naming_rule.constants_should_be_pascal_case.symbols = constants
|
||||||
|
dotnet_naming_rule.constants_should_be_pascal_case.style = pascal_case
|
||||||
|
|
||||||
|
dotnet_naming_symbols.constants.applicable_kinds = field
|
||||||
|
dotnet_naming_symbols.constants.required_modifiers = const
|
||||||
|
|
||||||
|
dotnet_naming_style.pascal_case.capitalization = pascal_case
|
||||||
|
|
||||||
|
# Interfaces — I prefix
|
||||||
|
dotnet_naming_rule.interfaces_should_begin_with_i.severity = warning
|
||||||
|
dotnet_naming_rule.interfaces_should_begin_with_i.symbols = interfaces
|
||||||
|
dotnet_naming_rule.interfaces_should_begin_with_i.style = begins_with_i
|
||||||
|
|
||||||
|
dotnet_naming_symbols.interfaces.applicable_kinds = interface
|
||||||
|
|
||||||
|
dotnet_naming_style.begins_with_i.required_prefix = I
|
||||||
|
dotnet_naming_style.begins_with_i.capitalization = pascal_case
|
||||||
|
|
||||||
|
# Async methods — Async suffix
|
||||||
|
dotnet_naming_rule.async_methods_should_end_with_async.severity = suggestion
|
||||||
|
dotnet_naming_rule.async_methods_should_end_with_async.symbols = async_methods
|
||||||
|
dotnet_naming_rule.async_methods_should_end_with_async.style = ends_with_async
|
||||||
|
|
||||||
|
dotnet_naming_symbols.async_methods.applicable_kinds = method
|
||||||
|
dotnet_naming_symbols.async_methods.required_modifiers = async
|
||||||
|
|
||||||
|
dotnet_naming_style.ends_with_async.required_suffix = Async
|
||||||
|
dotnet_naming_style.ends_with_async.capitalization = pascal_case
|
||||||
@ -1,6 +1,6 @@
|
|||||||
# CLAUDE.md
|
# CLAUDE.md
|
||||||
|
|
||||||
This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
|
This file provides guidance to AI agents when working with code in this repository.
|
||||||
|
|
||||||
## Project Overview
|
## Project Overview
|
||||||
|
|
||||||
|
|||||||
@ -4,6 +4,15 @@
|
|||||||
|
|
||||||
Our implementation of query and command responsibility segregation (CQRS).
|
Our implementation of query and command responsibility segregation (CQRS).
|
||||||
|
|
||||||
|
## Where This Fits
|
||||||
|
|
||||||
|
This is a backend framework of the [Svrnty Agent System](../README.md).
|
||||||
|
|
||||||
|
**Layer**: Framework
|
||||||
|
**Depends on**: Nothing (standalone .NET framework)
|
||||||
|
**Depended on by**: a-gent-app (backend services), flutter_cqrs_datasource (client)
|
||||||
|
**Git**: [git.openharbor.io/svrnty/dotnet-cqrs](https://git.openharbor.io/svrnty/dotnet-cqrs)
|
||||||
|
|
||||||
## Getting Started
|
## Getting Started
|
||||||
|
|
||||||
> Install nuget package to your awesome project.
|
> Install nuget package to your awesome project.
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions.Attributes;
|
namespace Svrnty.CQRS.Abstractions.Attributes;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions.Attributes;
|
namespace Svrnty.CQRS.Abstractions.Attributes;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using Svrnty.CQRS.Abstractions.Attributes;
|
using Svrnty.CQRS.Abstractions.Attributes;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions.Discovery;
|
namespace Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions.Discovery;
|
namespace Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions.Discovery;
|
namespace Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using Svrnty.CQRS.Abstractions.Attributes;
|
using Svrnty.CQRS.Abstractions.Attributes;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions;
|
namespace Svrnty.CQRS.Abstractions;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Abstractions;
|
namespace Svrnty.CQRS.Abstractions;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
namespace Svrnty.CQRS.Abstractions.Security;
|
namespace Svrnty.CQRS.Abstractions.Security;
|
||||||
|
|
||||||
public enum AuthorizationResult
|
public enum AuthorizationResult
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Svrnty.CQRS.Abstractions.Discovery;
|
using Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
namespace Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|
||||||
public interface IDynamicQueryParams<out TParams>
|
public interface IDynamicQueryParams<out TParams>
|
||||||
where TParams : class
|
where TParams : class
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
|||||||
@ -7,6 +7,7 @@ using Microsoft.AspNetCore.Builder;
|
|||||||
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Http;
|
||||||
using Microsoft.AspNetCore.Routing;
|
using Microsoft.AspNetCore.Routing;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
using Svrnty.CQRS.Abstractions;
|
using Svrnty.CQRS.Abstractions;
|
||||||
using Svrnty.CQRS.Abstractions.Attributes;
|
using Svrnty.CQRS.Abstractions.Attributes;
|
||||||
using Svrnty.CQRS.Abstractions.Discovery;
|
using Svrnty.CQRS.Abstractions.Discovery;
|
||||||
@ -14,7 +15,6 @@ using Svrnty.CQRS.Abstractions.Security;
|
|||||||
using Svrnty.CQRS.DynamicQuery;
|
using Svrnty.CQRS.DynamicQuery;
|
||||||
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
using Svrnty.CQRS.DynamicQuery.Discover;
|
using Svrnty.CQRS.DynamicQuery.Discover;
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery.MinimalApi;
|
namespace Svrnty.CQRS.DynamicQuery.MinimalApi;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using Pluralize.NET;
|
using Pluralize.NET;
|
||||||
using Svrnty.CQRS.Abstractions.Discovery;
|
using Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|
||||||
@ -7,7 +7,7 @@ namespace Svrnty.CQRS.DynamicQuery.Discover;
|
|||||||
public class DynamicQueryMeta(Type queryType, Type serviceType, Type queryResultType)
|
public class DynamicQueryMeta(Type queryType, Type serviceType, Type queryResultType)
|
||||||
: QueryMeta(queryType, serviceType, queryResultType)
|
: QueryMeta(queryType, serviceType, queryResultType)
|
||||||
{
|
{
|
||||||
public Type SourceType => QueryType.GetGenericArguments()[0];
|
public Type SourceType => QueryType.GetGenericArguments()[0];
|
||||||
public Type DestinationType => QueryType.GetGenericArguments()[1];
|
public Type DestinationType => QueryType.GetGenericArguments()[1];
|
||||||
public override string Category => "DynamicQuery";
|
public override string Category => "DynamicQuery";
|
||||||
public override string Name
|
public override string Name
|
||||||
|
|||||||
@ -1,8 +1,8 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
|
||||||
using PoweredSoft.DynamicQuery;
|
using PoweredSoft.DynamicQuery;
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
|
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery;
|
namespace Svrnty.CQRS.DynamicQuery;
|
||||||
|
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
|
using System;
|
||||||
using PoweredSoft.DynamicQuery;
|
using PoweredSoft.DynamicQuery;
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery;
|
namespace Svrnty.CQRS.DynamicQuery;
|
||||||
|
|
||||||
|
|||||||
@ -1,10 +1,10 @@
|
|||||||
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
|
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery;
|
namespace Svrnty.CQRS.DynamicQuery;
|
||||||
|
|
||||||
@ -49,7 +49,7 @@ public class DynamicQueryHandler<TSource, TDestination, TParams>
|
|||||||
|
|
||||||
protected override async Task<IQueryable<TSource>> AlterSourceAsync(IQueryable<TSource> source, IDynamicQuery query, CancellationToken cancellationToken)
|
protected override async Task<IQueryable<TSource>> AlterSourceAsync(IQueryable<TSource> source, IDynamicQuery query, CancellationToken cancellationToken)
|
||||||
{
|
{
|
||||||
source = await base.AlterSourceAsync(source, query, cancellationToken);
|
source = await base.AlterSourceAsync(source, query, cancellationToken);
|
||||||
|
|
||||||
if (query is IDynamicQueryParams<TParams> withParams)
|
if (query is IDynamicQueryParams<TParams> withParams)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
@ -6,9 +6,9 @@ using System.Linq;
|
|||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
|
||||||
using PoweredSoft.DynamicQuery;
|
using PoweredSoft.DynamicQuery;
|
||||||
using PoweredSoft.DynamicQuery.Core;
|
using PoweredSoft.DynamicQuery.Core;
|
||||||
|
using Svrnty.CQRS.DynamicQuery.Abstractions;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.DynamicQuery;
|
namespace Svrnty.CQRS.DynamicQuery;
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||||
using PoweredSoft.Data.Core;
|
using PoweredSoft.Data.Core;
|
||||||
@ -91,10 +91,10 @@ public static class ServiceCollectionExtensions
|
|||||||
where TParams : class
|
where TParams : class
|
||||||
=> AddDynamicQueryWithParams<TSourceAndDestination, TSourceAndDestination, TParams>(services, name: name);
|
=> AddDynamicQueryWithParams<TSourceAndDestination, TSourceAndDestination, TParams>(services, name: name);
|
||||||
|
|
||||||
public static IServiceCollection AddDynamicQueryWithParams<TSource, TDestination, TParams>(this IServiceCollection services, string name = null)
|
public static IServiceCollection AddDynamicQueryWithParams<TSource, TDestination, TParams>(this IServiceCollection services, string name = null)
|
||||||
where TSource : class
|
where TSource : class
|
||||||
where TDestination : class
|
where TDestination : class
|
||||||
where TParams : class
|
where TParams : class
|
||||||
{
|
{
|
||||||
// add query handler.
|
// add query handler.
|
||||||
services.AddTransient<IQueryHandler<IDynamicQuery<TSource, TDestination, TParams>, IQueryExecutionResult<TDestination>>, DynamicQueryHandler<TSource, TDestination, TParams>>();
|
services.AddTransient<IQueryHandler<IDynamicQuery<TSource, TDestination, TParams>, IQueryExecutionResult<TDestination>>, DynamicQueryHandler<TSource, TDestination, TParams>>();
|
||||||
@ -133,7 +133,7 @@ public static class ServiceCollectionExtensions
|
|||||||
where TParams : class
|
where TParams : class
|
||||||
where TService : class, IAlterQueryableService<TSourceAndTDestination, TSourceAndTDestination, TParams>
|
where TService : class, IAlterQueryableService<TSourceAndTDestination, TSourceAndTDestination, TParams>
|
||||||
{
|
{
|
||||||
return services.AddTransient<IAlterQueryableService< TSourceAndTDestination, TSourceAndTDestination, TParams>, TService>();
|
return services.AddTransient<IAlterQueryableService<TSourceAndTDestination, TSourceAndTDestination, TParams>, TService>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static IServiceCollection AddAlterQueryableWithParams<TSource, TDestination, TParams, [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicConstructors)] TService>
|
public static IServiceCollection AddAlterQueryableWithParams<TSource, TDestination, TParams, [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicConstructors)] TService>
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using FluentValidation;
|
using FluentValidation;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Svrnty.CQRS.Abstractions;
|
using Svrnty.CQRS.Abstractions;
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@ -1,102 +1,101 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Grpc.Generators.Helpers
|
namespace Svrnty.CQRS.Grpc.Generators.Helpers;
|
||||||
|
|
||||||
|
internal static class ProtoTypeMapper
|
||||||
{
|
{
|
||||||
internal static class ProtoTypeMapper
|
private static readonly Dictionary<string, string> TypeMap = new Dictionary<string, string>
|
||||||
{
|
{
|
||||||
private static readonly Dictionary<string, string> TypeMap = new Dictionary<string, string>
|
// Primitives
|
||||||
|
{ "System.String", "string" },
|
||||||
|
{ "System.Boolean", "bool" },
|
||||||
|
{ "System.Int32", "int32" },
|
||||||
|
{ "System.Int64", "int64" },
|
||||||
|
{ "System.UInt32", "uint32" },
|
||||||
|
{ "System.UInt64", "uint64" },
|
||||||
|
{ "System.Single", "float" },
|
||||||
|
{ "System.Double", "double" },
|
||||||
|
{ "System.Byte", "uint32" },
|
||||||
|
{ "System.SByte", "int32" },
|
||||||
|
{ "System.Int16", "int32" },
|
||||||
|
{ "System.UInt16", "uint32" },
|
||||||
|
{ "System.Decimal", "string" }, // Decimal as string to preserve precision
|
||||||
|
{ "System.DateTime", "int64" }, // Unix timestamp
|
||||||
|
{ "System.DateTimeOffset", "int64" }, // Unix timestamp
|
||||||
|
{ "System.Guid", "string" },
|
||||||
|
{ "System.TimeSpan", "int64" }, // Ticks
|
||||||
|
|
||||||
|
// Nullable variants
|
||||||
|
{ "System.Boolean?", "bool" },
|
||||||
|
{ "System.Int32?", "int32" },
|
||||||
|
{ "System.Int64?", "int64" },
|
||||||
|
{ "System.UInt32?", "uint32" },
|
||||||
|
{ "System.UInt64?", "uint64" },
|
||||||
|
{ "System.Single?", "float" },
|
||||||
|
{ "System.Double?", "double" },
|
||||||
|
{ "System.Byte?", "uint32" },
|
||||||
|
{ "System.SByte?", "int32" },
|
||||||
|
{ "System.Int16?", "int32" },
|
||||||
|
{ "System.UInt16?", "uint32" },
|
||||||
|
{ "System.Decimal?", "string" },
|
||||||
|
{ "System.DateTime?", "int64" },
|
||||||
|
{ "System.DateTimeOffset?", "int64" },
|
||||||
|
{ "System.Guid?", "string" },
|
||||||
|
{ "System.TimeSpan?", "int64" },
|
||||||
|
};
|
||||||
|
|
||||||
|
public static string MapToProtoType(string csharpType, out bool isRepeated, out bool isOptional)
|
||||||
|
{
|
||||||
|
isRepeated = false;
|
||||||
|
isOptional = false;
|
||||||
|
|
||||||
|
// Handle byte[] as bytes proto type (NOT repeated uint32)
|
||||||
|
if (csharpType == "System.Byte[]" || csharpType == "byte[]" || csharpType == "Byte[]")
|
||||||
{
|
{
|
||||||
// Primitives
|
return "bytes";
|
||||||
{ "System.String", "string" },
|
|
||||||
{ "System.Boolean", "bool" },
|
|
||||||
{ "System.Int32", "int32" },
|
|
||||||
{ "System.Int64", "int64" },
|
|
||||||
{ "System.UInt32", "uint32" },
|
|
||||||
{ "System.UInt64", "uint64" },
|
|
||||||
{ "System.Single", "float" },
|
|
||||||
{ "System.Double", "double" },
|
|
||||||
{ "System.Byte", "uint32" },
|
|
||||||
{ "System.SByte", "int32" },
|
|
||||||
{ "System.Int16", "int32" },
|
|
||||||
{ "System.UInt16", "uint32" },
|
|
||||||
{ "System.Decimal", "string" }, // Decimal as string to preserve precision
|
|
||||||
{ "System.DateTime", "int64" }, // Unix timestamp
|
|
||||||
{ "System.DateTimeOffset", "int64" }, // Unix timestamp
|
|
||||||
{ "System.Guid", "string" },
|
|
||||||
{ "System.TimeSpan", "int64" }, // Ticks
|
|
||||||
|
|
||||||
// Nullable variants
|
|
||||||
{ "System.Boolean?", "bool" },
|
|
||||||
{ "System.Int32?", "int32" },
|
|
||||||
{ "System.Int64?", "int64" },
|
|
||||||
{ "System.UInt32?", "uint32" },
|
|
||||||
{ "System.UInt64?", "uint64" },
|
|
||||||
{ "System.Single?", "float" },
|
|
||||||
{ "System.Double?", "double" },
|
|
||||||
{ "System.Byte?", "uint32" },
|
|
||||||
{ "System.SByte?", "int32" },
|
|
||||||
{ "System.Int16?", "int32" },
|
|
||||||
{ "System.UInt16?", "uint32" },
|
|
||||||
{ "System.Decimal?", "string" },
|
|
||||||
{ "System.DateTime?", "int64" },
|
|
||||||
{ "System.DateTimeOffset?", "int64" },
|
|
||||||
{ "System.Guid?", "string" },
|
|
||||||
{ "System.TimeSpan?", "int64" },
|
|
||||||
};
|
|
||||||
|
|
||||||
public static string MapToProtoType(string csharpType, out bool isRepeated, out bool isOptional)
|
|
||||||
{
|
|
||||||
isRepeated = false;
|
|
||||||
isOptional = false;
|
|
||||||
|
|
||||||
// Handle byte[] as bytes proto type (NOT repeated uint32)
|
|
||||||
if (csharpType == "System.Byte[]" || csharpType == "byte[]" || csharpType == "Byte[]")
|
|
||||||
{
|
|
||||||
return "bytes";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle arrays
|
|
||||||
if (csharpType.EndsWith("[]"))
|
|
||||||
{
|
|
||||||
isRepeated = true;
|
|
||||||
var elementType = csharpType.Substring(0, csharpType.Length - 2);
|
|
||||||
return MapToProtoType(elementType, out _, out _);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle generic collections
|
|
||||||
if (csharpType.StartsWith("System.Collections.Generic.List<") ||
|
|
||||||
csharpType.StartsWith("System.Collections.Generic.IList<") ||
|
|
||||||
csharpType.StartsWith("System.Collections.Generic.IEnumerable<") ||
|
|
||||||
csharpType.StartsWith("System.Collections.Generic.ICollection<"))
|
|
||||||
{
|
|
||||||
isRepeated = true;
|
|
||||||
var startIndex = csharpType.IndexOf('<') + 1;
|
|
||||||
var endIndex = csharpType.LastIndexOf('>');
|
|
||||||
var elementType = csharpType.Substring(startIndex, endIndex - startIndex);
|
|
||||||
return MapToProtoType(elementType, out _, out _);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle nullable value types
|
|
||||||
if (csharpType.EndsWith("?"))
|
|
||||||
{
|
|
||||||
isOptional = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if it's a known primitive type
|
|
||||||
if (TypeMap.TryGetValue(csharpType, out var protoType))
|
|
||||||
{
|
|
||||||
return protoType;
|
|
||||||
}
|
|
||||||
|
|
||||||
// For unknown types, assume it's a custom message type
|
|
||||||
// Extract just the type name without namespace
|
|
||||||
var lastDot = csharpType.LastIndexOf('.');
|
|
||||||
if (lastDot >= 0)
|
|
||||||
{
|
|
||||||
return csharpType.Substring(lastDot + 1).Replace("?", "");
|
|
||||||
}
|
|
||||||
|
|
||||||
return csharpType.Replace("?", "");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Handle arrays
|
||||||
|
if (csharpType.EndsWith("[]"))
|
||||||
|
{
|
||||||
|
isRepeated = true;
|
||||||
|
var elementType = csharpType.Substring(0, csharpType.Length - 2);
|
||||||
|
return MapToProtoType(elementType, out _, out _);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle generic collections
|
||||||
|
if (csharpType.StartsWith("System.Collections.Generic.List<") ||
|
||||||
|
csharpType.StartsWith("System.Collections.Generic.IList<") ||
|
||||||
|
csharpType.StartsWith("System.Collections.Generic.IEnumerable<") ||
|
||||||
|
csharpType.StartsWith("System.Collections.Generic.ICollection<"))
|
||||||
|
{
|
||||||
|
isRepeated = true;
|
||||||
|
var startIndex = csharpType.IndexOf('<') + 1;
|
||||||
|
var endIndex = csharpType.LastIndexOf('>');
|
||||||
|
var elementType = csharpType.Substring(startIndex, endIndex - startIndex);
|
||||||
|
return MapToProtoType(elementType, out _, out _);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle nullable value types
|
||||||
|
if (csharpType.EndsWith("?"))
|
||||||
|
{
|
||||||
|
isOptional = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if it's a known primitive type
|
||||||
|
if (TypeMap.TryGetValue(csharpType, out var protoType))
|
||||||
|
{
|
||||||
|
return protoType;
|
||||||
|
}
|
||||||
|
|
||||||
|
// For unknown types, assume it's a custom message type
|
||||||
|
// Extract just the type name without namespace
|
||||||
|
var lastDot = csharpType.LastIndexOf('.');
|
||||||
|
if (lastDot >= 0)
|
||||||
|
{
|
||||||
|
return csharpType.Substring(lastDot + 1).Replace("?", "");
|
||||||
|
}
|
||||||
|
|
||||||
|
return csharpType.Replace("?", "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,83 +1,82 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Microsoft.CodeAnalysis;
|
using Microsoft.CodeAnalysis;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Grpc.Generators.Models
|
namespace Svrnty.CQRS.Grpc.Generators.Models;
|
||||||
|
|
||||||
|
public class CommandInfo
|
||||||
{
|
{
|
||||||
public class CommandInfo
|
public string Name { get; set; }
|
||||||
|
public string FullyQualifiedName { get; set; }
|
||||||
|
public string Namespace { get; set; }
|
||||||
|
public List<PropertyInfo> Properties { get; set; }
|
||||||
|
public string? ResultType { get; set; }
|
||||||
|
public string? ResultFullyQualifiedName { get; set; }
|
||||||
|
public bool HasResult => ResultType != null;
|
||||||
|
public string HandlerInterfaceName { get; set; }
|
||||||
|
public List<PropertyInfo> ResultProperties { get; set; }
|
||||||
|
public bool IsResultPrimitiveType { get; set; }
|
||||||
|
|
||||||
|
public CommandInfo()
|
||||||
{
|
{
|
||||||
public string Name { get; set; }
|
Name = string.Empty;
|
||||||
public string FullyQualifiedName { get; set; }
|
FullyQualifiedName = string.Empty;
|
||||||
public string Namespace { get; set; }
|
Namespace = string.Empty;
|
||||||
public List<PropertyInfo> Properties { get; set; }
|
Properties = new List<PropertyInfo>();
|
||||||
public string? ResultType { get; set; }
|
HandlerInterfaceName = string.Empty;
|
||||||
public string? ResultFullyQualifiedName { get; set; }
|
ResultProperties = new List<PropertyInfo>();
|
||||||
public bool HasResult => ResultType != null;
|
IsResultPrimitiveType = false;
|
||||||
public string HandlerInterfaceName { get; set; }
|
}
|
||||||
public List<PropertyInfo> ResultProperties { get; set; }
|
}
|
||||||
public bool IsResultPrimitiveType { get; set; }
|
|
||||||
|
public class PropertyInfo
|
||||||
public CommandInfo()
|
{
|
||||||
{
|
public string Name { get; set; }
|
||||||
Name = string.Empty;
|
public string Type { get; set; }
|
||||||
FullyQualifiedName = string.Empty;
|
public string FullyQualifiedType { get; set; }
|
||||||
Namespace = string.Empty;
|
public string ProtoType { get; set; }
|
||||||
Properties = new List<PropertyInfo>();
|
public int FieldNumber { get; set; }
|
||||||
HandlerInterfaceName = string.Empty;
|
public bool IsComplexType { get; set; }
|
||||||
ResultProperties = new List<PropertyInfo>();
|
public List<PropertyInfo> NestedProperties { get; set; }
|
||||||
IsResultPrimitiveType = false;
|
|
||||||
}
|
// Type conversion metadata
|
||||||
}
|
public bool IsEnum { get; set; }
|
||||||
|
public bool IsList { get; set; }
|
||||||
public class PropertyInfo
|
public bool IsNullable { get; set; }
|
||||||
{
|
public bool IsDecimal { get; set; }
|
||||||
public string Name { get; set; }
|
public bool IsDateTime { get; set; }
|
||||||
public string Type { get; set; }
|
public bool IsDateTimeOffset { get; set; }
|
||||||
public string FullyQualifiedType { get; set; }
|
public bool IsGuid { get; set; }
|
||||||
public string ProtoType { get; set; }
|
public bool IsJsonElement { get; set; }
|
||||||
public int FieldNumber { get; set; }
|
public bool IsBinaryType { get; set; } // Stream, byte[], MemoryStream
|
||||||
public bool IsComplexType { get; set; }
|
public bool IsStream { get; set; } // Specifically Stream types (not byte[])
|
||||||
public List<PropertyInfo> NestedProperties { get; set; }
|
public bool IsReadOnly { get; set; } // Read-only/computed properties should be skipped
|
||||||
|
public bool IsValueTypeCollection { get; set; } // Value types that implement IList<T> (like NpgsqlPolygon)
|
||||||
// Type conversion metadata
|
public string? ElementType { get; set; }
|
||||||
public bool IsEnum { get; set; }
|
public bool IsElementComplexType { get; set; }
|
||||||
public bool IsList { get; set; }
|
public bool IsElementGuid { get; set; }
|
||||||
public bool IsNullable { get; set; }
|
public List<PropertyInfo>? ElementNestedProperties { get; set; }
|
||||||
public bool IsDecimal { get; set; }
|
|
||||||
public bool IsDateTime { get; set; }
|
public PropertyInfo()
|
||||||
public bool IsDateTimeOffset { get; set; }
|
{
|
||||||
public bool IsGuid { get; set; }
|
Name = string.Empty;
|
||||||
public bool IsJsonElement { get; set; }
|
Type = string.Empty;
|
||||||
public bool IsBinaryType { get; set; } // Stream, byte[], MemoryStream
|
FullyQualifiedType = string.Empty;
|
||||||
public bool IsStream { get; set; } // Specifically Stream types (not byte[])
|
ProtoType = string.Empty;
|
||||||
public bool IsReadOnly { get; set; } // Read-only/computed properties should be skipped
|
IsComplexType = false;
|
||||||
public bool IsValueTypeCollection { get; set; } // Value types that implement IList<T> (like NpgsqlPolygon)
|
NestedProperties = new List<PropertyInfo>();
|
||||||
public string? ElementType { get; set; }
|
IsEnum = false;
|
||||||
public bool IsElementComplexType { get; set; }
|
IsList = false;
|
||||||
public bool IsElementGuid { get; set; }
|
IsNullable = false;
|
||||||
public List<PropertyInfo>? ElementNestedProperties { get; set; }
|
IsDecimal = false;
|
||||||
|
IsDateTime = false;
|
||||||
public PropertyInfo()
|
IsDateTimeOffset = false;
|
||||||
{
|
IsGuid = false;
|
||||||
Name = string.Empty;
|
IsJsonElement = false;
|
||||||
Type = string.Empty;
|
IsBinaryType = false;
|
||||||
FullyQualifiedType = string.Empty;
|
IsStream = false;
|
||||||
ProtoType = string.Empty;
|
IsReadOnly = false;
|
||||||
IsComplexType = false;
|
IsValueTypeCollection = false;
|
||||||
NestedProperties = new List<PropertyInfo>();
|
IsElementComplexType = false;
|
||||||
IsEnum = false;
|
IsElementGuid = false;
|
||||||
IsList = false;
|
|
||||||
IsNullable = false;
|
|
||||||
IsDecimal = false;
|
|
||||||
IsDateTime = false;
|
|
||||||
IsDateTimeOffset = false;
|
|
||||||
IsGuid = false;
|
|
||||||
IsJsonElement = false;
|
|
||||||
IsBinaryType = false;
|
|
||||||
IsStream = false;
|
|
||||||
IsReadOnly = false;
|
|
||||||
IsValueTypeCollection = false;
|
|
||||||
IsElementComplexType = false;
|
|
||||||
IsElementGuid = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,28 +1,27 @@
|
|||||||
namespace Svrnty.CQRS.Grpc.Generators.Models
|
namespace Svrnty.CQRS.Grpc.Generators.Models;
|
||||||
{
|
|
||||||
public class DynamicQueryInfo
|
|
||||||
{
|
|
||||||
public string Name { get; set; }
|
|
||||||
public string SourceType { get; set; }
|
|
||||||
public string SourceTypeFullyQualified { get; set; }
|
|
||||||
public string DestinationType { get; set; }
|
|
||||||
public string DestinationTypeFullyQualified { get; set; }
|
|
||||||
public string? ParamsType { get; set; }
|
|
||||||
public string? ParamsTypeFullyQualified { get; set; }
|
|
||||||
public string HandlerInterfaceName { get; set; }
|
|
||||||
public string QueryInterfaceName { get; set; }
|
|
||||||
public bool HasParams { get; set; }
|
|
||||||
|
|
||||||
public DynamicQueryInfo()
|
public class DynamicQueryInfo
|
||||||
{
|
{
|
||||||
Name = string.Empty;
|
public string Name { get; set; }
|
||||||
SourceType = string.Empty;
|
public string SourceType { get; set; }
|
||||||
SourceTypeFullyQualified = string.Empty;
|
public string SourceTypeFullyQualified { get; set; }
|
||||||
DestinationType = string.Empty;
|
public string DestinationType { get; set; }
|
||||||
DestinationTypeFullyQualified = string.Empty;
|
public string DestinationTypeFullyQualified { get; set; }
|
||||||
HandlerInterfaceName = string.Empty;
|
public string? ParamsType { get; set; }
|
||||||
QueryInterfaceName = string.Empty;
|
public string? ParamsTypeFullyQualified { get; set; }
|
||||||
HasParams = false;
|
public string HandlerInterfaceName { get; set; }
|
||||||
}
|
public string QueryInterfaceName { get; set; }
|
||||||
|
public bool HasParams { get; set; }
|
||||||
|
|
||||||
|
public DynamicQueryInfo()
|
||||||
|
{
|
||||||
|
Name = string.Empty;
|
||||||
|
SourceType = string.Empty;
|
||||||
|
SourceTypeFullyQualified = string.Empty;
|
||||||
|
DestinationType = string.Empty;
|
||||||
|
DestinationTypeFullyQualified = string.Empty;
|
||||||
|
HandlerInterfaceName = string.Empty;
|
||||||
|
QueryInterfaceName = string.Empty;
|
||||||
|
HasParams = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,50 +1,49 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Grpc.Generators.Models
|
namespace Svrnty.CQRS.Grpc.Generators.Models;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Represents a discovered streaming notification type for proto/gRPC generation.
|
||||||
|
/// </summary>
|
||||||
|
public class NotificationInfo
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Represents a discovered streaming notification type for proto/gRPC generation.
|
/// The notification type name (e.g., "InventoryChangeNotification").
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class NotificationInfo
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The fully qualified type name including namespace.
|
||||||
|
/// </summary>
|
||||||
|
public string FullyQualifiedName { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The namespace of the notification type.
|
||||||
|
/// </summary>
|
||||||
|
public string Namespace { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The property name used as the subscription key (from [StreamingNotification] attribute).
|
||||||
|
/// </summary>
|
||||||
|
public string SubscriptionKeyProperty { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The subscription key property info.
|
||||||
|
/// </summary>
|
||||||
|
public PropertyInfo SubscriptionKeyInfo { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// All properties of the notification type.
|
||||||
|
/// </summary>
|
||||||
|
public List<PropertyInfo> Properties { get; set; }
|
||||||
|
|
||||||
|
public NotificationInfo()
|
||||||
{
|
{
|
||||||
/// <summary>
|
Name = string.Empty;
|
||||||
/// The notification type name (e.g., "InventoryChangeNotification").
|
FullyQualifiedName = string.Empty;
|
||||||
/// </summary>
|
Namespace = string.Empty;
|
||||||
public string Name { get; set; }
|
SubscriptionKeyProperty = string.Empty;
|
||||||
|
SubscriptionKeyInfo = new PropertyInfo();
|
||||||
/// <summary>
|
Properties = new List<PropertyInfo>();
|
||||||
/// The fully qualified type name including namespace.
|
|
||||||
/// </summary>
|
|
||||||
public string FullyQualifiedName { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The namespace of the notification type.
|
|
||||||
/// </summary>
|
|
||||||
public string Namespace { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The property name used as the subscription key (from [StreamingNotification] attribute).
|
|
||||||
/// </summary>
|
|
||||||
public string SubscriptionKeyProperty { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// The subscription key property info.
|
|
||||||
/// </summary>
|
|
||||||
public PropertyInfo SubscriptionKeyInfo { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// All properties of the notification type.
|
|
||||||
/// </summary>
|
|
||||||
public List<PropertyInfo> Properties { get; set; }
|
|
||||||
|
|
||||||
public NotificationInfo()
|
|
||||||
{
|
|
||||||
Name = string.Empty;
|
|
||||||
FullyQualifiedName = string.Empty;
|
|
||||||
Namespace = string.Empty;
|
|
||||||
SubscriptionKeyProperty = string.Empty;
|
|
||||||
SubscriptionKeyInfo = new PropertyInfo();
|
|
||||||
Properties = new List<PropertyInfo>();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,30 +1,29 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.Grpc.Generators.Models
|
namespace Svrnty.CQRS.Grpc.Generators.Models;
|
||||||
{
|
|
||||||
public class QueryInfo
|
|
||||||
{
|
|
||||||
public string Name { get; set; }
|
|
||||||
public string FullyQualifiedName { get; set; }
|
|
||||||
public string Namespace { get; set; }
|
|
||||||
public List<PropertyInfo> Properties { get; set; }
|
|
||||||
public string ResultType { get; set; }
|
|
||||||
public string ResultFullyQualifiedName { get; set; }
|
|
||||||
public string HandlerInterfaceName { get; set; }
|
|
||||||
public List<PropertyInfo> ResultProperties { get; set; }
|
|
||||||
public bool IsResultPrimitiveType { get; set; }
|
|
||||||
|
|
||||||
public QueryInfo()
|
public class QueryInfo
|
||||||
{
|
{
|
||||||
Name = string.Empty;
|
public string Name { get; set; }
|
||||||
FullyQualifiedName = string.Empty;
|
public string FullyQualifiedName { get; set; }
|
||||||
Namespace = string.Empty;
|
public string Namespace { get; set; }
|
||||||
Properties = new List<PropertyInfo>();
|
public List<PropertyInfo> Properties { get; set; }
|
||||||
ResultType = string.Empty;
|
public string ResultType { get; set; }
|
||||||
ResultFullyQualifiedName = string.Empty;
|
public string ResultFullyQualifiedName { get; set; }
|
||||||
HandlerInterfaceName = string.Empty;
|
public string HandlerInterfaceName { get; set; }
|
||||||
ResultProperties = new List<PropertyInfo>();
|
public List<PropertyInfo> ResultProperties { get; set; }
|
||||||
IsResultPrimitiveType = false;
|
public bool IsResultPrimitiveType { get; set; }
|
||||||
}
|
|
||||||
|
public QueryInfo()
|
||||||
|
{
|
||||||
|
Name = string.Empty;
|
||||||
|
FullyQualifiedName = string.Empty;
|
||||||
|
Namespace = string.Empty;
|
||||||
|
Properties = new List<PropertyInfo>();
|
||||||
|
ResultType = string.Empty;
|
||||||
|
ResultFullyQualifiedName = string.Empty;
|
||||||
|
HandlerInterfaceName = string.Empty;
|
||||||
|
ResultProperties = new List<PropertyInfo>();
|
||||||
|
IsResultPrimitiveType = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,3 +1,4 @@
|
|||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Svrnty.CQRS.Abstractions;
|
using Svrnty.CQRS.Abstractions;
|
||||||
using Svrnty.CQRS.Discovery;
|
using Svrnty.CQRS.Discovery;
|
||||||
@ -43,7 +44,7 @@ public class CqrsBuilder
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Adds a command handler to the CQRS pipeline
|
/// Adds a command handler to the CQRS pipeline
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public CqrsBuilder AddCommand<TCommand, TCommandHandler>()
|
public CqrsBuilder AddCommand<TCommand, [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicConstructors)] TCommandHandler>()
|
||||||
where TCommand : class
|
where TCommand : class
|
||||||
where TCommandHandler : class, ICommandHandler<TCommand>
|
where TCommandHandler : class, ICommandHandler<TCommand>
|
||||||
{
|
{
|
||||||
@ -54,7 +55,7 @@ public class CqrsBuilder
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Adds a command handler with result to the CQRS pipeline
|
/// Adds a command handler with result to the CQRS pipeline
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public CqrsBuilder AddCommand<TCommand, TResult, TCommandHandler>()
|
public CqrsBuilder AddCommand<TCommand, TResult, [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicConstructors)] TCommandHandler>()
|
||||||
where TCommand : class
|
where TCommand : class
|
||||||
where TCommandHandler : class, ICommandHandler<TCommand, TResult>
|
where TCommandHandler : class, ICommandHandler<TCommand, TResult>
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Svrnty.CQRS.Abstractions.Discovery;
|
using Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Svrnty.CQRS.Abstractions.Discovery;
|
using Svrnty.CQRS.Abstractions.Discovery;
|
||||||
|
|||||||
@ -26,6 +26,10 @@
|
|||||||
<None Include="..\README.md" Pack="true" PackagePath="" CopyToOutputDirectory="Always" />
|
<None Include="..\README.md" Pack="true" PackagePath="" CopyToOutputDirectory="Always" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<FrameworkReference Include="Microsoft.AspNetCore.App" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\Svrnty.CQRS.Abstractions\Svrnty.CQRS.Abstractions.csproj" />
|
<ProjectReference Include="..\Svrnty.CQRS.Abstractions\Svrnty.CQRS.Abstractions.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|||||||
@ -2,7 +2,7 @@ using Microsoft.AspNetCore.Builder;
|
|||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Svrnty.CQRS.Configuration;
|
using Svrnty.CQRS.Configuration;
|
||||||
|
|
||||||
namespace Svrnty.CQRS.MinimalApi;
|
namespace Svrnty.CQRS;
|
||||||
|
|
||||||
public static class WebApplicationExtensions
|
public static class WebApplicationExtensions
|
||||||
{
|
{
|
||||||
@ -1,11 +1,11 @@
|
|||||||
using Microsoft.AspNetCore.Server.Kestrel.Core;
|
using Microsoft.AspNetCore.Server.Kestrel.Core;
|
||||||
using Svrnty.CQRS;
|
using Svrnty.CQRS;
|
||||||
|
using Svrnty.CQRS.Abstractions;
|
||||||
|
using Svrnty.CQRS.DynamicQuery;
|
||||||
using Svrnty.CQRS.FluentValidation;
|
using Svrnty.CQRS.FluentValidation;
|
||||||
using Svrnty.CQRS.Grpc;
|
using Svrnty.CQRS.Grpc;
|
||||||
using Svrnty.Sample;
|
|
||||||
using Svrnty.CQRS.MinimalApi;
|
using Svrnty.CQRS.MinimalApi;
|
||||||
using Svrnty.CQRS.DynamicQuery;
|
using Svrnty.Sample;
|
||||||
using Svrnty.CQRS.Abstractions;
|
|
||||||
|
|
||||||
var builder = WebApplication.CreateBuilder(args);
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
using PoweredSoft.Data.Core;
|
|
||||||
using System.Linq.Expressions;
|
using System.Linq.Expressions;
|
||||||
|
using PoweredSoft.Data.Core;
|
||||||
|
|
||||||
namespace Svrnty.Sample;
|
namespace Svrnty.Sample;
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user