Vanetza
Loading...
Searching...
No Matches
secured_message.hpp
1#ifndef SECURED_MESSAGE_HPP_DCBC74AC
2#define SECURED_MESSAGE_HPP_DCBC74AC
3
4#include <vanetza/asn1/asn1c_wrapper.hpp>
5#include <vanetza/asn1/security/EtsiTs103097Data.h>
6#include <vanetza/common/archives.hpp>
7#include <vanetza/common/its_aid.hpp>
8#include <vanetza/net/packet_variant.hpp>
9#include <vanetza/security/hash_algorithm.hpp>
10#include <vanetza/security/hashed_id.hpp>
11#include <vanetza/security/signature.hpp>
12#include <vanetza/security/v3/asn1_types.hpp>
13#include <vanetza/security/v3/certificate.hpp>
14
15#include <boost/optional/optional_fwd.hpp>
16#include <boost/variant/variant_fwd.hpp>
17#include <array>
18#include <cstdint>
19#include <list>
20
21namespace vanetza
22{
23namespace security
24{
25namespace v3
26{
27
28struct SecuredMessage : public asn1::asn1c_oer_wrapper<asn1::EtsiTs103097Data>
29{
30 using Time64 = std::uint64_t;
31 using SignerIdentifier = boost::variant<const asn1::HashedId8*, const asn1::Certificate*>;
32
33 SecuredMessage();
34 static SecuredMessage with_signed_data();
35 static SecuredMessage with_signed_data_hash();
36 static SecuredMessage with_encrypted_data();
37
38 uint8_t protocol_version() const;
39 ItsAid its_aid() const;
40 PacketVariant payload() const;
41 bool is_signed() const;
42 bool is_encrypted() const;
43 boost::optional<Time64> generation_time() const;
44 boost::optional<Signature> signature() const;
45 SignerIdentifier signer_identifier() const;
46 ByteBuffer signing_payload() const;
47 HashAlgorithm hash_id() const;
48
49 void set_its_aid(ItsAid its_aid);
50 void set_generation_time(Time64 time);
51 void set_generation_location(const asn1::ThreeDLocation& location);
52 void set_payload(const ByteBuffer& payload);
53 void set_external_payload_hash(const Sha256Digest& hash);
54 void set_hash_id(HashAlgorithm);
55 void set_signature(const Signature& signature);
56 std::list<HashedId3> get_inline_p2pcd_request() const;
57 void set_inline_p2pcd_request(std::list<HashedId3> requests);
58 void add_inline_p2pcd_request(HashedId3 unkown_certificate_digest);
59 void set_signature(const SomeEcdsaSignature& signature);
60 void set_dummy_signature();
61 void set_signer_identifier_self();
62 void set_signer_identifier(const HashedId8&);
63 void set_signer_identifier(const Certificate&);
64 void set_requested_certificate(const Certificate&);
65
66 void get_aes_ccm_ciphertext(ByteBuffer& ccm_ciphertext, std::array<uint8_t, 12>& nonce) const;
67 void set_aes_ccm_ciphertext(const ByteBuffer& ccm_ciphertext, const std::array<uint8_t, 12>& nonce);
68 void set_cert_recip_info(const HashedId8& recipient_id,
69 const KeyType curve_type,
70 const std::array<uint8_t, 16>& ecies_ciphertext,
71 const std::array<uint8_t, 16>& ecies_tag,
72 const ecdsa256::PublicKey& ecies_pub_key);
73 bool check_psk_match(const std::array<uint8_t, 16>& psk) const;
74};
75
76/**
77 * \brief Calculate size of encoded secured message
78 * \param msg secured message
79 * \return number of octets needed to serialize this message
80 */
81size_t get_size(const SecuredMessage& msg);
82
83/**
84 * \brief Serialize a secured message
85 *
86 * @param ar output archive
87 * @param msg message to be serialized
88 */
89void serialize(OutputArchive& ar, const SecuredMessage& msg);
90
91/**
92 * \brief Deserialize a secured message
93 *
94 * \param ar input archive
95 * \param msg destination message object
96 * \return size of deserialized message
97 */
98size_t deserialize(InputArchive& ar, SecuredMessage& msg);
99
100ByteBuffer get_payload(const asn1::Opaque*);
101ByteBuffer get_payload(const asn1::SignedData*);
102void set_payload(asn1::Opaque* unsecured, const ByteBuffer& buffer);
103ByteBuffer convert_to_payload(vanetza::ChunkPacket packet);
104
105boost::optional<HashedId8> get_certificate_id(const SecuredMessage::SignerIdentifier&);
106
107/**
108 * Check if signer identifier contains a full certificate
109 * \param signer_identifier to check
110 * \param true if signer identifier contains a full certificate
111 */
112bool contains_certificate(const SecuredMessage::SignerIdentifier& signer_identifier);
113
114} // namespace v3
115} // namespace security
116} // namespace vanetza
117
118#endif /* SECURED_MESSAGE_HPP_DCBC74AC */
ChunckPacket is a packet consisting of several memory chunks.