Schemata.Mapping.Foundation 9.0.0-preview.25270.29

This is a prerelease version of Schemata.Mapping.Foundation.
dotnet add package Schemata.Mapping.Foundation --version 9.0.0-preview.25270.29
                    
NuGet\Install-Package Schemata.Mapping.Foundation -Version 9.0.0-preview.25270.29
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Schemata.Mapping.Foundation" Version="9.0.0-preview.25270.29" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Schemata.Mapping.Foundation" Version="9.0.0-preview.25270.29" />
                    
Directory.Packages.props
<PackageReference Include="Schemata.Mapping.Foundation" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Schemata.Mapping.Foundation --version 9.0.0-preview.25270.29
                    
#r "nuget: Schemata.Mapping.Foundation, 9.0.0-preview.25270.29"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Schemata.Mapping.Foundation@9.0.0-preview.25270.29
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Schemata.Mapping.Foundation&version=9.0.0-preview.25270.29&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Schemata.Mapping.Foundation&version=9.0.0-preview.25270.29&prerelease
                    
Install as a Cake Tool

Schemata

Application Framework aims on modular business applications.

GitHub Workflow Status Codecov license

netstandard2.0 netstandard2.1 net8.0 net9.0

Quick Start

dotnet new web
dotnet add package --prerelease Schemata.Application.Complex.Targets
var builder = WebApplication.CreateBuilder(args)
                            .UseSchemata(schema => {
                                 schema.UseLogging();
                                 schema.UseDeveloperExceptionPage();

                                 schema.ConfigureServices(services => {
                                     services.AddTransient(typeof(IRepositoryAddAsyncAdvice<>), typeof(MyAdviceAddAsync<>));

                                     services.AddRepository(typeof(MyRepository<>))
                                             .UseEntityFrameworkCore<MyDbContext>((sp, options) => options.UseSqlServer(schema.Configuration.GetConnectionString("Default")));

                                     services.AddDistributedMemoryCache();
                                 });

                                 schema.UseForwardedHeaders();
                                 schema.UseHttps();
                                 schema.UseCookiePolicy();

                                 schema.UseSession();

                                 schema.UseCors();
                                 schema.UseRouting();
                                 schema.UseControllers();
                                 schema.UseJsonSerializer();

                                 schema.UseTenancy()
                                       .UseHostResolver();
                                 schema.UseModular();

                                 schema.UseSecurity();
                                 schema.UseIdentity();
                                 schema.UseAuthorization(options => {
                                            options.AddEphemeralEncryptionKey()
                                                   .AddEphemeralSigningKey();
                                        })
                                       .UseCodeFlow()
                                       .UseRefreshTokenFlow()
                                       .UseDeviceFlow()
                                       .UseIntrospection()
                                       .UseCaching();
                                 schema.UseWorkflow();

                                 // You can also utilize UseAutoMapper() once you've incorporated the Schemata.Mapping.AutoMapper package into your project.
                                 schema.UseMapster()
                                       .Map<Source, Destination>(map => {
                                            map.For(d => d.DisplayName).From(s => s.Name);
                                            map.For(d => d.Age).From(s => s.Age).Ignore((s, d) => s.Age < 18);
                                            map.For(d => d.Grade).Ignore()
                                               .For(d => d.Sex).From(s => s.Sex.ToString());
                                        });

                                 schema.UseResource()
                                       .MapHttp()
                             });

var app = builder.Build();

app.Run();

Fields

Features

Features are modular components that can be integrated during the application startup process.

Each feature must implement the ISimpleFeature interface.

Features are characterized by Order and Priority, both of which are Int32 values. The Order determines the sequence in which the ConfigureServices methods are invoked. The Priority establishes the sequence for invoking the Configure<Application|Endpoints> methods.

The range [100_000_000, 1_000_000_000) and (2_147_000_000, 2_147_400_000] for Order and Priority is reserved for built-in features and Schemata extensions.

Built-in Features

A built-in feature can be activated by calling the UseXXX method on the SchemataBuilder instance. These features may also have additional configuration methods.

