// // Copyright (c) 2019-2022 Ruben Perez Hidalgo (rubenperez038 at gmail dot com) // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // #include "er_network_variant.hpp" #include "er_connection.hpp" #include "er_resultset.hpp" #include "er_statement.hpp" #include "network_result.hpp" #include "streams.hpp" #include "er_impl_common.hpp" #include "get_endpoint.hpp" #include "boost/mysql/connection_params.hpp" #include "boost/mysql/errc.hpp" #include "boost/mysql/error.hpp" #include "boost/mysql/execute_params.hpp" #include "boost/mysql/prepared_statement.hpp" #include "boost/mysql/row.hpp" #include #include #include using namespace boost::mysql::test; using boost::mysql::row; using boost::mysql::error_code; using boost::mysql::error_info; using boost::mysql::field_view; using boost::mysql::connection_params; namespace { template using impl_result_type = decltype(std::declval()()); template static network_result> impl(Callable&& cb) { network_result> res; try { res.value = cb(); } catch (const boost::system::system_error& err) { res.err = err.code(); res.info = error_info(err.what()); } return res; } template class sync_exc_resultset : public er_resultset_base { public: using er_resultset_base::er_resultset_base; network_result read_one(row& output) override { return impl([&] { return this->r_.read_one(output); }); } network_result> read_many(std::size_t count) override { return impl([&] { return this->r_.read_many(count); }); } network_result> read_all() override { return impl([&] { return this->r_.read_all(); }); } }; template class sync_exc_statement : public er_statement_base { public: using er_statement_base::er_statement_base; network_result execute_params( const boost::mysql::execute_params& params ) override { return impl([&]{ return erase_resultset(this->stmt_.execute(params)); }); } network_result execute_container( const std::vector& values ) override { return impl([&] { return erase_resultset(this->stmt_.execute(values)); }); } network_result close() override { return impl([&] { this->stmt_.close(); return no_result(); }); } }; template class sync_exc_connection : public er_connection_base { public: using er_connection_base::er_connection_base; network_result physical_connect(er_endpoint kind) override { return impl([&] { this->conn_.next_layer().lowest_layer().connect(get_endpoint(kind)); return no_result(); }); } network_result connect( er_endpoint kind, const boost::mysql::connection_params& params ) override { return impl([&] { this->conn_.connect(get_endpoint(kind), params); return no_result(); }); } network_result handshake(const connection_params& params) override { return impl([&] { this->conn_.handshake(params); return no_result(); }); } network_result query(boost::string_view query) override { return impl([&] { return erase_resultset(this->conn_.query(query)); }); } network_result prepare_statement(boost::string_view statement) override { return impl([&] { return erase_statement(this->conn_.prepare_statement(statement)); }); } network_result quit() override { return impl([&] { this->conn_.quit(); return no_result(); }); } network_result close() override { return impl([&] { this->conn_.close(); return no_result(); }); } }; template class sync_exc_variant : public er_network_variant_base { public: const char* variant_name() const override { return "sync_exc"; } }; sync_exc_variant tcp; sync_exc_variant tcp_ssl; // UNIX sockets don't add much value here } // anon namespace void boost::mysql::test::add_sync_exc( std::vector& output ) { output.push_back(&tcp); output.push_back(&tcp_ssl); }