You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

33 lines
995 B

2 months ago
using System;
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Crypto.Signers;
namespace Org.BouncyCastle.Tls.Crypto.Impl.BC
{
public class BcTlsEd25519Signer
: BcTlsSigner
{
public BcTlsEd25519Signer(BcTlsCrypto crypto, Ed25519PrivateKeyParameters privateKey)
: base(crypto, privateKey)
{
}
public override byte[] GenerateRawSignature(SignatureAndHashAlgorithm algorithm, byte[] hash)
{
throw new NotSupportedException();
}
public override TlsStreamSigner GetStreamSigner(SignatureAndHashAlgorithm algorithm)
{
if (algorithm == null || SignatureScheme.From(algorithm) != SignatureScheme.ed25519)
throw new InvalidOperationException("Invalid algorithm: " + algorithm);
Ed25519Signer signer = new Ed25519Signer();
signer.Init(true, m_privateKey);
return new BcTlsStreamSigner(signer);
}
}
}