Perform first round of the JPAKE exchange.
aSignerID | String identifying the signer. |
aGX1 | Schnorr signature value g^x1, in hex representation. |
aGV1 | Schnorr signature value g^v1 (v1 is a random value), in hex representation. |
aR1 | Schnorr signature value r1 = v1 - x1 * h, in hex representation. |
aGX2 | Schnorr signature value g^x2, in hex representation. |
aGV2 | Schnorr signature value g^v2 (v2 is a random value), in hex representation. |
aR2 | Schnorr signature value r2 = v2 - x2 * h, in hex representation. |
Perform second round of the JPAKE exchange.
aPeerID | String identifying the peer. |
aPIN | String containing the weak secret (PIN). |
aGX3 | Schnorr signature value g^x3, in hex representation. |
aGV3 | Schnorr signature value g^v3 (v3 is a random value), in hex representation. |
aR3 | Schnorr signature value r3 = v3 - x3 * h, in hex representation. |
aGX4 | Schnorr signature value g^x4, in hex representation. |
aGV4 | Schnorr signature value g^v4 (v4 is a random value), in hex representation. |
aR4 | Schnorr signature value r4 = v4 - x4 * h, in hex representation. |
aA | Schnorr signature value A, in hex representation. |
aGVA | Schnorr signature value g^va (va is a random value), in hex representation. |
aRA | Schnorr signature value ra = va - xa * h, in hex representation. |
Perform the final step of the JPAKE exchange. This will compute
the key and expand the key to two keys, an AES256 encryption key
and a 256 bit HMAC key. It returns a key confirmation value
(SHA256d of the key) and the encryption and HMAC keys.
aB | Schnorr signature value B, in hex representation. |
aGVB | Schnorr signature value g^vb (vb is a random value), in hex representation. |
aRB | Schnorr signature value rb = vb - xb * h, in hex representation. |
aAES256Key | The AES 256 encryption key, in base64 representation. |
aHMAC256Key | The 256 bit HMAC key, in base64 representation. |