blob: 4ca0a6b3ba1567c7180bd59312965a8c050d0188 [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
* Copyright (c) 2013-2016 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/signing-info.hpp"
#define NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
namespace ndn {
namespace security {
namespace v1 {
class IdentityCertificate;
} // namespace v1
} // namespace security
namespace nfd {
/** \ingroup management
* \brief contains options for ControlCommand execution
* \note This type is intentionally copyable
*/
class CommandOptions
{
public:
/** \brief constructs CommandOptions
* \post getTimeout() == DEFAULT_TIMEOUT
* \post getPrefix() == DEFAULT_PREFIX
* \post getSigningInfo().getSignerType() == SIGNER_TYPE_NULL
*/
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);
/** \return signing parameters
*/
const security::SigningInfo&
getSigningInfo() const
{
return m_signingInfo;
}
/** \brief sets signing parameters
* \return self
*/
CommandOptions&
setSigningInfo(const security::SigningInfo& signingInfo);
#ifdef NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
public: // signing parameters
/** \deprecated use getSigningInfo and setSigningInfo
* \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
};
/** \deprecated use getSigningInfo and setSigningInfo
* \return selection of signing parameters
*/
DEPRECATED(
SigningParamsKind
getSigningParamsKind() const);
/** \deprecated use getSigningInfo and setSigningInfo
* \return identity Name
* \pre getSigningParamsKind() == SIGNING_PARAMS_IDENTITY
*/
DEPRECATED(
const Name&
getSigningIdentity() const);
/** \deprecated use getSigningInfo and setSigningInfo
* \return certificate Name
* \pre getSigningParamsKind() == SIGNING_PARAMS_CERTIFICATE
*/
DEPRECATED(
const Name&
getSigningCertificate() const);
/** \deprecated use getSigningInfo and setSigningInfo
* \brief chooses to use default identity and certificate
* \post getSigningParamsKind() == SIGNING_PARAMS_DEFAULT
* \return self
*/
DEPRECATED(
CommandOptions&
setSigningDefault());
/** \deprecated use getSigningInfo and setSigningInfo
* \brief chooses to use a specific identity and its default certificate
* \post getSigningParamsKind() == SIGNING_PARAMS_IDENTITY
* \post getIdentityName() == identityName
* \return self
*/
DEPRECATED(
CommandOptions&
setSigningIdentity(const Name& identityName));
/** \deprecated use getSigningInfo and setSigningInfo
* \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 getSigningCertificate() == certificateName
* \return self
*/
DEPRECATED(
CommandOptions&
setSigningCertificate(const Name& certificateName));
/** \deprecated use getSigningInfo and setSigningInfo
* \brief chooses to use a specific identity certificate
* \details This is equivalent to .setIdentityCertificate(certificate.getName())
*/
DEPRECATED(
CommandOptions&
setSigningCertificate(const security::v1::IdentityCertificate& certificate));
#endif // NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
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;
security::SigningInfo m_signingInfo;
};
} // namespace nfd
} // namespace ndn
#endif // NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_HPP