Botan  2.7.0
Crypto and TLS for C++11
Public Member Functions | List of all members
Botan::XMSS_Signature Class Referencefinal

#include <xmss_signature.h>

Public Member Functions

secure_vector< uint8_t > bytes () const
 
const secure_vector< uint8_t > randomness () const
 
secure_vector< uint8_t > & randomness ()
 
void set_randomness (const secure_vector< uint8_t > &randomness)
 
void set_randomness (secure_vector< uint8_t > &&randomness)
 
void set_tree (const XMSS_WOTS_PublicKey::TreeSignature &tree_sig)
 
void set_tree (XMSS_WOTS_PublicKey::TreeSignature &&tree_sig)
 
void set_unused_leaf_idx (size_t idx)
 
const XMSS_WOTS_PublicKey::TreeSignaturetree () const
 
XMSS_WOTS_PublicKey::TreeSignaturetree ()
 
size_t unused_leaf_index () const
 
 XMSS_Signature (XMSS_Parameters::xmss_algorithm_t oid, const secure_vector< uint8_t > &raw_sig)
 
 XMSS_Signature (size_t leaf_idx, const secure_vector< uint8_t > &randomness, const XMSS_WOTS_PublicKey::TreeSignature &tree_sig)
 
 XMSS_Signature (size_t leaf_idx, secure_vector< uint8_t > &&randomness, XMSS_WOTS_PublicKey::TreeSignature &&tree_sig)
 

Detailed Description

Definition at line 20 of file xmss_signature.h.

Constructor & Destructor Documentation

◆ XMSS_Signature() [1/3]

Botan::XMSS_Signature::XMSS_Signature ( XMSS_Parameters::xmss_algorithm_t  oid,
const secure_vector< uint8_t > &  raw_sig 
)

Creates a signature from an XMSS signature method and a uint8_t sequence representing a raw signature.

Parameters
oidXMSS signature method
raw_sigAn XMSS signature serialized using XMSS_Signature::bytes().

Definition at line 13 of file xmss_signature.cpp.

References Botan::XMSS_WOTS_PublicKey::TreeSignature::authentication_path(), Botan::XMSS_Parameters::element_size(), Botan::XMSS_Parameters::len(), Botan::XMSS_WOTS_PublicKey::TreeSignature::ots_signature(), and Botan::XMSS_Parameters::tree_height().

15  : m_leaf_idx(0), m_randomness(0, 0x00), m_tree_sig()
16  {
17  XMSS_Parameters xmss_params(oid);
18 
19  if(raw_sig.size() != (xmss_params.len() + xmss_params.tree_height() + 1)
20  * xmss_params.element_size() + sizeof(m_leaf_idx))
21  {
22  throw Integrity_Failure("XMSS signature size invalid.");
23  }
24 
25  for(size_t i = 0; i < 8; i++)
26  { m_leaf_idx = ((m_leaf_idx << 8) | raw_sig[i]); }
27 
28  if(m_leaf_idx >= (1ull << xmss_params.tree_height()))
29  {
30  throw Integrity_Failure("XMSS signature leaf index out of bounds.");
31  }
32 
33  auto begin = raw_sig.begin() + sizeof(m_leaf_idx);
34  auto end = begin + xmss_params.element_size();
35  std::copy(begin, end, std::back_inserter(m_randomness));
36 
37  for(size_t i = 0; i < xmss_params.len(); i++)
38  {
39  begin = end;
40  end = begin + xmss_params.element_size();
41  m_tree_sig.ots_signature().push_back(secure_vector<uint8_t>(0));
42  m_tree_sig.ots_signature().back().reserve(
43  xmss_params.element_size());
44  std::copy(begin,
45  end,
46  std::back_inserter(m_tree_sig.ots_signature().back()));
47  }
48 
49  for(size_t i = 0; i < xmss_params.tree_height(); i++)
50  {
51  begin = end;
52  end = begin + xmss_params.element_size();
53  m_tree_sig.authentication_path().push_back(secure_vector<uint8_t>(0));
54  m_tree_sig.authentication_path().back().reserve(
55  xmss_params.element_size());
56  std::copy(begin,
57  end,
58  std::back_inserter(m_tree_sig.authentication_path().back()));
59  }
60  }
const wots_keysig_t & authentication_path() const
const wots_keysig_t & ots_signature() const

◆ XMSS_Signature() [2/3]

Botan::XMSS_Signature::XMSS_Signature ( size_t  leaf_idx,
const secure_vector< uint8_t > &  randomness,
const XMSS_WOTS_PublicKey::TreeSignature tree_sig 
)
inline

Creates an XMSS Signature from a leaf index used for signature generation, a random value and a tree signature.

Parameters
leaf_idxLeaf index used to generate the signature.
randomnessA random value.
tree_sigA tree signature.

Definition at line 42 of file xmss_signature.h.

45  : m_leaf_idx(leaf_idx), m_randomness(randomness),
46  m_tree_sig(tree_sig) {}
const secure_vector< uint8_t > randomness() const

◆ XMSS_Signature() [3/3]

Botan::XMSS_Signature::XMSS_Signature ( size_t  leaf_idx,
secure_vector< uint8_t > &&  randomness,
XMSS_WOTS_PublicKey::TreeSignature &&  tree_sig 
)
inline

