26#ifndef ROUTING_X_CONNECTION_INCLUDED
27#define ROUTING_X_CONNECTION_INCLUDED
34#include <mysqlx_connection.pb.h>
51 void caps(std::unique_ptr<Mysqlx::Connection::Capabilities>
caps) {
59 std::unique_ptr<Mysqlx::Connection::Capabilities>
caps_;
64 public std::enable_shared_from_this<MysqlRoutingXConnection> {
74 std::unique_ptr<ConnectionBase> client_connection,
75 std::unique_ptr<RoutingConnectionBase> client_routing_connection,
80 std::move(client_routing_connection),
96 template <
typename... Args>
97 [[nodiscard]]
static std::shared_ptr<MysqlRoutingXConnection>
create(
100 return std::shared_ptr<MysqlRoutingXConnection>(
105 std::shared_ptr<MysqlRoutingXConnection>
getptr() {
106 return shared_from_this();
110 std::vector<uint8_t> &error_frame, uint16_t error_code,
111 const std::string &msg,
const std::string &sql_state =
"HY000",
759 is_completed_.wait([](
auto ready) {
return ready ==
true; });
778 clock_type::time_point
started_{clock_type::now()};
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:247
SSL aware socket buffers.
Definition: channel.h:65
void set_routing_source(std::string name)
Definition: connection.h:267
const routing_guidelines::Server_info & server_info() const
Definition: connection.h:271
void destination_id(std::optional< mysql_harness::Destination > id)
Definition: connection.h:259
std::string routing_source() const
Definition: connection.h:266
Manage destinations for a Connection Routing.
Definition: destination.h:84
bool routing_guidelines_session_rand_used() const
Check if routing guidelines uses $.session.rand as a match criterion.
Definition: destination.h:166
Definition: connection.h:47
std::chrono::system_clock clock_type
Definition: connection.h:132
MySQLRoutingContext & context()
Definition: connection.h:56
void client_address(const std::string &dest)
Definition: connection.h:120
void set_routing_guidelines_session_rand()
Definition: connection.cc:342
MySQLRoutingContext holds data used by MySQLRouting (1 per plugin instances) and MySQLRoutingConnecti...
Definition: context.h:54
Definition: x_connection.h:64
void client_cap_get()
client wants to get the capabilities of the server.
Definition: x_connection.cc:861
void recv_client_failed(std::error_code ec)
Definition: x_connection.cc:353
const ServerSideConnection & server_conn() const
Definition: x_connection.h:738
void server_recv_switch_tls_response()
Definition: x_connection.cc:921
void async_send_server(Function next)
Definition: x_connection.cc:426
void server_recv_prepare_deallocate_response_forward()
Definition: x_connection.cc:2405
void server_recv_expect_close_response_forward_last()
Definition: x_connection.cc:2610
void server_recv_crud_delete_response()
Definition: x_connection.cc:2104
void client_crud_modify_view()
Definition: x_connection.cc:2682
void client_cursor_open()
Definition: x_connection.cc:2811
void server_recv_cap_get_response_forward()
Definition: x_connection.cc:1335
void server_recv_stmt_execute_response_forward()
Definition: x_connection.cc:2018
void server_recv_prepare_execute_response_forward()
Definition: x_connection.cc:2477
void client_cursor_fetch()
Definition: x_connection.cc:2878
void client_stmt_execute()
Definition: x_connection.cc:1961
void server_recv_crud_delete_response_forward()
Definition: x_connection.cc:2150
void server_recv_cap_get_response()
Definition: x_connection.cc:1291
stdx::expected< ForwardResult, std::error_code > forward_frame_from_server_to_client()
Definition: x_connection.cc:709
void client_prepare_execute()
Definition: x_connection.cc:2420
void passthrough_tls_init()
void server_recv_cap_set_response_forward_last()
Definition: x_connection.cc:1861
ServerSideConnection & server_conn()
Definition: x_connection.h:737
void server_recv_switch_tls_response_passthrough_forward_last()
Definition: x_connection.cc:1080
ClientSideConnection client_conn_
Definition: x_connection.h:788
void server_recv_crud_modify_view_response_forward()
Definition: x_connection.cc:2733
void async_run()
Definition: x_connection.cc:313
void server_recv_cursor_close_response()
Definition: x_connection.cc:2952
void server_tls_shutdown()
Definition: x_connection.cc:3185
void client_sess_auth_start()
Definition: x_connection.cc:1868
stdx::expected< ForwardResult, std::error_code > forward_frame_from_client_to_server()
Definition: x_connection.cc:675
void client_crud_drop_view()
Definition: x_connection.cc:2747
void connect()
Definition: x_connection.cc:742
void server_recv_crud_find_response()
Definition: x_connection.cc:2035
void client_crud_create_view()
Definition: x_connection.cc:2617
void server_recv_cap_get_response_forward_last()
Definition: x_connection.cc:1340
ServerSideConnection server_conn_
Definition: x_connection.h:789
static std::shared_ptr< MysqlRoutingXConnection > create(Args &&...args)
Definition: x_connection.h:97
void server_recv_expect_close_response_forward()
Definition: x_connection.cc:2605
void call_next_function(Function next)
Definition: x_connection.h:282
stdx::expected< void, std::error_code > forward_tls(Channel &src_channel, Channel &dst_channel)
Definition: x_connection.cc:1093
int active_work_
Definition: x_connection.h:774
void client_tls_shutdown()
Definition: x_connection.cc:3192
SslMode source_ssl_mode() const
Definition: x_connection.h:114
SslMode dest_ssl_mode() const
Definition: x_connection.h:116
connector_type connector_
Definition: x_connection.h:786
void client_crud_update()
Definition: x_connection.cc:2225
void server_recv_stmt_execute_response_forward_last()
Definition: x_connection.cc:2023
void server_recv_session_close_response_forward()
Definition: x_connection.cc:3061
void forward_tls_server_to_client()
Definition: x_connection.cc:1162
void server_recv_crud_drop_view_response_forward_last()
Definition: x_connection.cc:2804
std::optional< mysql_harness::Destination > get_destination_id() const override
Definition: x_connection.h:740
void client_recv_auth_continue()
Definition: x_connection.cc:1949
static stdx::expected< size_t, std::error_code > encode_error_packet(std::vector< uint8_t > &error_frame, uint16_t error_code, const std::string &msg, const std::string &sql_state="HY000", Mysqlx::Error::Severity severity=Mysqlx::Error::ERROR)
Definition: x_connection.cc:288
Function
Definition: x_connection.h:124
@ kServerRecvCrudDropViewResponseForward
@ kServerRecvCursorCloseResponseForward
@ kForwardTlsClientToServer
@ kServerRecvCrudUpdateResponse
@ kServerRecvCrudDeleteResponseForwardLast
@ kServerRecvSwitchTlsResponse
@ kServerRecvAuthResponseContinue
@ kServerRecvCrudModifyViewResponseForward
@ kServerRecvExpectOpenResponse
@ kServerRecvCursorOpenResponseForwardLast
@ kServerRecvCrudCreateViewResponseForwardLast
@ kServerRecvPreparePrepareResponse
@ kServerRecvCursorFetchResponseForward
@ kServerRecvExpectOpenResponseForward
@ kServerRecvCrudFindResponse
@ kServerRecvPrepareExecuteResponseForwardLast
@ kServerRecvCrudDeleteResponseForward
@ kServerRecvCrudUpdateResponseForward
@ kServerRecvPrepareDeallocateResponseForward
@ kServerRecvPrepareDeallocateResponseForwardLast
@ kServerRecvCrudCreateViewResponseForward
@ kServerRecvStmtExecuteResponseForwardLast
@ kServerRecvPreparePrepareResponseForward
@ kServerRecvCursorFetchResponseForwardLast
@ kServerRecvSessionCloseResponseForwardLast
@ kServerRecvPreparePrepareResponseForwardLast
@ kServerRecvCrudDeleteResponse
@ kServerRecvCursorCloseResponseForwardLast
@ kServerRecvSwitchTlsResponsePassthroughForward
@ kServerRecvCapGetResponse
@ kServerRecvSwitchTlsResponsePassthrough
@ kServerRecvExpectCloseResponseForwardLast
@ kServerRecvCrudModifyViewResponseForwardLast
@ kServerRecvExpectOpenResponseForwardLast
@ kServerRecvCursorCloseResponse
@ kServerRecvAuthResponse
@ kServerRecvExpectCloseResponseForward
@ kServerRecvCapGetResponseForwardLast
@ kServerRecvCrudFindResponseForward
@ kServerRecvCrudDropViewResponse
@ kServerRecvPrepareExecuteResponseForward
@ kServerRecvCrudUpdateResponseForwardLast
@ kServerRecvCapSetResponseForwardLast
@ kServerRecvCrudFindResponseForwardLast
@ kServerRecvCrudInsertResponse
@ kServerRecvCursorOpenResponseForward
@ kServerRecvCheckCapsResponse
@ kServerRecvSessionResetResponseForward
@ kServerRecvCursorOpenResponse
@ kServerRecvSwitchTlsResponsePassthroughForwardOk
@ kServerRecvSwitchTlsResponsePassthroughForwardLast
@ kServerRecvStmtExecuteResponse
@ kServerRecvCrudModifyViewResponse
@ kServerRecvExpectCloseResponse
@ kForwardTlsServerToClient
@ kServerRecvStmtExecuteResponseForward
@ kServerRecvCapSetResponse
@ kServerRecvCrudInsertResponseForward
@ kClientPrepareDeallocate
@ kServerRecvSessionCloseResponseForward
@ kServerRecvSessionResetResponseForwardLast
@ kServerRecvCrudDropViewResponseForwardLast
@ kServerRecvCapSetResponseForward
@ kServerRecvCapGetResponseForward
@ kServerRecvPrepareExecuteResponse
@ kServerRecvAuthResponseForward
@ kServerRecvAuthResponseForwardLast
@ kServerRecvSessionCloseResponse
@ kClientRecvAuthContinue
@ kServerRecvCursorFetchResponse
@ kServerRecvCrudCreateViewResponse
@ kServerRecvPrepareDeallocateResponse
@ kServerRecvCrudInsertResponseForwardLast
@ kServerRecvSessionResetResponse
void server_recv_expect_close_response()
Definition: x_connection.cc:2559
void server_recv_prepare_deallocate_response_forward_last()
Definition: x_connection.cc:2412
void server_recv_prepare_execute_response_forward_last()
Definition: x_connection.cc:2483
void server_recv_session_reset_response_forward()
Definition: x_connection.cc:3125
void tls_connect_init()
Definition: x_connection.cc:1204
bool greeting_from_router_
Definition: x_connection.h:781
void client_session_reset()
Definition: x_connection.cc:3074
void server_recv_session_close_response_forward_last()
Definition: x_connection.cc:3067
routing_guidelines::Server_info get_server_info() const override
Definition: x_connection.h:769
void server_recv_prepare_prepare_response_forward_last()
Definition: x_connection.cc:2345
void client_expect_close()
Definition: x_connection.cc:2554
void server_recv_cap_set_response_forward()
Definition: x_connection.cc:1856
void server_recv_cursor_open_response_forward_last()
Definition: x_connection.cc:2871
void forward_client_to_server(Function this_func, Function next_func)
Definition: x_connection.cc:687
void disconnect() override
Definition: x_connection.cc:247
void server_recv_cursor_fetch_response()
Definition: x_connection.cc:2883
void server_socket_failed(std::error_code ec)
Definition: x_connection.cc:361
const ClientSideConnection & client_conn() const
Definition: x_connection.h:735
ServerSideConnection::protocol_state_type & server_protocol()
Definition: x_connection.h:727
void server_recv_session_close_response()
Definition: x_connection.cc:3015
void async_send_client(Function next)
Definition: x_connection.cc:392
void server_recv_cursor_open_response_forward()
Definition: x_connection.cc:2866
std::string get_routing_source() const override
Definition: x_connection.h:750
void async_send_server_buffer(net::const_buffer send_buf, Function next)
Definition: x_connection.cc:1363
void send_server_failed(std::error_code ec)
Definition: x_connection.cc:329
void server_recv_server_greeting_from_server()
Definition: x_connection.cc:3138
void send_client_failed(std::error_code ec)
Definition: x_connection.cc:345
void async_send_client_buffer(net::const_buffer send_buf, Function next)
Definition: x_connection.cc:1345
void client_con_close()
Definition: x_connection.cc:303
void server_recv_crud_insert_response_forward_last()
Definition: x_connection.cc:2218
ClientSideConnection & client_conn()
Definition: x_connection.h:734
void server_recv_switch_tls_response_passthrough_forward()
Definition: x_connection.cc:1073
void server_recv_cursor_close_response_forward()
Definition: x_connection.cc:2998
void forward_tls_client_to_server()
Definition: x_connection.cc:1147
void client_session_close()
Definition: x_connection.cc:3010
ForwardResult
Definition: x_connection.h:565
void client_cursor_close()
Definition: x_connection.cc:2947
void server_recv_cursor_fetch_response_forward_last()
Definition: x_connection.cc:2940
void client_socket_failed(std::error_code ec)
Definition: x_connection.cc:376
void server_recv_prepare_prepare_response()
Definition: x_connection.cc:2293
void server_recv_auth_response_forward()
Definition: x_connection.cc:1939
void server_recv_auth_response_continue()
Definition: x_connection.cc:1944
std::optional< mysql_harness::DestinationEndpoint > destination_endpoint() const override
Definition: x_connection.h:745
void tls_accept_finalize()
Definition: x_connection.cc:1635
void server_recv_session_reset_response()
Definition: x_connection.cc:3079
void server_recv_crud_find_response_forward_last()
Definition: x_connection.cc:2092
void server_send_switch_to_tls()
Definition: x_connection.cc:1712
void client_send_server_greeting_from_router()
Definition: x_connection.cc:460
void client_recv_cmd()
Definition: x_connection.cc:464
void forward_tls_init()
Definition: x_connection.cc:1177
void client_expect_open()
Definition: x_connection.cc:2491
void server_recv_check_caps_response()
Definition: x_connection.cc:1740
void server_recv_crud_create_view_response_forward()
Definition: x_connection.cc:2668
void server_recv_crud_drop_view_response()
Definition: x_connection.cc:2752
void server_send_check_caps()
Definition: x_connection.cc:1727
void forward_server_to_client(Function this_func, Function next_func)
Definition: x_connection.cc:721
void recv_server_failed(std::error_code ec)
Definition: x_connection.cc:337
void server_recv_crud_insert_response_forward()
Definition: x_connection.cc:2213
void server_recv_crud_find_response_forward()
Definition: x_connection.cc:2087
void server_recv_expect_open_response_forward_last()
Definition: x_connection.cc:2547
void server_recv_auth_response()
Definition: x_connection.cc:1890
void server_recv_expect_open_response()
Definition: x_connection.cc:2496
void done()
Definition: x_connection.cc:3183
void tls_connect()
connect server_channel to a TLS server.
Definition: x_connection.cc:1233
void client_crud_insert()
Definition: x_connection.cc:2162
void set_routing_source(std::string name) override
Definition: x_connection.h:754
void server_recv_cursor_open_response()
Definition: x_connection.cc:2816
void server_recv_crud_drop_view_response_forward()
Definition: x_connection.cc:2798
void server_recv_cursor_fetch_response_forward()
Definition: x_connection.cc:2935
void server_recv_cap_set_response()
Definition: x_connection.cc:1810
void server_recv_crud_update_response()
Definition: x_connection.cc:2230
const ServerSideConnection::protocol_state_type & server_protocol() const
Definition: x_connection.h:730
void tls_accept()
accept a TLS handshake.
Definition: x_connection.cc:1585
void server_recv_crud_update_response_forward_last()
Definition: x_connection.cc:2281
void tls_accept_init()
Definition: x_connection.cc:1565
void server_recv_switch_tls_response_passthrough()
Definition: x_connection.cc:1023
void server_recv_crud_modify_view_response_forward_last()
Definition: x_connection.cc:2739
void client_prepare_prepare()
Definition: x_connection.cc:2288
void server_recv_auth_response_forward_last()
Definition: x_connection.cc:1954
MysqlRoutingXConnection(MySQLRoutingContext &context, DestinationManager *destination_manager, std::unique_ptr< ConnectionBase > client_connection, std::unique_ptr< RoutingConnectionBase > client_routing_connection, std::function< void(MySQLRoutingConnectionBase *)> remove_callback)
Definition: x_connection.h:72
void server_recv_crud_insert_response()
Definition: x_connection.cc:2167
void server_recv_session_reset_response_forward_last()
Definition: x_connection.cc:3131
ClientSideConnection::protocol_state_type & client_protocol()
Definition: x_connection.h:720
clock_type::time_point last_trace_
Definition: x_connection.h:779
const connector_type & connector() const
Definition: x_connection.h:784
void server_recv_expect_open_response_forward()
Definition: x_connection.cc:2542
void server_recv_switch_tls_response_passthrough_forward_ok()
Definition: x_connection.cc:1087
void client_cap_set()
client wants to set the capabilities.
Definition: x_connection.cc:1386
void server_recv_cursor_close_response_forward_last()
Definition: x_connection.cc:3003
void server_recv_crud_update_response_forward()
Definition: x_connection.cc:2276
void wait_client_close()
Definition: x_connection.cc:3178
void client_crud_find()
Definition: x_connection.cc:2030
net::impl::socket::native_handle_type get_client_fd() const override
Definition: x_connection.h:118
const ClientSideConnection::protocol_state_type & client_protocol() const
Definition: x_connection.h:723
WaitableMonitor< bool > is_completed_
Definition: x_connection.h:791
void server_init_tls()
Definition: x_connection.cc:1657
void server_recv_prepare_deallocate_response()
Definition: x_connection.cc:2358
void finish()
Definition: x_connection.cc:3142
void server_recv_crud_delete_response_forward_last()
Definition: x_connection.cc:2155
void completed() override
Definition: x_connection.h:762
void async_recv_server(Function next)
Definition: x_connection.cc:447
void server_recv_crud_create_view_response_forward_last()
Definition: x_connection.cc:2674
void server_recv_crud_create_view_response()
Definition: x_connection.cc:2622
std::shared_ptr< MysqlRoutingXConnection > getptr()
Definition: x_connection.h:105
void wait_until_completed() override
Definition: x_connection.h:758
void server_recv_prepare_prepare_response_forward()
Definition: x_connection.cc:2339
void server_recv_prepare_execute_response()
Definition: x_connection.cc:2425
void server_recv_crud_modify_view_response()
Definition: x_connection.cc:2687
void client_prepare_deallocate()
Definition: x_connection.cc:2353
connector_type & connector()
Definition: x_connection.h:783
void async_recv_client(Function next)
Definition: x_connection.cc:413
void server_recv_stmt_execute_response()
Definition: x_connection.cc:1966
void client_crud_delete()
Definition: x_connection.cc:2099
clock_type::time_point started_
Definition: x_connection.h:778
typename base_class_::protocol_state_type protocol_state_type
Definition: basic_protocol_splicer.h:91
protocol_state_type & protocol()
Definition: connection_base.h:399
std::unique_ptr< ConnectionBase > & connection()
Definition: connection_base.h:405
net::impl::socket::native_handle_type native_handle() const
Definition: connection_base.h:368
SslMode ssl_mode() const
Definition: connection_base.h:364
Monitor can be waited for.
Definition: monitor.h:62
Definition: x_connection.h:40
std::optional< uint8_t > msg_type_
Definition: x_connection.h:57
std::optional< FrameInfo > & current_frame()
Definition: x_connection.h:47
Mysqlx::Connection::Capabilities * caps()
Definition: x_connection.h:50
std::optional< FrameInfo > current_frame_
Definition: x_connection.h:56
void caps(std::unique_ptr< Mysqlx::Connection::Capabilities > caps)
Definition: x_connection.h:51
std::unique_ptr< Mysqlx::Connection::Capabilities > caps_
Definition: x_connection.h:59
std::optional< uint8_t > & current_msg_type()
Definition: x_connection.h:48
int native_handle_type
Definition: socket_constants.h:51
Define std::hash<Gtid>.
Definition: gtid.h:355
SslMode
Definition: ssl_mode.h:29
case opt name
Definition: sslopt-case.h:29
Capabilities.
Definition: mysqlx_connection.proto:53
Severity
Definition: mysqlx.proto:279
@ ERROR
Definition: mysqlx.proto:280
Definition: x_connection.h:42
size_t frame_size_
size of the whole frame
Definition: x_connection.h:43
size_t forwarded_frame_size_
size of the forwarded part of frame
Definition: x_connection.h:44
Information about one server destination.
Definition: routing_guidelines.h:80