Vanetza
 
Loading...
Searching...
No Matches
signature.cpp
1#ifndef FA909143_0CE7_4397_A42B_5CDA56AB4716
2#define FA909143_0CE7_4397_A42B_5CDA56AB4716
3
4#include <vanetza/security/ecc_point.hpp>
5#include <vanetza/security/signature.hpp>
6#include <cassert>
7
8namespace vanetza
9{
10namespace security
11{
12
13EcdsaSignatureFuture::EcdsaSignatureFuture(std::shared_future<EcdsaSignature> future,
14 EcdsaSignature placeholder) :
15 m_future(future), m_placeholder(std::move(placeholder))
16{
17 if (!m_future.valid()) {
18 throw std::invalid_argument("EcdsaSignature future has to be valid");
19 }
20}
21
22const EcdsaSignature& EcdsaSignatureFuture::get() const
23{
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));
29 return signature;
30}
31
32std::size_t EcdsaSignatureFuture::size() const
33{
34 return get_length(m_placeholder.R) + m_placeholder.s.size();
35}
36
37ByteBuffer extract_signature_buffer(const SomeEcdsaSignature& sig)
38{
39 struct extraction_visitor : public boost::static_visitor<>
40 {
41 void operator()(const EcdsaSignature& sig)
42 {
43 m_buffer = convert_for_signing(sig.R);
44 m_buffer.insert(m_buffer.end(), sig.s.begin(), sig.s.end());
45 }
46
47 void operator()(const EcdsaSignatureFuture& sig_future)
48 {
49 const EcdsaSignature& sig = sig_future.get();
50 (*this)(sig);
51 }
52
53 ByteBuffer m_buffer;
54 };
55
56 extraction_visitor visitor;
57 boost::apply_visitor(visitor, sig);
58
59 return visitor.m_buffer;
60}
61
62ByteBuffer extract_signature_buffer(const Signature& sig)
63{
64 ByteBuffer buffer = sig.r;
65 buffer.insert(buffer.end(), sig.s.begin(), sig.s.end());
66 return buffer;
67}
68
69} // namespace security
70} // namespace vanetza
71
72#endif /* FA909143_0CE7_4397_A42B_5CDA56AB4716 */
STL namespace.