Fga.Net.AspNetCore 0.1.0-alpha

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

// Install Fga.Net.AspNetCore as a Cake Tool
#tool nuget:?package=Fga.Net.AspNetCore&version=0.1.0-alpha&prerelease                

Auth0 FGA for .NET & ASP.NET Core

Nuget (with prereleases) Nuget (with prereleases)

Please ensure you have a basic understanding of how FGA works before continuing: https://docs.fga.dev/

Note: This project is an early alpha and is subject to breaking changes without notice.

ASP.NET Core Setup

Before getting started, ensure you have a Store ID, Client ID, and Client Secret ready from How to get your API keys.

I'm also assuming you have authentication setup within your project, such as JWT bearer authentication via Auth0.

  1. Install Fga.Net.AspNetCore from Nuget.
  2. Add your StoreId, ClientId and ClientSecret to your application configuration, ideally via the dotnet secrets manager.
  3. Add the following code to your ASP.NET Core configuration:
// Registers FgaAuthenticationClient & FgaAuthorizationClient, and the authorization handler
builder.Services.AddAuth0Fga(x =>
{
    x.ClientId = builder.Configuration["Auth0Fga:ClientId"];
    x.ClientSecret = builder.Configuration["Auth0Fga:ClientSecret"];
    x.StoreId = builder.Configuration["Auth0Fga:StoreId"];
});

// Register the authorization policy
builder.Services.AddAuthorization(options =>
{
    options.AddPolicy(FgaAuthorizationDefaults.PolicyKey, p => p.RequireAuthenticatedUser().AddFgaRequirement());
});
  1. Create an authorization attribute that inherits from ComputedAuthorizationAttribute. From here, you can pull metadata you require to perform your tuple checks out of the HTTP request. For example, an equivalent to the How To Integrate Within A Framework example would be:
public class EntityAuthorizationAttribute : ComputedAuthorizationAttribute
{
    private readonly string _prefix;
    private readonly string _routeValue;
    public EntityAuthorizationAttribute(string prefix, string routeValue)
    {
        _prefix = prefix;
        _routeValue = routeValue;
    }

    public override ValueTask<string> GetUser(HttpContext context)
    {
        return ValueTask.FromResult(context.User.Identity!.Name!);
    }

    public override ValueTask<string> GetRelation(HttpContext context)
    {
        return ValueTask.FromResult(context.Request.Method switch
        {
            "GET" => "viewer",
            "POST" => "writer",
            _ => "owner"
        });
    }

    public override ValueTask<string> GetObject(HttpContext context)
    {
        return ValueTask.FromResult($"{_prefix}:{context.GetRouteValue(_routeValue)}");
    }
}
  1. Apply the Authorize and EntityAuthorization attributes to your controller(s):
    [ApiController]
    [Route("[controller]")]
    [Authorize(FgaAuthorizationDefaults.PolicyKey)]
    public class DocumentController : ControllerBase
    {  
        [HttpGet("view/{documentId}")]
        [EntityAuthorization("doc", "documentId")]
        public string GetByConvention(string documentId)
        {
            return documentId;
        }
    }

If you need to manually perform checks, inject the IFgaAuthorizationClient as required.

An additional pre-made attribute that allows all tuple values to be hardcoded strings ships with the package (StringComputedAuthorizationAttribute). This attrbute is useful for testing and debug purposes, but should not be used in a real application.

Worker Service / Generic Host setup

Full docs coming soon.

Fga.Net ships with the AddAuth0FgaAuthenticationClient and AddAuth0FgaAuthorizationClient service collection extensions that should be self-explanatory. To use the authorization client, both clients must be registered.

Standalone client setup

Seriously consider if you need to run a standalone client before picking this option.

  1. Install Fga.Net
  2. Create the authorization client as below:
var client = FgaAuthorizationClient.Create(FgaAuthenticationClient.Create(), new FgaClientConfiguration()
{
    ClientId = args[0],
    ClientSecret = args[1],
    StoreId = args[2]
});

var response = await client.CheckAsync(new CheckTupleRequest()
{
    TupleKey = new TupleKey()
    {
        User = "",
        Relation = "",
        Object = ""
    }
});

Disclaimer

I am not affiliated with nor represent Auth0. All support queries regarding the underlying service go to the Auth0 Labs Discord.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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

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
1.2.0 18,218 4/9/2024
1.1.0 9,774 1/5/2024
1.0.0 292 12/18/2023
1.0.0-beta.1 12,615 5/29/2023
0.9.0-alpha 149 4/14/2023
0.8.0-alpha 268 1/3/2023
0.7.0-alpha 1,237 10/1/2022
0.6.0-alpha 163 9/1/2022
0.5.0-alpha 167 6/18/2022
0.4.0-alpha 175 4/17/2022
0.3.0-alpha 185 2/13/2022
0.2.0-alpha 186 12/20/2021
0.1.1-alpha 188 12/20/2021
0.1.0-alpha 165 12/20/2021