1#ifndef SIGN_HEADER_POLICY_HPP_KJIIEGCH
2#define SIGN_HEADER_POLICY_HPP_KJIIEGCH
4#include <vanetza/common/clock.hpp>
5#include <vanetza/common/runtime.hpp>
6#include <vanetza/security/hashed_id.hpp>
7#include <vanetza/security/v2/header_field.hpp>
20class CertificateProvider;
27
28
29
30
31
36
37
38
39
40
41
45
46
47
51
52
56
57
60 virtual ~SignHeaderPolicy() =
default;
64
65
79 Clock::time_point m_cam_next_certificate;
80 std::set<HashedId3> m_unknown_certificates;
81 bool m_cert_requested;
82 bool m_chain_requested;
virtual const PositionFix & position_fix()=0
virtual Clock::time_point now() const =0
static CertificateValidity valid()
Create CertificateValidity signalling a valid certificate This method is equivalent to default constr...
CertificateInvalidReason reason() const
Get reason for certificate invalidity This call is only safe if reason is available,...
void insert(const Certificate &certificate)
std::list< Certificate > lookup(const HashedId8 &id, SubjectType type)
virtual const ecdsa256::PrivateKey & own_private_key()=0
virtual const Certificate & own_certificate()=0
virtual std::list< Certificate > own_chain()=0
virtual CertificateValidity check_certificate(const Certificate &certificate)=0
IntX specified in TS 103 097 v1.2.1, section 4.2.1.
bool is_known(const HashedId8 &digest) const
bool announce(const HashedId8 &digest)
void store(Certificate cert)
virtual CertificateCache & cache()=0
virtual Verdict valid_for_signing(const CertificateView &certificate, ItsAid app)=0
described in TS 103 097 v1.2.1 (2015-06), section 6.1
SecuredMessage as specified in TS 103 097 v1.2.1, section 5.1.
const TrailerField * trailer_field(TrailerFieldType type) const