Class JPAKEUtil
java.lang.Object
org.bouncycastle.crypto.agreement.jpake.JPAKEUtil
Primitives needed for a J-PAKE exchange.
The recommended way to perform a J-PAKE exchange is by using
two JPAKEParticipants. Internally, those participants
call these primitive operations in JPAKEUtil.
The primitives, however, can be used without a JPAKEParticipant
if needed.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic BigIntegercalculateA(BigInteger p, BigInteger q, BigInteger gA, BigInteger x2s) Calculate A as done in round 2.static BigIntegercalculateGA(BigInteger p, BigInteger gx1, BigInteger gx3, BigInteger gx4) Calculate ga as done in round 2.static BigIntegercalculateGx(BigInteger p, BigInteger g, BigInteger x) Calculate g^x mod p as done in round 1.static BigIntegercalculateKeyingMaterial(BigInteger p, BigInteger q, BigInteger gx4, BigInteger x2, BigInteger s, BigInteger B) Calculates the keying material, which can be done after round 2 has completed.static BigIntegercalculateMacTag(String participantId, String partnerParticipantId, BigInteger gx1, BigInteger gx2, BigInteger gx3, BigInteger gx4, BigInteger keyingMaterial, Digest digest) Calculates the MacTag (to be used for key confirmation), as defined by NIST SP 800-56A Revision 1, Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.static BigIntegercalculateS(char[] password) Deprecated.Use version including the modulus instead.static BigIntegercalculateS(BigInteger q, byte[] password) Converts the given password to aBigIntegermod q.static BigIntegercalculateS(BigInteger q, char[] password) Converts the given password to aBigIntegermod q.static BigIntegercalculateX2s(BigInteger q, BigInteger x2, BigInteger s) Calculate x2 * s as done in round 2.static BigInteger[]calculateZeroKnowledgeProof(BigInteger p, BigInteger q, BigInteger g, BigInteger gx, BigInteger x, String participantId, Digest digest, SecureRandom random) Calculate a zero knowledge proof of x using Schnorr's signature.static BigIntegergenerateX1(BigInteger q, SecureRandom random) Return a value that can be used as x1 or x3 during round 1.static BigIntegergenerateX2(BigInteger q, SecureRandom random) Return a value that can be used as x2 or x4 during round 1.static voidvalidateGa(BigInteger ga) Validates that ga is not 1.static voidvalidateGx4(BigInteger gx4) Validates that g^x4 is not 1.static voidvalidateMacTag(String participantId, String partnerParticipantId, BigInteger gx1, BigInteger gx2, BigInteger gx3, BigInteger gx4, BigInteger keyingMaterial, Digest digest, BigInteger partnerMacTag) Validates the MacTag received from the partner participant.static voidvalidateNotNull(Object object, String description) Validates that the given object is not null.static voidvalidateParticipantIdsDiffer(String participantId1, String participantId2) Validates that the given participant ids are not equal.static voidvalidateParticipantIdsEqual(String expectedParticipantId, String actualParticipantId) Validates that the given participant ids are equal.static voidvalidateZeroKnowledgeProof(BigInteger p, BigInteger q, BigInteger g, BigInteger gx, BigInteger[] zeroKnowledgeProof, String participantId, Digest digest) Validates the zero knowledge proof (generated bycalculateZeroKnowledgeProof(BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, String, Digest, SecureRandom)) is correct.
-
Constructor Details
-
JPAKEUtil
public JPAKEUtil()
-
-
Method Details
-
generateX1
Return a value that can be used as x1 or x3 during round 1.The returned value is a random value in the range [0, q-1].
-
generateX2
Return a value that can be used as x2 or x4 during round 1.The returned value is a random value in the range [1, q-1].
-
calculateS
Deprecated.Use version including the modulus instead.Converts the given password to aBigIntegerfor use in arithmetic calculations. -
calculateS
Converts the given password to aBigIntegermod q.- Throws:
CryptoException
-
calculateS
Converts the given password to aBigIntegermod q.- Throws:
CryptoException
-
calculateGx
Calculate g^x mod p as done in round 1. -
calculateGA
Calculate ga as done in round 2. -
calculateX2s
Calculate x2 * s as done in round 2. -
calculateA
Calculate A as done in round 2. -
calculateZeroKnowledgeProof
public static BigInteger[] calculateZeroKnowledgeProof(BigInteger p, BigInteger q, BigInteger g, BigInteger gx, BigInteger x, String participantId, Digest digest, SecureRandom random) Calculate a zero knowledge proof of x using Schnorr's signature. The returned array has two elements {g^v, r = v-x*h} for x. -
validateGx4
Validates that g^x4 is not 1.- Throws:
CryptoException- if g^x4 is 1
-
validateGa
Validates that ga is not 1.As described by Feng Hao...
Alice could simply check ga != 1 to ensure it is a generator. In fact, as we will explain in Section 3, (x1 + x3 + x4 ) is random over Zq even in the face of active attacks. Hence, the probability for ga = 1 is extremely small - on the order of 2^160 for 160-bit q.
- Throws:
CryptoException- if ga is 1
-
validateZeroKnowledgeProof
public static void validateZeroKnowledgeProof(BigInteger p, BigInteger q, BigInteger g, BigInteger gx, BigInteger[] zeroKnowledgeProof, String participantId, Digest digest) throws CryptoException Validates the zero knowledge proof (generated bycalculateZeroKnowledgeProof(BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, String, Digest, SecureRandom)) is correct.- Throws:
CryptoException- if the zero knowledge proof is not correct
-
calculateKeyingMaterial
public static BigInteger calculateKeyingMaterial(BigInteger p, BigInteger q, BigInteger gx4, BigInteger x2, BigInteger s, BigInteger B) Calculates the keying material, which can be done after round 2 has completed. A session key must be derived from this key material using a secure key derivation function (KDF). The KDF used to derive the key is handled externally (i.e. not byJPAKEParticipant).KeyingMaterial = (B/g^{x2*x4*s})^x2 -
validateParticipantIdsDiffer
public static void validateParticipantIdsDiffer(String participantId1, String participantId2) throws CryptoException Validates that the given participant ids are not equal. (For the J-PAKE exchange, each participant must use a unique id.)- Throws:
CryptoException- if the participantId strings are equal.
-
validateParticipantIdsEqual
public static void validateParticipantIdsEqual(String expectedParticipantId, String actualParticipantId) throws CryptoException Validates that the given participant ids are equal. This is used to ensure that the payloads received from each round all come from the same participant.- Throws:
CryptoException- if the participantId strings are equal.
-
validateNotNull
Validates that the given object is not null.- Parameters:
object- object in questiondescription- name of the object (to be used in exception message)- Throws:
NullPointerException- if the object is null.
-
calculateMacTag
public static BigInteger calculateMacTag(String participantId, String partnerParticipantId, BigInteger gx1, BigInteger gx2, BigInteger gx3, BigInteger gx4, BigInteger keyingMaterial, Digest digest) Calculates the MacTag (to be used for key confirmation), as defined by NIST SP 800-56A Revision 1, Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.MacTag = HMAC(MacKey, MacLen, MacData) MacKey = H(K || "JPAKE_KC") MacData = "KC_1_U" || participantId || partnerParticipantId || gx1 || gx2 || gx3 || gx4 Note that both participants use "KC_1_U" because the sender of the round 3 message is always the initiator for key confirmation. HMAC =
HMacused with the givenDigestH = The givenDigestMacLen = length of MacTag -
validateMacTag
public static void validateMacTag(String participantId, String partnerParticipantId, BigInteger gx1, BigInteger gx2, BigInteger gx3, BigInteger gx4, BigInteger keyingMaterial, Digest digest, BigInteger partnerMacTag) throws CryptoException Validates the MacTag received from the partner participant.- Parameters:
partnerMacTag- the MacTag received from the partner.- Throws:
CryptoException- if the participantId strings are equal.
-