blob: f7f246b027675fa3ce77447f68c0f701ad896a09 [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/*
Junxiao Shifd2d1012022-01-11 18:20:38 +00003 * Copyright (c) 2014-2022, 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
Junxiao Shia5b60cc2017-07-26 01:35:48 +000035#include <ndn-cxx/link.hpp>
Davide Pesavento65d11552019-06-09 19:15:50 -040036#include <ndn-cxx/util/scheduler.hpp>
Zhuo Lib3558892016-08-12 15:51:12 -070037
Davide Pesaventob3570c62022-02-19 19:19:00 -050038namespace ndn::peek {
Zhuo Lib3558892016-08-12 15:51:12 -070039
40/**
41 * @brief options for NdnPeek
42 */
43struct PeekOptions
44{
Junxiao Shib54aabd2018-04-16 19:36:24 +000045 // Interest construction options
Davide Pesavento65d11552019-06-09 19:15:50 -040046 Name name;
Junxiao Shib54aabd2018-04-16 19:36:24 +000047 bool canBePrefix = false;
48 bool mustBeFresh = false;
Junxiao Shifd2d1012022-01-11 18:20:38 +000049 std::vector<Name> forwardingHint;
Davide Pesavento0da1f442019-07-26 17:38:13 -040050 time::milliseconds interestLifetime = DEFAULT_INTEREST_LIFETIME;
Davide Pesavento242d5062022-03-11 16:34:23 -050051 std::optional<uint8_t> hopLimit;
Davide Pesavento96028232019-08-17 01:26:13 -040052 shared_ptr<Buffer> applicationParameters;
Junxiao Shib54aabd2018-04-16 19:36:24 +000053
Davide Pesavento0da1f442019-07-26 17:38:13 -040054 // program behavior options
Junxiao Shib54aabd2018-04-16 19:36:24 +000055 bool isVerbose = false;
Junxiao Shib54aabd2018-04-16 19:36:24 +000056 bool wantPayloadOnly = false;
Davide Pesavento242d5062022-03-11 16:34:23 -050057 std::optional<time::milliseconds> timeout;
Zhuo Lib3558892016-08-12 15:51:12 -070058};
59
Davide Pesaventob3570c62022-02-19 19:19:00 -050060class NdnPeek : noncopyable
Zhuo Lib3558892016-08-12 15:51:12 -070061{
62public:
63 NdnPeek(Face& face, const PeekOptions& options);
64
Davide Pesavento87434be2019-07-25 19:04:23 -040065 enum class Result {
66 DATA = 0,
67 UNKNOWN = 1,
68 // 2 is reserved for "malformed command line"
69 TIMEOUT = 3,
70 NACK = 4,
71 };
72
Zhuo Lib3558892016-08-12 15:51:12 -070073 /**
Davide Pesavento65d11552019-06-09 19:15:50 -040074 * @return the result of NdnPeek execution
Zhuo Lib3558892016-08-12 15:51:12 -070075 */
Davide Pesavento87434be2019-07-25 19:04:23 -040076 Result
77 getResult() const
Davide Pesavento65d11552019-06-09 19:15:50 -040078 {
Davide Pesavento87434be2019-07-25 19:04:23 -040079 return m_result;
Davide Pesavento65d11552019-06-09 19:15:50 -040080 }
Zhuo Lib3558892016-08-12 15:51:12 -070081
82 /**
83 * @brief express the Interest
84 * @note The caller must invoke face.processEvents() afterwards
85 */
86 void
87 start();
88
89private:
90 Interest
91 createInterest() const;
92
93 /**
94 * @brief called when a Data packet is received
95 */
96 void
97 onData(const Data& data);
98
99 /**
100 * @brief called when a Nack packet is received
101 */
102 void
103 onNack(const lp::Nack& nack);
104
Davide Pesavento65d11552019-06-09 19:15:50 -0400105 /**
106 * @brief called when the Interest times out
107 */
108 void
109 onTimeout();
110
Zhuo Lib3558892016-08-12 15:51:12 -0700111private:
Davide Pesavento96028232019-08-17 01:26:13 -0400112 const PeekOptions m_options;
Davide Pesavento65d11552019-06-09 19:15:50 -0400113 Face& m_face;
114 Scheduler m_scheduler;
Davide Pesaventof8d9a532021-07-03 16:04:12 -0400115 time::steady_clock::time_point m_sendTime;
Davide Pesavento65d11552019-06-09 19:15:50 -0400116 ScopedPendingInterestHandle m_pendingInterest;
117 scheduler::ScopedEventId m_timeoutEvent;
Davide Pesavento87434be2019-07-25 19:04:23 -0400118 Result m_result = Result::UNKNOWN;
Zhuo Lib3558892016-08-12 15:51:12 -0700119};
120
Davide Pesaventob3570c62022-02-19 19:19:00 -0500121} // namespace ndn::peek
Zhuo Lib3558892016-08-12 15:51:12 -0700122
123#endif // NDN_TOOLS_NDNPEEK_NDNPEEK_HPP