blob: dc487bc9cdded6d56ece662ccc753e9200d27783 [file] [log] [blame]
Alexander Afanasyev60a7b622014-12-20 17:04:07 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2011-2015 Regents of the University of California.
Alexander Afanasyevab1d5602011-08-17 19:17:18 -07004 *
Alexander Afanasyev60a7b622014-12-20 17:04:07 -08005 * This file is part of ndnSIM. See AUTHORS for complete list of ndnSIM authors and
6 * contributors.
Alexander Afanasyevab1d5602011-08-17 19:17:18 -07007 *
Alexander Afanasyev60a7b622014-12-20 17:04:07 -08008 * ndnSIM is free software: you can redistribute it and/or modify it under the terms
9 * of the GNU General Public License as published by the Free Software Foundation,
10 * either version 3 of the License, or (at your option) any later version.
Alexander Afanasyevab1d5602011-08-17 19:17:18 -070011 *
Alexander Afanasyev60a7b622014-12-20 17:04:07 -080012 * ndnSIM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
Alexander Afanasyevab1d5602011-08-17 19:17:18 -070015 *
Alexander Afanasyev60a7b622014-12-20 17:04:07 -080016 * You should have received a copy of the GNU General Public License along with
17 * ndnSIM, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 **/
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070019
Alexander Afanasyev0c395372014-12-20 15:54:02 -080020#include "ndn-l3-protocol.hpp"
Alexander Afanasyev45b92d42011-08-14 23:11:38 -070021
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070022#include "ns3/packet.h"
Alexander Afanasyev45b92d42011-08-14 23:11:38 -070023#include "ns3/node.h"
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070024#include "ns3/log.h"
25#include "ns3/callback.h"
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070026#include "ns3/uinteger.h"
27#include "ns3/trace-source-accessor.h"
28#include "ns3/object-vector.h"
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080029#include "ns3/pointer.h"
Alexander Afanasyev4975f732011-12-20 17:52:19 -080030#include "ns3/simulator.h"
Alexander Afanasyevff8c5d62012-04-25 15:14:51 -070031#include "ns3/random-variable.h"
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070032
Spyridon Mastorakise4f0d3c2014-10-29 13:20:03 -070033#include "ndn-face.hpp"
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -080034
Alexander Afanasyev0c395372014-12-20 15:54:02 -080035#include "ndn-net-device-face.hpp"
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -080036#include "../helper/ndn-stack-helper.hpp"
Spyridon Mastorakisde1f7732014-12-05 22:43:34 -080037#include "cs/ndn-content-store.hpp"
Alexander Afanasyev52e9aa92011-11-15 20:23:20 -080038
Alexander Afanasyevdde1e812015-01-06 14:26:09 -080039#include <boost/property_tree/info_parser.hpp>
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070040
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -080041#include "ns3/ndnSIM/NFD/daemon/fw/forwarder.hpp"
42#include "ns3/ndnSIM/NFD/daemon/mgmt/internal-face.hpp"
43#include "ns3/ndnSIM/NFD/daemon/mgmt/fib-manager.hpp"
44#include "ns3/ndnSIM/NFD/daemon/mgmt/face-manager.hpp"
45#include "ns3/ndnSIM/NFD/daemon/mgmt/strategy-choice-manager.hpp"
46#include "ns3/ndnSIM/NFD/daemon/mgmt/status-server.hpp"
47
48#include "ns3/ndnSIM/NFD/daemon/face/null-face.hpp"
49#include "ns3/ndnSIM/NFD/core/config-file.hpp"
50#include "ns3/ndnSIM/NFD/daemon/mgmt/general-config-section.hpp"
51#include "ns3/ndnSIM/NFD/daemon/mgmt/tables-config-section.hpp"
52
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080053NS_LOG_COMPONENT_DEFINE("ndn.L3Protocol");
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070054
55namespace ns3 {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070056namespace ndn {
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070057
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070058const uint16_t L3Protocol::ETHERNET_FRAME_TYPE = 0x7777;
Alexander Afanasyev016a5d82013-07-15 10:41:29 -070059const uint16_t L3Protocol::IP_STACK_PORT = 9695;
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070060
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080061NS_OBJECT_ENSURE_REGISTERED(L3Protocol);
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070062
Alexander Afanasyev06dba7c2013-02-21 11:36:26 -080063TypeId
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080064L3Protocol::GetTypeId(void)
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070065{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080066 static TypeId tid =
67 TypeId("ns3::ndn::L3Protocol")
68 .SetGroupName("ndn")
69 .SetParent<Object>()
70 .AddConstructor<L3Protocol>()
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -080071
72 .AddTraceSource("OutInterests", "OutInterests",
73 MakeTraceSourceAccessor(&L3Protocol::m_outInterests))
74 .AddTraceSource("InInterests", "InInterests",
75 MakeTraceSourceAccessor(&L3Protocol::m_inInterests))
76
77 ////////////////////////////////////////////////////////////////////
78
79 .AddTraceSource("OutData", "OutData", MakeTraceSourceAccessor(&L3Protocol::m_outData))
80 .AddTraceSource("InData", "InData", MakeTraceSourceAccessor(&L3Protocol::m_inData));
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070081 return tid;
82}
83
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -080084class L3Protocol::Impl {
85private:
Alexander Afanasyevdde1e812015-01-06 14:26:09 -080086 Impl()
87 {
88 // Do not modify initial config file. Use helpers to set specific NFD parameters
89 std::string initialConfig =
90 "general\n"
91 "{\n"
92 "}\n"
93 "\n"
94 "tables\n"
95 "{\n"
96 " cs_max_packets 100\n"
97 "\n"
98 " strategy_choice\n"
99 " {\n"
100 " / /localhost/nfd/strategy/best-route\n"
101 " /localhost /localhost/nfd/strategy/broadcast\n"
102 " /localhost/nfd /localhost/nfd/strategy/best-route\n"
103 " /ndn/broadcast /localhost/nfd/strategy/broadcast\n"
104 " }\n"
105 "}\n"
106 "\n"
107 // "face_system\n"
108 // "{\n"
109 // "}\n"
110 "\n"
111 "authorizations\n"
112 "{\n"
113 " authorize\n"
114 " {\n"
115 " certfile any\n"
116 " privileges\n"
117 " {\n"
118 " faces\n"
119 " fib\n"
120 " strategy-choice\n"
121 " }\n"
122 " }\n"
123 "}\n"
124 "\n"
125 "rib\n"
126 "{\n"
127 " localhost_security\n"
128 " {\n"
129 " trust-anchor\n"
130 " {\n"
131 " type any\n"
132 " }\n"
133 " }\n"
134 "}\n"
135 "\n";
136
137 std::istringstream input(initialConfig);
138 boost::property_tree::read_info(input, m_config);
139 }
140
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800141 friend class L3Protocol;
142
143 shared_ptr<nfd::Forwarder> m_forwarder;
144
145 shared_ptr<nfd::InternalFace> m_internalFace;
146 shared_ptr<nfd::FibManager> m_fibManager;
147 shared_ptr<nfd::FaceManager> m_faceManager;
148 shared_ptr<nfd::StrategyChoiceManager> m_strategyChoiceManager;
149 shared_ptr<nfd::StatusServer> m_statusServer;
Spyridon Mastorakisde1f7732014-12-05 22:43:34 -0800150
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800151 nfd::ConfigSection m_config;
152
Spyridon Mastorakisde1f7732014-12-05 22:43:34 -0800153 Ptr<ContentStore> m_csFromNdnSim;
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800154};
155
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800156L3Protocol::L3Protocol()
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800157 : m_impl(new Impl())
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700158{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800159 NS_LOG_FUNCTION(this);
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700160}
161
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800162L3Protocol::~L3Protocol()
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700163{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800164 NS_LOG_FUNCTION(this);
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700165}
166
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800167void
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800168L3Protocol::initialize()
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800169{
170 m_impl->m_forwarder = make_shared<nfd::Forwarder>();
171
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800172 initializeManagement();
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800173
174 m_impl->m_forwarder->getFaceTable().addReserved(make_shared<nfd::NullFace>(), nfd::FACEID_NULL);
175 m_impl->m_forwarder->getFaceTable().addReserved(make_shared<nfd::NullFace>(
176 FaceUri("contentstore://")),
177 nfd::FACEID_CONTENT_STORE);
178}
179
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800180class IgnoreSections
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800181{
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800182public:
183 IgnoreSections(const std::vector<std::string>& ignored)
184 : m_ignored(ignored)
185 {
186 }
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800187
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800188 void
189 operator()(const std::string& filename, const std::string& sectionName,
190 const nfd::ConfigSection& section, bool isDryRun)
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800191
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800192 {
193 if (std::find(m_ignored.begin(), m_ignored.end(), sectionName) == m_ignored.end()) {
194 nfd::ConfigFile::throwErrorOnUnknownSection(filename, sectionName, section, isDryRun);
195 }
196 }
197private:
198 std::vector<std::string> m_ignored;
199};
200
201void
202L3Protocol::initializeManagement()
203{
204 auto keyChain = std::ref(StackHelper::getKeyChain());
205 auto& forwarder = m_impl->m_forwarder;
206 using namespace nfd;
207
208 m_impl->m_internalFace = make_shared<InternalFace>();
209
210 m_impl->m_fibManager = make_shared<FibManager>(std::ref(forwarder->getFib()),
211 bind(&Forwarder::getFace, forwarder.get(), _1),
212 m_impl->m_internalFace, keyChain);
213
214 m_impl->m_faceManager = make_shared<FaceManager>(std::ref(forwarder->getFaceTable()),
215 m_impl->m_internalFace,
216 keyChain);
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800217
218 m_impl->m_strategyChoiceManager =
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800219 make_shared<StrategyChoiceManager>(std::ref(forwarder->getStrategyChoice()),
220 m_impl->m_internalFace,
221 keyChain);
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800222
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800223 m_impl->m_statusServer = make_shared<StatusServer>(m_impl->m_internalFace,
224 ref(*forwarder),
225 keyChain);
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800226
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800227 ConfigFile config((IgnoreSections({"general", "log", "rib"})));
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800228
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800229 TablesConfigSection tablesConfig(forwarder->getCs(),
230 forwarder->getPit(),
231 forwarder->getFib(),
232 forwarder->getStrategyChoice(),
233 forwarder->getMeasurements());
234 tablesConfig.setConfigFile(config);
235
236 m_impl->m_internalFace->getValidator().setConfigFile(config);
237
238 forwarder->getFaceTable().addReserved(m_impl->m_internalFace, FACEID_INTERNAL_FACE);
239
240 m_impl->m_faceManager->setConfigFile(config);
241
242 // apply config
243 config.parse(m_impl->m_config, false, "ndnSIM.conf");
244
245 tablesConfig.ensureTablesAreConfigured();
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800246
247 // add FIB entry for NFD Management Protocol
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800248 shared_ptr<fib::Entry> entry = forwarder->getFib().insert("/localhost/nfd").first;
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800249 entry->addNextHop(m_impl->m_internalFace, 0);
250}
251
252shared_ptr<nfd::Forwarder>
253L3Protocol::getForwarder()
254{
255 return m_impl->m_forwarder;
256}
257
258shared_ptr<nfd::FibManager>
259L3Protocol::getFibManager()
260{
261 return m_impl->m_fibManager;
262}
263
264shared_ptr<nfd::StrategyChoiceManager>
265L3Protocol::getStrategyChoiceManager()
266{
267 return m_impl->m_strategyChoiceManager;
268}
269
Alexander Afanasyevdde1e812015-01-06 14:26:09 -0800270nfd::ConfigSection&
271L3Protocol::getConfig()
272{
273 return m_impl->m_config;
274}
275
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700276/*
277 * This method is called by AddAgregate and completes the aggregation
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700278 * by setting the node in the ndn stack
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700279 */
280void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800281L3Protocol::NotifyNewAggregate()
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700282{
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800283 if (m_node == nullptr) {
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800284 m_node = GetObject<Node>();
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800285 if (m_node != nullptr) {
Spyridon Mastorakisde1f7732014-12-05 22:43:34 -0800286 NS_ASSERT(m_impl->m_forwarder != nullptr);
287 m_impl->m_csFromNdnSim = GetObject<ContentStore>();
288 if (m_impl->m_csFromNdnSim != nullptr) {
289 m_impl->m_forwarder->setCsFromNdnSim(m_impl->m_csFromNdnSim);
290 }
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700291 }
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800292 }
Alexander Afanasyevd9fecdd2012-06-08 16:22:24 -0700293
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800294 Object::NotifyNewAggregate();
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700295}
296
Alexander Afanasyev06dba7c2013-02-21 11:36:26 -0800297void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800298L3Protocol::DoDispose(void)
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700299{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800300 NS_LOG_FUNCTION(this);
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700301
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700302 m_node = 0;
Alexander Afanasyevd02a5d62011-11-21 11:01:51 -0800303
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800304 Object::DoDispose();
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700305}
306
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800307nfd::FaceId
308L3Protocol::addFace(shared_ptr<Face> face)
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700309{
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800310 NS_LOG_FUNCTION(this << face.get());
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700311
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800312 m_impl->m_forwarder->addFace(face);
313
314 // Connect Signals to TraceSource
315 face->onReceiveInterest +=
316 [this, face](const Interest& interest) { this->m_inInterests(interest, *face); };
317
318 face->onSendInterest +=
319 [this, face](const Interest& interest) { this->m_outInterests(interest, *face); };
320
321 face->onReceiveData += [this, face](const Data& data) { this->m_inData(data, *face); };
322
323 face->onSendData += [this, face](const Data& data) { this->m_outData(data, *face); };
324
325 return face->getId();
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700326}
327
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800328// void
329// L3Protocol::removeFace(shared_ptr<Face> face)
330// {
331// NS_LOG_FUNCTION(this << std::cref(*face));
332// }
333
334shared_ptr<Face>
335L3Protocol::getFaceById(nfd::FaceId id) const
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700336{
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800337 return m_impl->m_forwarder->getFaceTable().get(id);
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700338}
339
Spyridon Mastorakise4f0d3c2014-10-29 13:20:03 -0700340shared_ptr<Face>
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800341L3Protocol::getFaceByNetDevice(Ptr<NetDevice> netDevice) const
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700342{
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800343 for (const auto& i : m_impl->m_forwarder->getFaceTable()) {
344 shared_ptr<NetDeviceFace> netDeviceFace = std::dynamic_pointer_cast<NetDeviceFace>(i);
345 if (netDeviceFace == nullptr)
346 continue;
Alexander Afanasyevaebf5cf2012-08-28 17:32:17 -0700347
Spyridon Mastorakis9760bd02014-11-12 13:32:55 -0800348 if (netDeviceFace->GetNetDevice() == netDevice)
349 return i;
350 }
Spyridon Mastorakise4f0d3c2014-10-29 13:20:03 -0700351 return nullptr;
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700352}
353
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800354} // namespace ndn
355} // namespace ns3