blob: 828d64ae8365041b8348da257a2315b8ee6db870 [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Ashlesh Gawandee8d8bd52018-08-09 17:18:51 -05003 * Copyright (c) 2014-2018, The University of Memphis,
Vince Lehmancae33b62015-06-05 09:21:30 -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 Lehmancae33b62015-06-05 09:21:30 -050021
akmhoquefdbddb12014-05-02 18:35:19 -050022#ifndef NLSR_NAME_PREFIX_TABLE_ENTRY_HPP
23#define NLSR_NAME_PREFIX_TABLE_ENTRY_HPP
akmhoque53353462014-04-22 08:43:45 -050024
Nick Gordonb50e51b2016-07-22 16:05:57 -050025#include "routing-table-pool-entry.hpp"
26
27#include "test-access-control.hpp"
Vince Lehmancae33b62015-06-05 09:21:30 -050028
akmhoque53353462014-04-22 08:43:45 -050029#include <list>
30#include <utility>
akmhoque53353462014-04-22 08:43:45 -050031
32namespace nlsr {
33
akmhoquec8a10f72014-04-25 18:42:55 -050034class NamePrefixTableEntry
akmhoque53353462014-04-22 08:43:45 -050035{
36public:
akmhoquec8a10f72014-04-25 18:42:55 -050037 NamePrefixTableEntry()
akmhoque53353462014-04-22 08:43:45 -050038 {
39 }
40
akmhoque31d1d4b2014-05-05 22:08:14 -050041 NamePrefixTableEntry(const ndn::Name& namePrefix)
42 : m_namePrefix(namePrefix)
43 , m_nexthopList()
akmhoque53353462014-04-22 08:43:45 -050044 {
akmhoque53353462014-04-22 08:43:45 -050045 }
46
akmhoque31d1d4b2014-05-05 22:08:14 -050047 const ndn::Name&
akmhoquefdbddb12014-05-02 18:35:19 -050048 getNamePrefix() const
akmhoque53353462014-04-22 08:43:45 -050049 {
50 return m_namePrefix;
51 }
52
Nick Gordonb50e51b2016-07-22 16:05:57 -050053 const std::list<std::shared_ptr<RoutingTablePoolEntry>>&
Vince Lehmancae33b62015-06-05 09:21:30 -050054 getRteList() const
akmhoque53353462014-04-22 08:43:45 -050055 {
56 return m_rteList;
57 }
58
Nick Gordond0a7df32017-05-30 16:44:34 -050059 /*! \brief Resets the next hop lists of all routing table entries
60 * that advertise this name prefix.
61 */
akmhoque53353462014-04-22 08:43:45 -050062 void
63 resetRteListNextHop()
64 {
akmhoque157b0a42014-05-13 00:26:37 -050065 if (m_rteList.size() > 0) {
Nick Gordonb50e51b2016-07-22 16:05:57 -050066 for (auto it = m_rteList.begin(); it != m_rteList.end(); ++it) {
67 (*it)->getNexthopList().reset();
akmhoque53353462014-04-22 08:43:45 -050068 }
69 }
70 }
71
akmhoquefdbddb12014-05-02 18:35:19 -050072 size_t
akmhoque53353462014-04-22 08:43:45 -050073 getRteListSize()
74 {
75 return m_rteList.size();
76 }
77
Ashlesh Gawandee8d8bd52018-08-09 17:18:51 -050078 const NexthopList&
79 getNexthopList() const
akmhoque53353462014-04-22 08:43:45 -050080 {
akmhoquefdbddb12014-05-02 18:35:19 -050081 return m_nexthopList;
akmhoque53353462014-04-22 08:43:45 -050082 }
83
Nick Gordond0a7df32017-05-30 16:44:34 -050084 /*! \brief Collect all next-hops that are advertised by this entry's
85 * routing entries.
86 */
akmhoque53353462014-04-22 08:43:45 -050087 void
88 generateNhlfromRteList();
89
Nick Gordonb50e51b2016-07-22 16:05:57 -050090 /*! \brief Removes a routing entry from this NPT entry.
Nick Gordond0a7df32017-05-30 16:44:34 -050091 * \return The number of NPTs using the just-removed routing entry.
92 */
Nick Gordonb50e51b2016-07-22 16:05:57 -050093 uint64_t
94 removeRoutingTableEntry(std::shared_ptr<RoutingTablePoolEntry> rtpePtr);
akmhoque53353462014-04-22 08:43:45 -050095
Nick Gordonb50e51b2016-07-22 16:05:57 -050096 /*! \brief Adds a routing entry to this NPT entry.
Nick Gordond0a7df32017-05-30 16:44:34 -050097 * \param rtpePtr The routing entry.
98 *
99 * Adds a routing table pool entry to this NPT entry's list
100 * (reminder: each RTPE has a next-hop list). They are used to
101 * calculate this entry's overall next-hop list.
102 */
akmhoque53353462014-04-22 08:43:45 -0500103 void
Nick Gordonb50e51b2016-07-22 16:05:57 -0500104 addRoutingTableEntry(std::shared_ptr<RoutingTablePoolEntry> rtpePtr);
akmhoque53353462014-04-22 08:43:45 -0500105
akmhoque674b0b12014-05-20 14:33:28 -0500106 void
107 writeLog();
108
akmhoque53353462014-04-22 08:43:45 -0500109private:
akmhoque31d1d4b2014-05-05 22:08:14 -0500110 ndn::Name m_namePrefix;
Nick Gordonb50e51b2016-07-22 16:05:57 -0500111
112PUBLIC_WITH_TESTS_ELSE_PRIVATE:
113 std::list<std::shared_ptr<RoutingTablePoolEntry>> m_rteList;
akmhoquefdbddb12014-05-02 18:35:19 -0500114 NexthopList m_nexthopList;
Nick Gordonb50e51b2016-07-22 16:05:57 -0500115
akmhoque53353462014-04-22 08:43:45 -0500116};
117
Nick Gordonb50e51b2016-07-22 16:05:57 -0500118bool
119operator==(const NamePrefixTableEntry& lhs, const NamePrefixTableEntry& rhs);
120
121bool
122operator==(const NamePrefixTableEntry& lhs, const ndn::Name& rhs);
123
Vince Lehmancae33b62015-06-05 09:21:30 -0500124std::ostream&
125operator<<(std::ostream& os, const NamePrefixTableEntry& entry);
akmhoque53353462014-04-22 08:43:45 -0500126
Vince Lehmancae33b62015-06-05 09:21:30 -0500127} // namespace nlsr
128
129#endif // NLSR_NAME_PREFIX_TABLE_ENTRY_HPP