blob: c5e9634a6224114b7c8c17260924e024fd25a554 [file] [log] [blame]
Eric Newberry94996d62015-05-07 13:48:46 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2015, Arizona Board of Regents.
4 *
5 * This file is part of ndn-tools (Named Data Networking Essential Tools).
6 * See AUTHORS.md for complete list of ndn-tools authors and contributors.
7 *
8 * ndn-tools is free software: you can redistribute it and/or modify it under the terms
9 * of the GNU General Public License as published by the Free Software Foundation,
10 * either version 3 of the License, or (at your option) any later version.
11 *
12 * ndn-tools is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * ndn-tools, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 *
19 * @author Eric Newberry <enewberry@email.arizona.edu>
20 * @author Jerald Paul Abraham <jeraldabraham@email.arizona.edu>
21 */
22
23#ifndef NDN_TOOLS_PING_SERVER_PING_SERVER_HPP
24#define NDN_TOOLS_PING_SERVER_PING_SERVER_HPP
25
26#include "core/common.hpp"
27
28namespace ndn {
29namespace ping {
30namespace server {
31
32/**
33 * @brief options for ndnping server
34 */
35struct Options
36{
37 Name prefix; //!< prefix to register
38 time::milliseconds freshnessPeriod; //!< freshness period
39 bool shouldLimitSatisfied; //!< should limit the number of pings satisfied
40 int nMaxPings; //!< max number of pings to satisfy
41 bool shouldPrintTimestamp; //!< print timestamp when response sent
Eric Newberry62f7f712015-05-17 12:15:52 -070042 int payloadSize; //!< user specified payload size
Eric Newberry94996d62015-05-07 13:48:46 -070043};
44
45/**
46 * @brief NDN modular ping server
47 */
48class PingServer : noncopyable
49{
50public:
51 PingServer(Face& face, const Options& options);
52
53 /**
54 * Signals when Interest received
55 * @param name incoming interest name
56 */
57 signal::Signal<PingServer, Name> afterReceive;
58
59 /** @brief starts ping server
60 *
61 * If options.shouldLimitSatisfied is false, this method does not return unless there's an error.
62 * Otherwise, this method returns when options.nMaxPings Interests are processed.
63 */
64 void
65 run();
66
67 /**
68 * @brief gets the number of pings received
69 */
70 int
71 getNPings() const;
72
73private:
74 /**
75 * Called when interest received
76 * @param interest incoming interest
77 */
78 void
79 onInterest(const Interest& interest);
80
81 /**
82 * Called when prefix registration failed
83 * @param reason reason for failure
84 */
85 void
86 onRegisterFailed(const std::string& reason);
87
88private:
89 const Options& m_options;
90 Name m_name;
91 KeyChain m_keyChain;
92 int m_nPings;
93 Face& m_face;
Eric Newberry62f7f712015-05-17 12:15:52 -070094 Block m_payload;
Eric Newberry94996d62015-05-07 13:48:46 -070095};
96
97} // namespace server
98} // namespace ping
99} // namespace ndn
100
101#endif //NDN_TOOLS_PING_SERVER_PING_SERVER_HPP