command-options.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
22 #include "command-options.hpp"
23 
24 #ifdef NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
25 #include "../../security/v1/identity-certificate.hpp"
26 #include "../../security/signing-helpers.hpp"
27 #endif // NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
28 
29 namespace ndn {
30 namespace nfd {
31 
32 const time::milliseconds CommandOptions::DEFAULT_TIMEOUT(10000);
33 const Name CommandOptions::DEFAULT_PREFIX("ndn:/localhost/nfd");
34 
36  : m_timeout(DEFAULT_TIMEOUT)
37  , m_prefix(DEFAULT_PREFIX)
38 {
39 }
40 
42 CommandOptions::setTimeout(const time::milliseconds& timeout)
43 {
44  if (timeout <= time::milliseconds::zero()) {
45  BOOST_THROW_EXCEPTION(std::out_of_range("Timeout must be positive"));
46  }
47 
48  m_timeout = timeout;
49  return *this;
50 }
51 
54 {
55  m_prefix = prefix;
56  return *this;
57 }
58 
61 {
62  m_signingInfo = signingInfo;
63  return *this;
64 }
65 
66 #ifdef NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
67 
70 {
71  switch (m_signingInfo.getSignerType()) {
78  default:
79  BOOST_THROW_EXCEPTION(std::out_of_range("SigningInfo::SignerType is not convertible to "
80  "CommandOptions::SigningParamsKind"));
81  }
82 }
83 
84 const Name&
86 {
87  BOOST_ASSERT(m_signingInfo.getSignerType() == security::SigningInfo::SIGNER_TYPE_ID);
88  return m_signingInfo.getSignerName();
89 }
90 
91 const Name&
93 {
94  BOOST_ASSERT(m_signingInfo.getSignerType() == security::SigningInfo::SIGNER_TYPE_CERT);
95  return m_signingInfo.getSignerName();
96 }
97 
98 CommandOptions&
100 {
101  m_signingInfo = security::SigningInfo();
102  return *this;
103 }
104 
105 CommandOptions&
106 CommandOptions::setSigningIdentity(const Name& identityName)
107 {
108  m_signingInfo = security::signingByIdentity(identityName);
109  return *this;
110 }
111 
112 static security::SigningInfo
113 makeSigningInfoFromIdentityCertificate(const Name& certificateName)
114 {
115  // A valid IdentityCertificate has at least 4 name components,
116  // as it follows `<...>/KEY/<...>/<key-id>/ID-CERT/<version>` naming model.
117  if (certificateName.size() < 4) {
118  BOOST_THROW_EXCEPTION(std::invalid_argument("Certificate is invalid"));
119  }
120 
121  return security::signingByCertificate(certificateName);
122 }
123 
124 CommandOptions&
125 CommandOptions::setSigningCertificate(const Name& certificateName)
126 {
127  m_signingInfo = makeSigningInfoFromIdentityCertificate(certificateName);
128  return *this;
129 }
130 
131 CommandOptions&
132 CommandOptions::setSigningCertificate(const security::v1::IdentityCertificate& certificate)
133 {
134  m_signingInfo = makeSigningInfoFromIdentityCertificate(certificate.getName());
135  return *this;
136 }
137 
138 #endif // NDN_MANAGEMENT_NFD_COMMAND_OPTIONS_KEEP_DEPRECATED_SIGNING_PARAMS
139 
140 } // namespace nfd
141 } // namespace ndn
const Name & getSigningIdentity() const
Copyright (c) 2013-2016 Regents of the University of California.
Definition: common.hpp:74
CommandOptions()
constructs CommandOptions
CommandOptions & setSigningCertificate(const Name &certificateName)
chooses to use a specific identity certificate
const Name & getSignerName() const
SigningParamsKind getSigningParamsKind() const
static const Name DEFAULT_PREFIX
gives the default command prefix: ndn:/localhost/nfd
SigningParamsKind
indicates the selection of signing parameters
Signing parameters passed to KeyChain.
SigningInfo signingByCertificate(const Name &certName)
CommandOptions & setTimeout(const time::milliseconds &timeout)
sets command timeout
picks the default certificate of a specific identity Name
contains options for ControlCommand execution
no signer is specified, use default setting or follow the trust schema
Name abstraction to represent an absolute name.
Definition: name.hpp:46
CommandOptions & setSigningDefault()
chooses to use default identity and certificate
signer is a certificate, use it directly
CommandOptions & setSigningInfo(const security::SigningInfo &signingInfo)
sets signing parameters
CommandOptions & setSigningIdentity(const Name &identityName)
chooses to use a specific identity and its default certificate
picks a specific identity certificate
SigningInfo signingByIdentity(const Name &identityName)
static const time::milliseconds DEFAULT_TIMEOUT
gives the default command timeout: 10000ms
signer is an identity, use its default key and default certificate
const Name & getSigningCertificate() const
SignerType getSignerType() const
picks the default signing identity and certificate
CommandOptions & setPrefix(const Name &prefix)
sets command prefix