blob: 8d11bc883610dd91f3da476e8e788e3fe6ad37e4 [file] [log] [blame]
Zhuo Lib3558892016-08-12 15:51:12 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shib54aabd2018-04-16 19:36:24 +00002/*
Davide Pesavento5748e822024-01-26 18:40:22 -05003 * Copyright (c) 2014-2024, Regents of the University of California,
Zhuo Lib3558892016-08-12 15:51:12 -07004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
10 *
11 * This file is part of ndn-tools (Named Data Networking Essential Tools).
12 * See AUTHORS.md for complete list of ndn-tools authors and contributors.
13 *
14 * ndn-tools is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * ndn-tools is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * ndn-tools, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 *
25 * @author Jerald Paul Abraham <jeraldabraham@email.arizona.edu>
26 * @author Zhuo Li <zhuoli@email.arizona.edu>
Davide Pesavento96028232019-08-17 01:26:13 -040027 * @author Davide Pesavento <davidepesa@gmail.com>
Zhuo Lib3558892016-08-12 15:51:12 -070028 */
29
30#ifndef NDN_TOOLS_NDNPEEK_NDNPEEK_HPP
31#define NDN_TOOLS_NDNPEEK_NDNPEEK_HPP
32
33#include "core/common.hpp"
Davide Pesavento65d11552019-06-09 19:15:50 -040034
Davide Pesavento5748e822024-01-26 18:40:22 -050035#include <ndn-cxx/face.hpp>
Junxiao Shia5b60cc2017-07-26 01:35:48 +000036#include <ndn-cxx/link.hpp>
Davide Pesavento65d11552019-06-09 19:15:50 -040037#include <ndn-cxx/util/scheduler.hpp>
Zhuo Lib3558892016-08-12 15:51:12 -070038
Davide Pesavento5748e822024-01-26 18:40:22 -050039#include <optional>
40#include <vector>
41
Davide Pesaventob3570c62022-02-19 19:19:00 -050042namespace ndn::peek {
Zhuo Lib3558892016-08-12 15:51:12 -070043
44/**
45 * @brief options for NdnPeek
46 */
47struct PeekOptions
48{
Junxiao Shib54aabd2018-04-16 19:36:24 +000049 // Interest construction options
Davide Pesavento65d11552019-06-09 19:15:50 -040050 Name name;
Junxiao Shib54aabd2018-04-16 19:36:24 +000051 bool canBePrefix = false;
52 bool mustBeFresh = false;
Junxiao Shifd2d1012022-01-11 18:20:38 +000053 std::vector<Name> forwardingHint;
Davide Pesavento0da1f442019-07-26 17:38:13 -040054 time::milliseconds interestLifetime = DEFAULT_INTEREST_LIFETIME;
Davide Pesavento242d5062022-03-11 16:34:23 -050055 std::optional<uint8_t> hopLimit;
Davide Pesavento5748e822024-01-26 18:40:22 -050056 std::shared_ptr<Buffer> applicationParameters;
Junxiao Shib54aabd2018-04-16 19:36:24 +000057
Davide Pesavento0da1f442019-07-26 17:38:13 -040058 // program behavior options
Junxiao Shib54aabd2018-04-16 19:36:24 +000059 bool isVerbose = false;
Junxiao Shib54aabd2018-04-16 19:36:24 +000060 bool wantPayloadOnly = false;
Davide Pesavento242d5062022-03-11 16:34:23 -050061 std::optional<time::milliseconds> timeout;
Zhuo Lib3558892016-08-12 15:51:12 -070062};
63
Davide Pesaventob3570c62022-02-19 19:19:00 -050064class NdnPeek : noncopyable
Zhuo Lib3558892016-08-12 15:51:12 -070065{
66public:
67 NdnPeek(Face& face, const PeekOptions& options);
68
Davide Pesavento87434be2019-07-25 19:04:23 -040069 enum class Result {
70 DATA = 0,
71 UNKNOWN = 1,
72 // 2 is reserved for "malformed command line"
73 TIMEOUT = 3,
74 NACK = 4,
75 };
76
Zhuo Lib3558892016-08-12 15:51:12 -070077 /**
Davide Pesavento65d11552019-06-09 19:15:50 -040078 * @return the result of NdnPeek execution
Zhuo Lib3558892016-08-12 15:51:12 -070079 */
Davide Pesavento87434be2019-07-25 19:04:23 -040080 Result
81 getResult() const
Davide Pesavento65d11552019-06-09 19:15:50 -040082 {
Davide Pesavento87434be2019-07-25 19:04:23 -040083 return m_result;
Davide Pesavento65d11552019-06-09 19:15:50 -040084 }
Zhuo Lib3558892016-08-12 15:51:12 -070085
86 /**
87 * @brief express the Interest
88 * @note The caller must invoke face.processEvents() afterwards
89 */
90 void
91 start();
92
93private:
94 Interest
95 createInterest() const;
96
97 /**
98 * @brief called when a Data packet is received
99 */
100 void
101 onData(const Data& data);
102
103 /**
104 * @brief called when a Nack packet is received
105 */
106 void
107 onNack(const lp::Nack& nack);
108
Davide Pesavento65d11552019-06-09 19:15:50 -0400109 /**
110 * @brief called when the Interest times out
111 */
112 void
113 onTimeout();
114
Zhuo Lib3558892016-08-12 15:51:12 -0700115private:
Davide Pesavento96028232019-08-17 01:26:13 -0400116 const PeekOptions m_options;
Davide Pesavento65d11552019-06-09 19:15:50 -0400117 Face& m_face;
118 Scheduler m_scheduler;
Davide Pesaventof8d9a532021-07-03 16:04:12 -0400119 time::steady_clock::time_point m_sendTime;
Davide Pesavento65d11552019-06-09 19:15:50 -0400120 ScopedPendingInterestHandle m_pendingInterest;
121 scheduler::ScopedEventId m_timeoutEvent;
Davide Pesavento87434be2019-07-25 19:04:23 -0400122 Result m_result = Result::UNKNOWN;
Zhuo Lib3558892016-08-12 15:51:12 -0700123};
124
Davide Pesaventob3570c62022-02-19 19:19:00 -0500125} // namespace ndn::peek
Zhuo Lib3558892016-08-12 15:51:12 -0700126
127#endif // NDN_TOOLS_NDNPEEK_NDNPEEK_HPP