Skip to content

Implementation of AEAD_CHACHA20_POLY1305 an authenticated encryption with additional data algorithm using ChaCha20, and Poly1305 designed by D. J. Bernstein. Optimized for PinnedMemory, and .NET core.

License

Notifications You must be signed in to change notification settings

TimothyMeadows/AeadChaCha20Poly1305.NetCore

Repository files navigation

AeadChaCha20Poly1305.NetCore

License: MIT nuget

Implementation of AEAD_CHACHA20_POLY1305 an authenticated encryption with additional data algorithm using ChaCha20, and Poly1305 designed by D. J. Bernstein. Optimized for PinnedMemory, and .NET core.

You can read more about AEAD, ChaCha20, and Poly1305 using the resources below:

Install

From a command prompt

dotnet add package AeadChaCha20Poly1305.NetCore
Install-Package AeadChaCha20Poly1305.NetCore

You can also search for package via your nuget ui / website:

https://www.nuget.org/packages/AeadChaCha20Poly1305.NetCore/

Examples

You can find more examples in the github examples project.

var nonce = new byte[16];
var key = new byte[32];
var data = new byte[1024];

using var provider = new RNGCryptoServiceProvider();
provider.GetBytes(nonce);
provider.GetBytes(key);
provider.GetBytes(data);

using var keyPin = new PinnedMemory<byte>(key, false);
var aeadChaCha20Poly1305 = new AeadChaCha20Poly1305(keyPin, nonce, new byte[] { 32 });

// Encryption / Authentication
using var dataPin = new PinnedMemory<byte>(data, false);
eadChaCha20Poly1305.UpdateBlock(dataPin,0, dataPin.Length);

using var output = new PinnedMemory<byte>(new byte[aeadChaCha20Poly1305.GetLength()]);
aeadChaCha20Poly1305.DoFinal(output, 0);
var tag = aeadChaCha20Poly1305.GetTag(); // Poly1305 tag used to authenticate cipher

// Decryption / Authentication
aeadChaCha20Poly1305.Reset();
aeadChaCha20Poly1305.SetTag(tag);
aeadChaCha20Poly1305.UpdateBlock(output,0, output.Length);

using var plain = new PinnedMemory<byte>(new byte[aeadChaCha20Poly1305.GetLength()]);
aeadChaCha20Poly1305.DoFinal(plain, 0);

Constructor

AeadChaCha20Poly1305(PinnedMemory<byte> key, byte[] nonce, byte[] ad = null, int rounds = 20)

Methods

Get the cipher output length.

int GetLength()

Get the cipher authentication tag length.

int GetTagLength()

Get the contents of the internal buffer, this can be used to compare data before encryption, or decryption.

byte[] GetBuffer()

Update the cipher with a single byte.

void Update(byte input)

Update the cipher with a pinned memory byte array.

void UpdateBlock(PinnedMemory<byte> input, int inOff, int len)

Update the cipher with a byte array.

void UpdateBlock(byte[] input, int inOff, int len)

Produce the final cipher outputting to pinned memory. Key & nonce remain.

void DoFinal(PinnedMemory<byte> output, int outOff)

Get the final cipher tag, this should be called after DoFinal.

PinnedMemory<byte> GetTag()

Set the final cipher tag, this should be called before DoFinal, and is required for decryption.

void SetTag(PinnedMemory<byte> value)

Reset the cipher back to it's initial state for further processing. Key remains until dispose is called.

void Reset()

Clear key & nonce, reset cipher back to it's initial state.

void Dispose()

About

Implementation of AEAD_CHACHA20_POLY1305 an authenticated encryption with additional data algorithm using ChaCha20, and Poly1305 designed by D. J. Bernstein. Optimized for PinnedMemory, and .NET core.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages