AlgorandAuthentication 2.1.1
dotnet add package AlgorandAuthentication --version 2.1.1
NuGet\Install-Package AlgorandAuthentication -Version 2.1.1
<PackageReference Include="AlgorandAuthentication" Version="2.1.1" />
<PackageVersion Include="AlgorandAuthentication" Version="2.1.1" />
<PackageReference Include="AlgorandAuthentication" />
paket add AlgorandAuthentication --version 2.1.1
#r "nuget: AlgorandAuthentication, 2.1.1"
#:package AlgorandAuthentication@2.1.1
#addin nuget:?package=AlgorandAuthentication&version=2.1.1
#tool nuget:?package=AlgorandAuthentication&version=2.1.1
Algorand Standard for authentication implementation in .net
ARC-0014 implementation in .net
https://github.com/algorandfoundation/ARCs/issues/42
Usage
Install nuget
dotnet add package AlgorandAuthentication --version 2.0.4
StartUp.cs
public void ConfigureServices(
IServiceCollection services)
{
...
var authOptions = builder.Configuration.GetSection("AlgorandAuthentication").Get<AlgorandAuthenticationOptionsV2>();
if (authOptions == null) throw new Exception("Config for the authentication is missing");
builder.Services.AddAuthentication(AlgorandAuthenticationHandlerV2.ID).AddAlgorand(a =>
{
a.Realm = authOptions.Realm;
a.CheckExpiration = authOptions.CheckExpiration;
a.EmptySuccessOnFailure = authOptions.EmptySuccessOnFailure;
a.AllowedNetworks = authOptions.AllowedNetworks;
a.Debug = authOptions.Debug;
});
...
}
public void Configure(
IApplicationBuilder app
)
{
...
app.UseAuthentication();
app.UseAuthorization();
...
}
appsettings.json
{
"AlgorandAuthentication": {
"Realm": "MyProject#ARC14",
"CheckExpiration": true,
"AllowEmptyAccounts": false,
"Debug": false,
"AllowedNetworks": {
"SGO1GKSzyE7IEPItTxCByw9x8FmnrCDexi9/cOUJOiI=": {
"Server": "https://testnet-api.4160.nodely.dev",
"Token": "",
"Header": ""
}
}
}
}
{
"AlgorandAuthentication": {
"Realm": "MyProject#ARC14",
"CheckExpiration": true,
"AllowEmptyAccounts": false,
"Debug": false,
"AllowedNetworks": {
"SGO1GKSzyE7IEPItTxCByw9x8FmnrCDexi9/cOUJOiI=": {
"Server": "https://testnet-api.4160.nodely.dev",
"Token": "",
"Header": ""
},
"wGHE2Pwdvd7S12BL5FaOP20EGYesN73ktiC1qzkkit8=": {
"Server": "https://mainnet-api.4160.nodely.dev",
"Token": "",
"Header": ""
},
"r20fSQI8gWe/kFZziNonSPCXLwcQmH/nxROvnnueWOk=": {
"Server": "https://mainnet-api.voi.nodely.dev",
"Token": "",
"Header": ""
},
"PgeQVJJgx/LYKJfIEz7dbfNPuXmDyJ+O7FwQ4XL9tE8=": {
"Server": "https://algod.aramidmain.a-wallet.net",
"Token": "",
"Header": ""
}
}
}
}
Controller/Example.cs
[Authorize]
[HttpPost("Create")]
public async Task<ActionResult<bool>> Create()
{
...
}
Activity diagram
Plantuml:
@startuml
User -> Website: User wish to login to the website
Website -> AnyAlgorandNode : Request /v2/transactions/params
AnyAlgorandNode -> Website : Returns transaction params
Website -> Wallet : Website produces through algosdk messege to be signed, note as realm, params as session timeout
Wallet -> Website: Signed tx, website stores tx in temporary memory, localstorage or cookie the same as jwt
Website --> User: Displays eg auth address
Website -> Backend: Request authorized method, use SigTx Authorization header, fe /getUser
Backend -> AnyAlgorandNode : Request /v2/transactions/params
AnyAlgorandNode -> Backend : Returns current block round number
Backend -> Website: 401 if signature, genesis or round is wrong
Backend -> Website: 200 if authorized and returns content
Website --> User: Displays /getUser content, fe roles or username
@enduml

