<!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++: DL_PublicKeyImpl< GP > Class 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-types">Public Types</a> | <a href="#pub-methods">Public Member Functions</a> | <a href="class_d_l___public_key_impl-members.html">List of all members</a> </div> <div class="headertitle"> <div class="title">DL_PublicKeyImpl< GP > Class Template Reference</div> </div> </div><!--header--> <div class="contents"> <p>Discrete Log (DL) public key base implementation. <a href="class_d_l___public_key_impl.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 DL_PublicKeyImpl< GP >:</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="class_d_l___public_key_impl.png" usemap="#DL_5FPublicKeyImpl_3C_20GP_20_3E_map" alt=""/> <map id="DL_5FPublicKeyImpl_3C_20GP_20_3E_map" name="DL_5FPublicKeyImpl_3C_20GP_20_3E_map"> <area href="class_d_l___public_key.html" alt="DL_PublicKey< GP::Element >" shape="rect" coords="0,280,216,304"/> <area href="class_d_l___key_impl.html" alt="DL_KeyImpl< X509PublicKey, GP >" shape="rect" coords="226,280,442,304"/> <area href="class_d_l___key.html" alt="DL_Key< GP::Element >" shape="rect" coords="0,224,216,248"/> <area href="class_x509_public_key.html" title="Encodes and decodes subjectPublicKeyInfo. " alt="X509PublicKey" shape="rect" coords="226,224,442,248"/> <area href="class_a_s_n1_crypto_material.html" alt="ASN1CryptoMaterial< PublicKey >" shape="rect" coords="226,168,442,192"/> <area href="class_a_s_n1_object.html" title="Interface for encoding and decoding ASN1 objects. " alt="ASN1Object" shape="rect" coords="113,112,329,136"/> <area href="class_public_key.html" title="Interface for public keys. " alt="PublicKey" shape="rect" coords="339,112,555,136"/> <area href="class_crypto_material.html" title="Interface for crypto material, such as public and private keys, and crypto parameters. " alt="CryptoMaterial" shape="rect" coords="339,56,555,80"/> <area href="class_name_value_pairs.html" title="Interface for retrieving values given their names. " alt="NameValuePairs" shape="rect" coords="339,0,555,24"/> <area href="class_d_l___public_key___g_f_p.html" title="Discrete Log (DL) public key in GF(p) groups. " alt="DL_PublicKey_GFP< GP >" shape="rect" coords="113,392,329,416"/> </map> </div></div> <table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a> Public Types</h2></td></tr> <tr class="memitem:a78f2e62a746f8a54b57b18df988598a8"><td class="memItemLeft" align="right" valign="top"><a id="a78f2e62a746f8a54b57b18df988598a8"></a> typedef GP::Element </td><td class="memItemRight" valign="bottom"><b>Element</b></td></tr> <tr class="separator:a78f2e62a746f8a54b57b18df988598a8"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_types_class_d_l___public_key"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_d_l___public_key')"><img src="closed.png" alt="-"/> Public Types inherited from <a class="el" href="class_d_l___public_key.html">DL_PublicKey< GP::Element ></a></td></tr> <tr class="memitem:a26c192a54ad555f24082894c5f271ebf inherit pub_types_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top"><a id="a26c192a54ad555f24082894c5f271ebf"></a> typedef GP::Element </td><td class="memItemRight" valign="bottom"><b>Element</b></td></tr> <tr class="separator:a26c192a54ad555f24082894c5f271ebf inherit pub_types_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_types_class_d_l___key_impl"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_d_l___key_impl')"><img src="closed.png" alt="-"/> Public Types inherited from <a class="el" href="class_d_l___key_impl.html">DL_KeyImpl< X509PublicKey, GP ></a></td></tr> <tr class="memitem:ab79562fe76880b7eb21c9f926a3161f2 inherit pub_types_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="ab79562fe76880b7eb21c9f926a3161f2"></a> typedef GP </td><td class="memItemRight" valign="bottom"><b>GroupParameters</b></td></tr> <tr class="separator:ab79562fe76880b7eb21c9f926a3161f2 inherit pub_types_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> </table><table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a> Public Member Functions</h2></td></tr> <tr class="memitem:ad915aa79d9a19b4c7a6bab99181250b1"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#ad915aa79d9a19b4c7a6bab99181250b1">Validate</a> (<a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> &rng, unsigned int level) const</td></tr> <tr class="memdesc:ad915aa79d9a19b4c7a6bab99181250b1"><td class="mdescLeft"> </td><td class="mdescRight">Check this object for errors. <a href="#ad915aa79d9a19b4c7a6bab99181250b1">More...</a><br /></td></tr> <tr class="separator:ad915aa79d9a19b4c7a6bab99181250b1"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a743eb7afb3d047103f82d78f619165e5"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a743eb7afb3d047103f82d78f619165e5">GetVoidValue</a> (const char *name, const std::type_info &valueType, void *pValue) const</td></tr> <tr class="memdesc:a743eb7afb3d047103f82d78f619165e5"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value. <a href="#a743eb7afb3d047103f82d78f619165e5">More...</a><br /></td></tr> <tr class="separator:a743eb7afb3d047103f82d78f619165e5"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:afa2dcb7fc8d0d83dd6d4563b7ba6ca41"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#afa2dcb7fc8d0d83dd6d4563b7ba6ca41">AssignFrom</a> (const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> &source)</td></tr> <tr class="memdesc:afa2dcb7fc8d0d83dd6d4563b7ba6ca41"><td class="mdescLeft"> </td><td class="mdescRight">Assign values to this object. <a href="#afa2dcb7fc8d0d83dd6d4563b7ba6ca41">More...</a><br /></td></tr> <tr class="separator:afa2dcb7fc8d0d83dd6d4563b7ba6ca41"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a2fc2bcec20e2c15a4848b5c9913d2faf"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a2fc2bcec20e2c15a4848b5c9913d2faf">SupportsPrecomputation</a> () const</td></tr> <tr class="memdesc:a2fc2bcec20e2c15a4848b5c9913d2faf"><td class="mdescLeft"> </td><td class="mdescRight">Determines whether the object supports precomputation. <a href="#a2fc2bcec20e2c15a4848b5c9913d2faf">More...</a><br /></td></tr> <tr class="separator:a2fc2bcec20e2c15a4848b5c9913d2faf"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a95e25f6632ec2621289d10abc557b17b"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b">Precompute</a> (unsigned int precomputationStorage=16)</td></tr> <tr class="memdesc:a95e25f6632ec2621289d10abc557b17b"><td class="mdescLeft"> </td><td class="mdescRight">Perform precomputation. <a href="#a95e25f6632ec2621289d10abc557b17b">More...</a><br /></td></tr> <tr class="separator:a95e25f6632ec2621289d10abc557b17b"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a8f1379edc09486d79c3ad6c374d01243"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a8f1379edc09486d79c3ad6c374d01243">LoadPrecomputation</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &storedPrecomputation)</td></tr> <tr class="memdesc:a8f1379edc09486d79c3ad6c374d01243"><td class="mdescLeft"> </td><td class="mdescRight">Retrieve previously saved precomputation. <a href="#a8f1379edc09486d79c3ad6c374d01243">More...</a><br /></td></tr> <tr class="separator:a8f1379edc09486d79c3ad6c374d01243"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af562a63129ab05c2818e404b3446b2c7"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#af562a63129ab05c2818e404b3446b2c7">SavePrecomputation</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &storedPrecomputation) const</td></tr> <tr class="memdesc:af562a63129ab05c2818e404b3446b2c7"><td class="mdescLeft"> </td><td class="mdescRight">Save precomputation for later use. <a href="#af562a63129ab05c2818e404b3446b2c7">More...</a><br /></td></tr> <tr class="separator:af562a63129ab05c2818e404b3446b2c7"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:aab8d5cddf210d9f920b38627a70e4ba1"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_d_l___group_parameters.html">DL_GroupParameters</a>< Element > & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#aab8d5cddf210d9f920b38627a70e4ba1">GetAbstractGroupParameters</a> () const</td></tr> <tr class="memdesc:aab8d5cddf210d9f920b38627a70e4ba1"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves abstract group parameters. <a href="#aab8d5cddf210d9f920b38627a70e4ba1">More...</a><br /></td></tr> <tr class="separator:aab8d5cddf210d9f920b38627a70e4ba1"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a2ff2c005ee4b85eb1406799afc28b8a0"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_d_l___group_parameters.html">DL_GroupParameters</a>< Element > & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a2ff2c005ee4b85eb1406799afc28b8a0">AccessAbstractGroupParameters</a> ()</td></tr> <tr class="memdesc:a2ff2c005ee4b85eb1406799afc28b8a0"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves abstract group parameters. <a href="#a2ff2c005ee4b85eb1406799afc28b8a0">More...</a><br /></td></tr> <tr class="separator:a2ff2c005ee4b85eb1406799afc28b8a0"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ac1eab8c6ae65408dcb80a3d451b5c45d"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_d_l___fixed_base_precomputation.html">DL_FixedBasePrecomputation</a>< Element > & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#ac1eab8c6ae65408dcb80a3d451b5c45d">GetPublicPrecomputation</a> () const</td></tr> <tr class="memdesc:ac1eab8c6ae65408dcb80a3d451b5c45d"><td class="mdescLeft"> </td><td class="mdescRight">Accesses the public precomputation. <a href="#ac1eab8c6ae65408dcb80a3d451b5c45d">More...</a><br /></td></tr> <tr class="separator:ac1eab8c6ae65408dcb80a3d451b5c45d"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a43c88026bb625ad49dea861f807eb9c3"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_d_l___fixed_base_precomputation.html">DL_FixedBasePrecomputation</a>< Element > & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key_impl.html#a43c88026bb625ad49dea861f807eb9c3">AccessPublicPrecomputation</a> ()</td></tr> <tr class="memdesc:a43c88026bb625ad49dea861f807eb9c3"><td class="mdescLeft"> </td><td class="mdescRight">Accesses the public precomputation. <a href="#a43c88026bb625ad49dea861f807eb9c3">More...</a><br /></td></tr> <tr class="separator:a43c88026bb625ad49dea861f807eb9c3"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a02b85b4832f718afb7daaafcef791a7e"><td class="memItemLeft" align="right" valign="top"><a id="a02b85b4832f718afb7daaafcef791a7e"></a> bool </td><td class="memItemRight" valign="bottom"><b>operator==</b> (const <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP > &rhs) const</td></tr> <tr class="separator:a02b85b4832f718afb7daaafcef791a7e"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_d_l___public_key"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_d_l___public_key')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_d_l___public_key.html">DL_PublicKey< GP::Element ></a></td></tr> <tr class="memitem:ac2ecb1de28d09a66c7a000e6f9417930 inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#ac2ecb1de28d09a66c7a000e6f9417930">GetVoidValue</a> (const char *name, const std::type_info &valueType, void *pValue) const</td></tr> <tr class="memdesc:ac2ecb1de28d09a66c7a000e6f9417930 inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value. <a href="class_d_l___public_key.html#ac2ecb1de28d09a66c7a000e6f9417930">More...</a><br /></td></tr> <tr class="separator:ac2ecb1de28d09a66c7a000e6f9417930 inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a7adbe2e3adc4bdb8a60ffd653d91532e inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#a7adbe2e3adc4bdb8a60ffd653d91532e">AssignFrom</a> (const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> &source)</td></tr> <tr class="memdesc:a7adbe2e3adc4bdb8a60ffd653d91532e inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Initialize or reinitialize this this key. <a href="class_d_l___public_key.html#a7adbe2e3adc4bdb8a60ffd653d91532e">More...</a><br /></td></tr> <tr class="separator:a7adbe2e3adc4bdb8a60ffd653d91532e inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ab748086e14a92416ff49183f81f777c4 inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">virtual const Element & </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#ab748086e14a92416ff49183f81f777c4">GetPublicElement</a> () const</td></tr> <tr class="memdesc:ab748086e14a92416ff49183f81f777c4 inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves the public element. <a href="class_d_l___public_key.html#ab748086e14a92416ff49183f81f777c4">More...</a><br /></td></tr> <tr class="separator:ab748086e14a92416ff49183f81f777c4 inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a86cac45fc0ddaf07c057061b93cd8ce1 inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#a86cac45fc0ddaf07c057061b93cd8ce1">SetPublicElement</a> (const Element &y)</td></tr> <tr class="memdesc:a86cac45fc0ddaf07c057061b93cd8ce1 inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Sets the public element. <a href="class_d_l___public_key.html#a86cac45fc0ddaf07c057061b93cd8ce1">More...</a><br /></td></tr> <tr class="separator:a86cac45fc0ddaf07c057061b93cd8ce1 inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a276f2ab6a25f60c48a6296bcd742647f inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">virtual Element </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#a276f2ab6a25f60c48a6296bcd742647f">ExponentiatePublicElement</a> (const <a class="el" href="class_integer.html">Integer</a> &exponent) const</td></tr> <tr class="memdesc:a276f2ab6a25f60c48a6296bcd742647f inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Exponentiates this element. <a href="class_d_l___public_key.html#a276f2ab6a25f60c48a6296bcd742647f">More...</a><br /></td></tr> <tr class="separator:a276f2ab6a25f60c48a6296bcd742647f inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ac9f9cdb455c4a859e50d202f67008cb8 inherit pub_methods_class_d_l___public_key"><td class="memItemLeft" align="right" valign="top">virtual Element </td><td class="memItemRight" valign="bottom"><a class="el" href="class_d_l___public_key.html#ac9f9cdb455c4a859e50d202f67008cb8">CascadeExponentiateBaseAndPublicElement</a> (const <a class="el" href="class_integer.html">Integer</a> &baseExp, const <a class="el" href="class_integer.html">Integer</a> &publicExp) const</td></tr> <tr class="memdesc:ac9f9cdb455c4a859e50d202f67008cb8 inherit pub_methods_class_d_l___public_key"><td class="mdescLeft"> </td><td class="mdescRight">Exponentiates an element. <a href="class_d_l___public_key.html#ac9f9cdb455c4a859e50d202f67008cb8">More...</a><br /></td></tr> <tr class="separator:ac9f9cdb455c4a859e50d202f67008cb8 inherit pub_methods_class_d_l___public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_d_l___key_impl"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_d_l___key_impl')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_d_l___key_impl.html">DL_KeyImpl< X509PublicKey, GP ></a></td></tr> <tr class="memitem:a1b6ec226b38af123e6a53a95da47b6a6 inherit pub_methods_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="a1b6ec226b38af123e6a53a95da47b6a6"></a> <a class="el" href="class_o_i_d.html">OID</a> </td><td class="memItemRight" valign="bottom"><b>GetAlgorithmID</b> () const</td></tr> <tr class="separator:a1b6ec226b38af123e6a53a95da47b6a6 inherit pub_methods_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a25b475d09a1217fa4f64369e76346e57 inherit pub_methods_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="a25b475d09a1217fa4f64369e76346e57"></a> bool </td><td class="memItemRight" valign="bottom"><b>BERDecodeAlgorithmParameters</b> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt)</td></tr> <tr class="separator:a25b475d09a1217fa4f64369e76346e57 inherit pub_methods_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:aa2e574353b7bbb69be29437c518682b1 inherit pub_methods_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="aa2e574353b7bbb69be29437c518682b1"></a> bool </td><td class="memItemRight" valign="bottom"><b>DEREncodeAlgorithmParameters</b> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt) const</td></tr> <tr class="separator:aa2e574353b7bbb69be29437c518682b1 inherit pub_methods_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a2ba2a2dfd2a412a186affea3bf558407 inherit pub_methods_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="a2ba2a2dfd2a412a186affea3bf558407"></a> const GP & </td><td class="memItemRight" valign="bottom"><b>GetGroupParameters</b> () const</td></tr> <tr class="separator:a2ba2a2dfd2a412a186affea3bf558407 inherit pub_methods_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a2ec144a5bedd2151b4bd0bb5118f1a8f inherit pub_methods_class_d_l___key_impl"><td class="memItemLeft" align="right" valign="top"><a id="a2ec144a5bedd2151b4bd0bb5118f1a8f"></a> GP & </td><td class="memItemRight" valign="bottom"><b>AccessGroupParameters</b> ()</td></tr> <tr class="separator:a2ec144a5bedd2151b4bd0bb5118f1a8f inherit pub_methods_class_d_l___key_impl"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_x509_public_key"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_x509_public_key')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_x509_public_key.html">X509PublicKey</a></td></tr> <tr class="memitem:a4eb86b0b55185f10a13ff7e1b083a67b inherit pub_methods_class_x509_public_key"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_x509_public_key.html#a4eb86b0b55185f10a13ff7e1b083a67b">BERDecode</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt)</td></tr> <tr class="memdesc:a4eb86b0b55185f10a13ff7e1b083a67b inherit pub_methods_class_x509_public_key"><td class="mdescLeft"> </td><td class="mdescRight">Decode this object from a <a class="el" href="class_buffered_transformation.html" title="Interface for buffered transformations. ">BufferedTransformation</a>. <a href="class_x509_public_key.html#a4eb86b0b55185f10a13ff7e1b083a67b">More...</a><br /></td></tr> <tr class="separator:a4eb86b0b55185f10a13ff7e1b083a67b inherit pub_methods_class_x509_public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a3135313b20cea541be900cf67a9eb9c7 inherit pub_methods_class_x509_public_key"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_x509_public_key.html#a3135313b20cea541be900cf67a9eb9c7">DEREncode</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt) const</td></tr> <tr class="memdesc:a3135313b20cea541be900cf67a9eb9c7 inherit pub_methods_class_x509_public_key"><td class="mdescLeft"> </td><td class="mdescRight">Encode this object into a <a class="el" href="class_buffered_transformation.html" title="Interface for buffered transformations. ">BufferedTransformation</a>. <a href="class_x509_public_key.html#a3135313b20cea541be900cf67a9eb9c7">More...</a><br /></td></tr> <tr class="separator:a3135313b20cea541be900cf67a9eb9c7 inherit pub_methods_class_x509_public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a3c60ac987c0d3c6aa537155946729c51 inherit pub_methods_class_x509_public_key"><td class="memItemLeft" align="right" valign="top"><a id="a3c60ac987c0d3c6aa537155946729c51"></a> virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_x509_public_key.html#a3c60ac987c0d3c6aa537155946729c51">BERDecodePublicKey</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt, bool parametersPresent, size_t size)=0</td></tr> <tr class="memdesc:a3c60ac987c0d3c6aa537155946729c51 inherit pub_methods_class_x509_public_key"><td class="mdescLeft"> </td><td class="mdescRight">decode subjectPublicKey part of subjectPublicKeyInfo, without the BIT STRING header <br /></td></tr> <tr class="separator:a3c60ac987c0d3c6aa537155946729c51 inherit pub_methods_class_x509_public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:aa8d06ad72e977bb175dabad152604d66 inherit pub_methods_class_x509_public_key"><td class="memItemLeft" align="right" valign="top"><a id="aa8d06ad72e977bb175dabad152604d66"></a> virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_x509_public_key.html#aa8d06ad72e977bb175dabad152604d66">DEREncodePublicKey</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt) const =0</td></tr> <tr class="memdesc:aa8d06ad72e977bb175dabad152604d66 inherit pub_methods_class_x509_public_key"><td class="mdescLeft"> </td><td class="mdescRight">encode subjectPublicKey part of subjectPublicKeyInfo, without the BIT STRING header <br /></td></tr> <tr class="separator:aa8d06ad72e977bb175dabad152604d66 inherit pub_methods_class_x509_public_key"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_a_s_n1_crypto_material"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_a_s_n1_crypto_material')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_a_s_n1_crypto_material.html">ASN1CryptoMaterial< PublicKey ></a></td></tr> <tr class="memitem:a52ea60c7684e0f3ea2749307d151de33 inherit pub_methods_class_a_s_n1_crypto_material"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_a_s_n1_crypto_material.html#a52ea60c7684e0f3ea2749307d151de33">Save</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt) const</td></tr> <tr class="memdesc:a52ea60c7684e0f3ea2749307d151de33 inherit pub_methods_class_a_s_n1_crypto_material"><td class="mdescLeft"> </td><td class="mdescRight">DER encode ASN.1 object. <a href="class_a_s_n1_crypto_material.html#a52ea60c7684e0f3ea2749307d151de33">More...</a><br /></td></tr> <tr class="separator:a52ea60c7684e0f3ea2749307d151de33 inherit pub_methods_class_a_s_n1_crypto_material"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a23d34a094f5765a1cf51f22ae1233f66 inherit pub_methods_class_a_s_n1_crypto_material"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_a_s_n1_crypto_material.html#a23d34a094f5765a1cf51f22ae1233f66">Load</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt)</td></tr> <tr class="memdesc:a23d34a094f5765a1cf51f22ae1233f66 inherit pub_methods_class_a_s_n1_crypto_material"><td class="mdescLeft"> </td><td class="mdescRight">BER decode ASN.1 object. <a href="class_a_s_n1_crypto_material.html#a23d34a094f5765a1cf51f22ae1233f66">More...</a><br /></td></tr> <tr class="separator:a23d34a094f5765a1cf51f22ae1233f66 inherit pub_methods_class_a_s_n1_crypto_material"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_a_s_n1_object"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_a_s_n1_object')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_a_s_n1_object.html">ASN1Object</a></td></tr> <tr class="memitem:a23d4aa134b80757d98145ecc832b5abb inherit pub_methods_class_a_s_n1_object"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_a_s_n1_object.html#a23d4aa134b80757d98145ecc832b5abb">BEREncode</a> (<a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> &bt) const</td></tr> <tr class="memdesc:a23d4aa134b80757d98145ecc832b5abb inherit pub_methods_class_a_s_n1_object"><td class="mdescLeft"> </td><td class="mdescRight">Encode this object into a <a class="el" href="class_buffered_transformation.html" title="Interface for buffered transformations. ">BufferedTransformation</a>. <a href="class_a_s_n1_object.html#a23d4aa134b80757d98145ecc832b5abb">More...</a><br /></td></tr> <tr class="separator:a23d4aa134b80757d98145ecc832b5abb inherit pub_methods_class_a_s_n1_object"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_crypto_material"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_crypto_material')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_crypto_material.html">CryptoMaterial</a></td></tr> <tr class="memitem:aedb65ba5323f7bb41fc57973566d20cd inherit pub_methods_class_crypto_material"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_crypto_material.html#aedb65ba5323f7bb41fc57973566d20cd">ThrowIfInvalid</a> (<a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> &rng, unsigned int level) const</td></tr> <tr class="memdesc:aedb65ba5323f7bb41fc57973566d20cd inherit pub_methods_class_crypto_material"><td class="mdescLeft"> </td><td class="mdescRight">Check this object for errors. <a href="class_crypto_material.html#aedb65ba5323f7bb41fc57973566d20cd">More...</a><br /></td></tr> <tr class="separator:aedb65ba5323f7bb41fc57973566d20cd inherit pub_methods_class_crypto_material"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:aa1da44802c5cf00946043922cb9e7e6e inherit pub_methods_class_crypto_material"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_crypto_material.html#aa1da44802c5cf00946043922cb9e7e6e">DoQuickSanityCheck</a> () const</td></tr> <tr class="memdesc:aa1da44802c5cf00946043922cb9e7e6e inherit pub_methods_class_crypto_material"><td class="mdescLeft"> </td><td class="mdescRight">Perform a quick sanity check. <a href="class_crypto_material.html#aa1da44802c5cf00946043922cb9e7e6e">More...</a><br /></td></tr> <tr class="separator:aa1da44802c5cf00946043922cb9e7e6e inherit pub_methods_class_crypto_material"><td class="memSeparator" colspan="2"> </td></tr> <tr class="inherit_header pub_methods_class_name_value_pairs"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_name_value_pairs')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="class_name_value_pairs.html">NameValuePairs</a></td></tr> <tr class="memitem:a3401528f3d69d70f200086501b8af282 inherit pub_methods_class_name_value_pairs"><td class="memTemplParams" colspan="2">template<class T > </td></tr> <tr class="memitem:a3401528f3d69d70f200086501b8af282 inherit pub_methods_class_name_value_pairs"><td class="memTemplItemLeft" align="right" valign="top">bool </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a3401528f3d69d70f200086501b8af282">GetThisObject</a> (T &object) const</td></tr> <tr class="memdesc:a3401528f3d69d70f200086501b8af282 inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a copy of this object or subobject. <a href="class_name_value_pairs.html#a3401528f3d69d70f200086501b8af282">More...</a><br /></td></tr> <tr class="separator:a3401528f3d69d70f200086501b8af282 inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:abce7b413ce1345ab7b7d05fa3d1834f5 inherit pub_methods_class_name_value_pairs"><td class="memTemplParams" colspan="2">template<class T > </td></tr> <tr class="memitem:abce7b413ce1345ab7b7d05fa3d1834f5 inherit pub_methods_class_name_value_pairs"><td class="memTemplItemLeft" align="right" valign="top">bool </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#abce7b413ce1345ab7b7d05fa3d1834f5">GetThisPointer</a> (T *&ptr) const</td></tr> <tr class="memdesc:abce7b413ce1345ab7b7d05fa3d1834f5 inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a pointer to this object. <a href="class_name_value_pairs.html#abce7b413ce1345ab7b7d05fa3d1834f5">More...</a><br /></td></tr> <tr class="separator:abce7b413ce1345ab7b7d05fa3d1834f5 inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a5357c3a09602e44671d1e42cb9a9408d inherit pub_methods_class_name_value_pairs"><td class="memTemplParams" colspan="2">template<class T > </td></tr> <tr class="memitem:a5357c3a09602e44671d1e42cb9a9408d inherit pub_methods_class_name_value_pairs"><td class="memTemplItemLeft" align="right" valign="top">bool </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a5357c3a09602e44671d1e42cb9a9408d">GetValue</a> (const char *name, T &value) const</td></tr> <tr class="memdesc:a5357c3a09602e44671d1e42cb9a9408d inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value. <a href="class_name_value_pairs.html#a5357c3a09602e44671d1e42cb9a9408d">More...</a><br /></td></tr> <tr class="separator:a5357c3a09602e44671d1e42cb9a9408d inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a4daf1ef67b547c6be96188a43e5ec05e inherit pub_methods_class_name_value_pairs"><td class="memTemplParams" colspan="2">template<class T > </td></tr> <tr class="memitem:a4daf1ef67b547c6be96188a43e5ec05e inherit pub_methods_class_name_value_pairs"><td class="memTemplItemLeft" align="right" valign="top">T </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a4daf1ef67b547c6be96188a43e5ec05e">GetValueWithDefault</a> (const char *name, T defaultValue) const</td></tr> <tr class="memdesc:a4daf1ef67b547c6be96188a43e5ec05e inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value. <a href="class_name_value_pairs.html#a4daf1ef67b547c6be96188a43e5ec05e">More...</a><br /></td></tr> <tr class="separator:a4daf1ef67b547c6be96188a43e5ec05e inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a13faea827ee047cd58557282806ed2e1 inherit pub_methods_class_name_value_pairs"><td class="memItemLeft" align="right" valign="top">std::string </td><td class="memItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a13faea827ee047cd58557282806ed2e1">GetValueNames</a> () const</td></tr> <tr class="memdesc:a13faea827ee047cd58557282806ed2e1 inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a list of value names that can be retrieved. <a href="class_name_value_pairs.html#a13faea827ee047cd58557282806ed2e1">More...</a><br /></td></tr> <tr class="separator:a13faea827ee047cd58557282806ed2e1 inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a94e5b19dc54625799797668ff8627c57 inherit pub_methods_class_name_value_pairs"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a94e5b19dc54625799797668ff8627c57">GetIntValue</a> (const char *name, int &value) const</td></tr> <tr class="memdesc:a94e5b19dc54625799797668ff8627c57 inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value with type int. <a href="class_name_value_pairs.html#a94e5b19dc54625799797668ff8627c57">More...</a><br /></td></tr> <tr class="separator:a94e5b19dc54625799797668ff8627c57 inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a7ddb654b7afcd1a04422a7b4b01366d9 inherit pub_methods_class_name_value_pairs"><td class="memItemLeft" align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#a7ddb654b7afcd1a04422a7b4b01366d9">GetIntValueWithDefault</a> (const char *name, int defaultValue) const</td></tr> <tr class="memdesc:a7ddb654b7afcd1a04422a7b4b01366d9 inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Get a named value with type int, with default. <a href="class_name_value_pairs.html#a7ddb654b7afcd1a04422a7b4b01366d9">More...</a><br /></td></tr> <tr class="separator:a7ddb654b7afcd1a04422a7b4b01366d9 inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af28f6e7abf98606d8146bfda271e99db inherit pub_methods_class_name_value_pairs"><td class="memTemplParams" colspan="2">template<class T > </td></tr> <tr class="memitem:af28f6e7abf98606d8146bfda271e99db inherit pub_methods_class_name_value_pairs"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#af28f6e7abf98606d8146bfda271e99db">GetRequiredParameter</a> (const char *className, const char *name, T &value) const</td></tr> <tr class="memdesc:af28f6e7abf98606d8146bfda271e99db inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves a required name/value pair. <a href="class_name_value_pairs.html#af28f6e7abf98606d8146bfda271e99db">More...</a><br /></td></tr> <tr class="separator:af28f6e7abf98606d8146bfda271e99db inherit pub_methods_class_name_value_pairs"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:acfb673d912e1bc19386bebba9d58c23f inherit pub_methods_class_name_value_pairs"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#acfb673d912e1bc19386bebba9d58c23f">GetRequiredIntParameter</a> (const char *className, const char *name, int &value) const</td></tr> <tr class="memdesc:acfb673d912e1bc19386bebba9d58c23f inherit pub_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves a required name/value pair. <a href="class_name_value_pairs.html#acfb673d912e1bc19386bebba9d58c23f">More...</a><br /></td></tr> <tr class="separator:acfb673d912e1bc19386bebba9d58c23f inherit pub_methods_class_name_value_pairs"><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_static_methods_class_name_value_pairs"><td colspan="2" onclick="javascript:toggleInherit('pub_static_methods_class_name_value_pairs')"><img src="closed.png" alt="-"/> Static Public Member Functions inherited from <a class="el" href="class_name_value_pairs.html">NameValuePairs</a></td></tr> <tr class="memitem:ad4b80eeeb5f1f58e3cedb12f02a6b870 inherit pub_static_methods_class_name_value_pairs"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_name_value_pairs.html#ad4b80eeeb5f1f58e3cedb12f02a6b870">ThrowIfTypeMismatch</a> (const char *name, const std::type_info &stored, const std::type_info &retrieving)</td></tr> <tr class="memdesc:ad4b80eeeb5f1f58e3cedb12f02a6b870 inherit pub_static_methods_class_name_value_pairs"><td class="mdescLeft"> </td><td class="mdescRight">Ensures an expected name and type is present. <a href="class_name_value_pairs.html#ad4b80eeeb5f1f58e3cedb12f02a6b870">More...</a><br /></td></tr> <tr class="separator:ad4b80eeeb5f1f58e3cedb12f02a6b870 inherit pub_static_methods_class_name_value_pairs"><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 GP><br /> class DL_PublicKeyImpl< GP ></h3> <p>Discrete Log (DL) public key base implementation. </p> <dl class="tparams"><dt>Template Parameters</dt><dd> <table class="tparams"> <tr><td class="paramname">GP</td><td>GroupParameters class </td></tr> </table> </dd> </dl> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01298">1298</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div><h2 class="groupheader">Member Function Documentation</h2> <a id="ad915aa79d9a19b4c7a6bab99181250b1"></a> <h2 class="memtitle"><span class="permalink"><a href="#ad915aa79d9a19b4c7a6bab99181250b1">◆ </a></span>Validate()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::Validate </td> <td>(</td> <td class="paramtype"><a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> & </td> <td class="paramname"><em>rng</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">unsigned int </td> <td class="paramname"><em>level</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Check this object for errors. </p> <dl class="params"><dt>Parameters</dt><dd> <table class="params"> <tr><td class="paramname">rng</td><td>a <a class="el" href="class_random_number_generator.html" title="Interface for random number generators. ">RandomNumberGenerator</a> for objects which use randomized testing </td></tr> <tr><td class="paramname">level</td><td>the level of thoroughness </td></tr> </table> </dd> </dl> <dl class="section return"><dt>Returns</dt><dd>true if the tests succeed, false otherwise</dd></dl> <p>There are four levels of thoroughness: </p><ul> <li> 0 - using this object won't cause a crash or exception </li> <li> 1 - this object will probably function, and encrypt, sign, other operations correctly </li> <li> 2 - ensure this object will function correctly, and perform reasonable security checks </li> <li> 3 - perform reasonable security checks, and do checks that may take a long time </li> </ul> <p>Level 0 does not require a <a class="el" href="class_random_number_generator.html" title="Interface for random number generators. ">RandomNumberGenerator</a>. A <a class="el" href="cryptlib_8h.html#a1e53479a6d427158247ac1ece3161a6d" title="Random Number Generator that does not produce random numbers. ">NullRNG()</a> can be used for level 0. Level 1 may not check for weak keys and such. Levels 2 and 3 are recommended. </p><dl class="section see"><dt>See also</dt><dd><a class="el" href="class_crypto_material.html#aedb65ba5323f7bb41fc57973566d20cd" title="Check this object for errors. ">ThrowIfInvalid()</a> </dd></dl> <p>Implements <a class="el" href="class_crypto_material.html#aaa7d67d0c12712de0e33713c73f5b718">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01306">1306</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a743eb7afb3d047103f82d78f619165e5"></a> <h2 class="memtitle"><span class="permalink"><a href="#a743eb7afb3d047103f82d78f619165e5">◆ </a></span>GetVoidValue()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::GetVoidValue </td> <td>(</td> <td class="paramtype">const char * </td> <td class="paramname"><em>name</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">const std::type_info & </td> <td class="paramname"><em>valueType</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">void * </td> <td class="paramname"><em>pValue</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Get a named value. </p> <dl class="params"><dt>Parameters</dt><dd> <table class="params"> <tr><td class="paramname">name</td><td>the name of the object or value to retrieve </td></tr> <tr><td class="paramname">valueType</td><td>reference to a variable that receives the value </td></tr> <tr><td class="paramname">pValue</td><td>void pointer to a variable that receives the value </td></tr> </table> </dd> </dl> <dl class="section return"><dt>Returns</dt><dd>true if the value was retrieved, false otherwise</dd></dl> <p><a class="el" href="class_d_l___public_key_impl.html#a743eb7afb3d047103f82d78f619165e5" title="Get a named value. ">GetVoidValue()</a> retrieves the value of name if it exists. </p><dl class="section note"><dt>Note</dt><dd><a class="el" href="class_d_l___public_key_impl.html#a743eb7afb3d047103f82d78f619165e5" title="Get a named value. ">GetVoidValue()</a> is an internal function and should be implemented by derived classes. Users should use one of the other functions instead. </dd></dl> <dl class="section see"><dt>See also</dt><dd><a class="el" href="class_name_value_pairs.html#a5357c3a09602e44671d1e42cb9a9408d" title="Get a named value. ">GetValue()</a>, <a class="el" href="class_name_value_pairs.html#a4daf1ef67b547c6be96188a43e5ec05e" title="Get a named value. ">GetValueWithDefault()</a>, <a class="el" href="class_name_value_pairs.html#a94e5b19dc54625799797668ff8627c57" title="Get a named value with type int. ">GetIntValue()</a>, <a class="el" href="class_name_value_pairs.html#a7ddb654b7afcd1a04422a7b4b01366d9" title="Get a named value with type int, with default. ">GetIntValueWithDefault()</a>, <a class="el" href="class_name_value_pairs.html#af28f6e7abf98606d8146bfda271e99db" title="Retrieves a required name/value pair. ">GetRequiredParameter()</a> and <a class="el" href="class_name_value_pairs.html#acfb673d912e1bc19386bebba9d58c23f" title="Retrieves a required name/value pair. ">GetRequiredIntParameter()</a> </dd></dl> <p>Implements <a class="el" href="class_name_value_pairs.html#a9fc3f5c4480d53b8104c67ca7958e332">NameValuePairs</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01313">1313</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="afa2dcb7fc8d0d83dd6d4563b7ba6ca41"></a> <h2 class="memtitle"><span class="permalink"><a href="#afa2dcb7fc8d0d83dd6d4563b7ba6ca41">◆ </a></span>AssignFrom()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">void <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::AssignFrom </td> <td>(</td> <td class="paramtype">const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> & </td> <td class="paramname"><em>source</em></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Assign values to this object. </p> <p>This function can be used to create a public key from a private key. </p> <p>Implements <a class="el" href="class_crypto_material.html#a20181c1b39a74a9fe91385b025b773c6">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01318">1318</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a2fc2bcec20e2c15a4848b5c9913d2faf"></a> <h2 class="memtitle"><span class="permalink"><a href="#a2fc2bcec20e2c15a4848b5c9913d2faf">◆ </a></span>SupportsPrecomputation()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::SupportsPrecomputation </td> <td>(</td> <td class="paramname"></td><td>)</td> <td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Determines whether the object supports precomputation. </p> <dl class="section return"><dt>Returns</dt><dd>true if the object supports precomputation, false otherwise </dd></dl> <dl class="section see"><dt>See also</dt><dd><a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b" title="Perform precomputation. ">Precompute()</a> </dd></dl> <p>Reimplemented from <a class="el" href="class_crypto_material.html#a35720c07870fcda4ae39148f8524274e">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01323">1323</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a95e25f6632ec2621289d10abc557b17b"></a> <h2 class="memtitle"><span class="permalink"><a href="#a95e25f6632ec2621289d10abc557b17b">◆ </a></span>Precompute()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">void <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::Precompute </td> <td>(</td> <td class="paramtype">unsigned int </td> <td class="paramname"><em>precomputationStorage</em> = <code>16</code></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Perform precomputation. </p> <dl class="params"><dt>Parameters</dt><dd> <table class="params"> <tr><td class="paramname">precomputationStorage</td><td>the suggested number of objects for the precompute table </td></tr> </table> </dd> </dl> <dl class="exception"><dt>Exceptions</dt><dd> <table class="exception"> <tr><td class="paramname"><a class="el" href="class_not_implemented.html" title="A method was called which was not implemented. ">NotImplemented</a></td><td></td></tr> </table> </dd> </dl> <p>The exact semantics of <a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b" title="Perform precomputation. ">Precompute()</a> varies, but it typically means calculate a table of n objects that can be used later to speed up computation.</p> <p>If a derived class does not override <a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b" title="Perform precomputation. ">Precompute()</a>, then the base class throws <a class="el" href="class_not_implemented.html" title="A method was called which was not implemented. ">NotImplemented</a>. </p><dl class="section see"><dt>See also</dt><dd><a class="el" href="class_d_l___public_key_impl.html#a2fc2bcec20e2c15a4848b5c9913d2faf" title="Determines whether the object supports precomputation. ">SupportsPrecomputation()</a>, <a class="el" href="class_d_l___public_key_impl.html#a8f1379edc09486d79c3ad6c374d01243" title="Retrieve previously saved precomputation. ">LoadPrecomputation()</a>, <a class="el" href="class_d_l___public_key_impl.html#af562a63129ab05c2818e404b3446b2c7" title="Save precomputation for later use. ">SavePrecomputation()</a> </dd></dl> <p>Reimplemented from <a class="el" href="class_crypto_material.html#a78380e019615a35d06e951a0f28e0a99">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01325">1325</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a8f1379edc09486d79c3ad6c374d01243"></a> <h2 class="memtitle"><span class="permalink"><a href="#a8f1379edc09486d79c3ad6c374d01243">◆ </a></span>LoadPrecomputation()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">void <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::LoadPrecomputation </td> <td>(</td> <td class="paramtype"><a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> & </td> <td class="paramname"><em>storedPrecomputation</em></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Retrieve previously saved precomputation. </p> <dl class="params"><dt>Parameters</dt><dd> <table class="params"> <tr><td class="paramname">storedPrecomputation</td><td><a class="el" href="class_buffered_transformation.html" title="Interface for buffered transformations. ">BufferedTransformation</a> with the saved precomputation </td></tr> </table> </dd> </dl> <dl class="exception"><dt>Exceptions</dt><dd> <table class="exception"> <tr><td class="paramname"><a class="el" href="class_not_implemented.html" title="A method was called which was not implemented. ">NotImplemented</a></td><td></td></tr> </table> </dd> </dl> <dl class="section see"><dt>See also</dt><dd><a class="el" href="class_d_l___public_key_impl.html#a2fc2bcec20e2c15a4848b5c9913d2faf" title="Determines whether the object supports precomputation. ">SupportsPrecomputation()</a>, <a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b" title="Perform precomputation. ">Precompute()</a> </dd></dl> <p>Reimplemented from <a class="el" href="class_crypto_material.html#a2911ebd9a28efa43dab71e5c12e2c90d">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01331">1331</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="af562a63129ab05c2818e404b3446b2c7"></a> <h2 class="memtitle"><span class="permalink"><a href="#af562a63129ab05c2818e404b3446b2c7">◆ </a></span>SavePrecomputation()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">void <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::SavePrecomputation </td> <td>(</td> <td class="paramtype"><a class="el" href="class_buffered_transformation.html">BufferedTransformation</a> & </td> <td class="paramname"><em>storedPrecomputation</em></td><td>)</td> <td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Save precomputation for later use. </p> <dl class="params"><dt>Parameters</dt><dd> <table class="params"> <tr><td class="paramname">storedPrecomputation</td><td><a class="el" href="class_buffered_transformation.html" title="Interface for buffered transformations. ">BufferedTransformation</a> to write the precomputation </td></tr> </table> </dd> </dl> <dl class="exception"><dt>Exceptions</dt><dd> <table class="exception"> <tr><td class="paramname"><a class="el" href="class_not_implemented.html" title="A method was called which was not implemented. ">NotImplemented</a></td><td></td></tr> </table> </dd> </dl> <dl class="section see"><dt>See also</dt><dd><a class="el" href="class_d_l___public_key_impl.html#a2fc2bcec20e2c15a4848b5c9913d2faf" title="Determines whether the object supports precomputation. ">SupportsPrecomputation()</a>, <a class="el" href="class_d_l___public_key_impl.html#a95e25f6632ec2621289d10abc557b17b" title="Perform precomputation. ">Precompute()</a> </dd></dl> <p>Reimplemented from <a class="el" href="class_crypto_material.html#a65b905e1af3efb962c356d49d2c90e73">CryptoMaterial</a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01337">1337</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="aab8d5cddf210d9f920b38627a70e4ba1"></a> <h2 class="memtitle"><span class="permalink"><a href="#aab8d5cddf210d9f920b38627a70e4ba1">◆ </a></span>GetAbstractGroupParameters()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">const <a class="el" href="class_d_l___group_parameters.html">DL_GroupParameters</a><Element>& <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::GetAbstractGroupParameters </td> <td>(</td> <td class="paramname"></td><td>)</td> <td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Retrieves abstract group parameters. </p> <dl class="section return"><dt>Returns</dt><dd>a const reference to the group parameters </dd></dl> <p>Implements <a class="el" href="class_d_l___key.html#a85e3d4eddb546c05acdca33a9939755e">DL_Key< GP::Element ></a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01344">1344</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a2ff2c005ee4b85eb1406799afc28b8a0"></a> <h2 class="memtitle"><span class="permalink"><a href="#a2ff2c005ee4b85eb1406799afc28b8a0">◆ </a></span>AccessAbstractGroupParameters()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname"><a class="el" href="class_d_l___group_parameters.html">DL_GroupParameters</a><Element>& <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::AccessAbstractGroupParameters </td> <td>(</td> <td class="paramname"></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Retrieves abstract group parameters. </p> <dl class="section return"><dt>Returns</dt><dd>a non-const reference to the group parameters </dd></dl> <p>Implements <a class="el" href="class_d_l___key.html#aaffcc772fd8fe1d37fae92ed77c54829">DL_Key< GP::Element ></a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01345">1345</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="ac1eab8c6ae65408dcb80a3d451b5c45d"></a> <h2 class="memtitle"><span class="permalink"><a href="#ac1eab8c6ae65408dcb80a3d451b5c45d">◆ </a></span>GetPublicPrecomputation()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">const <a class="el" href="class_d_l___fixed_base_precomputation.html">DL_FixedBasePrecomputation</a><Element>& <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::GetPublicPrecomputation </td> <td>(</td> <td class="paramname"></td><td>)</td> <td> const</td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Accesses the public precomputation. </p> <p>GetPublicPrecomputation returns a const reference, while AccessPublicPrecomputation returns a non-const reference. Must be overridden in derived classes. </p> <p>Implements <a class="el" href="class_d_l___public_key.html#a14a74e0fd35ec6441424fb09e5ba4512">DL_PublicKey< GP::Element ></a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01348">1348</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <a id="a43c88026bb625ad49dea861f807eb9c3"></a> <h2 class="memtitle"><span class="permalink"><a href="#a43c88026bb625ad49dea861f807eb9c3">◆ </a></span>AccessPublicPrecomputation()</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<class GP> </div> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname"><a class="el" href="class_d_l___fixed_base_precomputation.html">DL_FixedBasePrecomputation</a><Element>& <a class="el" href="class_d_l___public_key_impl.html">DL_PublicKeyImpl</a>< GP >::AccessPublicPrecomputation </td> <td>(</td> <td class="paramname"></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Accesses the public precomputation. </p> <p>GetPublicPrecomputation returns a const reference, while AccessPublicPrecomputation returns a non-const reference. Must be overridden in derived classes. </p> <p>Implements <a class="el" href="class_d_l___public_key.html#aaf42f2ffabd071995559be72eb7ae845">DL_PublicKey< GP::Element ></a>.</p> <p class="definition">Definition at line <a class="el" href="pubkey_8h_source.html#l01349">1349</a> of file <a class="el" href="pubkey_8h_source.html">pubkey.h</a>.</p> </div> </div> <hr/>The documentation for this class was generated from the following file:<ul> <li><a class="el" href="pubkey_8h_source.html">pubkey.h</a></li> </ul> </div><!-- contents --> <!-- start footer part --> <hr class="footer"/><address class="footer"><small> Generated on Sun Sep 16 2018 07:58:30 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>