NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.0: NDN, CCN, CCNx, content centric networks
API Documentation
manager-base.hpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
26 #ifndef NFD_DAEMON_MGMT_MANAGER_BASE_HPP
27 #define NFD_DAEMON_MGMT_MANAGER_BASE_HPP
28 
29 #include "common.hpp"
31 
32 #include <ndn-cxx/mgmt/dispatcher.hpp>
33 #include <ndn-cxx/management/nfd-control-command.hpp>
34 #include <ndn-cxx/management/nfd-control-response.hpp>
35 #include <ndn-cxx/management/nfd-control-parameters.hpp>
36 
37 namespace nfd {
38 
40 
44 
49 class ManagerBase : public noncopyable
50 {
51 public:
52  class Error : public std::runtime_error
53  {
54  public:
55  explicit
56  Error(const std::string& what)
57  : std::runtime_error(what)
58  {
59  }
60  };
61 
62 public:
63  ManagerBase(Dispatcher& dispatcher,
64  CommandValidator& validator,
65  const std::string& module);
66 
67 PUBLIC_WITH_TESTS_ELSE_PROTECTED: // registrations to the dispatcher
68 
69  // difference from mgmt::ControlCommand: accepts nfd::ControlParameters
70  typedef function<void(const ControlCommand& command,
71  const Name& prefix, const Interest& interest,
72  const ControlParameters& parameters,
74 
75  template<typename Command>
76  void
77  registerCommandHandler(const std::string& verb,
78  const ControlCommandHandler& handler);
79 
80  void
81  registerStatusDatasetHandler(const std::string& verb,
82  const ndn::mgmt::StatusDatasetHandler& handler);
83 
85  registerNotificationStream(const std::string& verb);
86 
87 PUBLIC_WITH_TESTS_ELSE_PRIVATE: // command validation
102  void
103  authorize(const Name& prefix, const Interest& interest,
104  const ndn::mgmt::ControlParameters* params,
107 
116  void
117  extractRequester(const Interest& interest,
119 
128  static bool
129  validateParameters(const nfd::ControlCommand& command,
130  const ndn::mgmt::ControlParameters& parameters);
131 
134  static void
135  handleCommand(shared_ptr<nfd::ControlCommand> command,
136  const ControlCommandHandler& handler,
137  const Name& prefix, const Interest& interest,
138  const ndn::mgmt::ControlParameters& params,
140 
150  makeRelPrefix(const std::string& verb);
151 
152 private:
153  Dispatcher& m_dispatcher;
154  CommandValidator& m_validator;
155  std::string m_mgmtModuleName;
156 };
157 
158 inline PartialName
159 ManagerBase::makeRelPrefix(const std::string& verb)
160 {
161  return PartialName(m_mgmtModuleName).append(verb);
162 }
163 
164 template<typename Command>
165 inline void
166 ManagerBase::registerCommandHandler(const std::string& verb,
167  const ControlCommandHandler& handler)
168 {
169  auto command = make_shared<Command>();
170 
171  m_dispatcher.addControlCommand<ControlParameters>(
172  makeRelPrefix(verb),
173  bind(&ManagerBase::authorize, this, _1, _2, _3, _4, _5),
174  bind(&ManagerBase::validateParameters, cref(*command), _1),
175  bind(&ManagerBase::handleCommand, command, handler, _1, _2, _3, _4));
176 }
177 
178 } // namespace nfd
179 
180 #endif // NFD_DAEMON_MGMT_MANAGER_BASE_HPP
a collection of common functions shared by all NFD managers, such as communicating with the dispatche...
represents parameters in a ControlCommand request or response
std::function< void(const Block &notification)> PostNotification
a function to post a notification
Definition: dispatcher.hpp:123
represents a dispatcher on server side of NFD Management protocol
Definition: dispatcher.hpp:129
Error(const std::string &what)
base class of NFD ControlCommand
STL namespace.
represents an Interest packet
Definition: interest.hpp:45
std::function< void(RejectReply act)> RejectContinuation
a function to be called if authorization is rejected
Definition: dispatcher.hpp:60
std::function< void(const std::string &requester)> AcceptContinuation
a function to be called if authorization is successful
Definition: dispatcher.hpp:45
ndn::mgmt::ControlResponse ControlResponse
Copyright (c) 2011-2015 Regents of the University of California.
Definition: ndn-common.hpp:40
Name abstraction to represent an absolute name.
Definition: name.hpp:46
#define PUBLIC_WITH_TESTS_ELSE_PROTECTED
Definition: common.hpp:38
std::function< void(const ControlResponse &resp)> CommandContinuation
a function to be called after ControlCommandHandler completes
Definition: dispatcher.hpp:95
base class for a struct that contains ControlCommand parameters
ManagerBase(Dispatcher &dispatcher, CommandValidator &validator, const std::string &module)
Name & append(const uint8_t *value, size_t valueLength)
Append a new component, copying from value of length valueLength.
Definition: name.hpp:148
void registerCommandHandler(const std::string &verb, const ControlCommandHandler &handler)
#define PUBLIC_WITH_TESTS_ELSE_PRIVATE
Definition: common.hpp:39
Name PartialName
Partial name abstraction to represent an arbitrary sequence of name components.
Definition: name.hpp:36
ndn::mgmt::PostNotification registerNotificationStream(const std::string &verb)
void registerStatusDatasetHandler(const std::string &verb, const ndn::mgmt::StatusDatasetHandler &handler)
function< void(const ControlCommand &command, const Name &prefix, const Interest &interest, const ControlParameters &parameters, const ndn::mgmt::CommandContinuation done)> ControlCommandHandler
std::function< void(const Name &prefix, const Interest &interest, StatusDatasetContext &context)> StatusDatasetHandler
a function to handle a StatusDataset request
Definition: dispatcher.hpp:117