CShells.AspNetCore
0.0.17
See the version list below for details.
dotnet add package CShells.AspNetCore --version 0.0.17
NuGet\Install-Package CShells.AspNetCore -Version 0.0.17
<PackageReference Include="CShells.AspNetCore" Version="0.0.17" />
<PackageVersion Include="CShells.AspNetCore" Version="0.0.17" />
<PackageReference Include="CShells.AspNetCore" />
paket add CShells.AspNetCore --version 0.0.17
#r "nuget: CShells.AspNetCore, 0.0.17"
#:package CShells.AspNetCore@0.0.17
#addin nuget:?package=CShells.AspNetCore&version=0.0.17
#tool nuget:?package=CShells.AspNetCore&version=0.0.17
CShells.AspNetCore
ASP.NET Core integration for CShells providing middleware and shell resolution based on HTTP context.
Purpose
This package provides ASP.NET Core middleware, shell resolution strategies, and extensions for building multi-tenant web applications with CShells.
Key Features
- HTTP middleware for shell resolution - Automatic per-request tenant/shell detection
- Host-based tenant resolution - Route requests based on hostname
- Path-based tenant resolution - Route requests based on URL path prefix
MapShells()extension - Automatically register endpoints from all shell features- Web routing configuration - Configure path prefixes and routing options per shell
- Custom shell resolvers - Extensibility for custom resolution strategies
Installation
dotnet add package CShells
dotnet add package CShells.AspNetCore
Quick Start
1. Create a Web Feature
using CShells.AspNetCore.Features;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Routing;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
[ShellFeature("Weather", DisplayName = "Weather API")]
public class WeatherFeature : IWebShellFeature
{
public void ConfigureServices(IServiceCollection services)
{
services.AddSingleton<IWeatherService, WeatherService>();
}
public void MapEndpoints(IEndpointRouteBuilder endpoints, IHostEnvironment? environment)
{
endpoints.MapGet("weather", (IWeatherService weatherService) =>
weatherService.GetForecast());
}
}
2. Configure Shells with Web Routing
{
"CShells": {
"Shells": [
{
"Name": "Default",
"Features": ["Weather"],
"Configuration": {
"WebRouting": {
"Path": ""
}
}
},
{
"Name": "Admin",
"Features": ["Admin"],
"Configuration": {
"WebRouting": {
"Path": "admin",
"RoutePrefix": "api/v1"
}
}
}
]
}
}
3. Register CShells in Program.cs
Simple setup:
var builder = WebApplication.CreateBuilder(args);
// Register CShells from configuration
builder.AddShells();
var app = builder.Build();
// Configure middleware and endpoints for all shells
app.MapShells();
app.Run();
Explicit feature assembly selection:
Use From* members to select discovery sources, and WithAssemblyProvider(...) when attaching a provider that contributes assemblies.
var builder = WebApplication.CreateBuilder(args);
builder.AddShells(cshells =>
{
cshells.WithConfigurationProvider(builder.Configuration);
cshells.FromAssemblies(typeof(Program).Assembly);
cshells.FromHostAssemblies();
});
var app = builder.Build();
app.MapShells();
app.Run();
If you do not call an assembly-source method, CShells uses the same host-derived feature assembly set as the default discovery behavior. Once you call FromAssemblies(...), FromHostAssemblies(), or WithAssemblyProvider(...), discovery switches to explicit provider mode and uses only the assemblies contributed by those appended providers.
Advanced setup with custom resolvers:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddCShellsAspNetCore(cshells =>
{
cshells.WithConfigurationProvider(builder.Configuration);
cshells.WithWebRoutingResolver(options =>
{
options.ExcludePaths = new[] { "/api", "/health" };
options.HeaderName = "X-Tenant-Id";
});
});
var app = builder.Build();
app.MapShells();
app.Run();
Shell Resolution Strategies
Path-Based Resolution
Shells are resolved based on the URL path prefix:
{
"Configuration": {
"WebRouting": {
"Path": "admin"
}
}
}
Requests to /admin/* will be routed to this shell.
Host-Based Resolution
Configure shells to respond to specific hostnames:
{
"Configuration": {
"WebRouting": {
"Host": "admin.example.com"
}
}
}
Route Prefix
Apply a route prefix to all endpoints in a shell:
{
"Configuration": {
"WebRouting": {
"Path": "tenant1",
"RoutePrefix": "api/v1"
}
}
}
With this configuration, an endpoint mapped at weather will be accessible at /tenant1/api/v1/weather.
Custom Resolution
Implement IShellResolver for custom resolution logic:
public class CustomShellResolver : IShellResolver
{
public Task<string?> ResolveShellIdAsync(HttpContext context)
{
// Custom logic to determine shell ID from HTTP context
var shellId = context.Request.Headers["X-Tenant-Id"].FirstOrDefault();
return Task.FromResult(shellId);
}
}
builder.Services.AddCShellsAspNetCore(cshells =>
{
cshells.WithResolver<CustomShellResolver>();
});
Web Routing Options
Configure routing behavior:
builder.Services.AddCShellsAspNetCore(cshells =>
{
cshells.WithWebRoutingResolver(options =>
{
// Exclude paths from shell resolution
options.ExcludePaths = new[] { "/api", "/health", "/swagger" };
// Use custom header for tenant ID
options.HeaderName = "X-Tenant-Id";
// Configure default shell
options.DefaultShell = "Default";
});
});
Learn More
- Main Documentation
- Sample Application
- CShells Package - Core runtime
| Product | Versions 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 is compatible. 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. |
-
net10.0
- CShells (>= 0.0.17)
- CShells.AspNetCore.Abstractions (>= 0.0.17)
- JetBrains.Annotations (>= 2025.2.4)
-
net8.0
- CShells (>= 0.0.17)
- CShells.AspNetCore.Abstractions (>= 0.0.17)
- JetBrains.Annotations (>= 2025.2.4)
-
net9.0
- CShells (>= 0.0.17)
- CShells.AspNetCore.Abstractions (>= 0.0.17)
- JetBrains.Annotations (>= 2025.2.4)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on CShells.AspNetCore:
| Package | Downloads |
|---|---|
|
CShells.FastEndpoints
FastEndpoints integration for CShells. Provides a shell feature that automatically discovers and registers FastEndpoints from all enabled features. Reference this package in your host application to enable FastEndpoints support. |
|
|
CShells.AspNetCore.Testing
Testing helpers for CShells ASP.NET Core integration. Provides utilities for integration tests, including shell initialization waiter for ensuring shells are fully loaded before test execution. |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on CShells.AspNetCore:
| Repository | Stars |
|---|---|
|
elsa-workflows/elsa-core
The Workflow Engine for .NET
|
| Version | Downloads | Last Updated |
|---|---|---|
| 0.0.21 | 19 | 5/12/2026 |
| 0.0.20 | 75 | 5/8/2026 |
| 0.0.19 | 106 | 5/6/2026 |
| 0.0.18 | 126 | 5/2/2026 |
| 0.0.17 | 137 | 4/29/2026 |
| 0.0.16 | 139 | 4/27/2026 |
| 0.0.15 | 130 | 4/27/2026 |
| 0.0.14 | 420 | 4/20/2026 |
| 0.0.13 | 131 | 4/17/2026 |
| 0.0.12 | 199 | 3/16/2026 |
| 0.0.11 | 211 | 2/28/2026 |
| 0.0.10 | 139 | 2/24/2026 |
| 0.0.9 | 365 | 2/15/2026 |
| 0.0.8 | 134 | 2/13/2026 |
| 0.0.7 | 146 | 2/9/2026 |
| 0.0.6 | 145 | 1/18/2026 |
| 0.0.5 | 297 | 12/18/2025 |
| 0.0.4 | 192 | 12/5/2025 |
| 0.0.3 | 207 | 12/3/2025 |
| 0.0.2 | 679 | 12/1/2025 |