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);
}
}
}
|