Example use
Algorand KMD Node
Algorand KMD Node is proxy to algorand participation node which allow to create participation keys. It uses ARC-0014 authentication to ensure no spam traffic to cpu sensitive methods.
Hasura Algorand Auth Web Hook
GraphQL algorand authentication for live websocket authenticated feeds.
https://github.com/scholtz/HasuraAlgorandAuthWebHook
Algorand 2FA Multisig
Project aims to create multisig account from hot wallet account, 2fa authentication account and cold storage account.
https://github.com/scholtz/Algorand2FAMultisig
Migration guide from V1 to V2
Convert appsettings.json
{
"AlgorandAuthentication": {
"AlgodServer": "https://testnet-api.algonode.cloud",
"AlgodServerToken": "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
"NetworkGenesisHash": "SGO1GKSzyE7IEPItTxCByw9x8FmnrCDexi9/cOUJOiI=",
"AlgodServerHeader": "X-Algo-API-Token",
"Realm": "2FA#ARC14",
"CheckExpiration": "true",
"Debug": "true"
}
}
to
{
"AlgorandAuthentication": {
"Realm": "MyProject#ARC14",
"CheckExpiration": true,
"AllowEmptyAccounts": false,
"Debug": false,
"AllowedNetworks": {
"SGO1GKSzyE7IEPItTxCByw9x8FmnrCDexi9/cOUJOiI=": {
"Server": "https://testnet-api.4160.nodely.dev",
"Token": "",
"Header": ""
}
}
}
}
in startup.cs or program.cs use
var authOptions = builder.Configuration.GetSection("AlgorandAuthentication").Get<AlgorandAuthenticationOptionsV2>();
if (authOptions == null) throw new Exception("Config for the authentication is missing");
builder.Services.AddAuthentication(AlgorandAuthenticationHandlerV2.ID).AddAlgorand(a =>
{
a.Realm = authOptions.Realm;
a.CheckExpiration = authOptions.CheckExpiration;
a.AllowEmptyAccounts = authOptions.AllowEmptyAccounts;
a.EmptySuccessOnFailure = authOptions.EmptySuccessOnFailure;
a.AllowedNetworks = authOptions.AllowedNetworks;
a.Debug = authOptions.Debug;
});
| 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. net9.0 is compatible. 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. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net10.0
- Algorand4 (>= 4.4.1.2025112914)
- Microsoft.AspNetCore.Authentication.Negotiate (>= 10.0.0)
- Microsoft.Extensions.Caching.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
-
net8.0
- Algorand4 (>= 4.4.1.2025112914)
- Microsoft.AspNetCore.Authentication.Negotiate (>= 8.0.14)
- Microsoft.Extensions.Caching.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Options (>= 8.0.2)
-
net9.0
- Algorand4 (>= 4.4.1.2025112914)
- Microsoft.AspNetCore.Authentication.Negotiate (>= 9.0.8)
- Microsoft.Extensions.Caching.Abstractions (>= 9.0.8)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.8)
- Microsoft.Extensions.Options (>= 9.0.8)
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 |
|---|---|---|
| 2.1.1 | 80 | 12/14/2025 |
| 2.1.0 | 112 | 12/6/2025 |
| 2.0.5 | 124 | 12/6/2025 |
| 2.0.4 | 276 | 8/6/2025 |
| 2.0.3 | 251 | 8/6/2025 |
| 2.0.2 | 260 | 8/6/2025 |
| 2.0.1 | 210 | 4/8/2025 |
| 2.0.0 | 151 | 2/5/2025 |
| 1.0.12 | 144 | 2/1/2025 |
| 1.0.11 | 179 | 10/15/2024 |
| 1.0.10 | 149 | 10/15/2024 |
| 1.0.9 | 362 | 6/25/2023 |
| 1.0.8 | 279 | 5/22/2023 |
| 1.0.7 | 589 | 9/16/2022 |
| 1.0.6 | 595 | 9/14/2022 |
| 1.0.5 | 594 | 9/14/2022 |
| 1.0.4 | 601 | 4/5/2022 |
| 1.0.3 | 568 | 4/5/2022 |
| 1.0.2 | 570 | 4/4/2022 |
| 1.0.0 | 557 | 10/31/2021 |