DotNetBrightener.Infrastructure.Security 2024.0.10

dotnet add package DotNetBrightener.Infrastructure.Security --version 2024.0.10
NuGet\Install-Package DotNetBrightener.Infrastructure.Security -Version 2024.0.10
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.10" />
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.10
#r "nuget: DotNetBrightener.Infrastructure.Security, 2024.0.10"
#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.10

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

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.MultiTenancy

Package Description

DotNetBrightener.Infrastructure.ApiKeyAuthentication

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2024.0.10 0 3/3/2024
2024.0.9 78 2/27/2024
2024.0.8 139 2/1/2024
2024.0.7 95 1/26/2024
2024.0.6 95 1/25/2024
2024.0.5 80 1/24/2024
2024.0.4 83 1/24/2024
2024.0.3 95 1/22/2024
2024.0.2 160 1/10/2024
2024.0.1 93 1/9/2024
2024.0.1-alpha-3 83 1/9/2024
2024.0.1-alpha-2 91 1/9/2024
2024.0.1-alpha-1 109 1/3/2024
2024.0.0 149 12/26/2023
2023.0.27 160 12/21/2023
2023.0.26 122 12/21/2023
2023.0.25 154 12/11/2023
2023.0.24 136 12/8/2023
2023.0.23 126 12/6/2023
2023.0.21 188 12/4/2023
2023.0.20 179 11/27/2023
2023.0.19 142 11/20/2023
2023.0.18 147 10/25/2023
2023.0.17 195 10/22/2023
2023.0.16 209 10/16/2023
2023.0.16-alpha-1 86 10/16/2023
2023.0.15 138 10/14/2023
2023.0.14 109 10/14/2023
2023.0.13 112 10/14/2023
2023.0.12 128 10/14/2023
2023.0.11 116 10/10/2023
2023.0.10 129 10/9/2023
2023.0.9 199 8/16/2023
2023.0.8 187 8/15/2023
2023.0.8-alpha-2 240 5/31/2023
2023.0.7 493 5/12/2023
2023.0.6 202 5/10/2023
2023.0.5 170 5/7/2023
2023.0.4 205 4/22/2023
2023.0.3 245 4/19/2023
2023.0.2 237 4/6/2023
2023.0.1 224 3/13/2023
2022.10.4 327 11/9/2022
2022.10.3 386 10/19/2022
2022.10.2 457 10/19/2022
2022.10.0 436 10/16/2022
2022.7.1 466 7/18/2022

Basic infrastructure provided for authorizing User with given permission