Monero
Loading...
Searching...
No Matches
net_ssl.h
Go to the documentation of this file.
1// Copyright (c) 2006-2013, Andrey N. Sabelnikov, www.sabelnikov.net
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are met:
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above copyright
9// notice, this list of conditions and the following disclaimer in the
10// documentation and/or other materials provided with the distribution.
11// * Neither the name of the Andrey N. Sabelnikov nor the
12// names of its contributors may be used to endorse or promote products
13// derived from this software without specific prior written permission.
14//
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER BE LIABLE FOR ANY
19// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25//
26
27
28
29#ifndef _NET_SSL_H
30#define _NET_SSL_H
31
32#include <chrono>
33#include <stdint.h>
34#include <string>
35#include <vector>
36#include <boost/utility/string_ref.hpp>
37#include <boost/asio/io_context.hpp>
38#include <boost/asio/ip/tcp.hpp>
39#include <boost/asio/ssl.hpp>
40#include <boost/filesystem/path.hpp>
41#include <boost/system/error_code.hpp>
42
43#define SSL_FINGERPRINT_SIZE 32
44
45namespace epee
46{
47namespace net_utils
48{
54
62
64 {
65 std::string private_key_path;
66 std::string certificate_path;
67
69 void use_ssl_certificate(boost::asio::ssl::context &ssl_context) const;
70 };
71
77 {
78 // force sorted behavior in private
79 std::vector<std::vector<std::uint8_t>> fingerprints_;
80
81 public:
82 std::string ca_path;
86
95
97 ssl_options_t(std::vector<std::vector<std::uint8_t>> fingerprints, std::string ca_path);
98
99 ssl_options_t(const ssl_options_t&) = default;
101
104
106 explicit operator bool() const noexcept { return support != ssl_support_t::e_ssl_support_disabled; }
107
109 bool has_strong_verification(boost::string_ref host) const noexcept;
110
112 bool has_fingerprint(boost::asio::ssl::verify_context &ctx) const;
113
115 void configure(
116 boost::asio::ssl::stream<boost::asio::ip::tcp::socket> &socket,
117 boost::asio::ssl::stream_base::handshake_type type,
118 const std::string& host = {}) const;
119 boost::asio::ssl::context create_context() const;
120
140 bool handshake(
141 boost::asio::io_context& io_context,
142 boost::asio::ssl::stream<boost::asio::ip::tcp::socket> &socket,
143 boost::asio::ssl::stream_base::handshake_type type,
144 boost::asio::const_buffer buffer = {},
145 const std::string& host = {},
146 std::chrono::milliseconds timeout = std::chrono::seconds(15)) const;
147 };
148
149 // https://security.stackexchange.com/questions/34780/checking-client-hello-for-https-classification
150 constexpr size_t get_ssl_magic_size() { return 9; }
151 bool is_ssl(const unsigned char *data, size_t len);
152 bool ssl_support_from_string(ssl_support_t &ssl, boost::string_ref s);
153
154 bool create_ec_ssl_certificate(EVP_PKEY *&pkey, X509 *&cert);
155 bool create_rsa_ssl_certificate(EVP_PKEY *&pkey, X509 *&cert);
156
158 boost::system::error_code store_ssl_keys(boost::asio::ssl::context& ssl, const boost::filesystem::path& base);
159}
160}
161
162#endif //_NET_SSL_H
#define s(x, c)
Definition aesb.c:47
boost::asio::ssl::context create_context() const
Definition net_ssl.cpp:304
bool handshake(boost::asio::io_context &io_context, boost::asio::ssl::stream< boost::asio::ip::tcp::socket > &socket, boost::asio::ssl::stream_base::handshake_type type, boost::asio::const_buffer buffer={}, const std::string &host={}, std::chrono::milliseconds timeout=std::chrono::seconds(15)) const
Definition net_ssl.cpp:554
void configure(boost::asio::ssl::stream< boost::asio::ip::tcp::socket > &socket, boost::asio::ssl::stream_base::handshake_type type, const std::string &host={}) const
configure ssl_stream handshake verification
Definition net_ssl.cpp:501
ssl_verification_t verification
Definition net_ssl.h:85
std::string ca_path
Definition net_ssl.h:82
ssl_options_t(const ssl_options_t &)=default
ssl_options_t(ssl_support_t support)
Verification is set to system ca unless SSL is disabled.
Definition net_ssl.h:88
bool has_strong_verification(boost::string_ref host) const noexcept
Definition net_ssl.cpp:444
ssl_options_t & operator=(const ssl_options_t &)=default
std::vector< std::vector< std::uint8_t > > fingerprints_
Definition net_ssl.h:79
ssl_authentication_t auth
Definition net_ssl.h:83
ssl_options_t(ssl_options_t &&)=default
bool has_fingerprint(boost::asio::ssl::verify_context &ctx) const
Search against internal fingerprints. Always false if behavior() != user_certificate_check.
Definition net_ssl.cpp:463
ssl_options_t & operator=(ssl_options_t &&)=default
#define const
Definition ipfrdr.c:80
Definition base.py:1
ssl_verification_t
Definition net_ssl.h:56
@ user_certificates
Verify peer via specific (non-chain) certificate(s) only.
Definition net_ssl.h:59
@ none
Do not verify peer.
Definition net_ssl.h:57
@ system_ca
Verify peer via system ca only (do not inspect user certificates).
Definition net_ssl.h:58
@ user_ca
Verify peer via specific (possibly chain) certificate(s) only.
Definition net_ssl.h:60
boost::system::error_code store_ssl_keys(boost::asio::ssl::context &ssl, const boost::filesystem::path &base)
Store private key for ssl at base + ".key" unencrypted and certificate for ssl at base + "....
Definition net_ssl.cpp:667
bool is_ssl(const unsigned char *data, size_t len)
Definition net_ssl.cpp:424
constexpr size_t get_ssl_magic_size()
Definition net_ssl.h:150
bool ssl_support_from_string(ssl_support_t &ssl, boost::string_ref s)
Definition net_ssl.cpp:654
bool create_rsa_ssl_certificate(EVP_PKEY *&pkey, X509 *&cert)
Definition net_ssl.cpp:143
bool create_ec_ssl_certificate(EVP_PKEY *&pkey, X509 *&cert)
ssl_support_t
Definition net_ssl.h:49
@ e_ssl_support_disabled
Definition net_ssl.h:50
@ e_ssl_support_autodetect
Definition net_ssl.h:52
@ e_ssl_support_enabled
Definition net_ssl.h:51
TODO: (mj-xmr) This will be reduced in an another PR.
Definition byte_slice.h:40
Definition support.py:1
unsigned char uint8_t
Definition stdint.h:124
std::string certificate_path
Certificate used for authentication to peer.
Definition net_ssl.h:66
std::string private_key_path
Private key used for authentication.
Definition net_ssl.h:65
void use_ssl_certificate(boost::asio::ssl::context &ssl_context) const
Load private_key_path and certificate_path into ssl_context.
Definition net_ssl.cpp:413
std::string data
Definition base58.cpp:37