/******************************************************************************************** * SIDH: an efficient supersingular isogeny cryptography library * * Abstract: API header file for SIKE *********************************************************************************************/ #ifndef SIKE_H_ #define SIKE_H_ #include #include #if defined(__cplusplus) extern "C" { #endif /* SIKE * * SIKE is a isogeny based post-quantum key encapsulation mechanism. Description of the * algorithm is provided in [SIKE]. This implementation uses 434-bit field size. The code * is based on "Additional_Implementations" from PQC NIST submission package which can * be found here: * https://csrc.nist.gov/CSRC/media/Projects/Post-Quantum-Cryptography/documents/round-1/submissions/SIKE.zip * * [SIKE] https://sike.org/files/SIDH-spec.pdf */ // SIKE_PUB_BYTESZ is the number of bytes in a public key. #define SIKE_PUB_BYTESZ 330 // SIKE_PRV_BYTESZ is the number of bytes in a private key. #define SIKE_PRV_BYTESZ 28 // SIKE_SS_BYTESZ is the number of bytes in a shared key. #define SIKE_SS_BYTESZ 16 // SIKE_MSG_BYTESZ is the number of bytes in a random bit string concatenated // with the public key (see 1.4 of SIKE). #define SIKE_MSG_BYTESZ 16 // SIKE_SS_BYTESZ is the number of bytes in a ciphertext. #define SIKE_CT_BYTESZ (SIKE_PUB_BYTESZ + SIKE_MSG_BYTESZ) // SIKE_keypair outputs a public and secret key. Internally it uses BN_rand() as // an entropy source. In case of success function returns 1, otherwise 0. OPENSSL_EXPORT int SIKE_keypair( uint8_t out_priv[SIKE_PRV_BYTESZ], uint8_t out_pub[SIKE_PUB_BYTESZ]); // SIKE_encaps generates and encrypts a random session key, writing those values to // |out_shared_key| and |out_ciphertext|, respectively. OPENSSL_EXPORT void SIKE_encaps( uint8_t out_shared_key[SIKE_SS_BYTESZ], uint8_t out_ciphertext[SIKE_CT_BYTESZ], const uint8_t pub_key[SIKE_PUB_BYTESZ]); // SIKE_decaps outputs a random session key, writing it to |out_shared_key|. OPENSSL_EXPORT void SIKE_decaps( uint8_t out_shared_key[SIKE_SS_BYTESZ], const uint8_t ciphertext[SIKE_CT_BYTESZ], const uint8_t pub_key[SIKE_PUB_BYTESZ], const uint8_t priv_key[SIKE_PRV_BYTESZ]); #if defined(__cplusplus) } #endif #endif