blob: 29b2c05e27ffd14f9e88ca786636c8c17cf9dcb6 [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Nick Gordonc6a85222017-01-03 16:54:34 -06003 * Copyright (c) 2014-2017, The University of Memphis,
Vince Lehmanc2acdcb2015-04-29 11:14:35 -05004 * Regents of the University of California,
5 * Arizona Board of Regents.
akmhoque3d06e792014-05-27 16:23:20 -05006 *
7 * This file is part of NLSR (Named-data Link State Routing).
8 * See AUTHORS.md for complete list of NLSR authors and contributors.
9 *
10 * NLSR is free software: you can redistribute it and/or modify it under the terms
11 * of the GNU General Public License as published by the Free Software Foundation,
12 * either version 3 of the License, or (at your option) any later version.
13 *
14 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 * PURPOSE. See the GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along with
19 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
akmhoque3d06e792014-05-27 16:23:20 -050020 **/
Vince Lehmanc2acdcb2015-04-29 11:14:35 -050021
akmhoque31d1d4b2014-05-05 22:08:14 -050022#ifndef NLSR_HELLO_PROTOCOL_HPP
23#define NLSR_HELLO_PROTOCOL_HPP
24
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -060025#include "statistics.hpp"
Vince Lehmanf7eec4f2015-05-08 19:02:31 -050026#include "test-access-control.hpp"
27
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -060028#include <ndn-cxx/util/signal.hpp>
akmhoque31d1d4b2014-05-05 22:08:14 -050029#include <ndn-cxx/face.hpp>
Junxiao Shi3e5120c2016-09-10 16:58:34 +000030#include <ndn-cxx/mgmt/nfd/control-parameters.hpp>
31#include <ndn-cxx/mgmt/nfd/control-response.hpp>
akmhoque31d1d4b2014-05-05 22:08:14 -050032#include <ndn-cxx/util/scheduler.hpp>
33
34namespace nlsr {
35
36class Nlsr;
37
38class HelloProtocol
39{
akmhoque31d1d4b2014-05-05 22:08:14 -050040public:
Vince Lehman7c603292014-09-11 17:48:16 -050041 HelloProtocol(Nlsr& nlsr, ndn::Scheduler& scheduler)
akmhoque31d1d4b2014-05-05 22:08:14 -050042 : m_nlsr(nlsr)
Vince Lehman7c603292014-09-11 17:48:16 -050043 , m_scheduler(scheduler)
akmhoque31d1d4b2014-05-05 22:08:14 -050044 {
45 }
46
Nick Gordond0a7df32017-05-30 16:44:34 -050047 /*! \brief Schedules a Hello Interest event.
48 *
49 * This function serves as the Hello Interest loop, and must be
50 * explicitly called to start the Hello cycle. This is done at
51 * NLSR's initialization.
52 *
53 * \sa Nlsr::initialize
54 * \param seconds The number of seconds to wait before calling the event.
Nick G97e34942016-07-11 14:46:27 -050055 */
akmhoque31d1d4b2014-05-05 22:08:14 -050056 void
57 scheduleInterest(uint32_t seconds);
58
Nick Gordond0a7df32017-05-30 16:44:34 -050059 /*! \brief Sends a Hello Interest packet.
60 *
61 * \param interestNamePrefix The name of the router that has published the
62 * update we want. Here that should be: \<router name\>/NLSR/INFO
63 *
64 * \param seconds The lifetime of the Interest we construct, in seconds
65 *
66 * This function attempts to contact neighboring routers to
67 * determine their status (which currently is one of: ACTIVE,
68 * INACTIVE, or UNKNOWN)
Nick G97e34942016-07-11 14:46:27 -050069 */
akmhoque31d1d4b2014-05-05 22:08:14 -050070 void
71 expressInterest(const ndn::Name& interestNamePrefix, uint32_t seconds);
72
Nick Gordond0a7df32017-05-30 16:44:34 -050073 /*! \brief Sends Hello Interests to all neighbors
74 *
75 * \param seconds (ignored)
76 *
77 * This function is called as part of a schedule to regularly
78 * determine the adjacency status of neighbors. This function
79 * creates and sends a Hello Interest to each neighbor in
80 * Nlsr::m_adjacencyList. If the neighbor has not been contacted
81 * before and curerntly has no Face in NFD, this method will call a
82 * different pipeline that creates the Face first, then registers
83 * prefixes.
Nick G97e34942016-07-11 14:46:27 -050084 */
akmhoque31d1d4b2014-05-05 22:08:14 -050085 void
86 sendScheduledInterest(uint32_t seconds);
87
Nick Gordond0a7df32017-05-30 16:44:34 -050088 /*! \brief Processes a Hello Interest from a neighbor.
89 *
90 * \param name (ignored)
91 *
92 * \param interest The Interest object that we have received and need to
93 * process.
94 *
95 * Processes a Hello Interest that this router receives from one of
96 * its neighbors. If the neighbor that sent the Interest does not
97 * have a Face, NLSR will attempt to create one. Also, if the
98 * neighbor that sent the Interest was previously marked as
99 * INACTIVE, NLSR will attempt to contact it with its own Hello
100 * Interest.
Nick G97e34942016-07-11 14:46:27 -0500101 */
akmhoque31d1d4b2014-05-05 22:08:14 -0500102 void
103 processInterest(const ndn::Name& name, const ndn::Interest& interest);
104
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -0600105 ndn::util::signal::Signal<HelloProtocol, Statistics::PacketType> hpIncrementSignal;
106
akmhoque31d1d4b2014-05-05 22:08:14 -0500107private:
Nick Gordond0a7df32017-05-30 16:44:34 -0500108 /*! \brief Try to contact a neighbor via Hello protocol again
109 *
110 * This function will re-send Hello Interests a configured number
111 * of times. After that many failures, HelloProtocol will mark the neighbor as
112 * inactive and will not attempt to contact them until the next time
113 * HelloProtocol::sendScheduledInterest is called.
114 *
115 * \sa nlsr::ConfParameter::getInterestRetryNumber
116 */
akmhoque31d1d4b2014-05-05 22:08:14 -0500117 void
118 processInterestTimedOut(const ndn::Interest& interest);
119
Nick Gordond0a7df32017-05-30 16:44:34 -0500120 /*! \brief Verify signatures and validate incoming Hello data.
121 */
akmhoque31d1d4b2014-05-05 22:08:14 -0500122 void
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700123 onContent(const ndn::Interest& interest, const ndn::Data& data);
124
Vince Lehmanf7eec4f2015-05-08 19:02:31 -0500125PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Nick Gordond0a7df32017-05-30 16:44:34 -0500126
127 /*! \brief Change a neighbor's status
128 *
129 * Whenever incoming Hello data is verified and validated, change
130 * the status of this neighbor and then schedule an adjacency LSA
131 * build for us. This also resets the number of times we've failed
132 * to contact this neighbor so that we will retry later.
133 */
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700134 void
dmcoomes9f936662017-03-02 10:33:09 -0600135 onContentValidated(const std::shared_ptr<const ndn::Data>& data);
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700136
Vince Lehmanf7eec4f2015-05-08 19:02:31 -0500137private:
Nick Gordond0a7df32017-05-30 16:44:34 -0500138 /*! \brief Log that incoming data couldn't be validated, but do nothing else.
139 */
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700140 void
dmcoomes9f936662017-03-02 10:33:09 -0600141 onContentValidationFailed(const std::shared_ptr<const ndn::Data>& data,
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700142 const std::string& msg);
akmhoque31d1d4b2014-05-05 22:08:14 -0500143
Nick Gordond0a7df32017-05-30 16:44:34 -0500144 /*! \brief Treat a failed Face registration as an INACTIVE neighbor.
145 *
146 * If NLSR fails to register a Face when contacting a neighbor, it
147 * will instantly toggle that neighbor to INACTIVE. This is
148 * necessary because NLSR will put off building its own adjacency
149 * LSA until the status of each neighbor is definitively
150 * known. Without this, NLSR might have to wait many scheduled Hello
151 * intervals to finish building an adjacency LSA.
152 */
akmhoquec04e7272014-07-02 11:00:14 -0500153 void
Junxiao Shi63bd0342016-08-17 16:57:14 +0000154 onRegistrationFailure(const ndn::nfd::ControlResponse& response,
akmhoquedfe615f2014-07-27 14:12:21 -0500155 const ndn::Name& name);
akmhoquec04e7272014-07-02 11:00:14 -0500156
Nick Gordond0a7df32017-05-30 16:44:34 -0500157 /*! \brief Set up a Face for NLSR use.
158 *
159 * When NLSR receives a Hello Interest from a neighbor that it has
160 * not seen before, it may need to create a Face for that
161 * neighbor. After doing so, it will be necessary to inform NFD
162 * about the standard prefixes that NLSR needs a node to have in
163 * order to conduct normal operations. This function accomplishes
164 * that, and then sends its own Hello Interest to confirm the
165 * contact.
166 */
akmhoquec04e7272014-07-02 11:00:14 -0500167 void
168 onRegistrationSuccess(const ndn::nfd::ControlParameters& commandSuccessResult,
akmhoque102aea42014-08-04 10:22:12 -0500169 const ndn::Name& neighbor, const ndn::time::milliseconds& timeout);
akmhoquec04e7272014-07-02 11:00:14 -0500170
Nick Gordond0a7df32017-05-30 16:44:34 -0500171 /*! \brief Create a Face for an adjacency
172 * \sa HelloProtocol::onRegistrationSuccess
173 */
174 void
175 registerPrefixes(const ndn::Name& adjName, const std::string& faceUri,
176 double linkCost, const ndn::time::milliseconds& timeout);
akmhoque31d1d4b2014-05-05 22:08:14 -0500177private:
178 Nlsr& m_nlsr;
Vince Lehman7c603292014-09-11 17:48:16 -0500179 ndn::Scheduler& m_scheduler;
180
akmhoque157b0a42014-05-13 00:26:37 -0500181 static const std::string INFO_COMPONENT;
akmhoque93f1a072014-06-19 16:24:28 -0500182 static const std::string NLSR_COMPONENT;
akmhoque31d1d4b2014-05-05 22:08:14 -0500183};
184
Nick Gordonfad8e252016-08-11 14:21:38 -0500185} // namespace nlsr
akmhoque31d1d4b2014-05-05 22:08:14 -0500186
187#endif // NLSR_HELLO_PROTOCOL_HPP