2916058ab44f20a7706aec96a0194517a264377c
[pingcheck] / src / host / pingscheduler.h
1 /*
2 The software in this package is distributed under the GNU General
3 Public License version 2 (with a special exception described below).
4
5 A copy of GNU General Public License (GPL) is included in this distribution,
6 in the file COPYING.GPL.
7
8 As a special exception, if other files instantiate templates or use macros
9 or inline functions from this file, or you compile this file and link it
10 with other works to produce a work based on this file, this file
11 does not by itself cause the resulting work to be covered
12 by the GNU General Public License.
13
14 However the source code for this file must still be made available
15 in accordance with section (3) of the GNU General Public License.
16
17 This exception does not invalidate any other reasons why a work based
18 on this file might be covered by the GNU General Public License.
19 */
20 #ifndef PING_SCHEDULER_H
21 #define PING_SCHEDULER_H
22
23 #include <stdint.h>
24
25 #include <string>
26 #include <vector>
27
28 #include <boost/asio.hpp>
29 #include <boost/shared_ptr.hpp>
30
31 #include "link/linkstatus.h"
32 #include "host/hoststatus.h"
33 #include "host/pingstatus.h"
34 #include "host/pinger.h"
35 #include "host/pinginterval.h"
36 #include "host/pingnumber.h"
37 #include "host/pingprotocol.h"
38 #include "dns/resolverbase.h"
39
40 typedef std::vector<PingerItem> pinger_vec;
41
42 //-----------------------------------------------------------------------------
43 // PingScheduler
44 //-----------------------------------------------------------------------------
45
46 /**
47  * @brief This class is responsible to control whether to ping a host. It
48  * schedules periodic pings to a host.
49  * Scope: one object per host.
50  */
51 class PingScheduler
52 {
53 public:
54     PingScheduler(
55             const IoServiceItem io_service,
56             const std::string &network_interface,
57             const std::string &destination_address,
58             const uint16_t destination_port,
59             const PingProtocolList &ping_protocol_list,
60             const long ping_interval_in_sec,
61             const int ping_fail_percentage_limit,
62             const int ping_congestion_percentage_limit,
63             const int ping_congestion_duration_thresh,
64             const int ping_reply_timeout,
65             LinkStatusItem link_analyzer,
66             const int first_delay,
67             const int n_parallel_pings,
68             const int parallel_ping_delay
69     );
70     ~PingScheduler();
71
72     void start_pinging();
73     void stop_pinging();
74
75 private:
76     //
77     // Methods
78     //
79
80     void ping(const boost::system::error_code &error);
81     void ping_done_handler(const PingStatus &result,
82                            const long ping_duration_us);
83     void update_ping_interval();
84     void update_ping_number();
85
86     void init_ping_protocol();
87     void update_ping_protocol();
88     void get_next_ping_protocol();
89     bool can_change_ping_protocol() const;
90
91     void prepare_next_ping();
92     void update_dns_resolver();
93
94     void ping_when_ready();
95     void delayed_ping( const boost::system::error_code &error,
96                        const boost::asio::ip::address ip,
97                        const int pinger_index );
98     void dns_resolve_callback(const bool was_success,
99                               const int recursion_count);
100     void start_resolving_ping_address();
101
102     void update_log_prefix();
103     void cancel_resolve(const bool force_cancel);
104     void clear_pingers();
105
106     //
107     // Attributes
108     //
109
110     /// The IO service object, which has the loop event
111     IoServiceItem IoService;
112     /// The network interface name
113     std::string NetworkInterfaceName;
114     /// The address to ping
115     std::string DestinationAddress;
116     /// The port to ping at destination host (same for all protocols)
117     uint16_t DestinationPort;
118     /// The list of protocols to ping and iterator over them
119     PingProtocolList Protocols;
120     PingProtocolList::const_iterator ProtocolIter;
121     /// Interval between each ping to the same host
122     PingInterval PingIntervalInSec;
123     /// number of pingers that work in parallel
124     PingNumber NPingers;
125     /// delay for very first ping to avoid lots of simultaneous pings at startup
126     int FirstDelay;
127     /// Timer to trigger the next ping
128     boost::asio::deadline_timer NextPingTimer;
129     /// Keeps track of the time when the last ping was send
130     boost::posix_time::ptime TimeSentLastPing;
131     /// time threshold for ping
132     const int PingReplyTimeout;
133     /// Object responsible to evaluate the status of the host
134     HostStatus HostAnalyzer;
135     /// The Dns resolver
136     ResolverItem Resolver;
137     /// vector of pingers
138     pinger_vec Pingers;
139     /// number of results from pingers
140     int NPingersDone;
141     /// delay (in ms) between pings to same IP
142     int ParallelPingDelay;
143     /// timers for delayed pings
144     boost::asio::deadline_timer DelayedPingTimer;
145     /// a flag whether we should ping as soon as dns is ready
146     bool WantToPing;
147     /// Prefix to log messages for quicker analysis/debugging
148     std::string LogPrefix;
149     /// Flag whether DNS resolution has failed so we have to run on outdated IPs
150     bool ContinueOnOutdatedIps;
151 };
152
153 //-----------------------------------------------------------------------------
154 // PingSchedulerItem
155 //-----------------------------------------------------------------------------
156
157 typedef boost::shared_ptr<PingScheduler> PingSchedulerItem;
158
159 //-----------------------------------------------------------------------------
160 // PingSchedulerList
161 //-----------------------------------------------------------------------------
162
163 typedef std::vector< PingSchedulerItem > PingSchedulerList;
164
165 #endif // PING_SCHEDULER_H