<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <meta http-equiv="X-UA-Compatible" content="IE=9"/> <meta name="generator" content="Doxygen 1.8.14"/> <meta name="viewport" content="width=device-width, initial-scale=1"/> <title>Crypto++: LUC_IES< HASH, COFACTOR_OPTION, DHAES_MODE, LABEL_OCTETS > Struct Template Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="dynsections.js"></script> <link href="doxygen.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="top"><!-- do not remove this div, it is closed by doxygen! --> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td id="projectalign" style="padding-left: 0.5em;"> <div id="projectname">Crypto++  <span id="projectnumber">7.0</span> </div> <div id="projectbrief">Free C++ class library of cryptographic schemes</div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.14 --> <script type="text/javascript" src="menudata.js"></script> <script type="text/javascript" src="menu.js"></script> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ $(function() { initMenu('',false,false,'search.php','Search'); }); /* @license-end */</script> <div id="main-nav"></div> </div><!-- top --> <div class="header"> <div class="summary"> <a href="#pub-static-methods">Static Public Member Functions</a> | <a href="struct_l_u_c___i_e_s-members.html">List of all members</a> </div> <div class="headertitle"> <div class="title">LUC_IES< HASH, COFACTOR_OPTION, DHAES_MODE, LABEL_OCTETS > Struct Template Reference</div> </div> </div><!--header--> <div class="contents"> <p><a class="el" href="struct_l_u_c.html" title="LUC cryptosystem. ">LUC</a> Integrated Encryption Scheme. <a href="struct_l_u_c___i_e_s.html#details">More...</a></p> <div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;"> <img id="dynsection-0-trigger" src="closed.png" alt="+"/> Inheritance diagram for LUC_IES< HASH, COFACTOR_OPTION, DHAES_MODE, LABEL_OCTETS >:</div> <div id="dynsection-0-summary" class="dynsummary" style="display:block;"> </div> <div id="dynsection-0-content" class="dyncontent" style="display:none;"> <div class="center"> <img src="struct_l_u_c___i_e_s.png" usemap="#LUC_5FIES_3C_20HASH_2C_20COFACTOR_5FOPTION_2C_20DHAES_5FMODE_2C_20LABEL_5FOCTETS_20_3E_map" alt=""/> <map id="LUC_5FIES_3C_20HASH_2C_20COFACTOR_5FOPTION_2C_20DHAES_5FMODE_2C_20LABEL_5FOCTETS_20_3E_map" name="LUC_5FIES_3C_20HASH_2C_20COFACTOR_5FOPTION_2C_20DHAES_5FMODE_2C_20LABEL_5FOCTETS_20_3E_map"> <area href="class_d_l___e_s.html" alt="DL_ES< DL_CryptoKeys_LUC, DL_KeyAgreementAlgorithm_DH< Integer, COFACTOR_OPTION >, DL_KeyDerivationAlgorithm_P1363< Integer, DHAES_MODE, P1363_KDF2< HASH > >, DL_EncryptionAlgorithm_Xor< HMAC< HASH >, DHAES_MODE, LABEL_OCTETS >, LUC_IES<> >" shape="rect" coords="0,56,1664,80"/> <area href="struct_d_l___crypto_keys___l_u_c.html" title="LUC encryption keys. " alt="DL_CryptoKeys_LUC" shape="rect" coords="0,0,1664,24"/> </map> </div></div> <table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a> Static Public Member Functions</h2></td></tr> <tr class="memitem:a06a2b43254e363543014b49f0c2b0318"><td class="memItemLeft" align="right" valign="top"><a id="a06a2b43254e363543014b49f0c2b0318"></a> static const char * </td><td class="memItemRight" valign="bottom"><b>StaticAlgorithmName</b> ()</td></tr> <tr class="separator:a06a2b43254e363543014b49f0c2b0318"><td class="memSeparator" colspan="2"> </td></tr> </table><table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="inherited"></a> Additional Inherited Members</h2></td></tr> <tr class="inherit_header pub_types_class_d_l___e_s"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_d_l___e_s')"><img src="closed.png" alt="-"/> Public Types inherited from <a class="el" href="class_d_l___e_s.html">DL_ES< DL_CryptoKeys_LUC, DL_KeyAgreementAlgorithm_DH< Integer, COFACTOR_OPTION >, DL_KeyDerivationAlgorithm_P1363< Integer, DHAES_MODE, P1363_KDF2< HASH > >, DL_EncryptionAlgorithm_Xor< HMAC< HASH >, DHAES_MODE, LABEL_OCTETS >, LUC_IES<> ></a></td></tr> <tr class="memitem:a6f4960dec76bc05d9c720c9b903e2a79 inherit pub_types_class_d_l___e_s"><td class="memItemLeft" align="right" valign="top"><a id="a6f4960dec76bc05d9c720c9b903e2a79"></a> typedef <a class="el" href="class_p_k___final_template.html">PK_FinalTemplate</a>< <a class="el" href="class_d_l___decryptor_impl.html">DL_DecryptorImpl</a>< <a class="el" href="struct_d_l___crypto_scheme_options.html">SchemeOptions</a> > > </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___e_s.html#a6f4960dec76bc05d9c720c9b903e2a79">Decryptor</a></td></tr> <tr class="memdesc:a6f4960dec76bc05d9c720c9b903e2a79 inherit pub_types_class_d_l___e_s"><td class="mdescLeft"> </td><td class="mdescRight">implements <a class="el" href="class_p_k___decryptor.html" title="Interface for public-key decryptors. ">PK_Decryptor</a> interface <br /></td></tr> <tr class="separator:a6f4960dec76bc05d9c720c9b903e2a79 inherit pub_types_class_d_l___e_s"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ae0f5a08f99a0ff49d52a4400c58bde76 inherit pub_types_class_d_l___e_s"><td class="memItemLeft" align="right" valign="top"><a id="ae0f5a08f99a0ff49d52a4400c58bde76"></a> typedef <a class="el" href="class_p_k___final_template.html">PK_FinalTemplate</a>< <a class="el" href="class_d_l___encryptor_impl.html">DL_EncryptorImpl</a>< <a class="el" href="struct_d_l___crypto_scheme_options.html">SchemeOptions</a> > > </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___e_s.html#ae0f5a08f99a0ff49d52a4400c58bde76">Encryptor</a></td></tr> <tr class="memdesc:ae0f5a08f99a0ff49d52a4400c58bde76 inherit pub_types_class_d_l___e_s"><td class="mdescLeft"> </td><td class="mdescRight">implements <a class="el" href="class_p_k___encryptor.html" title="Interface for public-key encryptors. ">PK_Encryptor</a> interface <br /></td></tr> <tr class="separator:ae0f5a08f99a0ff49d52a4400c58bde76 inherit pub_types_class_d_l___e_s"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_types_struct_d_l___crypto_keys___l_u_c"><td colspan="2" onclick="javascript:toggleInherit('pub_types_struct_d_l___crypto_keys___l_u_c')"><img src="closed.png" alt="-"/> Public Types inherited from <a class="el" href="struct_d_l___crypto_keys___l_u_c.html">DL_CryptoKeys_LUC</a></td></tr> <tr class="memitem:a7f001656faa9ed50d3567a10a76617ec inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memItemLeft" align="right" valign="top"><a id="a7f001656faa9ed50d3567a10a76617ec"></a> typedef <a class="el" href="class_d_l___group_parameters___l_u_c___default_safe_prime.html">DL_GroupParameters_LUC_DefaultSafePrime</a> </td><td class="memItemRight" valign="bottom"><b>GroupParameters</b></td></tr> <tr class="separator:a7f001656faa9ed50d3567a10a76617ec inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a746c398250dea0027761656f8fec7436 inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memItemLeft" align="right" valign="top"><a id="a746c398250dea0027761656f8fec7436"></a> typedef <a class="el" href="class_d_l___public_key___g_f_p.html">DL_PublicKey_GFP</a>< <a class="el" href="class_d_l___group_parameters___l_u_c___default_safe_prime.html">GroupParameters</a> > </td><td class="memItemRight" valign="bottom"><b>PublicKey</b></td></tr> <tr class="separator:a746c398250dea0027761656f8fec7436 inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a723cfe2baaaa390bea37b30a658551c7 inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memItemLeft" align="right" valign="top"><a id="a723cfe2baaaa390bea37b30a658551c7"></a> typedef <a class="el" href="class_d_l___private_key___g_f_p.html">DL_PrivateKey_GFP</a>< <a class="el" href="class_d_l___group_parameters___l_u_c___default_safe_prime.html">GroupParameters</a> > </td><td class="memItemRight" valign="bottom"><b>PrivateKey</b></td></tr> <tr class="separator:a723cfe2baaaa390bea37b30a658551c7 inherit pub_types_struct_d_l___crypto_keys___l_u_c"><td class="memSeparator" colspan="2"> </td></tr> </table> <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> <div class="textblock"><h3>template<class HASH = SHA1, class COFACTOR_OPTION = NoCofactorMultiplication, bool DHAES_MODE = true, bool LABEL_OCTETS = false><br /> struct LUC_IES< HASH, COFACTOR_OPTION, DHAES_MODE, LABEL_OCTETS ></h3> <p><a class="el" href="struct_l_u_c.html" title="LUC cryptosystem. ">LUC</a> Integrated Encryption Scheme. </p> <dl class="tparams"><dt>Template Parameters</dt><dd> <table class="tparams"> <tr><td class="paramname">COFACTOR_OPTION</td><td>cofactor multiplication option </td></tr> <tr><td class="paramname">HASH</td><td><a class="el" href="class_hash_transformation.html" title="Interface for hash functions and data processing part of MACs. ">HashTransformation</a> derived class used for key drivation and MAC computation </td></tr> <tr><td class="paramname">DHAES_MODE</td><td>flag indicating if the MAC includes additional context parameters such as <em>u·V</em>, <em>v·U</em> and label </td></tr> <tr><td class="paramname">LABEL_OCTETS</td><td>flag indicating if the label size is specified in octets or bits </td></tr> </table> </dd> </dl> <dl class="section see"><dt>See also</dt><dd><a class="el" href="pubkey_8h.html#ae4b59f7b9d3c7e03bb739f0584905ff1" title="Methods for avoiding "Small-Subgroup" attacks on Diffie-Hellman Key Agreement. ">CofactorMultiplicationOption</a> </dd></dl> <dl class="section since"><dt>Since</dt><dd>Crypto++ 2.1, Crypto++ 5.7 for Bouncy Castle and Botan compatibility </dd></dl> <p class="definition">Definition at line <a class="el" href="luc_8h_source.html#l00316">316</a> of file <a class="el" href="luc_8h_source.html">luc.h</a>.</p> </div><hr/>The documentation for this struct was generated from the following file:<ul> <li><a class="el" href="luc_8h_source.html">luc.h</a></li> </ul> </div><!-- contents --> <!-- start footer part --> <hr class="footer"/><address class="footer"><small> Generated on Sun Sep 16 2018 07:58:42 for Crypto++ by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/> </a> 1.8.14 </small></address> </body> </html>