summary refs log tree commit diff
path: root/crypto/src/pqc/crypto/crystals/kyber/KyberParameters.cs
blob: 00bc3950bffadd0bf7ba4210883e689a642e1add (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
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;
    }
}