Botan 3.10.0
Crypto and TLS for C&
Botan::Roughtime::Chain Class Referencefinal

#include <roughtime.h>

Public Member Functions

void append (const Link &new_link, size_t max_chain_size)
 Chain ()=default
 Chain (std::string_view str)
const std::vector< Link > & links () const
Nonce next_nonce (const Nonce &blind) const
std::vector< Responseresponses () const
std::string to_string () const

Detailed Description

Definition at line 103 of file roughtime.h.

Constructor & Destructor Documentation

◆ Chain() [1/2]

Botan::Roughtime::Chain::Chain ( )
default

References Chain().

Referenced by Chain().

◆ Chain() [2/2]

Botan::Roughtime::Chain::Chain ( std::string_view str)
explicit

Definition at line 247 of file roughtime.cpp.

247 {
248 std::istringstream ss{std::string(str)}; // FIXME C++23 avoid copy
249 const std::string ERROR_MESSAGE = "Line does not have 4 space separated fields";
250 for(std::string s; std::getline(ss, s);) {
251 size_t start = 0;
252 size_t end = 0;
253 end = s.find(' ', start);
254 if(end == std::string::npos) {
255 throw Decoding_Error(ERROR_MESSAGE);
256 }
257 const auto publicKeyType = s.substr(start, end - start);
258 if(publicKeyType != "ed25519") {
259 throw Not_Implemented("Only ed25519 publicKeyType is implemented");
260 }
261
262 start = end + 1;
263 end = s.find(' ', start);
264 if(end == std::string::npos) {
265 throw Decoding_Error(ERROR_MESSAGE);
266 }
267 const auto serverPublicKey = Ed25519_PublicKey(base64_decode(s.substr(start, end - start)));
268
269 start = end + 1;
270 end = s.find(' ', start);
271 if(end == std::string::npos) {
272 throw Decoding_Error(ERROR_MESSAGE);
273 }
274 if((end - start) != 88) {
275 throw Decoding_Error("Nonce has invalid length");
276 }
277 const auto vec = base64_decode(s.substr(start, end - start));
278 const auto nonceOrBlind = Nonce(vector_to_array<64>(base64_decode(s.substr(start, end - start))));
279
280 start = end + 1;
281 end = s.find(' ', start);
282 if(end != std::string::npos) {
283 throw Decoding_Error(ERROR_MESSAGE);
284 }
285 const auto response = unlock(base64_decode(s.substr(start)));
286
287 m_links.push_back({response, serverPublicKey, nonceOrBlind});
288 }
289}
size_t base64_decode(uint8_t out[], const char in[], size_t input_length, size_t &input_consumed, bool final_inputs, bool ignore_ws)
Definition base64.cpp:167
std::vector< T > unlock(const secure_vector< T > &in)
Definition secmem.h:86

References Botan::base64_decode(), and Botan::unlock().

Member Function Documentation

◆ append()

void Botan::Roughtime::Chain::append ( const Link & new_link,
size_t max_chain_size )

Definition at line 309 of file roughtime.cpp.

309 {
310 if(max_chain_size <= 0) {
311 throw Invalid_Argument("Max chain size must be positive");
312 }
313
314 while(m_links.size() >= max_chain_size) {
315 if(m_links.size() == 1) {
316 auto new_link_updated = new_link;
317 new_link_updated.nonce_or_blind() =
318 nonce_from_blind(m_links[0].response(), new_link.nonce_or_blind()); //we need to convert blind to nonce
319 m_links.clear();
320 m_links.push_back(new_link_updated);
321 return;
322 }
323 if(m_links.size() >= 2) {
324 m_links[1].nonce_or_blind() =
325 nonce_from_blind(m_links[0].response(), m_links[1].nonce_or_blind()); //we need to convert blind to nonce
326 }
327 m_links.erase(m_links.begin());
328 }
329 m_links.push_back(new_link);
330}
Nonce nonce_from_blind(const std::vector< uint8_t > &previous_response, const Nonce &blind)

References Botan::Roughtime::nonce_from_blind(), and Botan::Roughtime::Link::nonce_or_blind().

◆ links()

const std::vector< Link > & Botan::Roughtime::Chain::links ( ) const
inline

Definition at line 108 of file roughtime.h.

108{ return m_links; }

◆ next_nonce()

Nonce Botan::Roughtime::Chain::next_nonce ( const Nonce & blind) const

Definition at line 305 of file roughtime.cpp.

305 {
306 return m_links.empty() ? blind : nonce_from_blind(m_links.back().response(), blind);
307}

References Botan::Roughtime::nonce_from_blind().

◆ responses()

std::vector< Response > Botan::Roughtime::Chain::responses ( ) const

Definition at line 291 of file roughtime.cpp.

291 {
292 std::vector<Response> responses;
293 for(size_t i = 0; i < m_links.size(); ++i) {
294 const auto& l = m_links[i];
295 const auto nonce = i > 0 ? nonce_from_blind(m_links[i - 1].response(), l.nonce_or_blind()) : l.nonce_or_blind();
296 const auto response = Response::from_bits(l.response(), nonce);
297 if(!response.validate(l.public_key())) {
298 throw Roughtime_Error("Invalid signature or public key");
299 }
300 responses.push_back(response);
301 }
302 return responses;
303}
std::vector< Response > responses() const
static Response from_bits(const std::vector< uint8_t > &response, const Nonce &nonce)

References Botan::Roughtime::Response::from_bits(), Botan::Roughtime::nonce_from_blind(), and responses().

Referenced by responses().

◆ to_string()

std::string Botan::Roughtime::Chain::to_string ( ) const

Definition at line 332 of file roughtime.cpp.

332 {
333 std::string s;
334 s.reserve((7 + 1 + 88 + 1 + 44 + 1 + 480) * m_links.size());
335 for(const auto& link : m_links) {
336 s += "ed25519";
337 s += ' ';
338 s += base64_encode(link.public_key().get_public_key());
339 s += ' ';
340 s += base64_encode(link.nonce_or_blind().get_nonce().data(), link.nonce_or_blind().get_nonce().size());
341 s += ' ';
342 s += base64_encode(link.response());
343 s += '\n';
344 }
345 return s;
346}
size_t base64_encode(char out[], const uint8_t in[], size_t input_length, size_t &input_consumed, bool final_inputs)
Definition base64.cpp:159

References Botan::base64_encode().


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