/*! \ingroup ED448 \brief この関数は、秘密鍵からEd448公開鍵を生成します。公開鍵をバッファpubKeyに格納し、このバッファに書き込まれたバイト数をpubKeySzに設定します。 \return 0 公開鍵の作成に成功した場合に返されます。 \return BAD_FUNC_ARG keyまたはpubKeyがNULLと評価された場合、または指定されたキーサイズが57バイトでない場合に返されます(Ed448は57バイトのキーを持ちます)。 \return MEMORY_E 関数実行中にメモリの割り当てエラーが発生した場合に返されます。 \param [in] key キーを生成するed448_keyへのポインタ。 \param [out] pubKey 公開鍵を格納するバッファへのポインタ。 \param [in] pubKeySz pubKeyバッファのサイズ(バイト単位)。 _Example_ \code int ret; ed448_key key; byte priv[] = { 57バイトの秘密鍵で初期化 }; byte pub[57]; word32 pubSz = sizeof(pub); wc_ed448_init(&key); wc_ed448_import_private_only(priv, sizeof(priv), &key); ret = wc_ed448_make_public(&key, pub, &pubSz); if (ret != 0) { // 公開鍵の作成エラー } \endcode \sa wc_ed448_init \sa wc_ed448_import_private_only \sa wc_ed448_make_key */ int wc_ed448_make_public(ed448_key* key, unsigned char* pubKey, word32 pubKeySz); /*! \ingroup ED448 \brief この関数は新しいEd448キーを生成し、それをkeyに格納します。 \return 0 ed448_keyの作成に成功した場合に返されます。 \return BAD_FUNC_ARG rngまたはkeyがNULLと評価された場合、または指定されたキーサイズが57バイトでない場合に返されます(Ed448は57バイトのキーを持ちます)。 \return MEMORY_E 関数実行中にメモリの割り当てエラーが発生した場合に返されます。 \param [in] rng キーを生成するために使用する初期化済みRNGオブジェクトへのポインタ。 \param [in] keysize 生成するキーの長さ。Ed448の場合は常に57である必要があります。 \param [in,out] key キーを生成するed448_keyへのポインタ。 _Example_ \code int ret; WC_RNG rng; ed448_key key; wc_InitRng(&rng); wc_ed448_init(&key); ret = wc_ed448_make_key(&rng, 57, &key); if (ret != 0) { // キー作成エラー } \endcode \sa wc_ed448_init */ int wc_ed448_make_key(WC_RNG* rng, int keysize, ed448_key* key); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにed448_keyオブジェクトを使用してメッセージに署名します。 \return 0 メッセージの署名の生成に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、または出力バッファが生成された署名を格納するには小さすぎる場合に返されます。 \return MEMORY_E 関数実行中にメモリの割り当てエラーが発生した場合に返されます。 \param [in] in 署名するメッセージを含むバッファへのポインタ。 \param [in] inLen 署名するメッセージの長さ。 \param [out] out 生成された署名を格納するバッファ。 \param [in,out] outLen 出力バッファの最大長。メッセージ署名の生成に成功した後、outに書き込まれたバイト数が格納されます。 \param [in] key 署名を生成するために使用する秘密ed448_keyへのポインタ。 \param [in] context メッセージが署名されるコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; WC_RNG rng; int ret, sigSz; byte sig[114]; // 生成された署名を保持 sigSz = sizeof(sig); byte message[] = { メッセージで初期化 }; wc_InitRng(&rng); // rngを初期化 wc_ed448_init(&key); // keyを初期化 wc_ed448_make_key(&rng, 57, &key); // 公開/秘密鍵ペアを作成 ret = wc_ed448_sign_msg(message, sizeof(message), sig, &sigSz, &key); if (ret != 0 ) { // メッセージ署名の生成エラー } \endcode \sa wc_ed448ph_sign_hash \sa wc_ed448ph_sign_msg \sa wc_ed448_verify_msg */ int wc_ed448_sign_msg(const byte* in, word32 inLen, byte* out, word32 *outLen, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにed448_keyオブジェクトを使用してメッセージダイジェストに署名します。コンテキストは署名されるデータの一部として含まれます。ハッシュは署名計算前の事前ハッシュ化されたメッセージです。 \return 0 メッセージダイジェストの署名の生成に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、または出力バッファが生成された署名を格納するには小さすぎる場合に返されます。 \return MEMORY_E 関数実行中にメモリの割り当てエラーが発生した場合に返されます。 \param [in] hash 署名するメッセージのハッシュを含むバッファへのポインタ。 \param [in] hashLen 署名するメッセージのハッシュの長さ。 \param [out] out 生成された署名を格納するバッファ。 \param [in,out] outLen 出力バッファの最大長。メッセージ署名の生成に成功した後、outに書き込まれたバイト数が格納されます。 \param [in] key 署名を生成するために使用する秘密ed448_keyへのポインタ。 \param [in] context メッセージが署名されているコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; WC_RNG rng; int ret, sigSz; byte sig[114]; // 生成された署名を保持 sigSz = sizeof(sig); byte hash[] = { メッセージのハッシュで初期化 }; byte context[] = { 署名のコンテキストで初期化 }; wc_InitRng(&rng); // rngを初期化 wc_ed448_init(&key); // keyを初期化 wc_ed448_make_key(&rng, 57, &key); // 公開/秘密鍵ペアを作成 ret = wc_ed448ph_sign_hash(hash, sizeof(hash), sig, &sigSz, &key, context, sizeof(context)); if (ret != 0) { // メッセージ署名の生成エラー } \endcode \sa wc_ed448_sign_msg \sa wc_ed448ph_sign_msg \sa wc_ed448ph_verify_hash */ int wc_ed448ph_sign_hash(const byte* hash, word32 hashLen, byte* out, word32 *outLen, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにed448_keyオブジェクトを使用してメッセージに署名します。コンテキストは署名されるデータの一部として含まれます。メッセージは署名計算前に事前ハッシュ化されます。 \return 0 メッセージの署名の生成に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、または出力バッファが生成された署名を格納するには小さすぎる場合に返されます。 \return MEMORY_E 関数実行中にメモリの割り当てエラーが発生した場合に返されます。 \param [in] in 署名するメッセージを含むバッファへのポインタ。 \param [in] inLen 署名するメッセージの長さ。 \param [out] out 生成された署名を格納するバッファ。 \param [in,out] outLen 出力バッファの最大長。メッセージ署名の生成に成功した後、outに書き込まれたバイト数が格納されます。 \param [in] key 署名を生成するために使用する秘密ed448_keyへのポインタ。 \param [in] context メッセージが署名されているコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; WC_RNG rng; int ret, sigSz; byte sig[114]; // 生成された署名を保持 sigSz = sizeof(sig); byte message[] = { メッセージで初期化 }; byte context[] = { 署名のコンテキストで初期化 }; wc_InitRng(&rng); // rngを初期化 wc_ed448_init(&key); // keyを初期化 wc_ed448_make_key(&rng, 57, &key); // 公開/秘密鍵ペアを作成 ret = wc_ed448ph_sign_msg(message, sizeof(message), sig, &sigSz, &key, context, sizeof(context)); if (ret != 0) { // メッセージ署名の生成エラー } \endcode \sa wc_ed448_sign_msg \sa wc_ed448ph_sign_hash \sa wc_ed448ph_verify_msg */ int wc_ed448ph_sign_msg(const byte* in, word32 inlen, byte* out, word32 *outlen, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにメッセージのEd448署名を検証します。コンテキストは検証されるデータの一部として含まれます。答えはresを通じて返され、1は有効な署名に対応し、0は無効な署名に対応します。 \return 0 署名の検証と認証の実行に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、またはsiglenが署名の実際の長さと一致しない場合に返されます。 \return SIG_VERIFY_E 検証は完了したが、生成された署名が提供された署名と一致しない場合に返されます。 \param [in] sig 検証する署名を含むバッファへのポインタ。 \param [in] siglen 検証する署名の長さ。 \param [in] msg 検証するメッセージを含むバッファへのポインタ。 \param [in] msgLen 検証するメッセージの長さ。 \param [out] res 検証完了後、有効な署名の場合は1、無効な署名の場合は0が設定されるint型へのポインタ。 \param [in] key 署名を検証するために使用する公開Ed448鍵へのポインタ。 \param [in] context メッセージが署名されたコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; int ret, verified = 0; byte sig[] { 受信した署名で初期化 }; byte msg[] = { メッセージで初期化 }; byte context[] = { 署名のコンテキストで初期化 }; // 受信した公開鍵でkeyを初期化 ret = wc_ed448_verify_msg(sig, sizeof(sig), msg, sizeof(msg), &verified, &key, context, sizeof(context)); if (ret < 0) { // 検証実行エラー } else if (verified == 0) // 署名が無効 } \endcode \sa wc_ed448ph_verify_hash \sa wc_ed448ph_verify_msg \sa wc_ed448_sign_msg */ int wc_ed448_verify_msg(const byte* sig, word32 siglen, const byte* msg, word32 msgLen, int* res, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにメッセージのダイジェストのEd448署名を検証します。コンテキストは検証されるデータの一部として含まれます。ハッシュは署名計算前の事前ハッシュ化されたメッセージです。答えはresを通じて返され、1は有効な署名に対応し、0は無効な署名に対応します。 \return 0 署名の検証と認証の実行に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、またはsiglenが署名の実際の長さと一致しない場合に返されます。 \return SIG_VERIFY_E 検証は完了したが、生成された署名が提供された署名と一致しない場合に返されます。 \param [in] sig 検証する署名を含むバッファへのポインタ。 \param [in] siglen 検証する署名の長さ。 \param [in] hash 検証するメッセージのハッシュを含むバッファへのポインタ。 \param [in] hashlen 検証するハッシュの長さ。 \param [out] res 検証完了後、有効な署名の場合は1、無効な署名の場合は0が設定されるint型へのポインタ。 \param [in] key 署名を検証するために使用する公開Ed448鍵へのポインタ。 \param [in] context メッセージが署名されたコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; int ret, verified = 0; byte sig[] { 受信した署名で初期化 }; byte hash[] = { メッセージのハッシュで初期化 }; byte context[] = { 署名のコンテキストで初期化 }; // 受信した公開鍵でkeyを初期化 ret = wc_ed448ph_verify_hash(sig, sizeof(sig), hash, sizeof(hash), &verified, &key, context, sizeof(context)); if (ret < 0) { // 検証実行エラー } else if (verified == 0) // 署名が無効 } \endcode \sa wc_ed448_verify_msg \sa wc_ed448ph_verify_msg \sa wc_ed448ph_sign_hash */ int wc_ed448ph_verify_hash(const byte* sig, word32 siglen, const byte* hash, word32 hashlen, int* res, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、真正性を保証するためにメッセージのEd448署名を検証します。コンテキストは検証されるデータの一部として含まれます。メッセージは検証前に事前ハッシュ化されます。答えはresを通じて返され、1は有効な署名に対応し、0は無効な署名に対応します。 \return 0 署名の検証と認証の実行に成功した場合に返されます。 \return BAD_FUNC_ARG 入力パラメータのいずれかがNULLと評価された場合、またはsiglenが署名の実際の長さと一致しない場合に返されます。 \return SIG_VERIFY_E 検証は完了したが、生成された署名が提供された署名と一致しない場合に返されます。 \param [in] sig 検証する署名を含むバッファへのポインタ。 \param [in] siglen 検証する署名の長さ。 \param [in] msg 検証するメッセージを含むバッファへのポインタ。 \param [in] msgLen 検証するメッセージの長さ。 \param [out] res 検証完了後、有効な署名の場合は1、無効な署名の場合は0が設定されるint型へのポインタ。 \param [in] key 署名を検証するために使用する公開Ed448鍵へのポインタ。 \param [in] context メッセージが署名されたコンテキストを含むバッファへのポインタ。 \param [in] contextLen コンテキストバッファの長さ。 _Example_ \code ed448_key key; int ret, verified = 0; byte sig[] { 受信した署名で初期化 }; byte msg[] = { メッセージで初期化 }; byte context[] = { 署名のコンテキストで初期化 }; // 受信した公開鍵でkeyを初期化 ret = wc_ed448ph_verify_msg(sig, sizeof(sig), msg, sizeof(msg), &verified, &key, context, sizeof(context)); if (ret < 0) { // 検証実行エラー } else if (verified == 0) // 署名が無効 } \endcode \sa wc_ed448_verify_msg \sa wc_ed448ph_verify_hash \sa wc_ed448ph_sign_msg */ int wc_ed448ph_verify_msg(const byte* sig, word32 siglen, const byte* msg, word32 msgLen, int* res, ed448_key* key, const byte* context, byte contextLen); /*! \ingroup ED448 \brief この関数は、メッセージ検証での将来の使用のためにed448_keyオブジェクトを初期化します。 \return 0 ed448_keyオブジェクトの初期化に成功した場合に返されます。 \return BAD_FUNC_ARG keyがNULLの場合に返されます。 \param [in,out] key 初期化するed448_keyオブジェクトへのポインタ。 _Example_ \code ed448_key key; wc_ed448_init(&key); \endcode \sa wc_ed448_make_key \sa wc_ed448_free */ int wc_ed448_init(ed448_key* key); /*! \ingroup ED448 \brief この関数は、使用後にEd448オブジェクトを解放します。 \param [in,out] key 解放するed448_keyオブジェクトへのポインタ _Example_ \code ed448_key key; // keyを初期化し、安全な交換を実行 ... wc_ed448_free(&key); \endcode \sa wc_ed448_init */ void wc_ed448_free(ed448_key* key); /*! \ingroup ED448 \brief この関数は、公開鍵を含むバッファから公開ed448_keyペアをインポートします。この関数は、圧縮キーと非圧縮キーの両方を処理します。公開鍵は、秘密鍵が存在する場合にそれと一致するかチェックされます。 \return 0 ed448_keyのインポートに成功した場合に返されます。 \return BAD_FUNC_ARG inまたはkeyがNULLと評価された場合、またはinLenがEd448鍵のサイズより小さい場合に返されます。 \param [in] in 公開鍵を含むバッファへのポインタ。 \param [in] inLen 公開鍵を含むバッファの長さ。 \param [in,out] key 公開鍵を格納するed448_keyオブジェクトへのポインタ。 _Example_ \code int ret; byte pub[] = { Ed448公開鍵で初期化 }; ed_448 key; wc_ed448_init_key(&key); ret = wc_ed448_import_public(pub, sizeof(pub), &key); if (ret != 0) { // 鍵のインポートエラー } \endcode \sa wc_ed448_import_public_ex \sa wc_ed448_import_private_key \sa wc_ed448_import_private_key_ex \sa wc_ed448_export_public */ int wc_ed448_import_public(const byte* in, word32 inLen, ed448_key* key); /*! \ingroup ED448 \brief この関数は、公開鍵を含むバッファから公開ed448_keyペアをインポートします。この関数は、圧縮キーと非圧縮キーの両方を処理します。信頼されていない場合、秘密鍵が存在するときに公開鍵が秘密鍵と一致するかチェックします。 \return 0 ed448_keyのインポートに成功した場合に返されます。 \return BAD_FUNC_ARG inまたはkeyがNULLと評価された場合、またはinLenがEd448鍵のサイズより小さい場合に返されます。 \param [in] in 公開鍵を含むバッファへのポインタ。 \param [in] inLen 公開鍵を含むバッファの長さ。 \param [in,out] key 公開鍵を格納するed448_keyオブジェクトへのポインタ。 \param [in] trusted 公開鍵データが信頼されているかどうか。 _Example_ \code int ret; byte pub[] = { Ed448公開鍵で初期化 }; ed_448 key; wc_ed448_init_key(&key); ret = wc_ed448_import_public_ex(pub, sizeof(pub), &key, 1); if (ret != 0) { // 鍵のインポートエラー } \endcode \sa wc_ed448_import_public \sa wc_ed448_import_private_key \sa wc_ed448_import_private_key_ex \sa wc_ed448_export_public */ int wc_ed448_import_public_ex(const byte* in, word32 inLen, ed448_key* key, int trusted); /*! \ingroup ED448 \brief この関数は、バッファからEd448秘密鍵のみをインポートします。 \return 0 Ed448秘密鍵のインポートに成功した場合に返されます。 \return BAD_FUNC_ARG inまたはkeyがNULLと評価された場合、またはprivSzがED448_KEY_SIZEより小さい場合に返されます。 \param [in] priv 秘密鍵を含むバッファへのポインタ。 \param [in] privSz 秘密鍵の長さ。 \param [in,out] key インポートされた秘密鍵を格納するed448_keyオブジェクトへのポインタ。 _Example_ \code int ret; byte priv[] = { 57バイトの秘密鍵で初期化 }; ed448_key key; wc_ed448_init_key(&key); ret = wc_ed448_import_private_only(priv, sizeof(priv), &key); if (ret != 0) { // 秘密鍵のインポートエラー } \endcode \sa wc_ed448_import_public \sa wc_ed448_import_public_ex \sa wc_ed448_import_private_key \sa wc_ed448_import_private_key_ex \sa wc_ed448_export_private_only */ int wc_ed448_import_private_only(const byte* priv, word32 privSz, ed448_key* key); /*! \ingroup ED448 \brief この関数は、一対のバッファから公開/秘密Ed448鍵ペアをインポートします。この関数は、圧縮キーと非圧縮キーの両方を処理します。 \return 0 Ed448鍵のインポートに成功した場合に返されます。 \return BAD_FUNC_ARG inまたはkeyがNULLと評価された場合、またはprivSzがED448_KEY_SIZEより小さい、もしくはpubSzがED448_PUB_KEY_SIZEより小さい場合に返されます。 \param [in] priv 秘密鍵を含むバッファへのポインタ。 \param [in] privSz 秘密鍵の長さ。 \param [in] pub 公開鍵を含むバッファへのポインタ。 \param [in] pubSz 公開鍵の長さ。 \param [in,out] key インポートされた秘密/公開鍵ペアを格納するed448_keyオブジェクトへのポインタ。 _Example_ \code int ret; byte priv[] = { 57バイトの秘密鍵で初期化 }; byte pub[] = { 対応する公開鍵で初期化 }; ed448_key key; wc_ed448_init_key(&key); ret = wc_ed448_import_private_key(priv, sizeof(priv), pub, sizeof(pub), &key); if (ret != 0) { // 鍵のインポートエラー } \endcode \sa wc_ed448_import_public \sa wc_ed448_import_public_ex \sa wc_ed448_import_private_only \sa wc_ed448_import_private_key_ex \sa wc_ed448_export_private */ int wc_ed448_import_private_key(const byte* priv, word32 privSz, const byte* pub, word32 pubSz, ed448_key* key); /*! \ingroup ED448 \brief この関数は、一対のバッファから公開/秘密Ed448鍵ペアをインポートします。この関数は、圧縮キーと非圧縮キーの両方を処理します。信頼されていない場合、公開鍵が秘密鍵に対してチェックされます。 \return 0 Ed448鍵のインポートに成功した場合に返されます。 \return BAD_FUNC_ARG inまたはkeyがNULLと評価された場合、またはprivSzがED448_KEY_SIZEより小さい、もしくはpubSzがED448_PUB_KEY_SIZEより小さい場合に返されます。 \param [in] priv 秘密鍵を含むバッファへのポインタ。 \param [in] privSz 秘密鍵の長さ。 \param [in] pub 公開鍵を含むバッファへのポインタ。 \param [in] pubSz 公開鍵の長さ。 \param [in,out] key インポートされた秘密/公開鍵ペアを格納するed448_keyオブジェクトへのポインタ。 \param [in] trusted 公開鍵データが信頼されているかどうか。 _Example_ \code int ret; byte priv[] = { 57バイトの秘密鍵で初期化 }; byte pub[] = { 対応する公開鍵で初期化 }; ed448_key key; wc_ed448_init_key(&key); ret = wc_ed448_import_private_key_ex(priv, sizeof(priv), pub, sizeof(pub), &key, 1); if (ret != 0) { // 鍵のインポートエラー } \endcode \sa wc_ed448_import_public \sa wc_ed448_import_public_ex \sa wc_ed448_import_private_only \sa wc_ed448_import_private_key \sa wc_ed448_export_private */ int wc_ed448_import_private_key_ex(const byte* priv, word32 privSz, const byte* pub, word32 pubSz, ed448_key* key, int trusted); /*! \ingroup ED448 \brief この関数は、ed448_key構造体から秘密鍵をエクスポートします。公開鍵をバッファoutに格納し、このバッファに書き込まれたバイト数をoutLenに設定します。 \return 0 公開鍵のエクスポートに成功した場合に返されます。 \return BAD_FUNC_ARG 入力値のいずれかがNULLと評価された場合に返されます。 \return BUFFER_E 提供されたバッファが秘密鍵を格納するのに十分な大きさでない場合に返されます。このエラーを返す際、関数はoutLenに必要なサイズを設定します。 \param [in] key 公開鍵をエクスポートするed448_key構造体へのポインタ。 \param [out] out 公開鍵を格納するバッファへのポインタ。 \param [in,out] outLen outで利用可能なサイズを持つword32オブジェクトへのポインタ。公開鍵のエクスポートに成功した後、outに書き込まれたバイト数が設定されます。 _Example_ \code int ret; ed448_key key; // keyを初期化し、keyを作成 char pub[57]; word32 pubSz = sizeof(pub); ret = wc_ed448_export_public(&key, pub, &pubSz); if (ret != 0) { // 公開鍵のエクスポートエラー } \endcode \sa wc_ed448_import_public \sa wc_ed448_import_public_ex \sa wc_ed448_export_private_only */ int wc_ed448_export_public(const ed448_key* key, byte* out, word32* outLen); /*! \ingroup ED448 \brief この関数は、ed448_key構造体から秘密鍵のみをエクスポートします。秘密鍵をバッファoutに格納し、このバッファに書き込まれたバイト数をoutLenに設定します。 \return 0 秘密鍵のエクスポートに成功した場合に返されます。 \return ECC_BAD_ARG_E 入力値のいずれかがNULLと評価された場合に返されます。 \return BUFFER_E 提供されたバッファが秘密鍵を格納するのに十分な大きさでない場合に返されます。 \param [in] key 秘密鍵をエクスポートするed448_key構造体へのポインタ。 \param [out] out 秘密鍵を格納するバッファへのポインタ。 \param [in,out] outLen outで利用可能なサイズを持つword32オブジェクトへのポインタ。秘密鍵のエクスポートに成功した後、outに書き込まれたバイト数が設定されます。 _Example_ \code int ret; ed448_key key; // keyを初期化し、keyを作成 char priv[57]; // 秘密鍵のみなので57バイト word32 privSz = sizeof(priv); ret = wc_ed448_export_private_only(&key, priv, &privSz); if (ret != 0) { // 秘密鍵のエクスポートエラー } \endcode \sa wc_ed448_export_public \sa wc_ed448_import_private_key \sa wc_ed448_import_private_key_ex */ int wc_ed448_export_private_only(const ed448_key* key, byte* out, word32* outLen); /*! \ingroup ED448 \brief この関数は、ed448_key構造体から鍵ペアをエクスポートします。鍵ペアをバッファoutに格納し、このバッファに書き込まれたバイト数をoutLenに設定します。 \return 0 鍵ペアのエクスポートに成功した場合に返されます。 \return ECC_BAD_ARG_E 入力値のいずれかがNULLと評価された場合に返されます。 \return BUFFER_E 提供されたバッファが鍵ペアを格納するのに十分な大きさでない場合に返されます。 \param [in] key 鍵ペアをエクスポートするed448_key構造体へのポインタ。 \param [out] out 鍵ペアを格納するバッファへのポインタ。 \param [in,out] outLen outで利用可能なサイズを持つword32オブジェクトへのポインタ。鍵ペアのエクスポートに成功した後、outに書き込まれたバイト数が設定されます。 _Example_ \code ed448_key key; wc_ed448_init(&key); WC_RNG rng; wc_InitRng(&rng); wc_ed448_make_key(&rng, 57, &key); // 57バイトのEd448鍵を初期化 byte out[114]; // outは十分なバッファサイズである必要があります word32 outLen = sizeof(out); int key_size = wc_ed448_export_private(&key, out, &outLen); if (key_size == BUFFER_E) { // 関数がoutLenをリセットしたかどうかを確認するため、outのサイズとoutLenを比較 } \endcode \sa wc_ed448_import_private \sa wc_ed448_export_private_only */ int wc_ed448_export_private(const ed448_key* key, byte* out, word32* outLen); /*! \ingroup ED448 \brief この関数は、ed448_key構造体から秘密鍵と公開鍵を個別にエクスポートします。秘密鍵をバッファprivに格納し、このバッファに書き込まれたバイト数をprivSzに設定します。公開鍵をバッファpubに格納し、このバッファに書き込まれたバイト数をpubSzに設定します。 \return 0 鍵ペアのエクスポートに成功した場合に返されます。 \return ECC_BAD_ARG_E 入力値のいずれかがNULLと評価された場合に返されます。 \return BUFFER_E 提供されたバッファが鍵ペアを格納するのに十分な大きさでない場合に返されます。 \param [in] key 鍵ペアをエクスポートするed448_key構造体へのポインタ。 \param [out] priv 秘密鍵を格納するバッファへのポインタ。 \param [in,out] privSz outで利用可能なサイズを持つword32オブジェクトへのポインタ。秘密鍵のエクスポートに成功した後、outに書き込まれたバイト数が設定されます。 \param [out] pub 公開鍵を格納するバッファへのポインタ。 \param [in,out] pubSz outで利用可能なサイズを持つword32オブジェクトへのポインタ。公開鍵のエクスポートに成功した後、outに書き込まれたバイト数が設定されます。 _Example_ \code int ret; ed448_key key; // keyを初期化し、keyを作成 char pub[57]; word32 pubSz = sizeof(pub); char priv[57]; word32 privSz = sizeof(priv); ret = wc_ed448_export_key(&key, priv, &pubSz, pub, &pubSz); if (ret != 0) { // 秘密鍵と公開鍵のエクスポートエラー } \endcode \sa wc_ed448_export_private \sa wc_ed448_export_public */ int wc_ed448_export_key(const ed448_key* key, byte* priv, word32 *privSz, byte* pub, word32 *pubSz); /*! \ingroup ED448 \brief この関数は、ed448_key構造体内の公開鍵が秘密鍵と一致するかチェックします。 \return 0 秘密鍵と公開鍵が一致した場合に返されます。 \return BAD_FUNC_ARGS 指定されたkeyがNULLの場合に返されます。 \param [in] key 秘密鍵と公開鍵を保持するed448_key構造体へのポインタ。 _Example_ \code int ret; byte priv[] = { 57バイトの秘密鍵で初期化 }; byte pub[] = { 対応する公開鍵で初期化 }; ed448_key key; wc_ed448_init_key(&key); wc_ed448_import_private_key_ex(priv, sizeof(priv), pub, sizeof(pub), &key, 1); ret = wc_ed448_check_key(&key); if (ret != 0) { // 鍵のチェックエラー } \endcode \sa wc_ed448_import_private_key \sa wc_ed448_import_private_key_ex */ int wc_ed448_check_key(ed448_key* key); /*! \ingroup ED448 \brief この関数は、Ed448秘密鍵のサイズ(57バイト)を返します。 \return ED448_KEY_SIZE 有効な秘密鍵のサイズ(57バイト)。 \return BAD_FUNC_ARGS 指定されたkeyがNULLの場合に返されます。 \param [in] key 鍵サイズを取得するed448_key構造体へのポインタ。 _Example_ \code int keySz; ed448_key key; // keyを初期化し、keyを作成 keySz = wc_ed448_size(&key); if (keySz == 0) { // 鍵サイズの決定エラー } \endcode \sa wc_ed448_make_key */ int wc_ed448_size(const ed448_key* key); /*! \ingroup ED448 \brief この関数は、秘密鍵のサイズ(秘密 + 公開)をバイト単位で返します。 \return ED448_PRV_KEY_SIZE 秘密鍵のサイズ(114バイト)。 \return BAD_FUNC_ARG key引数がNULLの場合に返されます。 \param [in] key 鍵サイズを取得するed448_key構造体へのポインタ。 _Example_ \code ed448_key key; wc_ed448_init(&key); WC_RNG rng; wc_InitRng(&rng); wc_ed448_make_key(&rng, 57, &key); // 57バイトのEd448鍵を初期化 int key_size = wc_ed448_priv_size(&key); \endcode \sa wc_ed448_pub_size */ int wc_ed448_priv_size(const ed448_key* key); /*! \ingroup ED448 \brief この関数は、圧縮鍵のサイズをバイト単位で返します(公開鍵)。 \return ED448_PUB_KEY_SIZE 圧縮公開鍵のサイズ(57バイト)。 \return BAD_FUNC_ARG key引数がNULLの場合に返されます。 \param [in] key 鍵サイズを取得するed448_key構造体へのポインタ。 _Example_ \code ed448_key key; wc_ed448_init(&key); WC_RNG rng; wc_InitRng(&rng); wc_ed448_make_key(&rng, 57, &key); // 57バイトのEd448鍵を初期化 int key_size = wc_ed448_pub_size(&key); \endcode \sa wc_ed448_priv_size */ int wc_ed448_pub_size(const ed448_key* key); /*! \ingroup ED448 \brief この関数は、Ed448署名のサイズ(バイト単位で114)を返します。 \return ED448_SIG_SIZE Ed448署名のサイズ(114バイト)。 \return BAD_FUNC_ARG key引数がNULLの場合に返されます。 \param [in] key 署名サイズを取得するed448_key構造体へのポインタ。 _Example_ \code int sigSz; ed448_key key; // keyを初期化し、keyを作成 sigSz = wc_ed448_sig_size(&key); if (sigSz == 0) { // 署名サイズの決定エラー } \endcode \sa wc_ed448_sign_msg */ int wc_ed448_sig_size(const ed448_key* key);