Cosmos.MultiTenancy.CritterStack 0.2.0

dotnet add package Cosmos.MultiTenancy.CritterStack --version 0.2.0
                    
NuGet\Install-Package Cosmos.MultiTenancy.CritterStack -Version 0.2.0
                    
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="Cosmos.MultiTenancy.CritterStack" Version="0.2.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Cosmos.MultiTenancy.CritterStack" Version="0.2.0" />
                    
Directory.Packages.props
<PackageReference Include="Cosmos.MultiTenancy.CritterStack" />
                    
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 Cosmos.MultiTenancy.CritterStack --version 0.2.0
                    
#r "nuget: Cosmos.MultiTenancy.CritterStack, 0.2.0"
                    
#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 Cosmos.MultiTenancy.CritterStack@0.2.0
                    
#: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=Cosmos.MultiTenancy.CritterStack&version=0.2.0
                    
Install as a Cake Addin
#tool nuget:?package=Cosmos.MultiTenancy.CritterStack&version=0.2.0
                    
Install as a Cake Tool

Cosmos.MultiTenancy.CritterStack

Resolver de tenant compuesto para servicios que combinan HTTP y daemon de Wolverine (inbox/outbox) en el mismo proceso.

Descripcion

Cosmos.MultiTenancy.AspNetCore provee TrustedHeadersTenantResolver, que lee el TenantId de un header HTTP. Funciona perfecto en el flujo HTTP, pero falla en handlers ejecutados por el daemon de Wolverine porque ahi no existe HttpContext.

Este paquete completa el cuadro:

  • WolverineMessageContextTenantResolver lee el TenantId desde IMessageContext.TenantId, hidratado automaticamente por Wolverine a partir del envelope entrante.
  • CompositeTenantResolver prueba un resolver primario (HTTP) y, si tira InvalidOperationException, cae al de message context.
  • La extension method AgregarTenantResolverHibrido() registra todo lo necesario para apps que combinan ambos modos.

Instalacion

dotnet add package Cosmos.MultiTenancy.CritterStack

Uso

Apps hibridas (HTTP + daemon Wolverine)

var builder = WebApplication.CreateBuilder(args);

builder.Services.AgregarTenantResolverHibrido();

El header HTTP usado es X-Tenant-Id (decision de diseño del equipo, no es configurable).

Comportamiento del composite

CompositeTenantResolver itera factories en orden:

  1. Primer factory: TrustedHeadersTenantResolver (HTTP). Si el scope tiene HttpContext con el header configurado, retorna el valor.
  2. Si el primer factory tira InvalidOperationException, prueba el segundo: WolverineMessageContextTenantResolver. Si el scope es un handler de Wolverine con TenantId en el envelope, retorna el valor.
  3. Si ninguno resuelve, lanza InvalidOperationException con un AggregateException que detalla las fallas.

Solo InvalidOperationException triggerea el fallback. Cualquier otra excepcion se propaga, evitando enmascarar bugs reales (NRE, errores de config, etc.).

Dependencias

  • Cosmos.MultiTenancy.AspNetCore — provee TrustedHeadersTenantResolver.
  • WolverineFx — provee IMessageContext y la propagacion automatica del TenantId via envelope.

Paquetes relacionados

Requisitos

  • .NET 10.0 o superior
  • App ASP.NET Core (requiere Microsoft.AspNetCore.App via dependencia transitiva)

Licencia

Copyright © Cosmos. Todos los derechos reservados.

Product Compatible and additional computed target framework versions.
.NET 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
0.2.0 73 5/22/2026
0.1.0 80 5/22/2026