prevent dependency on openssl from leaking outside of libtorrent (libssl and libcrypto should not be a usage requirement). This cleans up most tests to build without having to also link against openssl

This commit is contained in:
Arvid Norberg 2017-10-09 01:21:19 +02:00 committed by Arvid Norberg
parent 75f6b95050
commit 830ef0bedd
17 changed files with 108 additions and 48 deletions

View File

@ -567,6 +567,7 @@ lib advapi32 : : <name>advapi32 ;
lib user32 : : <name>user32 ; lib user32 : : <name>user32 ;
lib shell32 : : <name>shell32 ; lib shell32 : : <name>shell32 ;
lib gdi32 : : <name>gdi32 ; lib gdi32 : : <name>gdi32 ;
lib z : : <link>shared <name>z ;
lib crypto lib crypto
: # sources : # sources
@ -616,7 +617,6 @@ lib libiconv : : <name>iconv <link>shared <search>/usr/local/lib ;
# openssl on linux/bsd etc. # openssl on linux/bsd etc.
lib gcrypt : : <name>gcrypt <link>shared <search>/opt/local/lib ; lib gcrypt : : <name>gcrypt <link>shared <search>/opt/local/lib ;
lib z : : <link>shared <name>z ;
lib dl : : <link>shared <name>dl ; lib dl : : <link>shared <name>dl ;
# time functions used on linux require librt # time functions used on linux require librt

View File

@ -151,8 +151,9 @@ my-python-extension libtorrent
<toolset>darwin:<cxxflags>-Wno-deprecated-declarations <toolset>darwin:<cxxflags>-Wno-deprecated-declarations
<toolset>darwin:<cxxflags>-Wno-unused-command-line-argument <toolset>darwin:<cxxflags>-Wno-unused-command-line-argument
<conditional>@libtorrent_linking <conditional>@libtorrent_linking
<crypto>openssl:<library>/torrent//ssl
<crypto>openssl:<library>/torrent//crypto
: # usage-requirements : # usage-requirements
<conditional>@libtorrent_linking
<suppress-import-lib>false <suppress-import-lib>false
; ;

View File

@ -36,7 +36,10 @@ POSSIBILITY OF SUCH DAMAGE.
#include <libtorrent/socks5_stream.hpp> #include <libtorrent/socks5_stream.hpp>
#include <boost/asio/error.hpp> #include <boost/asio/error.hpp>
#if defined TORRENT_USE_OPENSSL #if defined TORRENT_USE_OPENSSL
#include <boost/asio/ssl/error.hpp> #include <boost/asio/ssl.hpp>
#endif
#if TORRENT_USE_I2P
#include <libtorrent/i2p_stream.hpp>
#endif #endif
#include "boost_python.hpp" #include "boost_python.hpp"

View File

@ -55,7 +55,14 @@ POSSIBILITY OF SUCH DAMAGE.
#endif #endif
#ifdef TORRENT_USE_OPENSSL #ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/context.hpp> // there is no forward declaration header for asio
namespace boost {
namespace asio {
namespace ssl {
struct context;
}
}
}
#endif #endif
#include "libtorrent/aux_/disable_warnings_pop.hpp" #include "libtorrent/aux_/disable_warnings_pop.hpp"

View File

@ -46,7 +46,14 @@ POSSIBILITY OF SUCH DAMAGE.
#include <string> #include <string>
#ifdef TORRENT_USE_OPENSSL #ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/context.hpp> // there is no forward declaration header for asio
namespace boost {
namespace asio {
namespace ssl {
struct context;
}
}
}
#endif #endif
#include "libtorrent/aux_/disable_warnings_pop.hpp" #include "libtorrent/aux_/disable_warnings_pop.hpp"

View File

@ -76,6 +76,18 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/debug.hpp" #include "libtorrent/debug.hpp"
#include "libtorrent/aux_/file_progress.hpp" #include "libtorrent/aux_/file_progress.hpp"
#ifdef TORRENT_USE_OPENSSL
// there is no forward declaration header for asio
namespace boost {
namespace asio {
namespace ssl {
struct context;
class verify_context;
}
}
}
#endif
#if TORRENT_COMPLETE_TYPES_REQUIRED #if TORRENT_COMPLETE_TYPES_REQUIRED
#include "libtorrent/peer_connection.hpp" #include "libtorrent/peer_connection.hpp"
#endif #endif

