You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Zero/ZeroLevel/Services/Encryption/AesEncryptor.cs

190 lines
6.7 KiB

6 years ago
using System;
using System.IO;
using System.Security.Cryptography;
namespace ZeroLevel.Services.Encryption
{
2 years ago
public class AesEncryptor
6 years ago
: IDisposable
{
protected const int DEFAULT_STREAM_BUFFER_SIZE = 16384;
private static readonly byte[] SALT = new byte[] { 0x26, 0xdc, 0xff, 0x00, 0xad, 0xed, 0x7a, 0xee, 0xc5, 0xfe, 0x07, 0xaf, 0x4d, 0x08, 0x22, 0x3c };
#region Crypt fields
2 years ago
private Aes _aes;
6 years ago
private CryptoStream _stream;
#endregion Crypt fields
6 years ago
9 months ago
public AesEncryptor(Stream stream, string password, byte[] salt = null!)
6 years ago
{
2 years ago
_aes = Aes.Create();
6 years ago
using (var pdb = new Rfc2898DeriveBytes(password, SALT))
{
2 years ago
_aes.Key = pdb.GetBytes(32);
_aes.IV = pdb.GetBytes(16);
6 years ago
}
2 years ago
_stream = new CryptoStream(stream, _aes.CreateEncryptor(), CryptoStreamMode.Write);
6 years ago
}
public void Write(byte[] data)
{
_stream.Write(data, 0, data.Length);
}
#region OneTime Read/Write
6 years ago
protected static void Transfer(Stream input, Stream output)
{
if (input.CanRead == false)
{
throw new InvalidOperationException("Input stream can not be read.");
}
if (output.CanWrite == false)
{
throw new InvalidOperationException("Output stream can not be write.");
}
var readed = 0;
var buffer = new byte[DEFAULT_STREAM_BUFFER_SIZE];
while ((readed = input.Read(buffer, 0, buffer.Length)) != 0)
{
output.Write(buffer, 0, readed);
}
output.Flush();
}
9 months ago
public static byte[] Encrypt(byte[] plain, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
6 years ago
using (var memoryStream = new MemoryStream())
{
2 years ago
using (var cryptoStream = new CryptoStream(memoryStream, aes.CreateEncryptor(), CryptoStreamMode.Write))
6 years ago
{
cryptoStream.Write(plain, 0, plain.Length);
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}
}
9 months ago
public static byte[] Encrypt(Stream stream, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
6 years ago
using (var memoryStream = new MemoryStream())
{
2 years ago
using (var cryptoStream = new CryptoStream(memoryStream, aes.CreateEncryptor(), CryptoStreamMode.Write))
6 years ago
{
Transfer(stream, cryptoStream);
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}
}
9 months ago
public static void Encrypt(Stream inputStream, Stream outputStream, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
using (var cryptoStream = new CryptoStream(outputStream, aes.CreateEncryptor(), CryptoStreamMode.Write))
6 years ago
{
Transfer(inputStream, cryptoStream);
cryptoStream.Close();
}
}
}
}
9 months ago
public static byte[] Decrypt(byte[] cipher, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
6 years ago
using (var memoryStream = new MemoryStream())
{
2 years ago
using (var cryptoStream = new CryptoStream(memoryStream, aes.CreateDecryptor(), CryptoStreamMode.Write))
6 years ago
{
cryptoStream.Write(cipher, 0, cipher.Length);
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}
}
9 months ago
public static byte[] Decrypt(Stream stream, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
6 years ago
using (var memoryStream = new MemoryStream())
{
2 years ago
using (var cryptoStream = new CryptoStream(memoryStream, aes.CreateDecryptor(), CryptoStreamMode.Write))
6 years ago
{
Transfer(stream, cryptoStream);
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}
}
9 months ago
public static void Decrypt(Stream inputStream, Stream outputStream, string password, byte[] salt = null!)
6 years ago
{
2 years ago
using (var aes = Aes.Create())
6 years ago
{
using (var pdb = new Rfc2898DeriveBytes(password, salt ?? SALT))
{
2 years ago
aes.Key = pdb.GetBytes(32);
aes.IV = pdb.GetBytes(16);
using (var cryptoStream = new CryptoStream(outputStream, aes.CreateDecryptor(), CryptoStreamMode.Write))
6 years ago
{
Transfer(inputStream, cryptoStream);
cryptoStream.Close();
}
}
}
}
#endregion OneTime Read/Write
6 years ago
public void Dispose()
{
try
{
_stream.Flush();
_stream.Close();
_stream.Dispose();
}
catch { }
2 years ago
_aes.Clear();
_aes.Dispose();
6 years ago
}
}
}

Powered by TurnKey Linux.