Hexalith.Security.Servers
                              
                            
                                2.11.20
                            
                        
                    dotnet add package Hexalith.Security.Servers --version 2.11.20
NuGet\Install-Package Hexalith.Security.Servers -Version 2.11.20
<PackageReference Include="Hexalith.Security.Servers" Version="2.11.20" />
<PackageVersion Include="Hexalith.Security.Servers" Version="2.11.20" />
<PackageReference Include="Hexalith.Security.Servers" />
paket add Hexalith.Security.Servers --version 2.11.20
#r "nuget: Hexalith.Security.Servers, 2.11.20"
#:package Hexalith.Security.Servers@2.11.20
#addin nuget:?package=Hexalith.Security.Servers&version=2.11.20
#tool nuget:?package=Hexalith.Security.Servers&version=2.11.20
Hexalith.Security
Overview
Hexalith.Security is a comprehensive security framework for .NET applications providing authentication, authorization, and identity management capabilities. Built with modern C# and Blazor, it offers a robust approach to implementing security in web applications, API servers, and microservices.
Build Status
Architecture
The Hexalith.Security project follows a modular architecture with clear separation of concerns:
Core Components
- Abstractions: Defines interfaces, models, and contracts for security features
- Application: Business logic and services for security functionality
- Infrastructure: Implementation of data access and external service integration
- Presentation: UI components and pages for user interactions
- Modules: Integration modules for different application types (WebApp, WebServer, ApiServer)
Integration with Hexalith Framework
The security module integrates with:
- Hexalith.IdentityStores: For identity storage and management
- Hexalith.Application: For application module integration
- Hexalith.Infrastructure.DaprRuntime: For distributed application runtime support
Modules
WebApp Module (HexalithSecurityWebAppModule)
Client-side authentication and authorization for Blazor WebAssembly applications:
// Program.cs
var builder = WebAssemblyHostBuilder.CreateDefault(args);
// ...
HexalithSecurityWebAppModule.AddServices(builder.Services, builder.Configuration);
WebServer Module (HexalithSecurityWebServerModule)
Server-side authentication and authorization:
// Program.cs
var builder = WebApplication.CreateBuilder(args);
// ...
builder.Services.AddModule<HexalithSecurityWebServerModule>(builder.Configuration);
var app = builder.Build();
// ...
app.UseModule<HexalithSecurityWebServerModule>();
app.UseSecurity<HexalithSecurityWebServerModule>();
ApiServer Module (HexalithSecurityApiServerModule)
Security for API-focused applications:
// Program.cs
var builder = WebApplication.CreateBuilder(args);
// ...
builder.Services.AddModule<HexalithSecurityApiServerModule>(builder.Configuration);
Security Features
- Authentication: ASP.NET Core Authentication, multiple schemes, Dapr-based authentication
- Authorization: Policy-based, role-based access control
- Predefined Security Roles: Owner, Contributor, Reader
- Predefined Security Policies: For respective roles
Repository Structure
The repository is organized as follows:
- src Is the source code directory of your project.
- src/libraries Is the source code directory where you will add your Nuget package projects.
- src/examples Contains example implementations of your projects.
- src/servers Is the source code directory where you will add your Docker container projects.
- src/aspire Is the source code directory where you will add your Aspire project.
- test Contains test projects for your packages.
- Hexalith.Builds Contains shared build configurations and tools.
Getting Started
Prerequisites
- Hexalith.Builds
- Hexalith.IdentityStores
- .NET 8 SDK or later
- PowerShell 7 or later
- Git
Installation
Add the Hexalith.Security NuGet package to your project:
dotnet add package Hexalith.Security
Configuration
Configure security settings in your appsettings.json:
{
  "Security": {
    "Disabled": false
  }
}
Examples
Protecting a Blazor Page
@page "/secure-page"
@attribute [Authorize]
<h1>Secure Page</h1>
<p>This page is only accessible to authenticated users.</p>
Using Role-Based Authorization
@page "/admin-page"
@attribute [Authorize(Roles = SecurityRoles.Owner)]
<h1>Admin Page</h1>
<p>This page is only accessible to users with the Owner role.</p>
Using Policy-Based Authorization
@page "/contributor-page"
@attribute [Authorize(Policy = SecurityPolicies.Contributors)]
<h1>Contributors Page</h1>
<p>This page is only accessible to users who can contribute.</p>
Best Practices
- Use predefined roles and policies whenever possible
- Implement the principle of least privilege by assigning minimum required permissions
- Validate authorization at both UI and API levels
- Configure proper authentication mechanisms based on your application type
- Use cascading authentication state in Blazor applications for optimal performance
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support and Community
For support, please open an issue on the GitHub repository.
Join our Discord community: Hexalith Discord
| Product | Versions 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. | 
- 
                                                    net9.0- Hexalith.IdentityStores (>= 1.3.37)