Priority Feature Description
100_010_000 ExceptionHandler Asp.Net Exception Handler Middleware
100_110_000 Logging Asp.Net Logging Middleware
100_120_000 HttpLogging Asp.Net HTTP Logging Middleware
100_130_000 W3CLogging Asp.Net W3C Logging Middleware
110_000_000 DeveloperExceptionPage Asp.Net Developer Exception Page Middleware
111_000_000 ForwardedHeaders Asp.Net Forwarded Headers Middleware
120_000_000 Https Asp.Net HTTPS & HTTPS Redirection Middlewares
130_000_000 CookiePolicy Asp.Net Cookie Policy Middleware
140_000_000 Routing Asp.Net Routing Middleware
141_100_000 Quota Asp.Net Rate Limiter Middleware
150_000_000 Cors Asp.Net CORS Middleware
160_000_000 Authentication Asp.Net Authentication & Authorization Middlewares
170_000_000 Session Asp.Net Session Middleware
210_000_000 Controllers Asp.Net MVC Middlewares, without Views
210_100_000 JsonSerializer Configure System.Text.Json to use snake_case and handle JavaScript's 53-bits integers

Extension Features

An extension feature can be activated in the same way as a built-in feature.

Priority Package Feature Description
300_100_000 Schemata.Security.Foundation Security Schemata Security Foundation
310_000_000 Schemata.Identity.Foundation Identity Schemata Identity Foundation
320_000_000 Schemata.Authorization.Foundation Authorization Schemata Authorization Foundation
340_000_000 Schemata.Mapping.Foundation Mapping Schemata Mapper Foundation
350_000_000 Schemata.Workflow.Foundation Workflow Schemata Workflow Foundation
360_000_000 Schemata.Resource.Foundation Resource Schemata Resource Service
360_100_000 Schemata.Resource.Http Resource (MapHttp) Schemata Resource Service for HTTP
2_147_100_000 Schemata.Tenancy.Foundation Tenancy Schemata Tenancy Foundation
2_147_200_000 Schemata.Modular Modular Modularization

Compliance

Schemata is designed to be compatible with .NET Standard 2.0, .NET Standard 2.1, the latest .NET Long-Term Support (LTS) version, and the most recent .NET version.

Some packages may have additional compliance requirements, which are documented below.

Package Compliance
Schemata.DSL netstandard2.0
Schemata.Core net8.0 net9.0
Schemata.Modular net8.0 net9.0
Schemata.Authorization.Foundation net8.0 net9.0
Schemata.Identity.Foundation net8.0 net9.0
Schemata.Mapping.Foundation net8.0 net9.0
Schemata.Resource.Foundation net8.0 net9.0
Schemata.Security.Foundation net8.0 net9.0
Schemata.Tenancy.Foundation net8.0 net9.0
Schemata.Workflow.Foundation net8.0 net9.0

Schemata.Authorization.Foundation

Schemata Authorization Foundation is designed to comply with the OpenID Connect Core 1.0 specification.

Schemata.Identity.Foundation

Schemata Identity Foundation is designed to comply with Asp.Net Core Identity.

Additionally, we bring the Bearer Token Authentication Scheme and Core Identity API to platforms that do not support it.

Schemata.Mapping.Foundation

The Schemata Mapping Foundation is designed to be compatible with various mapping libraries, including AutoMapper and Mapster, among others.

It provides a unified interface for these libraries, enabling developers to switch between them without modifying their codes.

Schemata.Resource.Foundation

The Schemata Resource Foundation is designed to comply with the API Improvement Proposals - General AIPs proposals.

Schemata.Workflow.Foundation

Unfortunately, the Schemata Workflow Foundation is not yet compliant with enterprise standards such as BPMN 2.0.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Schemata.Mapping.Foundation:

Package Downloads
Schemata.Workflow.Foundation

Schemata Application Framework - Workflow Foundation

Schemata.Mapping.Mapster

Schemata Application Framework - Mapper (using Mapster)

Schemata.Mapping.AutoMapper

