Glossary.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <!-- HTML header for doxygen 1.8.10-->
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  6. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  7. <meta name="generator" content="Doxygen 1.8.11"/>
  8. <title>Intel&reg; Enhanced Privacy ID SDK: Glossary</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="navtree.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="resize.js"></script>
  14. <script type="text/javascript" src="navtreedata.js"></script>
  15. <script type="text/javascript" src="navtree.js"></script>
  16. <script type="text/javascript">
  17. $(document).ready(initResizable);
  18. $(window).load(resizeHeight);
  19. </script>
  20. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  21. <link href="epidstyle.css" rel="stylesheet" type="text/css"/>
  22. </head>
  23. <body>
  24. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  25. <div id="titlearea">
  26. <table cellspacing="0" cellpadding="0">
  27. <tbody>
  28. <tr style="height: 56px;">
  29. <td id="projectalign" style="padding-left: 0.5em;">
  30. <div id="projectname"><a
  31. onclick="storeLink('index.html')"
  32. id="projectlink"
  33. class="index.html"
  34. href="index.html">Intel&reg; Enhanced Privacy ID SDK</a>
  35. &#160;<span id="projectnumber">3.0.0</span>
  36. </div>
  37. </td>
  38. </tr>
  39. </tbody>
  40. </table>
  41. </div>
  42. <!-- end header part -->
  43. <!-- Generated by Doxygen 1.8.11 -->
  44. </div><!-- top -->
  45. <div id="side-nav" class="ui-resizable side-nav-resizable">
  46. <div id="nav-tree">
  47. <div id="nav-tree-contents">
  48. <div id="nav-sync" class="sync"></div>
  49. </div>
  50. </div>
  51. <div id="splitbar" style="-moz-user-select:none;"
  52. class="ui-resizable-handle">
  53. </div>
  54. </div>
  55. <script type="text/javascript">
  56. $(document).ready(function(){initNavTree('Glossary.html','');});
  57. </script>
  58. <div id="doc-content">
  59. <div class="header">
  60. <div class="headertitle">
  61. <div class="title">Glossary </div> </div>
  62. </div><!--header-->
  63. <div class="contents">
  64. <div class="toc"><h3>Table of Contents</h3>
  65. <ul><li class="level1"><a href="#Issuing_CA">CA public key</a></li>
  66. <li class="level1"><a href="#Glossary_Daa">DAA</a></li>
  67. <li class="level1"><a href="#Glossary_EllipticCurve">Elliptic curve</a></li>
  68. <li class="level1"><a href="#Glossary_EllipticCurvePoint">Elliptic curve point</a></li>
  69. <li class="level1"><a href="#Glossary_Group">Group</a></li>
  70. <li class="level1"><a href="#Glossary_Group_certificate">Group certificate</a></li>
  71. <li class="level1"><a href="#Glossary_GroupPublicKey">Group public key</a></li>
  72. <li class="level1"><a href="#Glossary_Epid">Intel&reg; EPID</a></li>
  73. <li class="level1"><a href="#Glossary_EpidSignature">Intel&reg; EPID signature</a></li>
  74. <li class="level1"><a href="#Glossary_Issuer">Issuer</a></li>
  75. <li class="level1"><a href="#Glossary_IssuingPrivateKey">Issuing private key</a></li>
  76. <li class="level1"><a href="#Glossary_Member">Member</a></li>
  77. <li class="level1"><a href="#Glossary_NameBasedSignature">Name-based signature</a></li>
  78. <li class="level1"><a href="#Glossary_MemberPrivateKey">Member private key</a></li>
  79. <li class="level1"><a href="#Glossary_NonRevokedProof">Non-revoked proof</a></li>
  80. <li class="level1"><a href="#Glossary_Pairing">Pairing</a></li>
  81. <li class="level1"><a href="#Glossary_Revocation">Revocation, revocation lists</a></li>
  82. <li class="level1"><a href="#Glossary_Verifier">Verifier</a></li>
  83. </ul>
  84. </div>
  85. <div class="textblock"><h1><a class="anchor" id="Issuing_CA"></a>
  86. CA public key</h1>
  87. <p>The CA (Certificate Authority) public key contains the ECDSA public key of the issuing CA. The verifier uses this key to authenticate that information provided by the issuer is genuine.</p>
  88. <h1><a class="anchor" id="Glossary_Daa"></a>
  89. DAA</h1>
  90. <p>Direct Anonymous Attestation (DAA) is a digital signature algorithm that supports anonymity by providing a group public verification key associated with many unique private signing keys. Intel&reg; EPID enhances DAA by enabling a private key to be revoked given a signature created by that key, even if the key itself is still unknown.</p>
  91. <h1><a class="anchor" id="Glossary_EllipticCurve"></a>
  92. Elliptic curve</h1>
  93. <p>In elliptic curve cryptography, an elliptic curve is an algebraic structure used to create a function whose output is easy to compute, but whose input is difficult to compute given the output. Elliptic curve cryptography requires smaller keys compared to non-elliptic curve cryptography (based on Galois fields) to provide equivalent security.</p>
  94. <h1><a class="anchor" id="Glossary_EllipticCurvePoint"></a>
  95. Elliptic curve point</h1>
  96. <p>An elliptic curve point is a point along an elliptic curve. The security of elliptic curve cryptography depends on the ability to compute a point multiplication and the inability to compute the multiplicand given the original and product points.</p>
  97. <h1><a class="anchor" id="Glossary_Group"></a>
  98. Group</h1>
  99. <p>An Intel&reg; EPID group represents a set of trusted entities called members.</p>
  100. <p>Issuers create groups and manage group membership. For each group, the issuer creates a group public key simultaneously with the corresponding issuing private key. The issuer uses the issuing private key to create unique member private keys for each group member, and makes the group public key available to verifiers.</p>
  101. <p>All groups have the following:</p>
  102. <ul>
  103. <li>Group public key, which corresponds to the issuing private key kept by the issuer</li>
  104. <li>Signature based revocation list</li>
  105. <li>Private key based revocation list</li>
  106. <li>Member private keys, generated from the issuing private key</li>
  107. </ul>
  108. <p>If a signature based revocation list or private key based revocation list does not exist, it is assumed to be empty.</p>
  109. <h1><a class="anchor" id="Glossary_Group_certificate"></a>
  110. Group certificate</h1>
  111. <p>The group certificate contains the group public key. The group certificate is created by the issuer and obtained by the verifier. When the issuer creates groups, it generates one issuing private key and one group certificate for each group.</p>
  112. <h1><a class="anchor" id="Glossary_GroupPublicKey"></a>
  113. Group public key</h1>
  114. <p>The group public key is the key used by the verifier to confirm that a member belongs to a group in good standing. Each member private key in a group is associated with the group's public key.</p>
  115. <p>When a group is created, the group public key and the issuing private key are simultaneously generated by the issuer. The verifier obtains the group public key from the issuer.</p>
  116. <h1><a class="anchor" id="Glossary_Epid"></a>
  117. Intel® EPID</h1>
  118. <p>Enhanced Privacy ID (Intel&reg; EPID) is a cryptographic protocol for attestation of a trusted platform while preserving the user's privacy. Intel&reg; EPID can be used as a foundational building block for a multitude of security solutions.</p>
  119. <h1><a class="anchor" id="Glossary_EpidSignature"></a>
  120. Intel® EPID signature</h1>
  121. <p>An Intel&reg; EPID signature is a type of digital signature that preserves anonymity of the signer, while still proving the signer is a member of a trusted group.</p>
  122. <h1><a class="anchor" id="Glossary_Issuer"></a>
  123. Issuer</h1>
  124. <p>The issuer is the entity in the Intel&reg; EPID scheme that is responsible for managing group membership. Issuer APIs are not included in the SDK. An example of an issuer is the Intel Key Generation Facility. For sample issuer material, refer to <a class="el" href="IssuerMaterial.html">Sample Issuer Material</a>. For tools that can help you if you choose to use iKGF as your issuer, refer to <a class="el" href="ChoosingiKGF.html">If You Choose iKGF as Your Issuer</a>.</p>
  125. <p>The issuer manages groups by doing the following:</p>
  126. <ul>
  127. <li>Creates groups by generating one issuing private key and one group certificate for each group. The group certificate contains the group public key.</li>
  128. <li>Creates group members by generating unique Intel&reg; EPID member private keys through bulk provisioning. Member private keys are created from the issuing private key for the group.</li>
  129. <li>Manages requests from prospective members to join existing groups by using the join protocol.</li>
  130. <li>Creates and maintains signature based revocation lists and private key based revocation lists. These lists of members no longer in good standing allow members to be dropped from a group.</li>
  131. <li>Creates and maintains group revocation lists.</li>
  132. <li>Makes group public keys and revocation lists available to verifiers.</li>
  133. </ul>
  134. <h1><a class="anchor" id="Glossary_IssuingPrivateKey"></a>
  135. Issuing private key</h1>
  136. <p>The issuing private key is the key used by the issuer to generate unique private keys for each member of a given group. For every group public key, there is a corresponding issuing private key. The issuing private key remains with the issuer and is kept private.</p>
  137. <h1><a class="anchor" id="Glossary_Member"></a>
  138. Member</h1>
  139. <p>The member is the entity that attempts to prove its group membership to the verifier. Members are authorized by the issuer as part of a group and each group member has a unique Intel&reg; EPID private key. The member uses its member private key to sign a message to prove group membership without revealing its identity. An example of a member is a PC with an embedded Intel&reg; EPID member private key.</p>
  140. <h1><a class="anchor" id="Glossary_NameBasedSignature"></a>
  141. Name-based signature</h1>
  142. <p>A name-based signature is a type of signature that gives the verifier the ability to link Intel&reg; EPID signatures from the same member, reducing the member's privacy.</p>
  143. <p>A name-based signature is created using the additional parameter of a basename. If a basename is not specified, a random number is chosen as the basename. If the member uses the same basename, the verifier can mathematically link signatures generated by the member, showing that the signatures are from the same member.</p>
  144. <h1><a class="anchor" id="Glossary_MemberPrivateKey"></a>
  145. Member private key</h1>
  146. <p>The member private key is the key used by the member to digitally sign a message when attempting to prove to the verifier that the member belongs to the group and is in good standing.</p>
  147. <p>Unique member private keys are generated by the issuer for each member of a given group. The same group public key corresponds to each member private key in the group.</p>
  148. <h1><a class="anchor" id="Glossary_NonRevokedProof"></a>
  149. Non-revoked proof</h1>
  150. <p>A non-revoked proof is part of an Intel&reg; EPID signature that proves that the member is not a specific revoked entity in the signature based revocation list. The member provides the signature with a number of non-revoked proofs, one per revocation list entry, to prove to the verifier that the member does not correspond to any entry in the revocation list.</p>
  151. <h1><a class="anchor" id="Glossary_Pairing"></a>
  152. Pairing</h1>
  153. <p>Pairing is a mathematical operation that maps two elliptic curve groups to a third multiplicative group.</p>
  154. <h1><a class="anchor" id="Glossary_Revocation"></a>
  155. Revocation, revocation lists</h1>
  156. <p>Revocation lists are data structures used by the verifier to identify members that are no longer approved members of the group.</p>
  157. <p>The verifier obtains the member private key based revocation list (PrivRL), signature based revocation list (SigRL), and group based revocation list (GroupRL) from the issuer. The verifier can also maintain its own verifier blacklist (VerifierRL). Verifier blacklist revocation only works with name based signatures.</p>
  158. <h1><a class="anchor" id="Glossary_Verifier"></a>
  159. Verifier</h1>
  160. <p>The verifier is the entity that checks an Intel&reg; EPID signature to establish whether it was signed by an entity or device that is a member in good standing.</p>
  161. <p>The verifier acts on behalf of a party that needs to know it is communicating with a trusted device. Verifiers obtain group certificates and revocation lists from issuers and negotiate details of signature protocol with members. </p>
  162. </div></div><!-- contents -->
  163. </div><!-- doc-content -->
  164. <!-- HTML footer for doxygen 1.8.10-->
  165. <!-- start footer part -->
  166. <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  167. <ul>
  168. <li class="footer">
  169. &copy; 2016 Intel Corporation
  170. </li>
  171. </ul>
  172. </div>
  173. </body>
  174. </html>