1#ifndef FA909143_0CE7_4397_A42B_5CDA56AB4716
2#define FA909143_0CE7_4397_A42B_5CDA56AB4716
4#include <vanetza/security/ecc_point.hpp>
5#include <vanetza/security/signature.hpp>
13EcdsaSignatureFuture::EcdsaSignatureFuture(std::shared_future<EcdsaSignature> future,
14 EcdsaSignature placeholder) :
15 m_future(future), m_placeholder(
std::move(placeholder))
17 if (!m_future.valid()) {
18 throw std::invalid_argument(
"EcdsaSignature future has to be valid");
22const EcdsaSignature& EcdsaSignatureFuture::get()
const
24 assert(m_future.valid());
25 const EcdsaSignature& signature = m_future.get();
26 assert(signature.s.size() == m_placeholder.s.size());
27 assert(signature.R.which() == m_placeholder.R.which());
28 assert(get_length(signature.R) == get_length(m_placeholder.R));
32std::size_t EcdsaSignatureFuture::size()
const
34 return get_length(m_placeholder.R) + m_placeholder.s.size();
37ByteBuffer extract_signature_buffer(
const SomeEcdsaSignature& sig)
39 struct extraction_visitor :
public boost::static_visitor<>
41 void operator()(
const EcdsaSignature& sig)
43 m_buffer = convert_for_signing(sig.R);
44 m_buffer.insert(m_buffer.end(), sig.s.begin(), sig.s.end());
47 void operator()(
const EcdsaSignatureFuture& sig_future)
49 const EcdsaSignature& sig = sig_future.get();
56 extraction_visitor visitor;
57 boost::apply_visitor(visitor, sig);
59 return visitor.m_buffer;
62ByteBuffer extract_signature_buffer(
const Signature& sig)
64 ByteBuffer buffer = sig.r;
65 buffer.insert(buffer.end(), sig.s.begin(), sig.s.end());