Vanetza
 
Loading...
Searching...
No Matches
data_request.cpp
1#include "data_request.hpp"
2#include <vanetza/btp/data_request.hpp>
3#include <vanetza/units/time.hpp>
4#include <boost/units/cmath.hpp>
5#include <stdexcept>
6
7namespace vanetza
8{
9namespace geonet
10{
11
12void decrement_by_one(DataRequest::Repetition& repetition)
13{
14 const auto zero = 0.0 * units::si::seconds;
15 if (repetition.maximum > zero && repetition.interval > zero
16 && repetition.maximum > repetition.interval) {
17 repetition.maximum = repetition.maximum - repetition.interval;
18
19 } else {
20 repetition.maximum = zero;
21 }
22}
23
24bool has_further_repetition(const DataRequest& request)
25{
26 bool repeat = false;
27 if (request.repetition) {
28 repeat = has_further_repetition(request.repetition.get());
29 }
30 return repeat;
31}
32
33bool has_further_repetition(const DataRequest::Repetition& repetition)
34{
35 const auto zero = 0.0 * units::si::seconds;
36 return repetition.maximum > zero && repetition.interval > zero &&
37 repetition.maximum >= repetition.interval;
38}
39
40struct access_request_visitor : public boost::static_visitor<DataRequest&>
41{
42 template<typename REQUEST>
43 DataRequest& operator()(REQUEST& request)
44 {
45 return request;
46 }
47};
48
49DataRequest& access_request(DataRequestVariant& variant)
50{
51 access_request_visitor visitor;
52 return boost::apply_visitor(visitor, variant);
53}
54
55void copy_request_parameters(const btp::DataRequestB& btp, DataRequest& gn)
56{
57 gn.upper_protocol = geonet::UpperProtocol::BTP_B;
58 gn.communication_profile = btp.gn.communication_profile;
59 gn.its_aid = btp.gn.its_aid;
60 if (btp.gn.maximum_lifetime) {
61 gn.maximum_lifetime = *btp.gn.maximum_lifetime;
62 }
63 gn.repetition = btp.gn.repetition;
64 if (btp.gn.maximum_hop_limit) {
65 gn.max_hop_limit = *btp.gn.maximum_hop_limit;
66 }
67 gn.traffic_class = btp.gn.traffic_class;
68}
69
70void copy_request_parameters(const btp::DataRequestB& btp, DataRequestWithAddress& gn)
71{
72 copy_request_parameters(btp, static_cast<DataRequest&>(gn));
73 const Address* address = boost::get<Address>(&btp.gn.destination);
74 if (address) {
75 gn.destination = *address;
76 } else {
77 throw std::runtime_error("BTP-B data request lacks destination address");
78 }
79}
80
81void copy_request_parameters(const btp::DataRequestB& btp, DataRequestWithArea& gn)
82{
83 copy_request_parameters(btp, static_cast<DataRequest&>(gn));
84 const Area* area = boost::get<Area>(&btp.gn.destination);
85 if (area) {
86 gn.destination = *area;
87 } else {
88 throw std::runtime_error("BTP-B data request lacks destination area");
89 }
90}
91
92} // namespace geonet
93} // namespace vanetza