NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
nfd-rib-readvertise-destination.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014-2021, Regents of the University of California,
4  * 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 
27 #include "common/logger.hpp"
28 
31 
32 namespace nfd {
33 namespace rib {
34 
36 
38 
40  Rib& rib,
41  const ndn::nfd::CommandOptions& options,
42  const ndn::nfd::ControlParameters& parameters)
43  : m_controller(controller)
44  , m_commandOptions(options)
45  , m_controlParameters(parameters)
46 {
47  m_ribInsertConn = rib.afterInsertEntry.connect([this] (const Name& name) {
48  if (name.isPrefixOf(m_commandOptions.getPrefix())) {
49  setAvailability(true);
50  }
51  });
52 
53  m_ribEraseConn = rib.afterEraseEntry.connect([this] (const Name& name) {
54  if (name.isPrefixOf(m_commandOptions.getPrefix())) {
55  setAvailability(false);
56  }
57  });
58 }
59 
60 void
62  std::function<void()> successCb,
63  std::function<void(const std::string&)> failureCb)
64 {
65  NFD_LOG_DEBUG("advertise " << rr.prefix << " on " << m_commandOptions.getPrefix());
66 
67  m_controller.start<ndn::nfd::RibRegisterCommand>(
69  [=] (const ControlParameters&) { successCb(); },
70  [=] (const ControlResponse& cr) { failureCb(cr.getText()); },
72 }
73 
74 void
76  std::function<void()> successCb,
77  std::function<void(const std::string&)> failureCb)
78 {
79  NFD_LOG_DEBUG("withdraw " << rr.prefix << " on " << m_commandOptions.getPrefix());
80 
83  [=] (const ControlParameters&) { successCb(); },
84  [=] (const ControlResponse& cr) { failureCb(cr.getText()); },
86 }
87 
88 } // namespace rib
89 } // namespace nfd
void start(const ControlParameters &parameters, const CommandSucceedCallback &onSuccess, const CommandFailCallback &onFailure, const CommandOptions &options=CommandOptions())
start command execution
Definition: controller.hpp:78
represents the Routing Information Base
Definition: rib.hpp:59
#define NFD_LOG_INIT(name)
Definition: logger.hpp:31
represents parameters in a ControlCommand request or response
bool isPrefixOf(const Name &other) const
Check if this name is a prefix of another name.
Definition: name.cpp:300
void withdraw(const ReadvertisedRoute &rr, std::function< void()> successCb, std::function< void(const std::string &)> failureCb) override
remove a name prefix from NFD RIB
void advertise(const ReadvertisedRoute &rr, std::function< void()> successCb, std::function< void(const std::string &)> failureCb) override
add a name prefix into NFD RIB
a readvertise destination using NFD RIB management protocol
signal::Signal< Rib, Name > afterEraseEntry
signals after a RIB entry is erased
Definition: rib.hpp:224
mgmt::ControlResponse ControlResponse
contains options for ControlCommand execution
Copyright (c) 2011-2015 Regents of the University of California.
Definition: ndn-common.hpp:39
state of a readvertised route
NfdRibReadvertiseDestination(ndn::nfd::Controller &controller, Rib &rib, const ndn::nfd::CommandOptions &options=ndn::nfd::CommandOptions(), const ndn::nfd::ControlParameters &parameters=ndn::nfd::ControlParameters().setOrigin(ndn::nfd::ROUTE_ORIGIN_CLIENT))
#define NFD_LOG_DEBUG
Definition: logger.hpp:38
signal::Signal< Rib, Name > afterInsertEntry
signals after a RIB entry is inserted
Definition: rib.hpp:217
ndn::security::SigningInfo signer
signer for commands
Name prefix
readvertised prefix
NFD Management protocol client.
Definition: controller.hpp:51
Represents an absolute name.
Definition: name.hpp:41
represents a rib/unregister command
CommandOptions & setSigningInfo(const security::SigningInfo &signingInfo)
sets signing parameters
represents a rib/register command
const Name & getPrefix() const
ControlParameters & setName(const Name &name)
ControlCommand response.
ndn::nfd::ControlParameters getControlParameters() const