blob: a664c9e0c73defa73cf1e8aaaf522387214039f6 [file] [log] [blame]
Yanbiao Li698f4fe2015-08-19 16:30:16 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento87fc0f82018-04-11 23:43:51 -04002/*
Davide Pesavento2c9d2ca2024-01-27 16:36:51 -05003 * Copyright (c) 2014-2024, Regents of the University of California,
Yanbiao Li698f4fe2015-08-19 16:30:16 -07004 * 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
Davide Pesavento78ddcab2019-02-28 22:00:03 -050026#ifndef NFD_DAEMON_MGMT_MANAGER_BASE_HPP
27#define NFD_DAEMON_MGMT_MANAGER_BASE_HPP
Yanbiao Li698f4fe2015-08-19 16:30:16 -070028
Davide Pesavento78ddcab2019-02-28 22:00:03 -050029#include "command-authenticator.hpp"
Yanbiao Li698f4fe2015-08-19 16:30:16 -070030
31#include <ndn-cxx/mgmt/dispatcher.hpp>
Junxiao Shi25c6ce42016-09-09 13:49:59 +000032#include <ndn-cxx/mgmt/nfd/control-command.hpp>
Junxiao Shi25c6ce42016-09-09 13:49:59 +000033#include <ndn-cxx/mgmt/nfd/control-parameters.hpp>
Davide Pesavento78ddcab2019-02-28 22:00:03 -050034#include <ndn-cxx/mgmt/nfd/control-response.hpp>
Yanbiao Li698f4fe2015-08-19 16:30:16 -070035
Davide Pesavento2c9d2ca2024-01-27 16:36:51 -050036#include <functional>
37
Yanbiao Li698f4fe2015-08-19 16:30:16 -070038namespace nfd {
39
40using ndn::mgmt::Dispatcher;
Yanbiao Li698f4fe2015-08-19 16:30:16 -070041using ndn::nfd::ControlCommand;
Yanbiao Li698f4fe2015-08-19 16:30:16 -070042using ndn::nfd::ControlParameters;
Davide Pesavento78ddcab2019-02-28 22:00:03 -050043using ndn::nfd::ControlResponse;
Yanbiao Li698f4fe2015-08-19 16:30:16 -070044
45/**
Davide Pesavento78ddcab2019-02-28 22:00:03 -050046 * @brief A collection of common functions shared by all NFD managers,
Yanbiao Li698f4fe2015-08-19 16:30:16 -070047 * such as communicating with the dispatcher and command validator.
48 */
Yanbiao Lidf846e52016-01-30 21:53:47 -080049class ManagerBase : noncopyable
Yanbiao Li698f4fe2015-08-19 16:30:16 -070050{
51public:
52 class Error : public std::runtime_error
53 {
54 public:
Davide Pesavento78ddcab2019-02-28 22:00:03 -050055 using std::runtime_error::runtime_error;
Yanbiao Li698f4fe2015-08-19 16:30:16 -070056 };
57
Junxiao Shi9ddf1b52016-08-22 03:58:55 +000058 const std::string&
59 getModule() const
60 {
61 return m_module;
62 }
63
Davide Pesavento78ddcab2019-02-28 22:00:03 -050064protected:
65 /**
Davide Pesaventoae430302023-05-11 01:42:46 -040066 * @warning If you use this constructor, you MUST override makeAuthorization().
Davide Pesavento78ddcab2019-02-28 22:00:03 -050067 */
Davide Pesaventoae430302023-05-11 01:42:46 -040068 ManagerBase(std::string_view module, Dispatcher& dispatcher);
Davide Pesavento78ddcab2019-02-28 22:00:03 -050069
Davide Pesaventoae430302023-05-11 01:42:46 -040070 ManagerBase(std::string_view module, Dispatcher& dispatcher,
Davide Pesavento78ddcab2019-02-28 22:00:03 -050071 CommandAuthenticator& authenticator);
72
Davide Pesavento0a05f7a2023-10-16 20:28:06 -040073 // ManagerBase is not supposed to be used polymorphically, so we make the destructor
74 // protected to prevent deletion of derived objects through a pointer to the base class,
75 // which would be UB when the destructor is non-virtual.
76 ~ManagerBase();
77
Davide Pesavento264af772021-02-09 21:48:24 -050078NFD_PUBLIC_WITH_TESTS_ELSE_PROTECTED: // registrations to the dispatcher
Yanbiao Li698f4fe2015-08-19 16:30:16 -070079 // difference from mgmt::ControlCommand: accepts nfd::ControlParameters
Davide Pesavento87fc0f82018-04-11 23:43:51 -040080 using ControlCommandHandler = std::function<void(const ControlCommand& command,
81 const Name& prefix, const Interest& interest,
82 const ControlParameters& parameters,
83 const ndn::mgmt::CommandContinuation done)>;
Yanbiao Li698f4fe2015-08-19 16:30:16 -070084
85 template<typename Command>
86 void
87 registerCommandHandler(const std::string& verb,
88 const ControlCommandHandler& handler);
89
90 void
91 registerStatusDatasetHandler(const std::string& verb,
92 const ndn::mgmt::StatusDatasetHandler& handler);
93
94 ndn::mgmt::PostNotification
95 registerNotificationStream(const std::string& verb);
96
Davide Pesavento264af772021-02-09 21:48:24 -050097NFD_PUBLIC_WITH_TESTS_ELSE_PROTECTED: // helpers
Yanbiao Li698f4fe2015-08-19 16:30:16 -070098 /**
Davide Pesavento6d6f2072022-09-12 23:08:34 -040099 * @brief Extracts the name from the %KeyLocator of a ControlCommand request.
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700100 *
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500101 * This is called after the signature has been validated.
Davide Pesavento6d6f2072022-09-12 23:08:34 -0400102 * Returns an empty string if %SignatureInfo or %KeyLocator are missing or malformed.
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700103 */
Davide Pesavento6d6f2072022-09-12 23:08:34 -0400104 static std::string
105 extractSigner(const Interest& interest);
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700106
Davide Pesavento264af772021-02-09 21:48:24 -0500107NFD_PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Junxiao Shi21738402016-08-19 19:48:00 +0000108 /**
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500109 * @brief Returns an authorization function for a specific management module and verb.
Junxiao Shi21738402016-08-19 19:48:00 +0000110 */
111 virtual ndn::mgmt::Authorization
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500112 makeAuthorization(const std::string& verb);
Junxiao Shi21738402016-08-19 19:48:00 +0000113
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700114 /**
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500115 * @brief Validates the @p parameters for a given @p command.
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700116 *
117 * @param parameters the original ControlParameters
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700118 * @return whether the original ControlParameters can be validated
119 */
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400120 [[nodiscard]] static bool
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500121 validateParameters(const ControlCommand& command,
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700122 const ndn::mgmt::ControlParameters& parameters);
123
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500124 /**
125 * @brief Handles a control command.
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700126 */
127 static void
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500128 handleCommand(shared_ptr<ControlCommand> command,
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700129 const ControlCommandHandler& handler,
130 const Name& prefix, const Interest& interest,
131 const ndn::mgmt::ControlParameters& params,
Davide Pesavento412c9822021-07-02 00:21:05 -0400132 const ndn::mgmt::CommandContinuation& done);
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700133
134 /**
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500135 * @brief Generates the relative prefix for a handler by appending the verb name to the module name.
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700136 *
137 * @param verb the verb name
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700138 * @return the generated relative prefix
139 */
140 PartialName
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500141 makeRelPrefix(const std::string& verb)
142 {
143 return PartialName(m_module).append(verb);
144 }
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700145
146private:
Junxiao Shi9ddf1b52016-08-22 03:58:55 +0000147 std::string m_module;
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500148 Dispatcher& m_dispatcher;
149 CommandAuthenticator* m_authenticator = nullptr;
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700150};
151
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700152template<typename Command>
Davide Pesavento412c9822021-07-02 00:21:05 -0400153void
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700154ManagerBase::registerCommandHandler(const std::string& verb,
155 const ControlCommandHandler& handler)
156{
157 auto command = make_shared<Command>();
158
159 m_dispatcher.addControlCommand<ControlParameters>(
160 makeRelPrefix(verb),
Junxiao Shi21738402016-08-19 19:48:00 +0000161 makeAuthorization(verb),
Davide Pesavento412c9822021-07-02 00:21:05 -0400162 [=] (const auto& params) { return validateParameters(*command, params); },
163 [=] (auto&&... args) { handleCommand(command, handler, std::forward<decltype(args)>(args)...); });
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700164}
165
166} // namespace nfd
167
Davide Pesavento78ddcab2019-02-28 22:00:03 -0500168#endif // NFD_DAEMON_MGMT_MANAGER_BASE_HPP