DotNetBrightener.Infrastructure.Security 2024.0.14.5

There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package DotNetBrightener.Infrastructure.Security --version 2024.0.14.5                
NuGet\Install-Package DotNetBrightener.Infrastructure.Security -Version 2024.0.14.5                
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="DotNetBrightener.Infrastructure.Security" Version="2024.0.14.5" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DotNetBrightener.Infrastructure.Security --version 2024.0.14.5                
#r "nuget: DotNetBrightener.Infrastructure.Security, 2024.0.14.5"                
#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.
// Install DotNetBrightener.Infrastructure.Security as a Cake Addin
#addin nuget:?package=DotNetBrightener.Infrastructure.Security&version=2024.0.14.5

// Install DotNetBrightener.Infrastructure.Security as a Cake Tool
#tool nuget:?package=DotNetBrightener.Infrastructure.Security&version=2024.0.14.5                

Security Infratructure Library

© DotNet Brightener

Installation

Run this in command line:

dotnet add package DotNetBrightener.Infrastructure.Security

Or add the following to .csproj file

<PackageReference Include="DotNetBrightener.Infrastructure.Security" Version="2022.10.0" />

You should check the latest version from Nuget Site

Adding Permission System

  1. Register the Permission System to IServiceCollection
serviceCollection.AddPermissionAuthorization();
  1. Calling the following before application starts.
var app = builder.Build();

// call this before app.Run()
app.LoadAndValidatePermissions();

app.Run();

If you use legacy Startup.cs file then the app.LoadAndValidatePermissions() should be called in Configure() method

Authorization Extensions

  1. Authorize with IAuthorizationService
var authorizationResult = await IAuthorizationService.AuthorizePermissionAsync(user, permissionKey);
  1. Authorize with [PermissionAuthorize] attribute

public class SomeController: Controller 
{
    [PermissionAuthorize("<your_permission_key>")]
    public async Task<IActionResult> SomeAction() 
    {
        // your action implementation
    }   
}

Automatically Register Permissions

Given the following class for defining permissions


public class SomePermissionsList: AutomaticPermissionProvider
{
    /// <summary>
    ///     Description for Permission 1
    /// </summary>
    public const string Permission1 = "ThisIsKey.OfThePermission";

    /// <summary>
    ///     Description for Permission 2
    /// </summary>
    public const string Permission2 = "Permission.Permission2";
}

You can register the permissions defined in this class into service collection by doing the following:

// with SomePermissionsList is the type of permission provider
serviceCollection.RegisterPermissionProvider<SomePermissionsList>();

The app.LoadAndValidatePermissions() call above should automatically register the permissions you defined in the class provided

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

NuGet packages (4)

Showing the top 4 NuGet packages that depend on DotNetBrightener.Infrastructure.Security:

Package Downloads
DotNetBrightener.Infrastructure.JwtAuthentication

Package Description

DotNetBrightener.WebApp.CommonShared

Package Description

DotNetBrightener.Infrastructure.ApiKeyAuthentication

Package Description

