Franz.Common.Http.MultiTenancy 1.5.4

There is a newer version of this package available.
See the version list below for details.
dotnet add package Franz.Common.Http.MultiTenancy --version 1.5.4
                    
NuGet\Install-Package Franz.Common.Http.MultiTenancy -Version 1.5.4
                    
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="Franz.Common.Http.MultiTenancy" Version="1.5.4" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Franz.Common.Http.MultiTenancy" Version="1.5.4" />
                    
Directory.Packages.props
<PackageReference Include="Franz.Common.Http.MultiTenancy" />
                    
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 Franz.Common.Http.MultiTenancy --version 1.5.4
                    
#r "nuget: Franz.Common.Http.MultiTenancy, 1.5.4"
                    
#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 Franz.Common.Http.MultiTenancy@1.5.4
                    
#: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=Franz.Common.Http.MultiTenancy&version=1.5.4
                    
Install as a Cake Addin
#tool nuget:?package=Franz.Common.Http.MultiTenancy&version=1.5.4
                    
Install as a Cake Tool

Franz.Common.Http.MultiTenancy

A library within the Franz Framework that extends multi-tenancy support for HTTP-based ASP.NET Core applications. This package provides tools for tenant-specific context management, dependency injection, and Swagger documentation enhancements, enabling seamless multi-tenant application development.


Features

  • Tenant Context Management:
    • TenantContextAccessor and DomainContextAccessor for managing tenant-specific information across HTTP requests.
  • Swagger Documentation:
    • AddRequiredHeaderParameter for including tenant-specific headers in Swagger documentation.
  • Dependency Injection:
    • ServiceCollectionExtensions for integrating multi-tenancy into your services and application pipeline.

Version Information

  • Current Version: 1.5.4
  • Part of the private Franz Framework ecosystem.

Dependencies

This package relies on:

  • Microsoft.AspNetCore.Mvc.Core (2.2.5): Core MVC functionality for tenant-based HTTP applications.
  • Swashbuckle.AspNetCore.SwaggerGen (6.5.0): For Swagger generation with multi-tenancy support.
  • Franz.Common.MultiTenancy: Core multi-tenancy utilities and patterns.
  • Franz.Common.Http.Headers: Provides header utilities for tenant-specific HTTP headers.
  • Franz.Common.Http: Core HTTP utilities for multi-tenant scenarios.
  • Franz.Common.Headers: Core header management utilities.

Installation

From Private Azure Feed

Since this package is hosted privately, configure your NuGet client:

dotnet nuget add source "https://your-private-feed-url" \
  --name "AzurePrivateFeed" \
  --username "YourAzureUsername" \
  --password "YourAzurePassword" \
  --store-password-in-clear-text

Install the package:

dotnet add package Franz.Common.Http.MultiTenancy  

Usage

1. Register Multi-Tenancy Services

Use ServiceCollectionExtensions to register tenant-specific services:

using Franz.Common.Http.MultiTenancy.Extensions;

public class Startup
{
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddMultiTenancy(); // Registers multi-tenancy utilities and services
    }
}

2. Access Tenant Context

Access tenant-specific information using TenantContextAccessor or DomainContextAccessor:

using Franz.Common.Http.MultiTenancy;

public class MyService
{
    private readonly TenantContextAccessor _tenantContextAccessor;

    public MyService(TenantContextAccessor tenantContextAccessor)
    {
        _tenantContextAccessor = tenantContextAccessor;
    }

    public string GetTenantId()
    {
        return _tenantContextAccessor.Tenant?.Id;
    }
}

3. Enhance Swagger Documentation

Use AddRequiredHeaderParameter to include tenant-specific headers in Swagger UI:

using Franz.Common.Http.MultiTenancy.Documentation;

services.AddSwaggerGen(options =>
{
    options.OperationFilter<AddRequiredHeaderParameter>();
});

This ensures tenant headers are explicitly documented in API specifications.


Integration with Franz Framework

The Franz.Common.Http.MultiTenancy package integrates seamlessly with:

  • Franz.Common.MultiTenancy: Provides foundational multi-tenancy utilities.
  • Franz.Common.Http.Headers: Enhances tenant-specific header handling.
  • Franz.Common.Http: Enables tenant-aware HTTP services.
  • Franz.Common.Headers: Provides shared header utilities for HTTP operations.

Ensure these dependencies are installed to fully leverage the library's capabilities.


Contributing

This package is part of a private framework. Contributions are limited to the internal development team. If you have access, follow these steps:

  1. Clone the repository. @ https://github.com/bestacio89/Franz.Common/
  2. Create a feature branch.
  3. Submit a pull request for review.

License

This library is licensed under the MIT License. See the LICENSE file for more details.


Changelog

Version 1.2.65

  • Upgrade version to .net 9

Version 1.3

  • Upgraded to .NET 9.0.8
  • Added new features and improvements
  • Separated business concepts from mediator concepts
  • Now compatible with both the in-house mediator and MediatR

Version 1.3.1

  • Introduced tenant resolution pipeline (DefaultTenantResolutionPipeline) to orchestrate multiple strategies.

  • Added resolvers for different multi-tenancy strategies:

    • HeaderTenantResolver (resolves tenant from request headers).
    • HostTenantResolver (resolves tenant from host/subdomain).
    • QueryStringTenantResolver (resolves tenant from query string).
    • JwtClaimTenantResolver (resolves tenant from JWT claims).
  • Implemented TenantResolutionMiddleware for resolving the tenant once per request and storing it in context.

  • Enhanced TenantContextAccessor and DomainContextAccessor to use HttpContext.Items for request-scoped tenant/domain storage.

  • Added DI extension methods (AddFranzMultiTenancy) for easy registration of multi-tenancy services.

  • Added middleware extension (UseFranzMultiTenancy) for seamless integration into the ASP.NET Core pipeline.

  • Improved Swagger integration by supporting tenant-specific headers in documentation via AddRequiredHeaderParameter.

  • Laid foundation for tenant-aware services (DbContexts, caching, feature flags) by standardizing tenant resolution across HTTP requests.

Product Compatible and additional computed target framework versions.
.NET 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 (2)

Showing the top 2 NuGet packages that depend on Franz.Common.Http.MultiTenancy:

Package Downloads
Franz.Common.MongoDB

Shared utility library for the Franz Framework.

Franz.Common.Http.Bootstrap

Shared utility library for the Franz Framework.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.6.15 113 10/20/2025
1.6.14 195 10/15/2025
1.6.3 202 10/9/2025
1.6.2 200 10/7/2025
1.5.9 192 9/24/2025
1.5.4 184 9/23/2025
1.5.3 232 9/21/2025
1.5.2 245 9/21/2025
1.5.0 214 9/21/2025
1.4.4 201 9/20/2025
1.3.14 315 9/18/2025
1.3.13 316 9/18/2025
1.3.5 300 9/17/2025
1.3.4 308 9/16/2025
1.3.3 303 9/16/2025
1.3.2 290 9/15/2025
1.3.1 93 9/12/2025
1.3.0 314 8/25/2025
1.2.65 207 3/3/2025
1.2.64 151 1/29/2025
1.2.63 150 1/27/2025
1.2.62 148 1/8/2025