|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
using Internal.Cryptography;
using Internal.NativeCrypto;
namespace System.Security.Cryptography
{
internal sealed partial class RC2Implementation
{
private static UniversalCryptoTransform CreateTransformCore(
CipherMode cipherMode,
PaddingMode paddingMode,
byte[] key,
byte[]? iv,
int blockSize,
int _ /*feedbackSize*/,
int paddingSize,
bool encrypting)
{
using (SafeAlgorithmHandle algorithm = RC2BCryptModes.GetHandle(cipherMode, key.Length * 8))
{
// The BasicSymmetricCipherBCrypt ctor will increase algorithm reference count and take ownership.
BasicSymmetricCipher cipher = new BasicSymmetricCipherBCrypt(algorithm, cipherMode, blockSize, paddingSize, key, true, iv, encrypting);
return UniversalCryptoTransform.Create(paddingMode, cipher, encrypting);
}
}
private static BasicSymmetricCipherLiteBCrypt CreateLiteCipher(
CipherMode cipherMode,
ReadOnlySpan<byte> key,
ReadOnlySpan<byte> iv,
int blockSize,
int paddingSize,
bool encrypting)
{
using (SafeAlgorithmHandle algorithm = RC2BCryptModes.GetHandle(cipherMode, key.Length * 8))
{
// The BasicSymmetricCipherBCrypt ctor will increase algorithm reference count and take ownership.
return new BasicSymmetricCipherLiteBCrypt(
algorithm,
blockSize,
paddingSize,
key,
ownsParentHandle: true,
iv,
encrypting);
}
}
}
}
|