NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
command-authenticator.hpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2014-2019, 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_MGMT_COMMAND_AUTHENTICATOR_HPP
27
#define NFD_DAEMON_MGMT_COMMAND_AUTHENTICATOR_HPP
28
29
#include "
common/config-file.hpp
"
30
31
#include <
ndn-cxx/mgmt/dispatcher.hpp
>
32
33
namespace
ndn
{
34
namespace
security {
35
namespace
v2 {
36
class
Validator
;
37
}
// namespace v2
38
}
// namespace security
39
}
// namespace ndn
40
41
namespace
nfd
{
42
45
class
CommandAuthenticator
:
public
std::enable_shared_from_this<CommandAuthenticator>, noncopyable
46
{
47
public
:
48
static
shared_ptr<CommandAuthenticator>
49
create
();
50
51
void
52
setConfigFile
(
ConfigFile
& configFile);
53
59
ndn::mgmt::Authorization
60
makeAuthorization
(
const
std::string& module,
const
std::string& verb);
61
62
private
:
63
CommandAuthenticator
();
64
68
void
69
processConfig(
const
ConfigSection
& section,
bool
isDryRun,
const
std::string& filename);
70
71
private
:
73
std::unordered_map<std::string, shared_ptr<ndn::security::v2::Validator>> m_validators;
74
};
75
76
}
// namespace nfd
77
78
#endif // NFD_DAEMON_MGMT_COMMAND_AUTHENTICATOR_HPP
ndn::security::v2::Validator
Interface for validating data and interest packets.
Definition:
validator.hpp:62
config-file.hpp
nfd::CommandAuthenticator::makeAuthorization
ndn::mgmt::Authorization makeAuthorization(const std::string &module, const std::string &verb)
Definition:
command-authenticator.cpp:205
nfd::CommandAuthenticator::setConfigFile
void setConfigFile(ConfigFile &configFile)
Definition:
command-authenticator.cpp:108
nfd::CommandAuthenticator::create
static shared_ptr< CommandAuthenticator > create()
Definition:
command-authenticator.cpp:100
nfd
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-common.hpp:40
dispatcher.hpp
nfd::ConfigFile
configuration file parsing utility
Definition:
config-file.hpp:58
ndn::mgmt::Authorization
std::function< void(const Name &prefix, const Interest &interest, const ControlParameters *params, const AcceptContinuation &accept, const RejectContinuation &reject)> Authorization
a function that performs authorization
Definition:
dispatcher.hpp:77
nfd::ConfigSection
boost::property_tree::ptree ConfigSection
a config file section
Definition:
ndn-l3-protocol.hpp:39
nfd::CommandAuthenticator
Provides ControlCommand authorization according to NFD configuration file.
Definition:
command-authenticator.hpp:46
ndn
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-strategy-choice-helper.hpp:34
ndnSIM
NFD
daemon
mgmt
command-authenticator.hpp
Generated on Mon Jun 1 2020 22:32:16 for ndnSIM by
1.8.18