NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
nfd-rib-readvertise-destination.hpp
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 
26 #ifndef NFD_DAEMON_RIB_READVERTISE_NFD_RIB_READVERTISE_DESTINATION_HPP
27 #define NFD_DAEMON_RIB_READVERTISE_NFD_RIB_READVERTISE_DESTINATION_HPP
28 
30 #include "rib/rib.hpp"
31 
35 
36 namespace nfd {
37 namespace rib {
38 
42 {
43 public:
45  Rib& rib,
47  const ndn::nfd::ControlParameters& parameters =
49 
52  void
53  advertise(const ReadvertisedRoute& rr,
54  std::function<void()> successCb,
55  std::function<void(const std::string&)> failureCb) override;
56 
59  void
60  withdraw(const ReadvertisedRoute& rr,
61  std::function<void()> successCb,
62  std::function<void(const std::string&)> failureCb) override;
63 
64 protected:
67  {
68  return m_controlParameters;
69  }
70 
73  {
74  return m_commandOptions;
75  }
76 
77 private:
78  ndn::nfd::Controller& m_controller;
79 
80  signal::ScopedConnection m_ribInsertConn;
81  signal::ScopedConnection m_ribEraseConn;
82 
83  ndn::nfd::CommandOptions m_commandOptions;
84  ndn::nfd::ControlParameters m_controlParameters;
85 };
86 
87 } // namespace rib
88 } // namespace nfd
89 
90 #endif // NFD_DAEMON_RIB_READVERTISE_NFD_RIB_READVERTISE_DESTINATION_HPP
represents the Routing Information Base
Definition: rib.hpp:59
represents parameters in a ControlCommand request or response
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
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))
Disconnects a Connection automatically upon destruction.
NFD Management protocol client.
Definition: controller.hpp:51
a destination to readvertise into
ndn::nfd::ControlParameters getControlParameters() const