- Hexalith.Security.Application (>= 2.11.20)
 
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Hexalith.Security.Servers:
| Package | Downloads | 
|---|---|
| Hexalith.Security.ApiServer Hexalith is a set of libraries to build an application with micro-service architecture. | |
| Hexalith.Security.WebServer Hexalith is a set of libraries to build an application with micro-service architecture. | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 2.11.20 | 187 | 9/20/2025 | 
| 2.11.19 | 188 | 9/20/2025 | 
| 2.11.18 | 181 | 8/10/2025 | 
| 2.11.17 | 129 | 8/10/2025 | 
| 2.11.16 | 269 | 8/5/2025 | 
| 2.11.15 | 249 | 8/5/2025 | 
| 2.11.14 | 153 | 7/31/2025 | 
| 2.11.13 | 152 | 7/30/2025 | 
| 2.11.12 | 156 | 7/30/2025 | 
| 2.11.11 | 152 | 7/30/2025 | 
| 2.11.10 | 414 | 7/25/2025 | 
| 2.11.9 | 504 | 7/24/2025 | 
| 2.11.8 | 504 | 7/24/2025 | 
| 2.11.7 | 511 | 7/24/2025 | 
| 2.11.6 | 568 | 7/22/2025 | 
| 2.11.5 | 561 | 7/22/2025 | 
| 2.11.4 | 558 | 7/22/2025 | 
| 2.11.3 | 106 | 7/19/2025 | 
| 2.11.2 | 102 | 7/19/2025 | 
| 2.11.1 | 118 | 7/18/2025 | 
| 2.11.0 | 177 | 7/16/2025 | 
| 2.10.0 | 188 | 7/16/2025 | 
| 2.9.0 | 145 | 7/11/2025 | 
| 2.8.32 | 195 | 7/9/2025 | 
| 2.8.31 | 190 | 7/9/2025 | 
| 2.8.30 | 199 | 7/9/2025 | 
| 2.8.29 | 192 | 7/8/2025 | 
| 2.8.28 | 185 | 7/8/2025 | 
| 2.8.27 | 188 | 7/8/2025 | 
| 2.8.26 | 195 | 7/7/2025 | 
| 2.8.25 | 187 | 7/6/2025 | 
| 2.8.24 | 294 | 7/6/2025 | 
| 2.8.23 | 192 | 7/6/2025 | 
| 2.8.22 | 134 | 7/4/2025 | 
| 2.8.21 | 130 | 7/4/2025 | 
| 2.8.20 | 145 | 7/4/2025 | 
| 2.8.19 | 178 | 6/30/2025 | 
| 2.8.18 | 181 | 6/29/2025 | 
| 2.8.17 | 183 | 6/29/2025 | 
| 2.8.16 | 183 | 6/29/2025 | 
| 2.8.15 | 143 | 6/29/2025 | 
| 2.8.14 | 142 | 6/27/2025 | 
| 2.8.13 | 150 | 6/27/2025 | 
| 2.8.12 | 148 | 6/27/2025 | 
| 2.8.11 | 175 | 6/26/2025 | 
| 2.8.10 | 175 | 6/26/2025 | 
| 2.8.9 | 171 | 6/26/2025 | 
| 2.8.8 | 173 | 6/26/2025 | 
| 2.8.7 | 176 | 6/26/2025 | 
| 2.8.6 | 178 | 6/26/2025 | 
| 2.8.5 | 179 | 6/26/2025 | 
| 2.8.4 | 185 | 6/26/2025 | 
| 2.8.3 | 176 | 6/26/2025 | 
| 2.8.2 | 182 | 6/26/2025 | 
| 2.8.1 | 182 | 6/26/2025 | 
| 2.8.0 | 171 | 6/26/2025 | 
| 2.7.9 | 183 | 6/26/2025 | 
| 2.7.8 | 177 | 6/26/2025 | 
| 2.7.7 | 181 | 6/26/2025 | 
| 2.7.6 | 180 | 6/26/2025 | 
| 2.7.5 | 180 | 6/26/2025 | 
| 2.7.4 | 178 | 6/26/2025 | 
| 2.7.3 | 183 | 6/25/2025 | 
| 2.7.2 | 180 | 6/25/2025 | 
| 2.7.1 | 193 | 6/25/2025 | 
| 2.7.0 | 185 | 6/25/2025 | 
| 2.6.2 | 186 | 6/24/2025 | 
| 2.6.1 | 190 | 6/24/2025 | 
| 2.6.0 | 181 | 6/23/2025 | 
| 2.5.0 | 199 | 6/19/2025 | 
| 2.4.0 | 168 | 6/19/2025 | 
| 2.3.1 | 188 | 6/18/2025 | 
| 2.3.0 | 207 | 6/17/2025 | 
| 2.2.1 | 189 | 6/17/2025 | 
| 2.2.0 | 187 | 6/17/2025 | 
| 2.1.8 | 194 | 6/16/2025 | 
| 2.1.7 | 194 | 6/14/2025 | 
| 2.1.6 | 220 | 4/22/2025 | 
| 2.1.5 | 194 | 4/22/2025 | 
| 2.1.4 | 204 | 4/22/2025 | 
| 2.1.3 | 210 | 4/22/2025 | 
| 2.1.2 | 221 | 4/21/2025 | 
| 2.1.1 | 210 | 4/21/2025 | 
| 2.1.0 | 224 | 4/21/2025 | 
| 2.0.1 | 209 | 4/21/2025 | 
| 2.0.0 | 148 | 4/19/2025 | 
| 1.54.6 | 220 | 3/19/2025 | 
| 1.54.5 | 202 | 3/19/2025 | 
| 1.53.4 | 201 | 3/18/2025 | 
| 1.53.3 | 224 | 3/11/2025 | 
| 1.53.0 | 163 | 2/28/2025 | 
| 1.52.14 | 163 | 1/15/2025 | 
| 1.52.10 | 147 | 1/10/2025 | 
| 1.52.8 | 164 | 1/6/2025 | 
| 1.52.7 | 150 | 1/6/2025 | 
| 1.51.8 | 189 | 12/15/2024 | 
| 1.51.7 | 164 | 12/15/2024 | 
| 1.1.1 | 154 | 4/19/2025 | 
| 1.1.0 | 135 | 4/19/2025 | 
| 1.0.0 | 153 | 4/19/2025 |