blob: 54f744ff6a5796749c57361fb3549fda48a36479 [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
* Copyright (c) 2013-2014 Regents of the University of California.
*
* This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
*
* ndn-cxx library is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later version.
*
* ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received copies of the GNU General Public License and GNU Lesser
* General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
* <http://www.gnu.org/licenses/>.
*
* See AUTHORS.md for complete list of ndn-cxx authors and contributors.
*/
#ifndef NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_HPP
#define NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_HPP
#include "../security/identity-certificate.hpp"
namespace ndn {
namespace nfd {
/** \ingroup management
* \brief contains options for ControlCommand execution
* \note This type is intentionally copyable
*/
class CommandOptions
{
public:
CommandOptions();
/** \return command timeout
*/
const time::milliseconds&
getTimeout() const
{
return m_timeout;
}
/** \brief sets command timeout
* \param timeout the new command timeout, must be positive
* \throw std::out_of_range if timeout is non-positive
* \return self
*/
CommandOptions&
setTimeout(const time::milliseconds& timeout);
/** \return command prefix
*/
const Name&
getPrefix() const
{
return m_prefix;
}
/** \brief sets command prefix
* \return self
*/
CommandOptions&
setPrefix(const Name& prefix);
public: // signing parameters
/** \brief indicates the selection of signing parameters
*/
enum SigningParamsKind {
/** \brief picks the default signing identity and certificate
*/
SIGNING_PARAMS_DEFAULT,
/** \brief picks the default certificate of a specific identity Name
*/
SIGNING_PARAMS_IDENTITY,
/** \brief picks a specific identity certificate
*/
SIGNING_PARAMS_CERTIFICATE
};
/** \return selection of signing parameters
*/
SigningParamsKind
getSigningParamsKind() const
{
return m_signingParamsKind;
}
/** \return identity Name
* \pre getSigningParamsKind() == SIGNING_PARAMS_IDENTITY
*/
const Name&
getSigningIdentity() const
{
BOOST_ASSERT(m_signingParamsKind == SIGNING_PARAMS_IDENTITY);
return m_identity;
}
/** \return certificate Name
* \pre getSigningParamsKind() == SIGNING_PARAMS_CERTIFICATE
*/
const Name&
getSigningCertificate() const
{
BOOST_ASSERT(m_signingParamsKind == SIGNING_PARAMS_CERTIFICATE);
return m_identity;
}
/** \brief chooses to use default identity and certificate
* \post getSigningParamsKind() == SIGNING_PARAMS_DEFAULT
* \return self
*/
CommandOptions&
setSigningDefault()
{
m_signingParamsKind = SIGNING_PARAMS_DEFAULT;
return *this;
}
/** \brief chooses to use a specific identity and its default certificate
* \post getSigningParamsKind() == SIGNING_PARAMS_IDENTITY
* \post getIdentityName() == identityName
* \return self
*/
CommandOptions&
setSigningIdentity(const Name& identityName);
/** \brief chooses to use a specific identity certificate
* \param certificateName identity certificate Name
* \throw std::invalid_argument if certificateName is invalid
* \post getSigningParamsKind() == SIGNING_PARAMS_CERTIFICATE
* \post getIdentityCertificate() is a copy of certificate
* \return self
*/
CommandOptions&
setSigningCertificate(const Name& certificateName);
/** \brief chooses to use a specific identity certificate
* \details This is equivalent to .setIdentityCertificate(certificate.getName())
*/
CommandOptions&
setSigningCertificate(const IdentityCertificate& certificate);
public:
/** \brief gives the default command timeout: 10000ms
*/
static const time::milliseconds DEFAULT_TIMEOUT;
/** \brief gives the default command prefix: ndn:/localhost/nfd
*/
static const Name DEFAULT_PREFIX;
private:
time::milliseconds m_timeout;
Name m_prefix;
SigningParamsKind m_signingParamsKind;
Name m_identity; // identityName or certificateName
};
} // namespace nfd
} // namespace ndn
#endif // NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_HPP