BTCPayServer.NTag424
1.0.10
See the version list below for details.
dotnet add package BTCPayServer.NTag424 --version 1.0.10
NuGet\Install-Package BTCPayServer.NTag424 -Version 1.0.10
<PackageReference Include="BTCPayServer.NTag424" Version="1.0.10" />
paket add BTCPayServer.NTag424 --version 1.0.10
#r "nuget: BTCPayServer.NTag424, 1.0.10"
// Install BTCPayServer.NTag424 as a Cake Addin #addin nuget:?package=BTCPayServer.NTag424&version=1.0.10 // Install BTCPayServer.NTag424 as a Cake Tool #tool nuget:?package=BTCPayServer.NTag424&version=1.0.10
BTCPayServer.BoltCardTools
Introduction
This repository hosts tools that help with the creation of Bolt Cards.
Content:
- BTCPayServer.NTag424 is the base library implementing the NTag424 protocol, this library is platform agnostic.
- BTCPayServer.NTag424.PCSC is a library implementing APDU transport via PCSC-Sharp for supporting Windows/Linux/Mac.
We tested the following smart card reader:
Examples
How to read the UID of an NTag 424 smart card
Plug in a smart card reader, and place an NTag 424 smart card on it.
Reference the nuget package BTCPayServer.NTag424.PCSC in your project.
dotnet add package BTCPayServer.NTag424.PCSC
Then to use it:
using BTCPayServer.NTag424;
using BTCPayServer.NTag424.PCSC;
using System;
using var ctx = await PCSCContext.WaitForCard();
var ntag = ctx.CreateNTag424();
var key = AESKey.Default;
await ntag.AuthenticateEV2First(0, key);
var id = await ntag.GetCardUID();
var idStr = Convert.ToHexString(id, 0, id.Length).ToLowerInvariant();
Console.WriteLine($"Card UID: {idStr}");
How to read the NDEF message of an NTag 424 smart card
using BTCPayServer.NTag424.PCSC;
using System;
using var ctx = await PCSCContext.WaitForCard();
var ntag = ctx.CreateNTag424();
var uri = await ntag.TryReadNDefURI();
Console.WriteLine($"Card URI: {uri}");
How to verify the signature of an NTag 424 smart card
using BTCPayServer.NTag424;
using BTCPayServer.NTag424.PCSC;
using System;
using System.Security;
using System.Collections;
// Set keys have you have setup the card
var encryptionKey = AESKey.Default;
var authenticationKey = AESKey.Default;
using var ctx = await PCSCContext.WaitForCard();
var ntag = ctx.CreateNTag424();
var uri = await ntag.TryReadNDefURI();
var piccData = PICCData.TryBoltcardDecrypt(encryptionKey, authenticationKey, uri);
if (piccData == null)
throw new SecurityException("Impossible to decrypt or validate");
// The LNUrlw service should also check `piccData.Counter` is always increasing between payments to avoid replay attacks.
How to setup a bolt card
using BTCPayServer.NTag424;
using BTCPayServer.NTag424.PCSC;
using System;
using System.Collections;
using var ctx = await PCSCContext.WaitForCard();
var ntag = ctx.CreateNTag424();
// Example with hard coded keys
var keys = new BoltcardKeys(
AppMasterKey: new AESKey("00000000000000000000000000000001".HexToBytes()),
EncryptionKey: new AESKey("00000000000000000000000000000002".HexToBytes()),
AuthenticationKey: new AESKey("00000000000000000000000000000003".HexToBytes()),
K3: new AESKey("00000000000000000000000000000004".HexToBytes()),
K4: new AESKey("00000000000000000000000000000005".HexToBytes()));
var lnurlwService = "lnurlw://test.com";
// Note `BoltcardKeys.Default` assumes the card hasn't been setup yet.
// If it was not the case, you would need to provide the access keys you provided during the last setup.
await ntag.SetupBoltcard(lnurlwService, BoltcardKeys.Default, keys);
// You can reset the card to its factory state with `await ntag.ResetCard(keys);`
How to setup a bolt card with deterministic keys, and decrypt the PICCData
Deterministic keys simplifies the management of Boltcard by removing the need to store the keys of each Boltcards in a database.
Here is an example of how to setup a card with deterministic keys, and decrypt the PICCData.
using BTCPayServer.NTag424;
using BTCPayServer.NTag424.PCSC;
using System;
using System.Security;
using System.Collections;
using var ctx = await PCSCContext.WaitForCard();
var ntag = ctx.CreateNTag424();
await ntag.AuthenticateEV2First(0, AESKey.Default);
var uid = await ntag.GetCardUID();
var issuerKey = new AESKey("00000000000000000000000000000001".HexToBytes());
var batchKeys = new DeterministicBatchKeys(issuerKey, BatchId: 0);
var uri = await ntag.TryReadNDefURI();
var piccData = PICCData.TryDeterministicBoltcardDecrypt(batchKeys, uri, uid);
if (piccData == null)
throw new SecurityException("Impossible to decrypt with batchKeys");
// If this method didn't throw an exception, it has been successfully decrypted and authenticated.
// You can reset the card with `await ntag.ResetCard(batchKeys);`.
License
MIT
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 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. |
-
net6.0
- NdefLibrary (>= 4.1.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on BTCPayServer.NTag424:
Package | Downloads |
---|---|
BTCPayServer.NTag424.PCSC
A library to communicate with NTag 424 chips and assist BoltCard creation |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on BTCPayServer.NTag424:
Repository | Stars |
---|---|
btcpayserver/btcpayserver
Accept Bitcoin payments. Free, open-source & self-hosted, Bitcoin payment processor.
|
Version | Downloads | Last updated |
---|---|---|
1.0.25 | 1,336 | 12/3/2024 |
1.0.24 | 976 | 9/4/2024 |
1.0.23 | 7,257 | 4/24/2024 |
1.0.22 | 4,153 | 2/8/2024 |
1.0.21 | 169 | 1/25/2024 |
1.0.20 | 1,592 | 12/21/2023 |
1.0.19 | 898 | 12/21/2023 |
1.0.18 | 705 | 12/8/2023 |
1.0.17 | 271 | 11/3/2023 |
1.0.16 | 222 | 10/25/2023 |
1.0.15 | 167 | 10/24/2023 |
1.0.14 | 144 | 10/24/2023 |
1.0.13 | 170 | 10/24/2023 |
1.0.12 | 160 | 10/24/2023 |
1.0.11 | 237 | 10/23/2023 |
1.0.10 | 189 | 10/22/2023 |
1.0.9 | 180 | 10/22/2023 |
1.0.8 | 158 | 10/21/2023 |
1.0.7 | 154 | 10/20/2023 |
1.0.6 | 163 | 10/20/2023 |
1.0.5 | 169 | 10/20/2023 |
1.0.4 | 162 | 10/20/2023 |
1.0.3 | 166 | 10/20/2023 |
1.0.2 | 139 | 10/20/2023 |
1.0.1 | 158 | 10/6/2023 |
1.0.0 | 145 | 10/4/2023 |