blob: 0289da2be26e53a35fb5a27db5907614e54cfaff [file] [log] [blame]
Eric Newberry94996d62015-05-07 13:48:46 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento5923bf82018-08-09 01:55:44 -04002/*
Junxiao Shi869d73e2023-08-10 22:52:26 +00003 * Copyright (c) 2015-2023, Arizona Board of Regents.
Eric Newberry94996d62015-05-07 13:48:46 -07004 *
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
Davide Pesaventoa0e6b602021-01-21 19:47:04 -050028#include <ndn-cxx/util/signal.hpp>
29
Davide Pesaventob3570c62022-02-19 19:19:00 -050030namespace ndn::ping::server {
Eric Newberry94996d62015-05-07 13:48:46 -070031
32/**
Davide Pesavento5923bf82018-08-09 01:55:44 -040033 * @brief Options for PingServer
Eric Newberry94996d62015-05-07 13:48:46 -070034 */
35struct Options
36{
Davide Pesavento5923bf82018-08-09 01:55:44 -040037 Name prefix; //!< prefix to register
38 time::milliseconds freshnessPeriod = 1_s; //!< data freshness period
39 size_t nMaxPings = 0; //!< max number of pings to satisfy (0 == no limit)
40 size_t payloadSize = 0; //!< response payload size (0 == no payload)
41 bool wantTimestamp = false; //!< print timestamp when response sent
Davide Pesavento2bdda1d2018-08-09 19:35:49 -040042 bool wantQuiet = false; //!< suppress printing per-packet log message
Eric Newberry94996d62015-05-07 13:48:46 -070043};
44
45/**
46 * @brief NDN modular ping server
47 */
48class PingServer : noncopyable
49{
50public:
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070051 PingServer(Face& face, KeyChain& keyChain, const Options& options);
Eric Newberry94996d62015-05-07 13:48:46 -070052
53 /**
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070054 * @brief Signals when Interest received
55 *
Eric Newberry94996d62015-05-07 13:48:46 -070056 * @param name incoming interest name
57 */
Junxiao Shi869d73e2023-08-10 22:52:26 +000058 signal::Signal<PingServer, Name> afterReceive;
Eric Newberry94996d62015-05-07 13:48:46 -070059
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070060 /**
61 * @brief Signals when finished pinging
62 */
Junxiao Shi869d73e2023-08-10 22:52:26 +000063 signal::Signal<PingServer> afterFinish;
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070064
Eric Newberry94996d62015-05-07 13:48:46 -070065 /** @brief starts ping server
66 *
67 * If options.shouldLimitSatisfied is false, this method does not return unless there's an error.
68 * Otherwise, this method returns when options.nMaxPings Interests are processed.
69 */
70 void
71 run();
72
73 /**
Eric Newberrya93680e2015-07-15 19:25:29 -070074 * @brief starts the Interest filter
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070075 *
76 * @note This method is non-blocking and caller need to call face.processEvents()
Eric Newberrya93680e2015-07-15 19:25:29 -070077 */
78 void
79 start();
80
81 /**
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070082 * @brief Unregister set interest filter
83 */
84 void
85 stop();
86
87 /**
Eric Newberry94996d62015-05-07 13:48:46 -070088 * @brief gets the number of pings received
89 */
Davide Pesavento5923bf82018-08-09 01:55:44 -040090 size_t
Eric Newberry94996d62015-05-07 13:48:46 -070091 getNPings() const;
92
93private:
94 /**
Alexander Afanasyev1e7a7b22015-08-26 15:35:26 -070095 * @brief Called when interest received
96 *
Eric Newberry94996d62015-05-07 13:48:46 -070097 * @param interest incoming interest
98 */
99 void
100 onInterest(const Interest& interest);
101
Eric Newberry94996d62015-05-07 13:48:46 -0700102private:
103 const Options& m_options;
Eric Newberry94996d62015-05-07 13:48:46 -0700104 Face& m_face;
Davide Pesavento5923bf82018-08-09 01:55:44 -0400105 KeyChain& m_keyChain;
Davide Pesaventob3570c62022-02-19 19:19:00 -0500106 size_t m_nPings = 0;
Eric Newberry62f7f712015-05-17 12:15:52 -0700107 Block m_payload;
Junxiao Shi06d008c2019-02-04 08:26:59 +0000108 RegisteredPrefixHandle m_registeredPrefix;
Eric Newberry94996d62015-05-07 13:48:46 -0700109};
110
Davide Pesaventob3570c62022-02-19 19:19:00 -0500111} // namespace ndn::ping::server
Eric Newberry94996d62015-05-07 13:48:46 -0700112
Davide Pesavento5923bf82018-08-09 01:55:44 -0400113#endif // NDN_TOOLS_PING_SERVER_PING_SERVER_HPP