9#include <botan/internal/prf_tls.h> 
   11#include <botan/exceptn.h> 
   12#include <botan/mem_ops.h> 
   13#include <botan/internal/fmt.h> 
   14#include <botan/internal/stl_util.h> 
   21void TLS_12_PRF::perform_kdf(std::span<uint8_t> key,
 
   22                             std::span<const uint8_t> secret,
 
   23                             std::span<const uint8_t> salt,
 
   24                             std::span<const uint8_t> label)
 const {
 
   26      m_mac->set_key(secret);
 
   27   } 
catch(Invalid_Key_Length&) {
 
   28      throw Internal_Error(
fmt(
"The premaster secret of {} bytes is too long for TLS-PRF", secret.size()));
 
   36      A = m_mac->process(A);
 
   43      const size_t writing = std::min(h.size(), o.remaining_capacity());
 
   44      xor_buf(o.next(writing), std::span{h}.first(writing));
 
   49   return fmt(
"TLS-12-PRF({})", m_mac->name());
 
 
   53   return std::make_unique<TLS_12_PRF>(m_mac->new_object());
 
 
std::unique_ptr< KDF > new_object() const override
 
std::string name() const override
 
std::string fmt(std::string_view format, const T &... args)
 
constexpr auto concat(Rs &&... ranges)
 
constexpr void xor_buf(ranges::contiguous_output_range< uint8_t > auto &&out, ranges::contiguous_range< uint8_t > auto &&in)
 
std::vector< T, secure_allocator< T > > secure_vector