blob: dfc630d12abea9b6fc5e377f7f98e37cb3b2181b [file] [log] [blame]
Yingdi Yuae734272015-07-04 17:38:48 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesaventof45fa212017-09-14 17:23:56 -04002/*
3 * Copyright (c) 2013-2017 Regents of the University of California.
Yingdi Yuae734272015-07-04 17:38:48 -07004 *
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#ifndef NDN_CXX_SECURITY_DETAIL_OPENSSL_HELPER_HPP
23#define NDN_CXX_SECURITY_DETAIL_OPENSSL_HELPER_HPP
24
Yingdi Yuae734272015-07-04 17:38:48 -070025#include "openssl.hpp"
Davide Pesaventof45fa212017-09-14 17:23:56 -040026#include "../security-common.hpp"
Yingdi Yuae734272015-07-04 17:38:48 -070027
28namespace ndn {
29namespace security {
30namespace detail {
31
32const EVP_MD*
33toDigestEvpMd(DigestAlgorithm algo);
34
Davide Pesaventoc21979d2017-09-16 14:52:17 -040035int
36getEvpPkeyType(EVP_PKEY* key);
37
Davide Pesaventof45fa212017-09-14 17:23:56 -040038class EvpPkeyCtx : noncopyable
Yingdi Yu202a2e92015-07-12 16:49:25 -070039{
40public:
41 explicit
42 EvpPkeyCtx(EVP_PKEY* key);
43
44 explicit
45 EvpPkeyCtx(int id);
46
47 ~EvpPkeyCtx();
48
Davide Pesaventof45fa212017-09-14 17:23:56 -040049 operator EVP_PKEY_CTX*() const
Yingdi Yu202a2e92015-07-12 16:49:25 -070050 {
51 return m_ctx;
52 }
53
54private:
55 EVP_PKEY_CTX* m_ctx;
56};
57
Davide Pesaventof45fa212017-09-14 17:23:56 -040058class Bio : noncopyable
Yingdi Yu202a2e92015-07-12 16:49:25 -070059{
60public:
Alexander Afanasyev02948ec2016-09-12 18:04:50 -070061#if OPENSSL_VERSION_NUMBER < 0x1010000fL
Davide Pesaventof45fa212017-09-14 17:23:56 -040062 using MethodPtr = BIO_METHOD*;
Alexander Afanasyev02948ec2016-09-12 18:04:50 -070063#else
Davide Pesaventof45fa212017-09-14 17:23:56 -040064 using MethodPtr = const BIO_METHOD*;
Alexander Afanasyev02948ec2016-09-12 18:04:50 -070065#endif // OPENSSL_VERSION_NUMBER < 0x1010000fL
Yingdi Yu202a2e92015-07-12 16:49:25 -070066
Davide Pesaventof45fa212017-09-14 17:23:56 -040067 explicit
68 Bio(MethodPtr method);
69
Yingdi Yu202a2e92015-07-12 16:49:25 -070070 ~Bio();
71
Davide Pesaventof45fa212017-09-14 17:23:56 -040072 operator BIO*() const
Yingdi Yu202a2e92015-07-12 16:49:25 -070073 {
74 return m_bio;
75 }
76
Davide Pesaventof45fa212017-09-14 17:23:56 -040077 bool
78 read(uint8_t* buf, size_t buflen) const noexcept;
79
80 bool
81 write(const uint8_t* buf, size_t buflen) noexcept;
82
Yingdi Yu202a2e92015-07-12 16:49:25 -070083private:
84 BIO* m_bio;
85};
86
Yingdi Yuae734272015-07-04 17:38:48 -070087} // namespace detail
88} // namespace security
89} // namespace ndn
90
91#endif // NDN_CXX_SECURITY_DETAIL_OPENSSL_HELPER_HPP