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
|
using Org.BouncyCastle.Crypto;
namespace Org.BouncyCastle.Pqc.Crypto.Crystals.Kyber
{
public sealed class KyberParameters
: ICipherParameters
{
public static KyberParameters kyber512 = new KyberParameters("kyber512", 2, 128, false);
public static KyberParameters kyber768 = new KyberParameters("kyber768", 3, 192, false);
public static KyberParameters kyber1024 = new KyberParameters("kyber1024", 4, 256, false);
public static KyberParameters kyber512_aes = new KyberParameters("kyber512-aes", 2, 128, true);
public static KyberParameters kyber768_aes = new KyberParameters("kyber768-aes", 3, 192, true);
public static KyberParameters kyber1024_aes = new KyberParameters("kyber1024-aes", 4, 256, true);
private string m_name;
private int m_sessionKeySize;
private KyberEngine m_engine;
public KyberParameters(string name, int k, int sessionKeySize, bool usingAes)
{
m_name = name;
this.m_sessionKeySize = sessionKeySize;
m_engine = new KyberEngine(k, usingAes);
}
public string Name => m_name;
public int K => m_engine.K;
public int SessionKeySize => m_sessionKeySize;
internal KyberEngine Engine => m_engine;
}
}
|