Vanetza
Loading...
Searching...
No Matches
sign_service.cpp
1#include <vanetza/common/its_aid.hpp>
2#include <vanetza/common/runtime.hpp>
3#include <vanetza/security/backend.hpp>
4#include <vanetza/security/v2/certificate_provider.hpp>
5#include <vanetza/security/v2/sign_header_policy.hpp>
6#include <vanetza/security/v2/sign_service.hpp>
7#include <vanetza/security/v2/signature.hpp>
8#include <future>
9
10namespace vanetza
11{
12namespace security
13{
14namespace v2
15{
16
17namespace
18{
19
20/**
21 * \brief signature used as placeholder until final signature is calculated
22 * \return placeholder containing dummy data
23 */
24EcdsaSignature signature_placeholder()
25{
26 const auto size = field_size(PublicKeyAlgorithm::ECDSA_NISTP256_With_SHA256);
27 EcdsaSignature ecdsa;
28 ecdsa.s.resize(size, 0x00);
29 X_Coordinate_Only coordinate;
30 coordinate.x.resize(size, 0x00);
31 ecdsa.R = std::move(coordinate);
32 return ecdsa;
33}
34
35} // namespace
36
37StraightSignService::StraightSignService(CertificateProvider& provider, Backend& backend, SignHeaderPolicy& policy) :
38 m_certificates(provider), m_backend(backend), m_policy(policy)
39{
40}
41
43{
44 SecuredMessage secured_message;
45 secured_message.payload.type = PayloadType::Signed;
46 secured_message.payload.data = std::move(request.plain_message);
47 secured_message.header_fields = m_policy.prepare_header(request, m_certificates);
48
49 const auto& private_key = m_certificates.own_private_key();
50 static const Signature placeholder = signature_placeholder();
51 static const std::list<TrailerField> trailer_fields = { placeholder };
52
53 ByteBuffer data_buffer = convert_for_signing(secured_message, trailer_fields);
54 TrailerField trailer_field = m_backend.sign_data(private_key, data_buffer);
55 secured_message.trailer_fields.push_back(trailer_field);
56
57 return SignConfirm::success(std::move(secured_message));
58}
59
60DeferredSignService::DeferredSignService(CertificateProvider& provider, Backend& backend, SignHeaderPolicy& policy) :
61 m_certificates(provider), m_backend(backend), m_policy(policy)
62{
63}
64
66{
67 SecuredMessage secured_message;
68 secured_message.payload.type = PayloadType::Signed;
69 secured_message.payload.data = std::move(request.plain_message);
70 secured_message.header_fields = m_policy.prepare_header(request, m_certificates);
71
72 const auto& private_key = m_certificates.own_private_key();
73 static const EcdsaSignature placeholder = signature_placeholder();
74 static const std::list<TrailerField> trailer_fields = { Signature { placeholder } };
75
76 auto future = std::async(std::launch::deferred, [this, secured_message, private_key]() {
77 ByteBuffer data = convert_for_signing(secured_message, trailer_fields);
78 return m_backend.sign_data(private_key, data);
79 });
80 EcdsaSignatureFuture signature(future.share(), placeholder);
81 secured_message.trailer_fields.push_back(Signature { std::move(signature) });
82
83 return SignConfirm::success(std::move(secured_message));
84}
85
86DummySignService::DummySignService(const Runtime& runtime, const SignerInfo& signer) :
87 m_runtime(runtime), m_signer_info(signer)
88{
89}
90
92{
93 static const Signature null_signature { signature_placeholder() };
94
95 SecuredMessage secured_message;
96 secured_message.payload.type = PayloadType::Signed;
97 secured_message.payload.data = std::move(request.plain_message);
98 secured_message.header_fields.push_back(convert_time64(m_runtime.now()));
99 secured_message.header_fields.push_back(request.its_aid);
100 secured_message.header_fields.push_back(m_signer_info);
101 secured_message.trailer_fields.push_back(null_signature);
102
103 return SignConfirm::success(std::move(secured_message));
104}
105
106} // namespace v2
107} // namespace security
108} // namespace vanetza
virtual Clock::time_point now() const =0
virtual const ecdsa256::PrivateKey & own_private_key()=0
DummySignService(const Runtime &rt, const SignerInfo &si)
EcdsaSignature specified in TS 103 097 v1.2.1, section 4.2.9.
Definition signature.hpp:17
X_Coordinate_Only specified in TS 103 097 v1.2.1 in section 4.2.5.
Definition ecc_point.hpp:18
SecuredMessage as specified in TS 103 097 v1.2.1, section 5.1.