NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.3: NDN, CCN, CCNx, content centric networks
API Documentation
openssl-helper.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013-2017 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 
22 #include "openssl-helper.hpp"
23 
24 namespace ndn {
25 namespace security {
26 namespace detail {
27 
28 const EVP_MD*
30 {
31  switch (algo) {
33  return EVP_sha224();
35  return EVP_sha256();
37  return EVP_sha384();
39  return EVP_sha512();
40  default:
41  return nullptr;
42  }
43 }
44 
45 int
46 getEvpPkeyType(EVP_PKEY* key)
47 {
48  return
49 #if OPENSSL_VERSION_NUMBER < 0x1010000fL
50  EVP_PKEY_type(key->type);
51 #else
52  EVP_PKEY_base_id(key);
53 #endif // OPENSSL_VERSION_NUMBER < 0x1010000fL
54 }
55 
57 #if OPENSSL_VERSION_NUMBER < 0x1010000fL
58  : m_ctx(EVP_MD_CTX_create())
59 #else
60  : m_ctx(EVP_MD_CTX_new())
61 #endif
62 {
63  if (m_ctx == nullptr)
64  BOOST_THROW_EXCEPTION(std::runtime_error("EVP_MD_CTX creation failed"));
65 }
66 
68 {
69 #if OPENSSL_VERSION_NUMBER < 0x1010000fL
70  EVP_MD_CTX_destroy(m_ctx);
71 #else
72  EVP_MD_CTX_free(m_ctx);
73 #endif
74 }
75 
76 EvpPkeyCtx::EvpPkeyCtx(EVP_PKEY* key)
77  : m_ctx(EVP_PKEY_CTX_new(key, nullptr))
78 {
79  if (m_ctx == nullptr)
80  BOOST_THROW_EXCEPTION(std::runtime_error("EVP_PKEY_CTX creation failed"));
81 }
82 
84  : m_ctx(EVP_PKEY_CTX_new_id(id, nullptr))
85 {
86  if (m_ctx == nullptr)
87  BOOST_THROW_EXCEPTION(std::runtime_error("EVP_PKEY_CTX creation failed"));
88 }
89 
91 {
92  EVP_PKEY_CTX_free(m_ctx);
93 }
94 
96  : m_bio(BIO_new(method))
97 {
98  if (m_bio == nullptr)
99  BOOST_THROW_EXCEPTION(std::runtime_error("BIO creation failed"));
100 }
101 
103 {
104  BIO_free_all(m_bio);
105 }
106 
107 bool
108 Bio::read(uint8_t* buf, size_t buflen) const noexcept
109 {
110  BOOST_ASSERT(buflen <= std::numeric_limits<int>::max());
111  int n = BIO_read(m_bio, buf, static_cast<int>(buflen));
112  return n >= 0 && static_cast<size_t>(n) == buflen;
113 }
114 
115 bool
116 Bio::write(const uint8_t* buf, size_t buflen) noexcept
117 {
118  BOOST_ASSERT(buflen <= std::numeric_limits<int>::max());
119  int n = BIO_write(m_bio, buf, static_cast<int>(buflen));
120  return n >= 0 && static_cast<size_t>(n) == buflen;
121 }
122 
123 } // namespace detail
124 } // namespace security
125 } // namespace ndn
Copyright (c) 2011-2015 Regents of the University of California.
int getEvpPkeyType(EVP_PKEY *key)
Catch-all error for security policy errors that don&#39;t fit in other categories.
Definition: base.hpp:79
bool read(uint8_t *buf, size_t buflen) const noexcept
const EVP_MD * digestAlgorithmToEvpMd(DigestAlgorithm algo)
Use the SHA256 hash of the public key as the key id.
bool write(const uint8_t *buf, size_t buflen) noexcept