blob: dee7ce26c990ffa9d5e57ce8690799d6eac8d611 [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesaventoaf7a2112019-03-19 14:55:20 -04002/*
Saurab Dulal427e0122019-11-28 11:58:02 -06003 * Copyright (c) 2014-2020, The University of Memphis,
Vince Lehmanc2e51f62015-01-20 15:03:11 -06004 * 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 **/
Ashlesh Gawande5bf83172014-09-19 12:38:17 -050021
akmhoque53353462014-04-22 08:43:45 -050022#ifndef NLSR_LSDB_HPP
23#define NLSR_LSDB_HPP
24
Vince Lehman50df6b72015-03-03 12:06:40 -060025#include "conf-parameter.hpp"
akmhoque53353462014-04-22 08:43:45 -050026#include "lsa.hpp"
Ashlesh Gawande3e105a02017-05-16 17:36:56 -050027#include "sequencing-manager.hpp"
Ashlesh Gawande5bf83172014-09-19 12:38:17 -050028#include "test-access-control.hpp"
Ashlesh Gawande3e105a02017-05-16 17:36:56 -050029#include "communication/sync-logic-handler.hpp"
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -060030#include "statistics.hpp"
Ashlesh Gawande85998a12017-12-07 22:22:13 -060031#include "route/name-prefix-table.hpp"
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -060032
33#include <ndn-cxx/security/key-chain.hpp>
34#include <ndn-cxx/util/signal.hpp>
35#include <ndn-cxx/util/time.hpp>
Ashlesh Gawande744e4812018-08-22 16:26:24 -050036#include <ndn-cxx/util/segment-fetcher.hpp>
Ashlesh Gawande15052402018-12-12 20:20:00 -060037#include <ndn-cxx/ims/in-memory-storage-persistent.hpp>
Ashlesh Gawande744e4812018-08-22 16:26:24 -050038
Ashlesh Gawande939b6f82018-12-09 16:51:09 -060039#include <PSync/segment-publisher.hpp>
40
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -060041#include <utility>
42#include <boost/cstdint.hpp>
akmhoque53353462014-04-22 08:43:45 -050043
Nick Gordone98480b2017-05-24 11:23:03 -050044namespace nlsr {
Alexander Afanasyev411ee4b2014-08-16 23:17:03 -070045
akmhoque53353462014-04-22 08:43:45 -050046class Lsdb
47{
48public:
Saurab Dulal427e0122019-11-28 11:58:02 -060049 Lsdb(ndn::Face& face, ndn::KeyChain& keyChain, ConfParameter& confParam,
Ashlesh Gawande85998a12017-12-07 22:22:13 -060050 NamePrefixTable& namePrefixTable, RoutingTable& routingTable);
Ashlesh Gawande3e105a02017-05-16 17:36:56 -050051
Ashlesh Gawande744e4812018-08-22 16:26:24 -050052 ~Lsdb();
53
akmhoque53353462014-04-22 08:43:45 -050054 bool
Nick Gordon727d4832017-10-13 18:04:25 -050055 isLsaNew(const ndn::Name& routerName, const Lsa::Type& lsaType, const uint64_t& sequenceNumber);
akmhoque53353462014-04-22 08:43:45 -050056
Nick Gordon8f23b5d2017-08-31 17:53:07 -050057 bool
Nick Gordon727d4832017-10-13 18:04:25 -050058 doesLsaExist(const ndn::Name& key, const Lsa::Type& lsType);
Nick G97e34942016-07-11 14:46:27 -050059
60 /*! \brief Builds a name LSA for this router and then installs it
61 into the LSDB.
62 */
akmhoque53353462014-04-22 08:43:45 -050063 bool
akmhoque31d1d4b2014-05-05 22:08:14 -050064 buildAndInstallOwnNameLsa();
akmhoque53353462014-04-22 08:43:45 -050065
Nick G97e34942016-07-11 14:46:27 -050066 /*! \brief Returns the name LSA with the given key.
67 \param key The name of the router that the desired LSA comes from.
68 */
akmhoqueb6450b12014-04-24 00:01:03 -050069 NameLsa*
akmhoque31d1d4b2014-05-05 22:08:14 -050070 findNameLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -050071
Nick G97e34942016-07-11 14:46:27 -050072 /*! \brief Installs a name LSA into the LSDB
73 \param nlsa The name LSA to install into the LSDB.
74 */
akmhoque53353462014-04-22 08:43:45 -050075 bool
akmhoque31d1d4b2014-05-05 22:08:14 -050076 installNameLsa(NameLsa& nlsa);
akmhoque53353462014-04-22 08:43:45 -050077
Nick G97e34942016-07-11 14:46:27 -050078 /*! \brief Remove a name LSA from the LSDB.
79 \param key The name of the router that published the LSA to remove.
80
81 This function will remove a name LSA from the LSDB by finding an
82 LSA whose name matches key. This removal also causes the NPT to
83 remove those name prefixes if no more LSAs advertise them.
84 */
akmhoque53353462014-04-22 08:43:45 -050085 bool
akmhoque31d1d4b2014-05-05 22:08:14 -050086 removeNameLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -050087
Nick G97e34942016-07-11 14:46:27 -050088 /*! Returns whether a seq. no. from a certain router signals a new LSA.
89 \param key The name of the originating router.
90 \param seqNo The sequence number to check.
91 */
akmhoque53353462014-04-22 08:43:45 -050092 bool
akmhoque31d1d4b2014-05-05 22:08:14 -050093 isNameLsaNew(const ndn::Name& key, uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -050094
95 void
akmhoque2f423352014-06-03 11:49:35 -050096 writeNameLsdbLog();
akmhoque53353462014-04-22 08:43:45 -050097
Jiewen Tana0497d82015-02-02 21:59:18 -080098 const std::list<NameLsa>&
Nick Gordon114537f2017-08-09 14:51:37 -050099 getNameLsdb() const;
Jiewen Tana0497d82015-02-02 21:59:18 -0800100
Nick G97e34942016-07-11 14:46:27 -0500101 /*! \brief Builds a cor. LSA for this router and installs it into the LSDB. */
akmhoque53353462014-04-22 08:43:45 -0500102 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500103 buildAndInstallOwnCoordinateLsa();
akmhoque53353462014-04-22 08:43:45 -0500104
Nick G97e34942016-07-11 14:46:27 -0500105 /*! \brief Finds a cor. LSA in the LSDB.
106 \param key The name of the originating router that published the LSA.
107 */
akmhoqueb6450b12014-04-24 00:01:03 -0500108 CoordinateLsa*
akmhoque31d1d4b2014-05-05 22:08:14 -0500109 findCoordinateLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500110
Nick G97e34942016-07-11 14:46:27 -0500111 /*! \brief Installs a cor. LSA into the LSDB.
112 \param clsa The cor. LSA to install.
113 */
akmhoque53353462014-04-22 08:43:45 -0500114 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500115 installCoordinateLsa(CoordinateLsa& clsa);
akmhoque53353462014-04-22 08:43:45 -0500116
Nick G97e34942016-07-11 14:46:27 -0500117 /*! \brief Removes a cor. LSA from the LSDB.
118 \param key The name of the router that published the LSA to remove.
119
120 Removes the coordinate LSA whose origin router name matches that
121 given by key. Additionally, ask the NPT to remove the prefix,
122 which will occur if no other LSAs point there.
123 */
akmhoque53353462014-04-22 08:43:45 -0500124 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500125 removeCoordinateLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500126
Nick G97e34942016-07-11 14:46:27 -0500127 /*! \brief Returns whether a cor. LSA from a router is new or not.
128 \param key The name prefix of the originating router.
129 \param seqNo The sequence number of the candidate LSA.
130 */
akmhoque53353462014-04-22 08:43:45 -0500131 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500132 isCoordinateLsaNew(const ndn::Name& key, uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -0500133
134 void
akmhoque2f423352014-06-03 11:49:35 -0500135 writeCorLsdbLog();
akmhoque53353462014-04-22 08:43:45 -0500136
Jiewen Tana0497d82015-02-02 21:59:18 -0800137 const std::list<CoordinateLsa>&
Nick Gordon114537f2017-08-09 14:51:37 -0500138 getCoordinateLsdb() const;
Jiewen Tana0497d82015-02-02 21:59:18 -0800139
Nick G97e34942016-07-11 14:46:27 -0500140 //function related to Adj LSDB
141
142 /*! \brief Schedules a build of this router's LSA. */
akmhoque53353462014-04-22 08:43:45 -0500143 void
Vince Lehman50df6b72015-03-03 12:06:40 -0600144 scheduleAdjLsaBuild();
akmhoque53353462014-04-22 08:43:45 -0500145
Nick G97e34942016-07-11 14:46:27 -0500146 /*! \brief Wrapper event to build and install an adj. LSA for this router. */
akmhoque53353462014-04-22 08:43:45 -0500147 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500148 buildAndInstallOwnAdjLsa();
akmhoque53353462014-04-22 08:43:45 -0500149
Nick G97e34942016-07-11 14:46:27 -0500150 /*! \brief Removes an adj. LSA from the LSDB.
151 \param key The name of the publishing router whose LSA to remove.
152 */
akmhoque53353462014-04-22 08:43:45 -0500153 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500154 removeAdjLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500155
Nick G97e34942016-07-11 14:46:27 -0500156 /*! \brief Returns whether an LSA is new.
157 \param key The name of the publishing router.
158 \param seqNo The seq. no. of the candidate LSA.
159
160 This function determines whether the LSA with the name key and
161 seq. no. seqNo would be new to this LSDB.
162 */
akmhoque53353462014-04-22 08:43:45 -0500163 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500164 isAdjLsaNew(const ndn::Name& key, uint64_t seqNo);
Jiewen Tana0497d82015-02-02 21:59:18 -0800165
Nick G97e34942016-07-11 14:46:27 -0500166 /*! \brief Installs an adj. LSA into the LSDB.
167 \param alsa The adj. LSA to add to the LSDB.
168 */
akmhoque53353462014-04-22 08:43:45 -0500169 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500170 installAdjLsa(AdjLsa& alsa);
akmhoque53353462014-04-22 08:43:45 -0500171
Nick G97e34942016-07-11 14:46:27 -0500172 /*! \brief Finds an adj. LSA in the LSDB.
173 \param key The name of the publishing router whose LSA to find.
174 */
akmhoqueb6450b12014-04-24 00:01:03 -0500175 AdjLsa*
akmhoque31d1d4b2014-05-05 22:08:14 -0500176 findAdjLsa(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500177
Jiewen Tana0497d82015-02-02 21:59:18 -0800178 const std::list<AdjLsa>&
Nick Gordon114537f2017-08-09 14:51:37 -0500179 getAdjLsdb() const;
akmhoque53353462014-04-22 08:43:45 -0500180
181 void
Vince Lehman50df6b72015-03-03 12:06:40 -0600182 setAdjLsaBuildInterval(uint32_t interval)
183 {
184 m_adjLsaBuildInterval = ndn::time::seconds(interval);
185 }
186
Vince Lehman50df6b72015-03-03 12:06:40 -0600187 void
akmhoque2f423352014-06-03 11:49:35 -0500188 writeAdjLsdbLog();
akmhoque53353462014-04-22 08:43:45 -0500189
akmhoque53353462014-04-22 08:43:45 -0500190 void
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500191 expressInterest(const ndn::Name& interestName, uint32_t timeoutCount,
Nick Gordone98480b2017-05-24 11:23:03 -0500192 ndn::time::steady_clock::TimePoint deadline = DEFAULT_LSA_RETRIEVAL_DEADLINE);
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500193
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600194 /* \brief Process interest which can be either:
195 * 1) Discovery interest from segment fetcher:
196 * /localhop/<network>/nlsr/LSA/<site>/<router>/<lsaType>/<seqNo>
197 * 2) Interest containing segment number:
198 * /localhop/<network>/nlsr/LSA/<site>/<router>/<lsaType>/<seqNo>/<version>/<segmentNo>
199 */
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500200 void
201 processInterest(const ndn::Name& name, const ndn::Interest& interest);
202
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600203 bool
204 getIsBuildAdjLsaSheduled()
205 {
206 return m_isBuildAdjLsaSheduled;
207 }
208
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500209 SyncLogicHandler&
Ashlesh Gawande08bce9c2019-04-05 11:08:07 -0500210 getSync() {
211 return m_sync;
212 }
213
akmhoque53353462014-04-22 08:43:45 -0500214private:
Nick G97e34942016-07-11 14:46:27 -0500215 /* \brief Add a name LSA to the LSDB if it isn't already there.
216 \param nlsa The candidade name LSA.
217 */
akmhoque53353462014-04-22 08:43:45 -0500218 bool
219 addNameLsa(NameLsa& nlsa);
220
Nick G97e34942016-07-11 14:46:27 -0500221 /*! \brief Returns whether the LSDB contains some LSA.
222 \param key The name of the publishing router whose LSA to check for.
223 */
akmhoque53353462014-04-22 08:43:45 -0500224 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500225 doesNameLsaExist(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500226
Nick G97e34942016-07-11 14:46:27 -0500227 /*! \brief Adds a cor. LSA to the LSDB if it isn't already there.
228 \param clsa The candidate cor. LSA.
229 */
akmhoque53353462014-04-22 08:43:45 -0500230 bool
akmhoqueb6450b12014-04-24 00:01:03 -0500231 addCoordinateLsa(CoordinateLsa& clsa);
akmhoque53353462014-04-22 08:43:45 -0500232
Nick G97e34942016-07-11 14:46:27 -0500233 /*! \brief Returns whether a cor. LSA is in the LSDB.
234 \param key The name of the router that published the queried LSA.
235 */
akmhoque53353462014-04-22 08:43:45 -0500236 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500237 doesCoordinateLsaExist(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500238
Nick G97e34942016-07-11 14:46:27 -0500239 /*! \brief Attempts to construct an adj. LSA.
240
241 This function will attempt to construct an adjacency LSA. An LSA
242 can only be built when the status of all of the router's neighbors
243 is known. That is, when we are not currently trying to contact any
244 neighbor.
245 */
Vince Lehman50df6b72015-03-03 12:06:40 -0600246 void
247 buildAdjLsa();
248
Nick G97e34942016-07-11 14:46:27 -0500249 /*! \brief Adds an adj. LSA to the LSDB if it isn't already there.
250 \param alsa The candidate adj. LSA to add to the LSDB.
251 */
akmhoque53353462014-04-22 08:43:45 -0500252 bool
253 addAdjLsa(AdjLsa& alsa);
254
Nick G97e34942016-07-11 14:46:27 -0500255 /*! \brief Returns whether the LSDB contains an LSA.
256 \param key The name of a router whose LSA to check for in the LSDB.
257 */
akmhoque53353462014-04-22 08:43:45 -0500258 bool
akmhoque31d1d4b2014-05-05 22:08:14 -0500259 doesAdjLsaExist(const ndn::Name& key);
akmhoque53353462014-04-22 08:43:45 -0500260
Nick G97e34942016-07-11 14:46:27 -0500261 /*! \brief Schedules a refresh/expire event in the scheduler.
262 \param key The name of the router that published the LSA.
263 \param seqNo The seq. no. associated with the LSA.
264 \param expTime How many seconds to wait before triggering the event.
265 */
Davide Pesaventoaf7a2112019-03-19 14:55:20 -0400266 ndn::scheduler::EventId
akmhoquec7a79b22014-05-26 08:06:19 -0500267 scheduleNameLsaExpiration(const ndn::Name& key, int seqNo,
Nick Gordone98480b2017-05-24 11:23:03 -0500268 const ndn::time::seconds& expTime);
akmhoque53353462014-04-22 08:43:45 -0500269
Nick G97e34942016-07-11 14:46:27 -0500270 /*! \brief Either allow to expire, or refresh a name LSA.
271 \param lsaKey The name of the router that published the LSA.
272 \param seqNo The seq. no. of the LSA to check.
273 */
akmhoque53353462014-04-22 08:43:45 -0500274 void
Ashlesh Gawande90173ad2017-08-09 15:19:50 -0500275 expireOrRefreshNameLsa(const ndn::Name& lsaKey, uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -0500276
Vince Lehman199e9cf2015-04-07 13:22:16 -0500277PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Nick G97e34942016-07-11 14:46:27 -0500278 /*! \brief Schedules an expire/refresh event in the LSA.
279 \param key The name of the router whose LSA is in question.
280 \param seqNo The sequence number of the LSA to check.
281 \param expTime The number of seconds to wait before triggering the event.
282 */
Davide Pesaventoaf7a2112019-03-19 14:55:20 -0400283 ndn::scheduler::EventId
akmhoquec7a79b22014-05-26 08:06:19 -0500284 scheduleAdjLsaExpiration(const ndn::Name& key, int seqNo,
Nick Gordone98480b2017-05-24 11:23:03 -0500285 const ndn::time::seconds& expTime);
akmhoque53353462014-04-22 08:43:45 -0500286
Vince Lehman199e9cf2015-04-07 13:22:16 -0500287private:
akmhoque53353462014-04-22 08:43:45 -0500288 void
Ashlesh Gawande90173ad2017-08-09 15:19:50 -0500289 expireOrRefreshAdjLsa(const ndn::Name& lsaKey, uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -0500290
Davide Pesaventoaf7a2112019-03-19 14:55:20 -0400291 ndn::scheduler::EventId
akmhoque31d1d4b2014-05-05 22:08:14 -0500292 scheduleCoordinateLsaExpiration(const ndn::Name& key, int seqNo,
Nick Gordone98480b2017-05-24 11:23:03 -0500293 const ndn::time::seconds& expTime);
akmhoque53353462014-04-22 08:43:45 -0500294
295 void
Ashlesh Gawande90173ad2017-08-09 15:19:50 -0500296 expireOrRefreshCoordinateLsa(const ndn::Name& lsaKey,
Davide Pesaventoaf7a2112019-03-19 14:55:20 -0400297 uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -0500298
akmhoque31d1d4b2014-05-05 22:08:14 -0500299 void
akmhoque31d1d4b2014-05-05 22:08:14 -0500300 processInterestForNameLsa(const ndn::Interest& interest,
301 const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500302 uint64_t seqNo);
akmhoque53353462014-04-22 08:43:45 -0500303
akmhoque31d1d4b2014-05-05 22:08:14 -0500304 void
305 processInterestForAdjacencyLsa(const ndn::Interest& interest,
306 const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500307 uint64_t seqNo);
akmhoque31d1d4b2014-05-05 22:08:14 -0500308
309 void
310 processInterestForCoordinateLsa(const ndn::Interest& interest,
311 const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500312 uint64_t seqNo);
Ashlesh Gawande15052402018-12-12 20:20:00 -0600313
akmhoque31d1d4b2014-05-05 22:08:14 -0500314 void
dmcoomes9f936662017-03-02 10:33:09 -0600315 onContentValidated(const std::shared_ptr<const ndn::Data>& data);
Yingdi Yu20e3a6e2014-05-26 23:16:10 -0700316
317 void
akmhoque31d1d4b2014-05-05 22:08:14 -0500318 processContentNameLsa(const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500319 uint64_t lsSeqNo, std::string& dataContent);
akmhoque31d1d4b2014-05-05 22:08:14 -0500320
321 void
322 processContentAdjacencyLsa(const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500323 uint64_t lsSeqNo, std::string& dataContent);
akmhoque31d1d4b2014-05-05 22:08:14 -0500324
325 void
326 processContentCoordinateLsa(const ndn::Name& lsaKey,
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500327 uint64_t lsSeqNo, std::string& dataContent);
akmhoque31d1d4b2014-05-05 22:08:14 -0500328
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500329PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Nick G97e34942016-07-11 14:46:27 -0500330 /*!
331 \brief Error callback when SegmentFetcher fails to return an LSA
332
333 In all error cases, a reattempt to fetch the LSA will be made.
334
335 Segment validation can fail either because the packet does not have a
336 valid signature (fatal) or because some of the certificates in the trust chain
337 could not be fetched (non-fatal).
338
339 Currently, the library does not provide clear indication (besides a plain-text message
340 in the error callback) of the reason for the failure nor the segment that failed
341 to be validated, thus we will continue to try to fetch the LSA until the deadline
342 is reached.
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500343 */
akmhoque31d1d4b2014-05-05 22:08:14 -0500344 void
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500345 onFetchLsaError(uint32_t errorCode,
346 const std::string& msg,
Ashlesh Gawande744e4812018-08-22 16:26:24 -0500347 const ndn::Name& interestName,
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500348 uint32_t retransmitNo,
349 const ndn::time::steady_clock::TimePoint& deadline,
350 ndn::Name lsaName,
351 uint64_t seqNo);
352
Nick G97e34942016-07-11 14:46:27 -0500353 /*!
354 \brief Success callback when SegmentFetcher returns a valid LSA
355
Nick Gordonb50e51b2016-07-22 16:05:57 -0500356 \param interestName The base Interest used to fetch the LSA in the format:
Nick G97e34942016-07-11 14:46:27 -0500357 /<network>/NLSR/LSA/<site>/%C1.Router/<router>/<lsa-type>/<seqNo>
Muktadir R Chowdhuryaa3b0852015-08-06 13:08:56 -0500358 */
359 void
Ashlesh Gawande744e4812018-08-22 16:26:24 -0500360 afterFetchLsa(const ndn::ConstBufferPtr& data, const ndn::Name& interestName);
akmhoque31d1d4b2014-05-05 22:08:14 -0500361
Saurab Dulal427e0122019-11-28 11:58:02 -0600362 void
363 emitSegmentValidatedSignal(const ndn::Data& data)
364 {
365 afterSegmentValidatedSignal(data);
366 }
367
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500368private:
Nick Gordone98480b2017-05-24 11:23:03 -0500369 ndn::time::system_clock::TimePoint
akmhoquec7a79b22014-05-26 08:06:19 -0500370 getLsaExpirationTimePoint();
371
Jiewen Tana0497d82015-02-02 21:59:18 -0800372public:
373 static const ndn::Name::Component NAME_COMPONENT;
374
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -0600375 ndn::util::signal::Signal<Lsdb, Statistics::PacketType> lsaIncrementSignal;
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600376 ndn::util::signal::Signal<Lsdb, const ndn::Data&> afterSegmentValidatedSignal;
Alejandro Gil Torrese0d20482016-03-06 23:56:19 -0600377
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500378private:
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600379 ndn::Face& m_face;
380 ndn::Scheduler m_scheduler;
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600381
382 ConfParameter& m_confParam;
383 NamePrefixTable& m_namePrefixTable;
384 RoutingTable& m_routingTable;
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600385
386PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Ashlesh Gawande15052402018-12-12 20:20:00 -0600387 SyncLogicHandler m_sync;
Vince Lehman7c603292014-09-11 17:48:16 -0500388
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600389private:
akmhoque53353462014-04-22 08:43:45 -0500390 std::list<NameLsa> m_nameLsdb;
391 std::list<AdjLsa> m_adjLsdb;
akmhoqueb6450b12014-04-24 00:01:03 -0500392 std::list<CoordinateLsa> m_corLsdb;
akmhoque53353462014-04-22 08:43:45 -0500393
Nick Gordone98480b2017-05-24 11:23:03 -0500394 ndn::time::seconds m_lsaRefreshTime;
akmhoque53353462014-04-22 08:43:45 -0500395 std::string m_thisRouterPrefix;
396
Ashlesh Gawande5bf83172014-09-19 12:38:17 -0500397 typedef std::map<ndn::Name, uint64_t> SequenceNumberMap;
398
399 // Maps the name of an LSA to its highest known sequence number from sync;
400 // Used to stop NLSR from trying to fetch outdated LSAs
401 SequenceNumberMap m_highestSeqNo;
402
Vince Lehman18841082014-08-19 17:15:24 -0500403 static const ndn::time::seconds GRACE_PERIOD;
Nick Gordone98480b2017-05-24 11:23:03 -0500404 static const ndn::time::steady_clock::TimePoint DEFAULT_LSA_RETRIEVAL_DEADLINE;
Vince Lehman50df6b72015-03-03 12:06:40 -0600405
Ashlesh Gawande15052402018-12-12 20:20:00 -0600406PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Vince Lehman50df6b72015-03-03 12:06:40 -0600407 ndn::time::seconds m_adjLsaBuildInterval;
Ashlesh Gawande3e105a02017-05-16 17:36:56 -0500408
409 SequencingManager m_sequencingManager;
Nick Gordon9eac4d92017-08-29 17:31:29 -0500410
Ashlesh Gawande15052402018-12-12 20:20:00 -0600411private:
Nick Gordon9eac4d92017-08-29 17:31:29 -0500412 ndn::util::signal::ScopedConnection m_onNewLsaConnection;
Ashlesh Gawande744e4812018-08-22 16:26:24 -0500413
414 std::set<std::shared_ptr<ndn::util::SegmentFetcher>> m_fetchers;
Ashlesh Gawande939b6f82018-12-09 16:51:09 -0600415 psync::SegmentPublisher m_segmentPublisher;
Ashlesh Gawande85998a12017-12-07 22:22:13 -0600416
417 bool m_isBuildAdjLsaSheduled;
418 int64_t m_adjBuildCount;
Ashlesh Gawande6b388fc2019-09-30 10:14:41 -0500419 ndn::scheduler::ScopedEventId m_scheduledAdjLsaBuild;
Ashlesh Gawande15052402018-12-12 20:20:00 -0600420
421PUBLIC_WITH_TESTS_ELSE_PRIVATE:
422 ndn::InMemoryStoragePersistent m_lsaStorage;
akmhoque53353462014-04-22 08:43:45 -0500423};
424
Nick Gordonfad8e252016-08-11 14:21:38 -0500425} // namespace nlsr
akmhoque53353462014-04-22 08:43:45 -0500426
dmcoomes9f936662017-03-02 10:33:09 -0600427#endif // NLSR_LSDB_HPP