1#include <vanetza/security/exception.hpp>
2#include <vanetza/security/v2/certificate.hpp>
3#include <vanetza/security/v2/length_coding.hpp>
4#include <vanetza/security/v2/signer_info.hpp>
13SignerInfoType get_type(
const SignerInfo& info)
15 struct SignerInfo_visitor :
public boost::static_visitor<SignerInfoType>
17 SignerInfoType operator()(
const std::nullptr_t)
19 return SignerInfoType::Self;
21 SignerInfoType operator()(
const HashedId8&)
23 return SignerInfoType::Certificate_Digest_With_SHA256;
27 return SignerInfoType::Certificate;
29 SignerInfoType operator()(
const std::list<Certificate>&)
31 return SignerInfoType::Certificate_Chain;
35 return SignerInfoType::Certificate_Digest_With_Other_Algorithm;
39 SignerInfo_visitor visit;
40 return boost::apply_visitor(visit, info);
45 size_t size = cert.digest.size();
46 size +=
sizeof(cert.algorithm);
50size_t get_size(
const SignerInfo& info)
52 size_t size =
sizeof(SignerInfoType);
53 struct SignerInfo_visitor :
public boost::static_visitor<size_t>
55 size_t operator()(
const std::nullptr_t&)
59 size_t operator()(
const HashedId8& id)
65 return get_size(cert);
67 size_t operator()(
const std::list<Certificate>& list)
69 size_t size = get_size(list);
70 size += length_coding_size(size);
75 return get_size(cert);
79 SignerInfo_visitor visit;
80 size += boost::apply_visitor(visit, info);
86 serialize(ar, cert.algorithm);
87 for (
auto& byte : cert.digest) {
94 struct SignerInfo_visitor :
public boost::static_visitor<>
101 void operator()(
const std::nullptr_t)
106 void operator()(
const HashedId8& id)
108 for (
auto& byte : id) {
115 serialize(m_archive, cert);
118 void operator()(
const std::list<Certificate>& list)
120 serialize(m_archive, list);
125 serialize(m_archive, cert);
130 SignerInfoType type = get_type(info);
132 SignerInfo_visitor visit(ar);
133 boost::apply_visitor(visit, info);
138 deserialize(ar, cert.algorithm);
139 for (size_t c = 0; c < 8; c++) {
140 ar >> cert.digest[c];
142 size_t size = cert.digest.size();
143 size +=
sizeof(cert.algorithm);
151 deserialize(ar, type);
152 size +=
sizeof(SignerInfoType);
154 case SignerInfoType::Certificate: {
156 size += deserialize(ar, cert);
160 case SignerInfoType::Certificate_Chain: {
161 std::list<Certificate> list;
162 size += deserialize(ar, list);
163 size += length_coding_size(size);
167 case SignerInfoType::Certificate_Digest_With_SHA256: {
169 for (size_t c = 0; c < 8; c++) {
173 size +=
sizeof(cert);
176 case SignerInfoType::Certificate_Digest_With_Other_Algorithm: {
178 size += deserialize(ar, cert);
182 case SignerInfoType::Self:
thrown when a deserialization error occurred
described in TS 103 097 v1.2.1, section 4.2.10
described in TS 103 097 v1.2.1 (2015-06), section 6.1