summary refs log tree commit diff
path: root/crypto/src/pqc/crypto/lms/LMSKeyPairGenerator.cs
blob: e1afb00d9738eefabdcb677c3a03f9e0403b16c8 (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
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Security;

namespace Org.BouncyCastle.Pqc.Crypto.Lms
{
    public sealed class LmsKeyPairGenerator
        : IAsymmetricCipherKeyPairGenerator
    {
        private LmsKeyGenerationParameters m_parameters;

        public void Init(KeyGenerationParameters parameters)
        {
            m_parameters = (LmsKeyGenerationParameters)parameters;
        }

        public AsymmetricCipherKeyPair GenerateKeyPair()
        {
            SecureRandom source = m_parameters.Random;

            byte[] I = new byte[16];
            source.NextBytes(I);

            byte[] rootSecret = new byte[32];
            source.NextBytes(rootSecret);

            LmsPrivateKeyParameters privKey = Lms.GenerateKeys(m_parameters.LmsParameters.LMSigParameters,
                m_parameters.LmsParameters.LMOtsParameters, 0, I, rootSecret);

            return new AsymmetricCipherKeyPair(privKey.GetPublicKey(), privKey);
        }
    }
}