Schemata Application Framework - Mapper (using AutoMapper)

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
9.0.0-preview.25270.29 161 5/20/2025
9.0.0-preview.25270.23 131 5/20/2025
9.0.0-preview.25269.38 133 5/19/2025
9.0.0-preview.25262.61 214 5/12/2025
9.0.0-preview.25262.14 173 5/12/2025
9.0.0-preview.25261.47 126 5/11/2025
9.0.0-preview.25255.55 138 5/5/2025
9.0.0-preview.25251.34 135 5/1/2025
9.0.0-preview.25251.30 132 5/1/2025
9.0.0-preview.25251.21 135 5/1/2025
9.0.0-preview.25230.59 133 4/30/2025
9.0.0-preview.25162.44 152 3/12/2025
9.0.0-preview.25154.28 191 3/4/2025
9.0.0-preview.25154.27 183 3/4/2025
9.0.0-preview.25153.54 131 3/3/2025
9.0.0-preview.25128.36 77 2/28/2025
9.0.0-preview.25128.31 69 2/28/2025
1.0.0-preview.24370.42 111 7/20/2024
1.0.0-preview.24305.58 89 6/5/2024
1.0.0-preview.24259.22 93 5/9/2024
1.0.0-preview.24230.15 93 4/30/2024
1.0.0-preview.24227.10 99 4/27/2024
1.0.0-preview.24226.92 84 4/26/2024
1.0.0-preview.24226.39 95 4/26/2024
1.0.0-preview.24225.65 95 4/25/2024
1.0.0-preview.24225.61 88 4/25/2024
1.0.0-preview.24225.33 79 4/25/2024
1.0.0-preview.24224.26 89 4/24/2024
1.0.0-preview.24223.62 86 4/23/2024
1.0.0-preview.24223.23 89 4/23/2024
1.0.0-preview.24222.70 88 4/22/2024
1.0.0-preview.24222.23 96 4/22/2024
1.0.0-preview.24222.21 91 4/22/2024
1.0.0-preview.24222.20 96 4/22/2024
1.0.0-preview.24221.62 95 4/21/2024
1.0.0-preview.24221.60 90 4/21/2024
1.0.0-preview.24219.37 91 4/19/2024
1.0.0-preview.24219.35 85 4/19/2024
1.0.0-preview.24218.65 84 4/18/2024
1.0.0-preview.24217.50 112 4/17/2024
1.0.0-preview.24217.16 96 4/17/2024
1.0.0-preview.24217.15 91 4/17/2024
1.0.0-preview.24217.9 86 4/17/2024
1.0.0-preview.24216.60 95 4/16/2024
1.0.0-preview.24216.55 96 4/16/2024
1.0.0-preview.24215.70 80 4/15/2024
1.0.0-preview.24213.26 91 4/13/2024
1.0.0-preview.24213.25 89 4/13/2024
1.0.0-preview.24213.21 91 4/13/2024
1.0.0-preview.24213.20 89 4/13/2024
1.0.0-preview.24213.11 101 4/13/2024
1.0.0-preview.24213.8 100 4/13/2024
1.0.0-preview.24213.5 92 4/13/2024
1.0.0-preview.24212.62 84 4/12/2024
1.0.0-preview.24212.52 89 4/12/2024
1.0.0-preview.24212.51 93 4/12/2024
1.0.0-preview.24212.43 92 4/12/2024
1.0.0-preview.24212.37 99 4/12/2024
1.0.0-preview.24212.36 90 4/12/2024
1.0.0-preview.24212.29 89 4/12/2024
1.0.0-preview.24212.24 97 4/12/2024
1.0.0-preview.24212.17 91 4/12/2024
1.0.0-preview.24211.59 91 4/11/2024
1.0.0-preview.24211.57 80 4/11/2024
1.0.0-preview.24211.54 90 4/11/2024
1.0.0-preview.24211.51 86 4/11/2024
1.0.0-preview.24211.50 92 4/11/2024
1.0.0-preview.24211.49 84 4/11/2024
1.0.0-preview.24211.47 89 4/11/2024
1.0.0-preview.24211.24 100 4/11/2024
1.0.0-preview.24211.23 96 4/11/2024
1.0.0-preview.24211.21 87 4/11/2024
1.0.0-preview.24211.18 88 4/11/2024
1.0.0-preview.24210.56 87 4/10/2024
1.0.0-preview.24210.52 86 4/10/2024
1.0.0-preview.24210.51 86 4/10/2024
1.0.0-preview.24210.49 84 4/10/2024
1.0.0-preview.24210.43 92 4/10/2024
1.0.0-preview.24210.42 89 4/10/2024
1.0.0-preview.24210.34 84 4/10/2024
1.0.0-preview.24210.31 88 4/10/2024
1.0.0-preview.24210.30 84 4/10/2024
1.0.0-preview.24209.57 100 4/9/2024
1.0.0-preview.24209.56 103 4/9/2024
1.0.0-preview.24209.35 96 4/9/2024
1.0.0-preview.24209.19 99 4/9/2024
1.0.0-preview.24209.9 90 4/9/2024
1.0.0-preview.24208.59 93 4/8/2024