Phoesion.DevJwt
0.1.6
Prefix Reserved
See the version list below for details.
dotnet add package Phoesion.DevJwt --version 0.1.6
NuGet\Install-Package Phoesion.DevJwt -Version 0.1.6
<PackageReference Include="Phoesion.DevJwt" Version="0.1.6" />
paket add Phoesion.DevJwt --version 0.1.6
#r "nuget: Phoesion.DevJwt, 0.1.6"
// Install Phoesion.DevJwt as a Cake Addin #addin nuget:?package=Phoesion.DevJwt&version=0.1.6 // Install Phoesion.DevJwt as a Cake Tool #tool nuget:?package=Phoesion.DevJwt&version=0.1.6
Phoesion.DevJwt
Library and dotnet-tool for developing and testing web api services with JWT authorization. Create custom tokens that can be used localy, without an external authority.
How to use in your service
dotnet add package Phoesion.DevJwt
- Enable dev-jwt on your JWT authorization services using the
UseDevJwt()
extension
services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
.AddJwtBearer(o => o.UseDevJwt(builder.Environment));
- Configure in
appsetting.Development.json
"Authentication": {
"Schemes": {
"Bearer": {
"ValidAudience": "myApi",
"ValidIssuer": "phoesion.devjwt"
}
}
}
Generate a jwt
- Install the dotnet tool
dotnet tool install --global phoesion.devjwt.cli
- Generate token using
dotnet devjwt create myApi --email user@mail.com --sub 42
You can now use the token for your requests.
General Information
The UseDevJwt()
extension configures an ISecurityTokenValidator
that validates the token.
Using the HostingEnvironment
, it checks that the handler is only added for Development
and Testing
environments.
Samples
The repository contains the following samples projects in the Samples
folder :
- SampleWebApi : an ASP.Net core web api application
- SampleGlowMicroservice : a Phoesion Glow microservice
- TokenGeneratorSample : a console application that demononstrates how to generate token programmatically
Custom signing key
By default, the generator and validator use a predefined key for signing/veryfing the token. This way it will pass validation and you don't need to care about where/how the token was generated (doesn't use UserSecrets store), which is fine since it's for local development and testing.
You can however generate/validate tokens using a custom key like so :
- In the tool specify a key to be used for signing the token using the
--signkey
parameter :
dotnet devjwt create myApi --email user@mail.com --sub 42 --signkey thiskeyisverylargetobreak
- In the service authentication setup, provide the key to the
UseDevJwt()
function
services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
.AddJwtBearer(o => o.UseDevJwt(builder.Environment, "thiskeyisverylargetobreak"));
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. 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 is compatible. 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. |
-
net5.0
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 5.0.17)
-
net6.0
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 6.0.16)
-
net7.0
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.