validation-error.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013-2022 Regents of the University of California.
4  *
5  * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6  *
7  * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8  * terms of the GNU Lesser General Public License as published by the Free Software
9  * Foundation, either version 3 of the License, or (at your option) any later version.
10  *
11  * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13  * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14  *
15  * You should have received copies of the GNU General Public License and GNU Lesser
16  * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17  * <http://www.gnu.org/licenses/>.
18  *
19  * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20  */
21 
23 
24 namespace ndn {
25 namespace security {
26 inline namespace v2 {
27 
28 std::ostream&
29 operator<<(std::ostream& os, ValidationError::Code code)
30 {
31  switch (code) {
33  return os << "No error";
35  return os << "Signature verification failed";
37  return os << "Missing or malformed signature";
39  return os << "Cannot retrieve certificate";
41  return os << "Certificate expired or not yet valid";
43  return os << "Loop detected in certification chain";
45  return os << "Malformed certificate";
47  return os << "Exceeded validation depth limit";
49  return os << "Invalid key locator";
51  return os << "Policy violation";
53  return os << "Internal error";
55  break;
56  }
57  if (code >= ValidationError::Code::USER_MIN) {
58  return os << "Custom error code " << to_underlying(code);
59  }
60  else {
61  return os << "Unknown error code " << to_underlying(code);
62  }
63 }
64 
65 void
66 ValidationError::print(std::ostream& os) const
67 {
68  os << m_code;
69  if (!m_info.empty()) {
70  os << " (" << m_info << ")";
71  }
72 }
73 
74 } // inline namespace v2
75 } // namespace security
76 } // namespace ndn
Code
Known error codes that can be returned by the Validator interface.
@ LOOP_DETECTED
Loop detected in the certification chain.
@ MALFORMED_CERT
The certificate is malformed.
@ EXCEEDED_DEPTH_LIMIT
Exceeded validation depth limit.
@ USER_MIN
Third-party validator implementations can use error codes greater than or equal to this value to indi...
@ MALFORMED_SIGNATURE
The signature (e.g., SignatureInfo element) is missing or malformed.
@ IMPLEMENTATION_ERROR
Internal implementation error.
@ INVALID_SIGNATURE
Signature verification failed.
@ CANNOT_RETRIEVE_CERT
The certificate cannot be retrieved.
@ POLICY_ERROR
The packet violates the validation rules enforced by the policy.
@ INVALID_KEY_LOCATOR
The KeyLocator element is missing or has an invalid format.
@ EXPIRED_CERT
The certificate expired or is not yet valid.
std::ostream & operator<<(std::ostream &os, const AdditionalDescription &desc)
Definition: data.cpp:25
constexpr std::underlying_type_t< T > to_underlying(T val) noexcept
Definition: backports.hpp:125