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>
24EcdsaSignature signature_placeholder()
26 const auto size = field_size(PublicKeyAlgorithm::ECDSA_NISTP256_With_SHA256);
28 ecdsa.s.resize(size, 0x00);
29 X_Coordinate_Only coordinate;
30 coordinate.x.resize(size, 0x00);
31 ecdsa.R = std::move(coordinate);
37StraightSignService::StraightSignService(CertificateProvider& provider, Backend& backend, SignHeaderPolicy& policy) :
38 m_certificates(provider), m_backend(backend), m_policy(policy)
42SignConfirm StraightSignService::sign(SignRequest&& request)
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);
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 };
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);
58 confirm.secured_message = std::move(secured_message);
62DeferredSignService::DeferredSignService(CertificateProvider& provider, Backend& backend, SignHeaderPolicy& policy) :
63 m_certificates(provider), m_backend(backend), m_policy(policy)
67SignConfirm DeferredSignService::sign(SignRequest&& request)
69 SecuredMessage secured_message;
70 secured_message.payload.type = PayloadType::Signed;
71 secured_message.payload.data = std::move(request.plain_message);
72 secured_message.header_fields = m_policy.prepare_header(request, m_certificates);
74 const auto& private_key = m_certificates.own_private_key();
75 static const EcdsaSignature placeholder = signature_placeholder();
76 static const size_t signature_size = get_size(placeholder);
77 static const std::list<TrailerField> trailer_fields = {
Signature { placeholder } };
79 auto future = std::async(std::launch::deferred, [
this, secured_message, private_key]() {
80 ByteBuffer data = convert_for_signing(secured_message, trailer_fields);
81 return m_backend.sign_data(private_key, data);
83 EcdsaSignatureFuture signature(future.share(), placeholder);
84 secured_message.trailer_fields.push_back(
Signature { std::move(signature) });
87 confirm.secured_message = std::move(secured_message);
91DummySignService::DummySignService(
const Runtime& runtime,
const SignerInfo& signer) :
92 m_runtime(runtime), m_signer_info(signer)
98 static const Signature null_signature { signature_placeholder() };
100 SecuredMessage secured_message;
101 secured_message.payload.type = PayloadType::Signed;
102 secured_message.payload.data = std::move(request.plain_message);
103 secured_message.header_fields.push_back(convert_time64(m_runtime.
now()));
104 secured_message.header_fields.push_back(request.its_aid);
105 secured_message.header_fields.push_back(m_signer_info);
106 secured_message.trailer_fields.push_back(null_signature);
109 confirm.secured_message = std::move(secured_message);
virtual Clock::time_point now() const =0