github.com/ethereum/go-ethereum@v1.16.1/crypto/ecies/README (about)

     1  # NOTE
     2  
     3  This implementation is direct fork of Kylom's implementation. I claim no authorship over this code apart from some minor modifications.
     4  Please be aware this code **has not yet been reviewed**.
     5  
     6  ecies implements the Elliptic Curve Integrated Encryption Scheme.
     7  
     8  The package is designed to be compliant with the appropriate NIST
     9  standards, and therefore doesn't support the full SEC 1 algorithm set.
    10  
    11  
    12  STATUS:
    13  
    14  ecies should be ready for use. The ASN.1 support is only complete so
    15  far as to supported the listed algorithms before.
    16  
    17  
    18  CAVEATS
    19  
    20  1. CMAC support is currently not present.
    21  
    22  
    23  SUPPORTED ALGORITHMS
    24  
    25          SYMMETRIC CIPHERS               HASH FUNCTIONS
    26               AES128                         SHA-1
    27               AES192                        SHA-224
    28               AES256                        SHA-256
    29                                             SHA-384
    30          ELLIPTIC CURVE                     SHA-512
    31               P256
    32               P384		    KEY DERIVATION FUNCTION
    33               P521	       NIST SP 800-65a Concatenation KDF
    34  
    35  Curve P224 isn't supported because it does not provide a minimum security
    36  level of AES128 with HMAC-SHA1. According to NIST SP 800-57, the security
    37  level of P224 is 112 bits of security. Symmetric ciphers use CTR-mode;
    38  message tags are computed using HMAC-<HASH> function.
    39  
    40  
    41  CURVE SELECTION
    42  
    43  According to NIST SP 800-57, the following curves should be selected:
    44  
    45      +----------------+-------+
    46      | SYMMETRIC SIZE | CURVE |
    47      +----------------+-------+
    48      |     128-bit    |  P256 |
    49      +----------------+-------+
    50      |     192-bit    |  P384 |
    51      +----------------+-------+
    52      |     256-bit    |  P521 |
    53      +----------------+-------+
    54  
    55  
    56  TODO
    57  
    58  1. Look at serialising the parameters with the SEC 1 ASN.1 module.
    59  2. Validate ASN.1 formats with SEC 1.
    60  
    61  
    62  TEST VECTORS
    63  
    64  The only test vectors I've found so far date from 1993, predating AES
    65  and including only 163-bit curves. Therefore, there are no published
    66  test vectors to compare to.
    67  
    68  
    69  LICENSE
    70  
    71  ecies is released under the same license as the Go source code. See the
    72  LICENSE file for details.
    73  
    74  
    75  REFERENCES
    76  
    77  * SEC (Standard for Efficient Cryptography) 1, version 2.0: Elliptic
    78    Curve Cryptography; Certicom, May 2009.
    79    http://www.secg.org/sec1-v2.pdf
    80  * GEC (Guidelines for Efficient Cryptography) 2, version 0.3: Test
    81    Vectors for SEC 1; Certicom, September 1999.
    82    http://read.pudn.com/downloads168/doc/772358/TestVectorsforSEC%201-gec2.pdf
    83  * NIST SP 800-56a: Recommendation for Pair-Wise Key Establishment Schemes
    84    Using Discrete Logarithm Cryptography. National Institute of Standards
    85    and Technology, May 2007.
    86    http://csrc.nist.gov/publications/nistpubs/800-56A/SP800-56A_Revision1_Mar08-2007.pdf
    87  * Suite B Implementer’s Guide to NIST SP 800-56A. National Security
    88    Agency, July 28, 2009.
    89    http://www.nsa.gov/ia/_files/SuiteB_Implementer_G-113808.pdf
    90  * NIST SP 800-57: Recommendation for Key Management – Part 1: General
    91    (Revision 3). National Institute of Standards and Technology, July
    92    2012.
    93    http://csrc.nist.gov/publications/nistpubs/800-57/sp800-57_part1_rev3_general.pdf
    94