View File

@ -51,7 +51,14 @@ POSSIBILITY OF SUCH DAMAGE.
#include <boost/unordered_map.hpp> #include <boost/unordered_map.hpp>
#ifdef TORRENT_USE_OPENSSL #ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/context.hpp> // there is no forward declaration header for asio
namespace boost {
namespace asio {
namespace ssl {
struct context;
}
}
}
#endif #endif
#include "libtorrent/aux_/disable_warnings_pop.hpp" #include "libtorrent/aux_/disable_warnings_pop.hpp"

View File

@ -36,7 +36,6 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/socket.hpp" #include "libtorrent/socket.hpp"
#include "libtorrent/error_code.hpp" #include "libtorrent/error_code.hpp"
#include "libtorrent/broadcast_socket.hpp" #include "libtorrent/broadcast_socket.hpp"
#include "libtorrent/http_connection.hpp"
#include "libtorrent/thread.hpp" #include "libtorrent/thread.hpp"
#include "libtorrent/deadline_timer.hpp" #include "libtorrent/deadline_timer.hpp"
#include "libtorrent/enum_net.hpp" #include "libtorrent/enum_net.hpp"
@ -51,6 +50,8 @@ POSSIBILITY OF SUCH DAMAGE.
namespace libtorrent namespace libtorrent
{ {
struct http_connection;
class http_parser;
namespace upnp_errors namespace upnp_errors
{ {
@ -300,26 +301,13 @@ private:
struct rootdevice struct rootdevice
{ {
rootdevice(): port(0) rootdevice();
, lease_duration(default_lease_time)
, supports_specific_external(true)
, disabled(false)
, non_router(false)
{
#if TORRENT_USE_ASSERTS
magic = 1337;
#endif
}
#if TORRENT_USE_ASSERTS #if TORRENT_USE_ASSERTS
~rootdevice() ~rootdevice();
{
TORRENT_ASSERT(magic == 1337);
magic = 0;
}
#if __cplusplus >= 201103L #if __cplusplus >= 201103L
rootdevice(rootdevice const&) = default; rootdevice(rootdevice const&);
rootdevice& operator=(rootdevice const&) = default; rootdevice& operator=(rootdevice const&);
#endif #endif
#endif #endif
@ -361,13 +349,7 @@ private:
#if TORRENT_USE_ASSERTS #if TORRENT_USE_ASSERTS
int magic; int magic;
#endif #endif
void close() const void close() const;
{
TORRENT_ASSERT(magic == 1337);
if (!upnp_connection) return;
upnp_connection->close();
upnp_connection.reset();
}
bool operator<(rootdevice const& rhs) const bool operator<(rootdevice const& rhs) const
{ return url < rhs.url; } { return url < rhs.url; }

View File

@ -53,6 +53,10 @@ POSSIBILITY OF SUCH DAMAGE.
#include <algorithm> #include <algorithm>
#include <sstream> #include <sstream>
#ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/context.hpp>
#endif
#include "libtorrent/aux_/disable_warnings_pop.hpp" #include "libtorrent/aux_/disable_warnings_pop.hpp"
namespace libtorrent { namespace libtorrent {

View File

@ -45,6 +45,10 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/udp_tracker_connection.hpp" #include "libtorrent/udp_tracker_connection.hpp"
#include "libtorrent/aux_/session_impl.hpp" #include "libtorrent/aux_/session_impl.hpp"
#ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/context.hpp>
#endif
using boost::tuples::make_tuple; using boost::tuples::make_tuple;
using boost::tuples::tuple; using boost::tuples::tuple;
@ -55,7 +59,6 @@ namespace
minimum_tracker_response_length = 3, minimum_tracker_response_length = 3,
http_buffer_size = 2048 http_buffer_size = 2048
}; };
} }
namespace libtorrent namespace libtorrent

View File

@ -40,6 +40,7 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/random.hpp" #include "libtorrent/random.hpp"
#include "libtorrent/aux_/time.hpp" // for aux::time_now() #include "libtorrent/aux_/time.hpp" // for aux::time_now()
#include "libtorrent/aux_/escape_string.hpp" // for convert_from_native #include "libtorrent/aux_/escape_string.hpp" // for convert_from_native
#include "libtorrent/http_connection.hpp"
#if defined TORRENT_ASIO_DEBUGGING #if defined TORRENT_ASIO_DEBUGGING
#include "libtorrent/debug.hpp" #include "libtorrent/debug.hpp"
@ -69,6 +70,38 @@ namespace upnp_errors
static error_code ignore_error; static error_code ignore_error;
upnp::rootdevice::rootdevice()
: port(0)
, lease_duration(default_lease_time)
, supports_specific_external(true)
, disabled(false)
, non_router(false)
{
#if TORRENT_USE_ASSERTS
magic = 1337;
#endif
}
void upnp::rootdevice::close() const
{
TORRENT_ASSERT(magic == 1337);
if (!upnp_connection) return;
upnp_connection->close();
upnp_connection.reset();
}
#if TORRENT_USE_ASSERTS
upnp::rootdevice::~rootdevice()
{
TORRENT_ASSERT(magic == 1337);
magic = 0;
}
#if __cplusplus >= 201103L
upnp::rootdevice::rootdevice(rootdevice const&) = default;
upnp::rootdevice& upnp::rootdevice::operator=(rootdevice const&) = default;
#endif
#endif
upnp::upnp(io_service& ios upnp::upnp(io_service& ios
, address const& listen_interface, std::string const& user_agent , address const& listen_interface, std::string const& user_agent
, portmap_callback_t const& cb, log_callback_t const& lcb , portmap_callback_t const& cb, log_callback_t const& lcb

View File

@ -138,7 +138,10 @@ test-suite libtorrent :
[ run test_privacy.cpp ] [ run test_privacy.cpp ]
[ run test_recheck.cpp ] [ run test_recheck.cpp ]
[ run test_resume.cpp ] [ run test_resume.cpp ]
[ run test_ssl.cpp ] [ run test_ssl.cpp : :
: <crypto>openssl:<library>/torrent//ssl
<crypto>openssl:<library>/torrent//crypto
]
[ run test_tracker.cpp ] [ run test_tracker.cpp ]
[ run test_checking.cpp ] [ run test_checking.cpp ]
[ run test_url_seed.cpp ] [ run test_url_seed.cpp ]
@ -158,7 +161,10 @@ test-suite libtorrent :
[ run test_remap_files.cpp ] [ run test_remap_files.cpp ]
[ run test_utp.cpp ] [ run test_utp.cpp ]
[ run test_auto_unchoke.cpp ] [ run test_auto_unchoke.cpp ]
[ run test_http_connection.cpp ] [ run test_http_connection.cpp : :
: <crypto>openssl:<library>/torrent//ssl
<crypto>openssl:<library>/torrent//crypto
]
[ run test_torrent.cpp ] [ run test_torrent.cpp ]
[ run test_transfer.cpp ] [ run test_transfer.cpp ]
[ run test_time_critical.cpp ] [ run test_time_critical.cpp ]

View File

@ -42,8 +42,6 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/alert_types.hpp" #include "libtorrent/alert_types.hpp"
#include "libtorrent/create_torrent.hpp" #include "libtorrent/create_torrent.hpp"
#include "libtorrent/socket_io.hpp" // print_endpoint #include "libtorrent/socket_io.hpp" // print_endpoint
#include "libtorrent/socket_type.hpp"
#include "libtorrent/instantiate_connection.hpp"
#include "libtorrent/ip_filter.hpp" #include "libtorrent/ip_filter.hpp"
#include "libtorrent/session_stats.hpp" #include "libtorrent/session_stats.hpp"
#include "libtorrent/thread.hpp" #include "libtorrent/thread.hpp"
@ -59,11 +57,6 @@ POSSIBILITY OF SUCH DAMAGE.
#include "test_utils.hpp" #include "test_utils.hpp"
#include "setup_transfer.hpp" #include "setup_transfer.hpp"
#ifdef TORRENT_USE_OPENSSL
#include <boost/asio/ssl/stream.hpp>
#include <boost/asio/ssl/context.hpp>
#endif
#ifndef _WIN32 #ifndef _WIN32
#include <spawn.h> #include <spawn.h>
#include <signal.h> #include <signal.h>

View File

@ -36,7 +36,7 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/socket.hpp" #include "libtorrent/socket.hpp"
#include "libtorrent/random.hpp" #include "libtorrent/random.hpp"
#include "libtorrent/socket_io.hpp" #include "libtorrent/socket_io.hpp"
#include "libtorrent/aux_/session_impl.hpp" #include "libtorrent/aux_/session_interface.hpp"
#include "libtorrent/broadcast_socket.hpp" // for supports_ipv6() #include "libtorrent/broadcast_socket.hpp" // for supports_ipv6()
#include "setup_transfer.hpp" // for rand_v4 #include "setup_transfer.hpp" // for rand_v4
@ -165,8 +165,8 @@ TORRENT_TEST(externa_ip_1)
TEST_CHECK(!ec); TEST_CHECK(!ec);
for (int i = 0; i < 50; ++i) for (int i = 0; i < 50; ++i)
{ {
ipv1.cast_vote(real_external, aux::session_impl::source_dht, rand_v4()); ipv1.cast_vote(real_external, aux::session_interface::source_dht, rand_v4());
ipv1.cast_vote(rand_v4(), aux::session_impl::source_dht, malicious); ipv1.cast_vote(rand_v4(), aux::session_interface::source_dht, malicious);
} }
TEST_CHECK(ipv1.external_address(rand_v4()) == real_external); TEST_CHECK(ipv1.external_address(rand_v4()) == real_external);
} }
@ -199,12 +199,12 @@ TORRENT_TEST(externa_ip_2)
TEST_CHECK(!ec); TEST_CHECK(!ec);
for (int i = 0; i < 50; ++i) for (int i = 0; i < 50; ++i)
{ {
ipv2.cast_vote(real_external1, aux::session_impl::source_dht, rand_v4()); ipv2.cast_vote(real_external1, aux::session_interface::source_dht, rand_v4());
#if TORRENT_USE_IPV6 #if TORRENT_USE_IPV6
if (supports_ipv6()) if (supports_ipv6())
ipv2.cast_vote(real_external2, aux::session_impl::source_dht, rand_v6()); ipv2.cast_vote(real_external2, aux::session_interface::source_dht, rand_v6());
#endif #endif
ipv2.cast_vote(malicious_external, aux::session_impl::source_dht, malicious); ipv2.cast_vote(malicious_external, aux::session_interface::source_dht, malicious);
} }
TEST_CHECK(ipv2.external_address(rand_v4()) == real_external1); TEST_CHECK(ipv2.external_address(rand_v4()) == real_external1);
#if TORRENT_USE_IPV6 #if TORRENT_USE_IPV6

View File

@ -40,13 +40,13 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/hasher.hpp" #include "libtorrent/hasher.hpp"
#include "libtorrent/session.hpp" #include "libtorrent/session.hpp"
#include "libtorrent/alert_types.hpp" #include "libtorrent/alert_types.hpp"
#include "libtorrent/aux_/session_impl.hpp"
#include "libtorrent/create_torrent.hpp" #include "libtorrent/create_torrent.hpp"
#include "libtorrent/thread.hpp" #include "libtorrent/thread.hpp"
#include "libtorrent/torrent_info.hpp" #include "libtorrent/torrent_info.hpp"
#include <boost/make_shared.hpp> #include <boost/make_shared.hpp>
#include <boost/utility.hpp> #include <boost/utility.hpp>
#include <boost/bind.hpp>
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>

View File

@ -33,6 +33,7 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/upnp.hpp" #include "libtorrent/upnp.hpp"
#include "libtorrent/socket.hpp" #include "libtorrent/socket.hpp"
#include "libtorrent/socket_io.hpp" // print_endpoint #include "libtorrent/socket_io.hpp" // print_endpoint
#include "libtorrent/http_parser.hpp"
#include "test.hpp" #include "test.hpp"
#include "setup_transfer.hpp" #include "setup_transfer.hpp"
#include <fstream> #include <fstream>

View File

@ -34,6 +34,7 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/upnp.hpp" #include "libtorrent/upnp.hpp"
#include "test.hpp" #include "test.hpp"
#include <iostream> #include <iostream>
#include <boost/bind.hpp>
char upnp_xml[] = char upnp_xml[] =
"<root>" "<root>"