summary refs log tree commit diff
path: root/crypto/src/crypto/IBufferedCipher.cs
blob: 69dec9596cda2dc9fedb9617b9af6c4e513ffbc3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
using System;

namespace Org.BouncyCastle.Crypto
{
	/// <remarks>Block cipher engines are expected to conform to this interface.</remarks>
    public interface IBufferedCipher
    {
		/// <summary>The name of the algorithm this cipher implements.</summary>
		string AlgorithmName { get; }

		/// <summary>Initialise the cipher.</summary>
		/// <param name="forEncryption">If true the cipher is initialised for encryption,
		/// if false for decryption.</param>
		/// <param name="parameters">The key and other data required by the cipher.</param>
        void Init(bool forEncryption, ICipherParameters parameters);

		int GetBlockSize();

		int GetOutputSize(int inputLen);

		int GetUpdateOutputSize(int inputLen);

		byte[] ProcessByte(byte input);
		int ProcessByte(byte input, byte[] output, int outOff);

		byte[] ProcessBytes(byte[] input);
		byte[] ProcessBytes(byte[] input, int inOff, int length);
		int ProcessBytes(byte[] input, byte[] output, int outOff);
		int ProcessBytes(byte[] input, int inOff, int length, byte[] output, int outOff);

		byte[] DoFinal();
		byte[] DoFinal(byte[] input);
		byte[] DoFinal(byte[] input, int inOff, int length);
		int DoFinal(byte[] output, int outOff);
		int DoFinal(byte[] input, byte[] output, int outOff);
		int DoFinal(byte[] input, int inOff, int length, byte[] output, int outOff);

		/// <summary>
		/// Reset the cipher. After resetting the cipher is in the same state
		/// as it was after the last init (if there was one).
		/// </summary>
        void Reset();
    }
}