GostCryptographyLite 0.1.0

dotnet add package GostCryptographyLite --version 0.1.0                
NuGet\Install-Package GostCryptographyLite -Version 0.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="GostCryptographyLite" Version="0.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add GostCryptographyLite --version 0.1.0                
#r "nuget: GostCryptographyLite, 0.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install GostCryptographyLite as a Cake Addin
#addin nuget:?package=GostCryptographyLite&version=0.1.0

// Install GostCryptographyLite as a Cake Tool
#tool nuget:?package=GostCryptographyLite&version=0.1.0                

GOST cryptoalgorithms in C#

Attention: this library is not certified and will not be in the future. Therefore, it is only available for use in a number of scenarios

Requirments

  • .NET 9

Installiation

Clone this repository and move the GostCryptographyLite project. In the future, it will be possible to use a NuGet package of this library.

Encryption and decrption

Example

using GostCryptographyLite;
using System.Security.Cryptography;

namespace TestGost
{
    internal class Program
    {
        static void Main(string[] args)
        {
            byte[] data = { 0x92, 0xde, 0xf0, 0x6b, 0x3c, 0x13, 0x0a, 0x59,
                            0xdb, 0x54, 0xc7, 0x04, 0xf8, 0x18, 0x9d, 0x20,
                            0x4a, 0x98, 0xfb, 0x2e, 0x67, 0xa8, 0x02, 0x4c,
                            0x89, 0x12, 0x40, 0x9b, 0x17 };

            Console.WriteLine("Input data:     " + BitConverter.ToString(data, 0, data.Length).Replace("-", "").ToLower());

            // Magma instance creation
            using (Magma magma = new Magma(GostCipherMode.OFB, PaddingMode.PKCS7, true)) // To use Kuznechik, replace Magma with Kuznechik
            {
                var key = new byte[] { 0xff, 0xee, 0xdd, 0xcc, 0xbb, 0xaa, 0x99, 0x88, 0x77, 0x66, 0x55, 0x44, 0x33, 0x22, 0x11, 0x00,
                                       0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff };

                var iv = new byte[] { 0x12, 0x34, 0x56, 0x78, 0x90, 0xab, 0xcd, 0xef,
                                      0x23, 0x45, 0x67, 0x89, 0x0a, 0xbc, 0xde, 0xf1 };

                // Encryptor creation
                var encryptor = magma.CreateEncryptor(key, iv);
                byte[] encryptedData;

                // Encrypt data with CryptoStream
                using (var memoryStream = new MemoryStream())
                using (var cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write))
                {
                    cryptoStream.Write(data, 0, data.Length);
                    cryptoStream.FlushFinalBlock();

                    encryptedData = memoryStream.ToArray();
                    Console.WriteLine("Encrypted data: " + BitConverter.ToString(encryptedData).Replace("-", "").ToLower());
                }

                // Decryptor creation
                var decryptor = magma.CreateDecryptor(key, iv);
                byte[] decryptedData;

                // Decrypt data with CryptoStream
                using (var memoryStream = new MemoryStream(encryptedData))
                using (var cryptoStream = new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read))
                using (var readMemoryStream = new MemoryStream())
                {
                    cryptoStream.CopyTo(readMemoryStream);
                    decryptedData = readMemoryStream.ToArray();

                    Console.WriteLine("Decrypted data: " + BitConverter.ToString(decryptedData).Replace("-", "").ToLower());
                }
            }
        }
    }
}

From the example, it is clear that this library interacts with the traditional C# CryptoStream, which facilitates its integration into both new systems and existing ones.

Program output:

Input data:     92def06b3c130a59db54c704f8189d204a98fb2e67a8024c8912409b17
Encrypted data: db37e0e266903c830d46644c1f9a089ca0f83062430e327ec824efb8bdf9a647
Decrypted data: 92def06b3c130a59db54c704f8189d204a98fb2e67a8024c8912409b17

Avaliabale cipher modes

Значение Режим шифрования Пояснение
1 CBC Cipher Block Chaining.
2 ECB Electronic Codebook.
3 OFB Output Feedback.
4 CFB Cipher Feedback.
5 CTS Cipher Text Stealing. (Not using)
6 CTR Counter mode.

IV length info

In GOST, encryption modes allow the use of an initialization vector with a length greater than the block size, but it must be a multiple of the block size. This behavior is NOT implemented when assigning an initialization vector to instances of the Magma and Kuznechik classes. To utilize this behavior, initialization vectors longer than the block size should be passed to the CreateEncryptor/CreateDecryptor methods as shown in example above.

Fast Implementation and Cryptanalysis of GOST R 34.12-2015 Block Ciphers (Payed accsess)

S. V. Matveev, “GOST 28147-89 masking against side channel attacks”

Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net9.0

    • No dependencies.

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
0.1.0 104 12/8/2024