Rocket.Libraries.Auth 1.0.0

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

// Install Rocket.Libraries.Auth as a Cake Tool
#tool nuget:?package=Rocket.Libraries.Auth&version=1.0.0                

Rocket.Libraries.Auth

An bare-bones dotnet wrapper around the excellent JWT library, to simplify encoding and decoding of tokens.

Quick Start

1. Installation

Install the package from nuget

2. Configure your dotnet app

  1. Include in your startup.cs file. using Rocket.Libraries.Auth;
  2. Implement the IRocketJwtSecretProvider interface.
public  class  LatticeSecretProvider : IRocketJwtSecretProvider`
{
	/// <summary>
	/// All this method requires to do is return a string to be used as the	secret
	/// during encoding and decoding.
	/// </summary>
	/// <returns></returns>
	public  Task<string> GetSecretAsync()
	{
		return  Task.FromResult("something extremely secret");
	}
}
  1. Register services auth library in your ConfigureServices method.
public  void  ConfigureServices (IServiceCollection services)
{
	services.SetupRocketJwtAuth<LatticeSecretProvider>();
	//Register other services
}

3. Encoding and Decoding Tokens

After installation and configuration as detailed above, you can now encode and decode tokens as show in the example class below.

public  class  TokenManager
{
	private  readonly  IRocketJwtIssuer rocketJwtIssuer;
	private  readonly  IRocketJwtTokenDecoder rocketJwtTokenDecoder;
	private  readonly  IMySystemAuthenticator mySystemAuthenticator;
	  

		public  TokenManager(
			IRocketJwtIssuer rocketJwtIssuer, //Provided Rocket.Library.Auth works out of box
		IRocketJwtTokenDecoder rocketJwtTokenDecoder, //Provided Rocket.Library.Auth works out of box
		IMySystemAuthenticator mySystemAuthenticator)
	{
		this.rocketJwtIssuer  =  rocketJwtIssuer;
		this.rocketJwtTokenDecoder  =  rocketJwtTokenDecoder;
		this.mySystemAuthenticator  =  mySystemAuthenticator;
	}

  
  

	public  async  Task  GetClaimsAsync(string token)
	{
		// Below call returns claims dictionary
		// Also verifies signature.
		var claims =  await  rocketJwtTokenDecoder.DecodeTokenAsync(token);
	}

	  

	public  async  Task<string> GetTokenAsync()
	{
		// Sign into your system and return an object of type
		// Rocket.Libraries.Auth.NativeAuthenticationResult
		var nativeAuthenticationResult =  await  mySystemAuthenticator.SignInAsync();

		//Flag whether authentication succeeded or not.
		nativeAuthenticationResult.Authenticated  =  true;

		// Add your claims (IDictionary<string,object>)
		nativeAuthenticationResult.Claims.Add("role", "admin");
		nativeAuthenticationResult.Claims.Add("userId", 23);
	  
		// Set the lifetime of the token in seconds
		nativeAuthenticationResult.LifetimeSeconds  =  3600;
	  
		// Call the token issuer
		return  await  rocketJwtIssuer.GetTokenAsync(nativeAuthenticationResult);
	}

}
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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.  net9.0 was computed.  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. 
.NET Core netcoreapp3.1 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Rocket.Libraries.Auth:

Package Downloads
Jattac.Users.Management.Sdk

Wrapper to simplify authentication with Jattac.User.Management service

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 309 6/15/2023
1.0.1 176 6/14/2023
1.0.0 483 10/11/2021
1.0.0-beta02 338 10/10/2021
1.0.0-beta01 230 10/8/2021