aboutsummaryrefslogtreecommitdiffstats
path: root/doc/kdf.txt
blob: 4ab2fd5dc318c1a818b7ecf8f3ce8effd527a812 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37

.. _key_derivation_function:

Key Derivation Functions
========================================

Key derivation functions are used to turn some amount of shared secret
material into uniform random keys suitable for use with symmetric
algorithms. An example of an input which is useful for a KDF is a
shared secret created using Diffie-Hellman key agreement.

.. cpp:class:: KDF

  .. cpp:function:: secure_vector<byte> derive_key( \
     size_t key_len, const std::vector<byte>& secret, \
     const std::string& salt = "") const

  .. cpp:function:: secure_vector<byte> derive_key( \
     size_t key_len, const std::vector<byte>& secret, \
     const std::vector<byte>& salt) const

  .. cpp:function:: secure_vector<byte> derive_key( \
     size_t key_len, const std::vector<byte>& secret, \
     const byte* salt, size_t salt_len) const

  .. cpp:function:: secure_vector<byte> derive_key( \
     size_t key_len, const byte* secret, size_t secret_len, \
     const std::string& salt) const

   All variations on the same theme. Deterministically creates a
   uniform random value from *secret* and *salt*. Typically *salt* is
   a lable or identifier, such as a session id.

You can create a :cpp:class:`KDF` using

.. cpp:function:: KDF* get_kdf(const std::string& algo_spec)