21 lines
538 B
C#
21 lines
538 B
C#
using Org.BouncyCastle.Crypto.Parameters;
|
|
|
|
namespace Org.BouncyCastle.Crypto.Agreement;
|
|
|
|
public sealed class X25519Agreement : IRawAgreement
|
|
{
|
|
private X25519PrivateKeyParameters privateKey;
|
|
|
|
public int AgreementSize => X25519PrivateKeyParameters.SecretSize;
|
|
|
|
public void Init(ICipherParameters parameters)
|
|
{
|
|
privateKey = (X25519PrivateKeyParameters)parameters;
|
|
}
|
|
|
|
public void CalculateAgreement(ICipherParameters publicKey, byte[] buf, int off)
|
|
{
|
|
privateKey.GenerateSecret((X25519PublicKeyParameters)publicKey, buf, off);
|
|
}
|
|
}
|