<PackageReference Include="BouncyCastle.Cryptography" Version="2.7.0-beta.98" />

JPakeRound1Payload

public class JPakeRound1Payload
The payload sent/received during the first round of a J-PAKE exchange. Each JPAKEParticipant creates and sends an instance of this payload to the other. The payload to send should be created via JPAKEParticipant.CreateRound1PayloadToSend(). Each participant must also validate the payload received from the other. The received payload should be validated via JPAKEParticipant.ValidateRound1PayloadReceived(JPakeRound1Payload).
using Org.BouncyCastle.Math; using Org.BouncyCastle.Utilities; namespace Org.BouncyCastle.Crypto.Agreement.JPake { public class JPakeRound1Payload { private readonly string participantId; private readonly BigInteger gx1; private readonly BigInteger gx2; private readonly BigInteger[] knowledgeProofForX1; private readonly BigInteger[] knowledgeProofForX2; public virtual string ParticipantId => participantId; public virtual BigInteger Gx1 => gx1; public virtual BigInteger Gx2 => gx2; public virtual BigInteger[] KnowledgeProofForX1 => Copy(knowledgeProofForX1); public virtual BigInteger[] KnowledgeProofForX2 => Copy(knowledgeProofForX2); public JPakeRound1Payload(string participantId, BigInteger gx1, BigInteger gx2, BigInteger[] knowledgeProofForX1, BigInteger[] knowledgeProofForX2) { JPakeUtilities.ValidateNotNull(participantId, "participantId"); JPakeUtilities.ValidateNotNull(gx1, "gx1"); JPakeUtilities.ValidateNotNull(gx2, "gx2"); JPakeUtilities.ValidateNotNull(knowledgeProofForX1, "knowledgeProofForX1"); JPakeUtilities.ValidateNotNull(knowledgeProofForX2, "knowledgeProofForX2"); this.participantId = participantId; this.gx1 = gx1; this.gx2 = gx2; this.knowledgeProofForX1 = Copy(knowledgeProofForX1); this.knowledgeProofForX2 = Copy(knowledgeProofForX2); } private static BigInteger[] Copy(BigInteger[] bis) { return Arrays.CopyOf(bis, bis.Length); } } }