EasyRefreshToken 8.2.2
dotnet add package EasyRefreshToken --version 8.2.2
NuGet\Install-Package EasyRefreshToken -Version 8.2.2
<PackageReference Include="EasyRefreshToken" Version="8.2.2" />
paket add EasyRefreshToken --version 8.2.2
#r "nuget: EasyRefreshToken, 8.2.2"
// Install EasyRefreshToken as a Cake Addin #addin nuget:?package=EasyRefreshToken&version=8.2.2 // Install EasyRefreshToken as a Cake Tool #tool nuget:?package=EasyRefreshToken&version=8.2.2
EasyRefreshToken
Overview
EasyRefreshToken is a .NET library that provides an easy-to-use token service for refreshing access tokens in ASP.NET Core applications. It offers a flexible and customizable solution for managing refresh tokens, token expiration, preventing simultaneous logins, and more.
With EasyRefreshToken, you can integrate refresh token functionality into your ASP.NET Core applications without the need to write complex code or manage token-related logic manually. It simplifies the process of refreshing access tokens and ensures a secure and seamless user experience.
It support .Net5, .Net6, .Net7 and .Net8.
Features
- Automatic management of refresh tokens and token expiration.
- Flexible options for configuring token behavior, such as token expiration duration and preventing simultaneous logins.
- Determine the number of tokens for each user according to global limit, its type or one of its properties.
- Support for different storage mechanisms, including in-memory and Entity Framework Core.
- Customizable token generation methods.
- Integration with ASP.NET Core Identity.
- Lightweight and minimal dependencies.
Getting Started
Follow these steps to get started with EasyRefreshToken in your ASP.NET Core application:
1. Installation
Install the EasyRefreshToken package from NuGet by using the following command:
// In-Memory Refrsh Token
dotnet add package EasyRefreshToken.InMemory
// EF Core Cache Refresh Token
dotnet add package EasyRefreshToken.EFCore
2. Configuration
In the ConfigureServices method of your Startup.cs / Program.cs file, add the EasyRefreshToken services and configure the options:
using EasyRefreshToken.InMemory;
// ...
// Add EasyRefreshToken services
builder.Services.AddInMemoryRefreshToken(options =>
{
// Configure the options as needed
options.TokenExpiredDays = 7;
options.PreventingLoginWhenAccessToMaxNumberOfActiveDevices = true;
// ...
});
// Other service configurations...
3. Usage
Make your TUser
inherit from IUser
:
public class User : IUser { }
Inject the ITokenService into your controller or service where you want to use the token service functionality:
using EasyRefreshToken;
// ...
private readonly ITokenService<string> _tokenService;
public MyRepository(ITokenService<string> tokenService)
{
_tokenService = tokenService;
}
public async Task<LoginResponse> Login(LoginDto dto)
{
// Login logic ...
TokenResult result = await _tokenService.OnLoginAsync(userId);
if (result.IsSucceeded)
{
// Return the new token to the client
}
else
{
// Handle the error
}
}
4. Documentation
Common Documentation:
You should make your
TUser
inherit fromIUser
.Use
IUser<TKey>
if the key of your User notstring
Use
ITokenService<TKey>
that contains:Task<TokenResult> OnLoginAsync(TKey userId)
: Adds a new refresh token for the specified user upon login.Task<bool> OnLogoutAsync(string token)
: Deletes a refresh token for the user that owns this token upon logout.Task<TokenResult> OnAccessTokenExpiredAsync(TKey userId, string oldToken)
: Updates the refresh token for the specified user when the current access token has expired.Task<string> OnChangePasswordAsync(TKey userId)
: This method should be called when changing the user's password.Task<bool> ClearAsync()
: Clears all token entities.Task<bool> ClearExpiredAsync()
: Clears expired token entities.Task<bool> ClearAsync(TKey userId)
: Clears the token entities for the specified user.Task<bool> ClearExpiredAsync(TKey userId)
: Clears the expired token entities for the specified user.
Configure your service by options:
int? TokenExpiredDays
:Sets the number of days until the token expires. If set to null, the token will never expire. Default value is 7 days.bool PreventingLoginWhenAccessToMaxNumberOfActiveDevices
: Sets a value indicating whether to prevent login operation when the maximum number of active devices is reached. If set to true and there is a valid token, login will be prevented. If set to false, the old token will be removed and a new token will be added. Default value is true.Func<string> TokenGenerationMethod
: Sets the method used for generating tokens.OnChangePasswordBehavior OnChangePasswordBehavior
: Sets the behavior of the OnChangePassword method. Default value is OnChangePasswordBehavior.DeleteAllTokens.MaxNumberOfActiveDevices MaxNumberOfActiveDevices
: Sets the maximum number of active devices per user type. If a type is not specified, the default value isint.MaxValue
MaxNumberOfActiveDevices
- Global Limit:
MaxNumberOfActiveDevices.Configure(int.MaxValue)
- Limit Per Type:
MaxNumberOfActiveDevices.Configure((typeof(Admin), 1), (typeof(Employee), 2))
- Limit Per Property:
MaxNumberOfActiveDevices.Configure("UserType", (UserType.Admin, 1), (UserType.Employee, 2))
Notes
- You can specifies a life time of the Service (the default is Scoped).
- For
MaxNumberOfActiveDevices
useMaxNumberOfActiveDevices.Configure()
. - Note: when change on options, I highly recommend cleaning the table by
Clear
EF Core RefreshToken:
Create your own class
MyRefreshToken
and add to it the properties you want and make it inherit fromRefreshToken<TUser, TKey>
If you do not want to add new features, you can skip the previous step.
In AppDbContext Class:
public DbSet<RefreshToken<TUser, TKey>> RefreshTokens { get; set; }
orpublic DbSet<MyRefreshToken> RefreshTokens { get; set; }
In Program Class:
builder.Services.AddEFCoreRefreshToken<AppDbContext, RefreshToken<TUser, TKey>, TUser, TKey>();
orbuilder.Services.AddEFCoreRefreshToken<AppDbContext, MyRefreshToken, TUser, TKey>();
You have an additional option
bool SaveChanges
: Sets a value indicating whether changes should be automatically saved to the database. The default value is true.Don't forget:
Add-Migration
Update-Database
In-Memory RefreshToken:
In Program Class:
builder.Services.AddInMemoryRefreshToken<TUser, TKey>();
You have an additional option
Func<IServiceProvider, TKey, TUser>? GetUserById
: Sets a function to retrieve a user by their ID.
Warning!!: You must set Func<IServiceProvider, TKey, TUser>? GetUserById
option, if you use LimitPerProperty
or LimitPerType
.
5. Contributing
Contributions to EasyRefreshToken are welcome and encouraged! If you find any bugs, issues, or have feature requests, please open a new issue on the GitHub repository. If you would like to contribute code, please fork the repository, make your changes, and submit a pull request.
6. License
EasyRefreshToken is licensed under the MIT License.
Product | Versions 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. |
-
net8.0
NuGet packages (2)
Showing the top 2 NuGet packages that depend on EasyRefreshToken:
Package | Downloads |
---|---|
EasyRefreshToken.InMemory
Package for manage refresh token |
|
EasyRefreshToken.EFCore
Package for manage refresh token |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
8.2.2 | 254 | 1/5/2024 |
7.2.2 | 150 | 1/5/2024 |
7.2.1 | 231 | 6/27/2023 |
7.2.0 | 227 | 6/9/2023 |
7.1.2 | 199 | 5/21/2023 |
7.1.1 | 206 | 5/5/2023 |
7.1.0 | 278 | 2/24/2023 |
7.0.10 | 370 | 11/26/2022 |
6.2.2 | 179 | 1/5/2024 |
6.2.1 | 233 | 6/27/2023 |
6.2.0 | 160 | 6/9/2023 |
6.1.2 | 166 | 5/21/2023 |
6.1.1 | 188 | 5/5/2023 |
6.1.0 | 285 | 2/24/2023 |
6.0.10 | 375 | 11/4/2022 |
6.0.9 | 415 | 8/31/2022 |
6.0.8 | 472 | 7/8/2022 |
6.0.7 | 464 | 7/3/2022 |
6.0.6 | 451 | 6/20/2022 |
6.0.5 | 437 | 6/20/2022 |
5.2.2 | 179 | 1/5/2024 |
5.2.1 | 222 | 6/27/2023 |
5.2.0 | 164 | 6/9/2023 |
5.1.2 | 169 | 5/21/2023 |
5.1.1 | 172 | 5/5/2023 |
5.1.0 | 272 | 2/24/2023 |
5.0.10 | 394 | 11/5/2022 |
5.0.9 | 481 | 8/31/2022 |
5.0.8 | 531 | 7/8/2022 |
5.0.7 | 461 | 7/3/2022 |
5.0.6 | 433 | 6/20/2022 |
5.0.5 | 506 | 6/20/2022 |