blob: f33afac09468dae3f2b70b23bc881ef4e8869268 [file] [log] [blame]
Junxiao Shi38f4ce92016-08-04 10:01:52 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014-2016, 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
Junxiao Shi331ade72016-08-19 14:07:19 +000026#ifndef NFD_TOOLS_NFDC_MODULE_HPP
27#define NFD_TOOLS_NFDC_MODULE_HPP
Junxiao Shi38f4ce92016-08-04 10:01:52 +000028
Junxiao Shi9f5b01d2016-08-05 03:54:28 +000029#include "core/common.hpp"
Junxiao Shi38f4ce92016-08-04 10:01:52 +000030#include <ndn-cxx/management/nfd-controller.hpp>
31
32namespace nfd {
33namespace tools {
Junxiao Shi331ade72016-08-19 14:07:19 +000034namespace nfdc {
Junxiao Shi38f4ce92016-08-04 10:01:52 +000035
36using ndn::nfd::Controller;
37using ndn::nfd::CommandOptions;
38
39/** \brief provides access to an NFD management module
40 * \note This type is an interface. It should not have member fields.
41 */
42class Module
43{
44public:
45 virtual
46 ~Module() = default;
47
48 /** \brief collect status from NFD
49 * \pre no other fetchStatus is in progress
50 * \param controller a controller through which StatusDataset can be requested
51 * \param onSuccess invoked when status has been collected into this instance
52 * \param onFailure passed to controller.fetch
53 * \param options passed to controller.fetch
54 */
55 virtual void
56 fetchStatus(Controller& controller,
57 const function<void()>& onSuccess,
58 const Controller::CommandFailCallback& onFailure,
59 const CommandOptions& options) = 0;
60
61 /** \brief format collected status as XML
62 * \pre fetchStatus has been successful
63 * \param os output stream
64 */
65 virtual void
66 formatStatusXml(std::ostream& os) const = 0;
67
68 /** \brief format collected status as text
69 * \pre fetchStatus has been successful
70 * \param os output stream
71 */
72 virtual void
73 formatStatusText(std::ostream& os) const = 0;
74};
75
Junxiao Shi331ade72016-08-19 14:07:19 +000076} // namespace nfdc
Junxiao Shi38f4ce92016-08-04 10:01:52 +000077} // namespace tools
78} // namespace nfd
79
Junxiao Shi331ade72016-08-19 14:07:19 +000080#endif // NFD_TOOLS_NFDC_MODULE_HPP