DotNetBrightener.MultiTenancy

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2024.0.14.6-preview-2041501 77 7/22/2024
2024.0.14.6-preview-1920603 141 7/10/2024
2024.0.14.6-preview-1920301 81 7/10/2024
2024.0.14.6-preview-1911302 95 7/9/2024
2024.0.14.6-preview-1901001 105 7/8/2024
2024.0.14.6-preview-1900901 100 7/8/2024
2024.0.14.6-preview-1900801 77 7/8/2024
2024.0.14.6-preview-1860304 87 7/4/2024
2024.0.14.5 150 7/1/2024
2024.0.14.5-preview-1811601 91 6/29/2024
2024.0.14.5-preview-1810501 110 6/29/2024
2024.0.14.5-preview-180132 109 6/28/2024
2024.0.14.5-preview-180131 94 6/28/2024
2024.0.14.5-preview-180121 85 6/28/2024
2024.0.14.4 123 6/27/2024
2024.0.14.4-preview-7 93 6/27/2024
2024.0.14.3 112 6/21/2024
2024.0.14.1 102 6/6/2024
2024.0.14.1-preview 86 6/6/2024
2024.0.14-preview-1 84 6/6/2024
2024.0.13.8-preview 94 6/6/2024
2024.0.13.1-preview-0146 92 6/6/2024
2024.0.12.15803-preview-03 90 6/6/2024
2024.0.12.15608 97 6/4/2024
2024.0.12.15515 176 6/3/2024
2024.0.12.15220 84 5/31/2024
2024.0.12.15220-alpha31-240... 75 5/31/2024
2024.0.12.14911 136 5/28/2024
2024.0.12.14910-alpha28-240... 89 5/28/2024
2024.0.12.14823 107 5/27/2024
2024.0.12.14522-alpha7-2405... 104 5/24/2024
2024.0.12.14514-alpha6-2405... 99 5/24/2024
2024.0.12.14511 118 5/24/2024
2024.0.12.14314 154 5/22/2024
2024.0.12.14114 123 5/20/2024
2024.0.12.12815 140 5/7/2024
2024.0.12.12814 111 5/7/2024
2024.0.12.12721 127 5/6/2024
2024.0.12.12702 122 5/5/2024
2024.0.12.12622 134 5/5/2024
2024.0.12.12514 112 5/4/2024
2024.0.12.12512 111 5/4/2024
2024.0.12.12510 113 5/4/2024
2024.0.12.12420 95 5/3/2024
2024.0.12.12319 66 5/2/2024
2024.0.12.12319-rc-2405021801 58 5/2/2024
2024.0.12.12318 68 5/2/2024
2024.0.12.12215 98 5/1/2024
2024.0.12.12011 103 4/29/2024
2024.0.12.11720 114 4/26/2024
2024.0.12.11719 105 4/26/2024
2024.0.12.11621 130 4/25/2024
2024.0.12.11523 106 4/24/2024
2024.0.12.11522 113 4/24/2024
2024.0.12.11417 130 4/23/2024
2024.0.12.11400 133 4/22/2024
2024.0.12.11316 117 4/22/2024
2024.0.11.10220 105 4/11/2024
2024.0.11.10120 97 4/10/2024
2024.0.11.10119 92 4/10/2024
2024.0.11.10115 102 4/10/2024
2024.0.11.9914 125 4/8/2024
2024.0.11.9901 104 4/7/2024
2024.0.11.9823 115 4/7/2024
2024.0.11.9401 120 4/2/2024
2024.0.11.9301 107 4/1/2024
2024.0.11.9206 107 3/31/2024
2024.0.11.9205 106 3/31/2024
2024.0.11.8200 128 3/21/2024
2024.0.11.8122 93 3/21/2024
2024.0.11.8120 94 3/21/2024
2024.0.11.7320 137 3/13/2024
2024.0.11.7316 112 3/13/2024
2024.0.11.7310 112 3/13/2024
2024.0.11 112 3/13/2024
2024.0.10 138 3/3/2024
2024.0.9 117 2/27/2024
2024.0.8 155 2/1/2024
2024.0.7 109 1/26/2024
2024.0.6 108 1/25/2024
2024.0.5 95 1/24/2024
2024.0.4 98 1/24/2024
2024.0.3 114 1/22/2024
2024.0.2 173 1/10/2024
2024.0.1 110 1/9/2024
2024.0.1-alpha-3 92 1/9/2024
2024.0.1-alpha-2 96 1/9/2024
2024.0.1-alpha-1 113 1/3/2024
2024.0.0 162 12/26/2023
2023.0.27 170 12/21/2023
2023.0.26 130 12/21/2023
2023.0.25 162 12/11/2023
2023.0.24 145 12/8/2023
2023.0.23 135 12/6/2023
2023.0.21 197 12/4/2023
2023.0.20 191 11/27/2023
2023.0.19 151 11/20/2023
2023.0.18 163 10/25/2023
2023.0.17 207 10/22/2023
2023.0.16 221 10/16/2023
2023.0.16-alpha-1 92 10/16/2023
2023.0.15 149 10/14/2023
2023.0.14 123 10/14/2023
2023.0.13 126 10/14/2023
2023.0.12 140 10/14/2023
2023.0.11 128 10/10/2023
2023.0.10 140 10/9/2023
2023.0.9 237 8/16/2023
2023.0.8 202 8/15/2023
2023.0.8-alpha-2 244 5/31/2023
2023.0.7 569 5/12/2023
2023.0.6 230 5/10/2023
2023.0.5 183 5/7/2023
2023.0.4 217 4/22/2023
2023.0.3 257 4/19/2023
2023.0.2 249 4/6/2023
2023.0.1 237 3/13/2023
2022.10.4 336 11/9/2022
2022.10.3 392 10/19/2022
2022.10.2 463 10/19/2022
2022.10.0 445 10/16/2022
2022.7.1 477 7/18/2022

Basic infrastructure provided for authorizing User with given permission