aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorlloyd <[email protected]>2013-03-27 17:16:31 +0000
committerlloyd <[email protected]>2013-03-27 17:16:31 +0000
commite2225f202e4ef4ecafc47922836f3d2c50fcc296 (patch)
tree20e1c1cdbd0acda822cdd6d3e2943168ca0290ed
parent4d69a574d050e010fdc1792ea0c8020bc1a5f55c (diff)
Basic docs for AEAD_Mode
-rw-r--r--doc/aead.rst74
-rw-r--r--doc/contents.rst1
-rw-r--r--doc/relnotes/1_11_3.rst8
3 files changed, 80 insertions, 3 deletions
diff --git a/doc/aead.rst b/doc/aead.rst
new file mode 100644
index 000000000..8f5ff8b94
--- /dev/null
+++ b/doc/aead.rst
@@ -0,0 +1,74 @@
+AEAD Modes
+========================================
+
+AEAD (Authenticated Encryption with Associated Data) modes provide
+message encryption, message authentication, and the ability to
+authenticate additional data that is not included in the ciphertext
+(such as a sequence number or header).
+
+The AEAD interface can be used directly, or as part of the filter
+system by using :cpp:class:`AEAD_Filter`.
+
+AEAD modes currently available include GCM, OCB, and EAX.
+
+.. cpp:class:: AEAD_Mode
+
+ .. cpp:function:: void set_key(const SymmetricKey& key)
+
+ Set the key
+
+ .. cpp:function:: Key_Length_Specification key_spec() const
+
+ Return the key length specification
+
+ .. cpp:function:: void set_associated_data(const byte ad[], size_t ad_len)
+
+ Set any associated data for this message. For maximum
+ portability between different modes, this must be called after
+ :cpp:func:`set_key` and before :cpp:func:`start`.
+
+ If the associated data does not change, it is not necessary to
+ call this function more than once, even across multiple calls
+ to :cpp:func:`start` and :cpp:func:`finish`.
+
+ .. cpp:function:: secure_vector<byte> start(const byte nonce[], size_t nonce_len)
+
+ Start processing a message, using *nonce* as the unique
+ per-message value.
+
+ Returns any initial data that should be emitted (such as a header).
+
+ .. cpp:function:: void update(secure_vector<byte>& buffer)
+
+ Continue processing a message. The *buffer* is an in/out
+ parameter and may be resized. In particular, some modes require
+ that all input be consumed before any output is produced; with
+ these modes, *buffer* will be returned resized to 0.
+
+ .. cpp:function:: void finish(secure_vector<byte>& buffer)
+
+ Complete processing a message with a final input of *buffer*,
+ which is treated the same as with :cpp:func:`update`. The
+ *buffer* is an in/out parameter. On input it contains any final
+ part of the message that needs to be processed. On output it
+ contains any final output.
+
+ Note that if you have the entire message in hand, calling
+ finish with the entire message (without ever calling update) is
+ both efficient and convenient.
+
+ .. cpp:function:: size_t update_granularity() const
+
+ The AEAD interface requires :cpp:func:`update` be called
+ with at least this many bytes.
+
+ .. cpp:function:: size_t final_minimum_size() const
+
+ The AEAD interface requires :cpp:func:`finish` be called
+ with at least this many bytes.
+
+ .. cpp:function:: bool valid_nonce_length(size_t nonce_len) const
+
+ Returns true if *nonce_len* is a valid nonce length for this
+ scheme. For EAX and GCM, any length nonces are allowed. OCB
+ allows any value between 8 and 15 bytes.
diff --git a/doc/contents.rst b/doc/contents.rst
index a5591d0b0..27a96de35 100644
--- a/doc/contents.rst
+++ b/doc/contents.rst
@@ -17,6 +17,7 @@ Contents
ocsp
tls
credentials_manager
+ aead
bigint
lowlevel
secmem
diff --git a/doc/relnotes/1_11_3.rst b/doc/relnotes/1_11_3.rst
index 3c1ab4c30..004cfef11 100644
--- a/doc/relnotes/1_11_3.rst
+++ b/doc/relnotes/1_11_3.rst
@@ -1,6 +1,11 @@
Version 1.11.3, Not Yet Released
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+* Add a new interface for AEAD modes (:cpp:class:`AEAD_Mode`).
+
+* Implementations of the OCB and GCM authenticated cipher modes are
+ now included.
+
* A new TLS policy mechanism
:cpp:func:`TLS::Policy::server_uses_own_ciphersuite_preferences`
controls how a server chooses a ciphersuite. Previously it always
@@ -8,9 +13,6 @@ Version 1.11.3, Not Yet Released
can allow configuring a server to choose by the client's preferences
instead.
-* Implementations of the OCB and GCM authenticated cipher modes are
- now included
-
* :cpp:class:`Keyed_Filter` now supports returning a
:cpp:class:`Key_Length_Specification` so the full details of what
keylengths are supported is now available in keyed filters.