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.
118 lines
2.4 KiB
118 lines
2.4 KiB
1 year ago
|
#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
|
||
|
#pragma warning disable
|
||
|
using System;
|
||
|
using System.IO;
|
||
|
|
||
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Engines;
|
||
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Parameters;
|
||
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
|
||
|
|
||
|
namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto
|
||
|
{
|
||
|
public class BufferedIesCipher
|
||
|
: BufferedCipherBase
|
||
|
{
|
||
|
private readonly IesEngine engine;
|
||
|
private bool forEncryption;
|
||
|
private MemoryStream buffer = new MemoryStream();
|
||
|
|
||
|
public BufferedIesCipher(
|
||
|
IesEngine engine)
|
||
|
{
|
||
|
if (engine == null)
|
||
|
throw new ArgumentNullException("engine");
|
||
|
|
||
|
this.engine = engine;
|
||
|
}
|
||
|
|
||
|
public override string AlgorithmName
|
||
|
{
|
||
|
// TODO Create IESEngine.AlgorithmName
|
||
|
get { return "IES"; }
|
||
|
}
|
||
|
|
||
|
public override void Init(
|
||
|
bool forEncryption,
|
||
|
ICipherParameters parameters)
|
||
|
{
|
||
|
this.forEncryption = forEncryption;
|
||
|
|
||
|
// TODO
|
||
|
throw BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.CreateNotImplementedException("IES");
|
||
|
}
|
||
|
|
||
|
public override int GetBlockSize()
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
public override int GetOutputSize(
|
||
|
int inputLen)
|
||
|
{
|
||
|
if (engine == null)
|
||
|
throw new InvalidOperationException("cipher not initialised");
|
||
|
|
||
|
int baseLen = inputLen + (int) buffer.Length;
|
||
|
return forEncryption
|
||
|
? baseLen + 20
|
||
|
: baseLen - 20;
|
||
|
}
|
||
|
|
||
|
public override int GetUpdateOutputSize(
|
||
|
int inputLen)
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
public override byte[] ProcessByte(
|
||
|
byte input)
|
||
|
{
|
||
|
buffer.WriteByte(input);
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
public override byte[] ProcessBytes(
|
||
|
byte[] input,
|
||
|
int inOff,
|
||
|
int length)
|
||
|
{
|
||
|
if (input == null)
|
||
|
throw new ArgumentNullException("input");
|
||
|
if (inOff < 0)
|
||
|
throw new ArgumentException("inOff");
|
||
|
if (length < 0)
|
||
|
throw new ArgumentException("length");
|
||
|
if (inOff + length > input.Length)
|
||
|
throw new ArgumentException("invalid offset/length specified for input array");
|
||
|
|
||
|
buffer.Write(input, inOff, length);
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
public override byte[] DoFinal()
|
||
|
{
|
||
|
byte[] buf = buffer.ToArray();
|
||
|
|
||
|
Reset();
|
||
|
|
||
|
return engine.ProcessBlock(buf, 0, buf.Length);
|
||
|
}
|
||
|
|
||
|
public override byte[] DoFinal(
|
||
|
byte[] input,
|
||
|
int inOff,
|
||
|
int length)
|
||
|
{
|
||
|
ProcessBytes(input, inOff, length);
|
||
|
return DoFinal();
|
||
|
}
|
||
|
|
||
|
public override void Reset()
|
||
|
{
|
||
|
buffer.SetLength(0);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
#pragma warning restore
|
||
|
#endif
|