init commit

This commit is contained in:
2025-10-09 09:57:24 +09:00
commit 4d551bd74f
6636 changed files with 1218703 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Crypto.Utilities;
using Org.BouncyCastle.Security;
using Org.BouncyCastle.Utilities.Date;
namespace Org.BouncyCastle.Crypto.Prng;
public class X931SecureRandomBuilder
{
private readonly SecureRandom mRandom;
private IEntropySourceProvider mEntropySourceProvider;
private byte[] mDateTimeVector;
public X931SecureRandomBuilder()
: this(new SecureRandom(), predictionResistant: false)
{
}
public X931SecureRandomBuilder(SecureRandom entropySource, bool predictionResistant)
{
mRandom = entropySource;
mEntropySourceProvider = new BasicEntropySourceProvider(mRandom, predictionResistant);
}
public X931SecureRandomBuilder(IEntropySourceProvider entropySourceProvider)
{
mRandom = null;
mEntropySourceProvider = entropySourceProvider;
}
public X931SecureRandomBuilder SetDateTimeVector(byte[] dateTimeVector)
{
mDateTimeVector = dateTimeVector;
return this;
}
public X931SecureRandom Build(IBlockCipher engine, KeyParameter key, bool predictionResistant)
{
if (mDateTimeVector == null)
{
mDateTimeVector = new byte[engine.GetBlockSize()];
Pack.UInt64_To_BE((ulong)DateTimeUtilities.CurrentUnixMs(), mDateTimeVector, 0);
}
engine.Init(forEncryption: true, key);
return new X931SecureRandom(mRandom, new X931Rng(engine, mDateTimeVector, mEntropySourceProvider.Get(engine.GetBlockSize() * 8)), predictionResistant);
}
}