blob: bb4f6f783f6da416db2c48fe4bb55e74fa4834f7 [file] [log] [blame]
Teng Liang39465c22018-11-12 19:43:04 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/*
Davide Pesavento3db98072021-03-09 23:03:27 -05003 * Copyright (c) 2014-2021, Regents of the University of California,
Teng Liang39465c22018-11-12 19:43:04 -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 NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD 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 * NFD 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 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
26#ifndef NFD_DAEMON_FW_SELF_LEARNING_STRATEGY_HPP
27#define NFD_DAEMON_FW_SELF_LEARNING_STRATEGY_HPP
28
29#include "fw/strategy.hpp"
30
31#include <ndn-cxx/lp/prefix-announcement-header.hpp>
32
33namespace nfd {
34namespace fw {
35
Teng Liangebc20f62020-06-23 16:55:20 -070036/** \brief Self-learning forwarding strategy
Teng Liang39465c22018-11-12 19:43:04 -070037 *
38 * This strategy first broadcasts Interest to learn a single path towards data,
Teng Liangebc20f62020-06-23 16:55:20 -070039 * then unicasts subsequent Interests along the learned path.
Teng Liang39465c22018-11-12 19:43:04 -070040 *
41 * \see https://redmine.named-data.net/attachments/864/Self-learning-strategy-v1.pdf
42 */
43class SelfLearningStrategy : public Strategy
44{
45public:
46 explicit
47 SelfLearningStrategy(Forwarder& forwarder, const Name& name = getStrategyName());
48
49 static const Name&
50 getStrategyName();
51
52 /// StrategyInfo on pit::InRecord
Davide Pesavento3db98072021-03-09 23:03:27 -050053 class InRecordInfo final : public StrategyInfo
Teng Liang39465c22018-11-12 19:43:04 -070054 {
55 public:
56 static constexpr int
57 getTypeId()
58 {
59 return 1040;
60 }
61
62 public:
63 bool isNonDiscoveryInterest = false;
64 };
65
66 /// StrategyInfo on pit::OutRecord
Davide Pesavento3db98072021-03-09 23:03:27 -050067 class OutRecordInfo final : public StrategyInfo
Teng Liang39465c22018-11-12 19:43:04 -070068 {
69 public:
70 static constexpr int
71 getTypeId()
72 {
73 return 1041;
74 }
75
76 public:
77 bool isNonDiscoveryInterest = false;
78 };
79
80public: // triggers
81 void
Davide Pesavento0498ce82021-06-14 02:02:21 -040082 afterReceiveInterest(const Interest& interest, const FaceEndpoint& ingress,
Teng Liang39465c22018-11-12 19:43:04 -070083 const shared_ptr<pit::Entry>& pitEntry) override;
84
85 void
Davide Pesavento0498ce82021-06-14 02:02:21 -040086 afterReceiveData(const Data& data, const FaceEndpoint& ingress,
87 const shared_ptr<pit::Entry>& pitEntry) override;
Teng Liang39465c22018-11-12 19:43:04 -070088
89 void
Davide Pesavento0498ce82021-06-14 02:02:21 -040090 afterReceiveNack(const lp::Nack& nack, const FaceEndpoint& ingress,
Teng Liang39465c22018-11-12 19:43:04 -070091 const shared_ptr<pit::Entry>& pitEntry) override;
92
93private: // operations
Teng Liang39465c22018-11-12 19:43:04 -070094 /** \brief Send an Interest to all possible faces
95 *
96 * This function is invoked when the forwarder has no matching FIB entries for
97 * an incoming discovery Interest, which will be forwarded to faces that
98 * - do not violate the Interest scope
99 * - are non-local
100 * - are not the face from which the Interest arrived, unless the face is ad-hoc
101 */
102 void
103 broadcastInterest(const Interest& interest, const Face& inFace,
104 const shared_ptr<pit::Entry>& pitEntry);
105
106 /** \brief Send an Interest to \p nexthops
107 */
108 void
109 multicastInterest(const Interest& interest, const Face& inFace,
110 const shared_ptr<pit::Entry>& pitEntry,
111 const fib::NextHopList& nexthops);
112
113 /** \brief Find a Prefix Announcement for the Data on the RIB thread, and forward
114 * the Data with the Prefix Announcement on the main thread
115 */
116 void
117 asyncProcessData(const shared_ptr<pit::Entry>& pitEntry, const Face& inFace, const Data& data);
118
119 /** \brief Check whether a PrefixAnnouncement needs to be attached to an incoming Data
120 *
121 * The conditions that a Data packet requires a PrefixAnnouncement are
122 * - the incoming Interest was discovery and
123 * - the outgoing Interest was non-discovery and
124 * - this forwarder does not directly connect to the consumer
125 */
126 static bool
127 needPrefixAnn(const shared_ptr<pit::Entry>& pitEntry);
128
129 /** \brief Add a route using RibManager::slAnnounce on the RIB thread
130 */
131 void
132 addRoute(const shared_ptr<pit::Entry>& pitEntry, const Face& inFace,
133 const Data& data, const ndn::PrefixAnnouncement& pa);
134
135 /** \brief renew a route using RibManager::slRenew on the RIB thread
136 */
137 void
138 renewRoute(const Name& name, FaceId inFaceId, time::milliseconds maxLifetime);
139
140private:
141 static const time::milliseconds ROUTE_RENEW_LIFETIME;
142};
143
144} // namespace fw
145} // namespace nfd
146
147#endif // NFD_DAEMON_FW_SELF_LEARNING_STRATEGY_HPP