MarkoPapic.TwoFactorAuthentication
1.0.0
dotnet add package MarkoPapic.TwoFactorAuthentication --version 1.0.0
NuGet\Install-Package MarkoPapic.TwoFactorAuthentication -Version 1.0.0
<PackageReference Include="MarkoPapic.TwoFactorAuthentication" Version="1.0.0" />
paket add MarkoPapic.TwoFactorAuthentication --version 1.0.0
#r "nuget: MarkoPapic.TwoFactorAuthentication, 1.0.0"
// Install MarkoPapic.TwoFactorAuthentication as a Cake Addin #addin nuget:?package=MarkoPapic.TwoFactorAuthentication&version=1.0.0 // Install MarkoPapic.TwoFactorAuthentication as a Cake Tool #tool nuget:?package=MarkoPapic.TwoFactorAuthentication&version=1.0.0
Two-Factor Authentication
A C# library for TOTP (RFC 6238) 2-factor authentication.
Usage
Authenticator app
To generate a new authenticator app key:
TwoFactorAuthenticationManager twoFactorAuthenticationManager = new TwoFactorAuthenticationManager();
string authenticatorKey = twoFactorAuthenticationManager.AuthenticatorApp.GenerateKey();
The authenticatorKey
should be inserted in an authenticator app.
Then, to validate a code generated by an authenticator app:
bool isCodeValid = twoFactorAuthenticationManager.AuthenticatorApp.ValidateCode(key, code); // code is generated by an authenticator app
Message based
To generate a TOTP to be sent to the user (via SMS, email...):
TwoFactorAuthenticationManager twoFactorAuthenticationManager = new TwoFactorAuthenticationManager();
string totp = twoFactorAuthenticationManager.Message.GenerateTotp(userKey);
Where userKey
is a Base32 encoded string that is uniquely associated to this user. This key should be provided by you.
Then, to validate the TOTP sent by the user:
bool isTotpValid = twoFactorAuthenticationManager.Message.ValidateCode(userKey, totp);
Where userKey
is the same key you used to generate the TOTP, and totp
is the TOTP code generated in the previous step.
Configuration
You can configure the following parameters:
MessageTotpDuration
: The duration for which message-based TOTPs should be valid. Default is 300 seconds.AuthenticatorTotpVarianceAllowed
: Allows up to the specified adjacent intervals to be checked when validating authenticator app TOTPs. This can make up for delays caused by latency or clock missmatch. Default is 0.MessageTotpVarianceAllowed
: Allows up to the specified adjacent intervals to be checked when validating message-based TOTPs. This can make up for delays caused by latency or clock missmatch. Default is 0.
Example:
TwoFactorAuthenticationManager twoFactorAuthenticationManager = new TwoFactorAuthenticationManager(new TwoFactorAuthenticationOptions
{
MessageTotpDuration = 500,
MessageTotpVarianceAllowed = 1,
AuthenticatorTotpVarianceAllowed = 0
});
Using .Net Core Dependency Injection
You can use the .NET Core middleware to register TwoFactorAuthenticationManager
as a service available via .NET dependency injection:
public void ConfigureServices(IServiceCollection services)
{
// ...
services.AddTwoFactorAuthentication();
services.Configure<TwoFactorAuthenticationOptions>(options =>
{
options.MessageTotpDuration = 500;
});
// ...
}
Product | Versions 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.DependencyInjection (>= 2.2.0)
- Microsoft.Extensions.Options (>= 2.2.0)
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.0.0 | 474 | 9/30/2020 |