Creates an XMSS Signature from a leaf index used for signature generation, a random value and a tree signature.

Parameters
leaf_idxLeaf index used to generate the signature.
randomnessA random value.
tree_sigA tree signature.

Definition at line 56 of file xmss_signature.h.

59  : m_leaf_idx(leaf_idx), m_randomness(std::move(randomness)),
60  m_tree_sig(std::move(tree_sig)) {}
const secure_vector< uint8_t > randomness() const

Member Function Documentation

◆ bytes()

secure_vector< uint8_t > Botan::XMSS_Signature::bytes ( ) const

Generates a serialized representation of XMSS Signature by concatenating the following elements in order: 8-byte leaf index, n-bytes randomness, ots_signature, authentication path.

n is the element_size(), len equal to len(), h the tree height defined by the chosen XMSS signature method.

Returns
serialized signature, a sequence of (len + h + 1)n bytes.

Definition at line 62 of file xmss_signature.cpp.

References Botan::XMSS_WOTS_PublicKey::TreeSignature::authentication_path(), Botan::XMSS_WOTS_PublicKey::TreeSignature::ots_signature(), and tree().

63  {
64  secure_vector<uint8_t> result
65  {
66  static_cast<uint8_t>(m_leaf_idx >> 56U),
67  static_cast<uint8_t>(m_leaf_idx >> 48U),
68  static_cast<uint8_t>(m_leaf_idx >> 40U),
69  static_cast<uint8_t>(m_leaf_idx >> 32U),
70  static_cast<uint8_t>(m_leaf_idx >> 24U),
71  static_cast<uint8_t>(m_leaf_idx >> 16U),
72  static_cast<uint8_t>(m_leaf_idx >> 8U),
73  static_cast<uint8_t>(m_leaf_idx)
74  };
75 
76  std::copy(m_randomness.begin(),
77  m_randomness.end(),
78  std::back_inserter(result));
79 
80  for(const auto& sig : tree().ots_signature())
81  {
82  std::copy(sig.begin(),
83  sig.end(),
84  std::back_inserter(result));
85  }
86 
87  for(const auto& auth : tree().authentication_path())
88  {
89  std::copy(auth.begin(),
90  auth.end(),
91  std::back_inserter(result));
92  }
93  return result;
94  }
const XMSS_WOTS_PublicKey::TreeSignature & tree() const
const wots_keysig_t & authentication_path() const
const wots_keysig_t & ots_signature() const

◆ randomness() [1/2]

const secure_vector<uint8_t> Botan::XMSS_Signature::randomness ( ) const
inline

Definition at line 65 of file xmss_signature.h.

Referenced by set_randomness().

66  {
67  return m_randomness;
68  }

◆ randomness() [2/2]

secure_vector<uint8_t>& Botan::XMSS_Signature::randomness ( )
inline

Definition at line 70 of file xmss_signature.h.

71  {
72  return m_randomness;
73  }

◆ set_randomness() [1/2]

void Botan::XMSS_Signature::set_randomness ( const secure_vector< uint8_t > &  randomness)
inline

Definition at line 75 of file xmss_signature.h.

References randomness().

76  {
77  m_randomness = randomness;
78  }
const secure_vector< uint8_t > randomness() const

◆ set_randomness() [2/2]

void Botan::XMSS_Signature::set_randomness ( secure_vector< uint8_t > &&  randomness)
inline

Definition at line 80 of file xmss_signature.h.

References randomness().

81  {
82  m_randomness = std::move(randomness);
83  }
const secure_vector< uint8_t > randomness() const

◆ set_tree() [1/2]

void Botan::XMSS_Signature::set_tree ( const XMSS_WOTS_PublicKey::TreeSignature tree_sig)
inline

Definition at line 95 of file xmss_signature.h.

96  {
97  m_tree_sig = tree_sig;
98  }

◆ set_tree() [2/2]

void Botan::XMSS_Signature::set_tree ( XMSS_WOTS_PublicKey::TreeSignature &&  tree_sig)
inline

Definition at line 100 of file xmss_signature.h.

101  {
102  m_tree_sig = std::move(tree_sig);
103  }

◆ set_unused_leaf_idx()

void Botan::XMSS_Signature::set_unused_leaf_idx ( size_t  idx)
inline

Definition at line 63 of file xmss_signature.h.

63 { m_leaf_idx = idx; }

◆ tree() [1/2]

const XMSS_WOTS_PublicKey::TreeSignature& Botan::XMSS_Signature::tree ( ) const
inline

Definition at line 85 of file xmss_signature.h.

Referenced by bytes().

86  {
87  return m_tree_sig;
88  }

◆ tree() [2/2]

XMSS_WOTS_PublicKey::TreeSignature& Botan::XMSS_Signature::tree ( )
inline

Definition at line 90 of file xmss_signature.h.

91  {
92  return m_tree_sig;
93  }

◆ unused_leaf_index()

size_t Botan::XMSS_Signature::unused_leaf_index ( ) const
inline

Definition at line 62 of file xmss_signature.h.

62 { return m_leaf_idx; }

The documentation for this class was generated from the following files: