26#ifndef ROUTING_X_CONNECTION_INCLUDED
27#define ROUTING_X_CONNECTION_INCLUDED
34#include <mysqlx_connection.pb.h>
50 void caps(std::unique_ptr<Mysqlx::Connection::Capabilities>
caps) {
58 std::unique_ptr<Mysqlx::Connection::Capabilities>
caps_;
63 public std::enable_shared_from_this<MysqlRoutingXConnection> {
73 std::unique_ptr<ConnectionBase> client_connection,
74 std::unique_ptr<RoutingConnectionBase> client_routing_connection,
79 connector_{client_connection->io_ctx(), route_destination,
82 std::move(client_routing_connection),
94 template <
typename... Args>
95 [[nodiscard]]
static std::shared_ptr<MysqlRoutingXConnection>
create(
98 return std::shared_ptr<MysqlRoutingXConnection>(
103 std::shared_ptr<MysqlRoutingXConnection>
getptr() {
104 return shared_from_this();
108 std::vector<uint8_t> &error_frame, uint16_t error_code,
109 const std::string &msg,
const std::string &sql_state =
"HY000",
751 clock_type::time_point
started_{clock_type::now()};
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:251
SSL aware socket buffers.
Definition: channel.h:65
void destination_id(std::string id)
Definition: connection.h:242
A forward iterable container of destinations.
Definition: destination.h:107
Definition: connection.h:44
std::chrono::system_clock clock_type
Definition: connection.h:117
MySQLRoutingContext & context()
Definition: connection.h:53
void client_address(const std::string &dest)
Definition: connection.h:105
MySQLRoutingContext holds data used by MySQLRouting (1 per plugin instances) and MySQLRoutingConnecti...
Definition: context.h:59
Definition: x_connection.h:63
void client_cap_get()
client wants to get the capabilities of the server.
Definition: x_connection.cc:860
void recv_client_failed(std::error_code ec)
Definition: x_connection.cc:353
const ServerSideConnection & server_conn() const
Definition: x_connection.h:736
void server_recv_switch_tls_response()
Definition: x_connection.cc:920
void async_send_server(Function next)
Definition: x_connection.cc:426
void server_recv_prepare_deallocate_response_forward()
Definition: x_connection.cc:2391
void server_recv_expect_close_response_forward_last()
Definition: x_connection.cc:2596
void server_recv_crud_delete_response()
Definition: x_connection.cc:2090
MysqlRoutingXConnection(MySQLRoutingContext &context, RouteDestination *route_destination, std::unique_ptr< ConnectionBase > client_connection, std::unique_ptr< RoutingConnectionBase > client_routing_connection, std::function< void(MySQLRoutingConnectionBase *)> remove_callback)
Definition: x_connection.h:71
void client_crud_modify_view()
Definition: x_connection.cc:2668
void client_cursor_open()
Definition: x_connection.cc:2797
void server_recv_cap_get_response_forward()
Definition: x_connection.cc:1327
void server_recv_stmt_execute_response_forward()
Definition: x_connection.cc:2004
void server_recv_prepare_execute_response_forward()
Definition: x_connection.cc:2463
void client_cursor_fetch()
Definition: x_connection.cc:2864
void client_stmt_execute()
Definition: x_connection.cc:1947
void server_recv_crud_delete_response_forward()
Definition: x_connection.cc:2136
void server_recv_cap_get_response()
Definition: x_connection.cc:1283
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:2406
void passthrough_tls_init()
void server_recv_cap_set_response_forward_last()
Definition: x_connection.cc:1847
ServerSideConnection & server_conn()
Definition: x_connection.h:735
void server_recv_switch_tls_response_passthrough_forward_last()
Definition: x_connection.cc:1079
ClientSideConnection client_conn_
Definition: x_connection.h:763
void server_recv_crud_modify_view_response_forward()
Definition: x_connection.cc:2719
void async_run()
Definition: x_connection.cc:313
void server_recv_cursor_close_response()
Definition: x_connection.cc:2938
void server_tls_shutdown()
Definition: x_connection.cc:3171
void client_sess_auth_start()
Definition: x_connection.cc:1854
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:2733
void connect()
Definition: x_connection.cc:742
void server_recv_crud_find_response()
Definition: x_connection.cc:2021
void client_crud_create_view()
Definition: x_connection.cc:2603
void server_recv_cap_get_response_forward_last()
Definition: x_connection.cc:1332
ServerSideConnection server_conn_
Definition: x_connection.h:764
static std::shared_ptr< MysqlRoutingXConnection > create(Args &&...args)
Definition: x_connection.h:95
void server_recv_expect_close_response_forward()
Definition: x_connection.cc:2591
void call_next_function(Function next)
Definition: x_connection.h:280
stdx::expected< void, std::error_code > forward_tls(Channel &src_channel, Channel &dst_channel)
Definition: x_connection.cc:1092
int active_work_
Definition: x_connection.h:747
void client_tls_shutdown()
Definition: x_connection.cc:3178
SslMode source_ssl_mode() const
Definition: x_connection.h:112
SslMode dest_ssl_mode() const
Definition: x_connection.h:114
connector_type connector_
Definition: x_connection.h:761
void client_crud_update()
Definition: x_connection.cc:2211
void server_recv_stmt_execute_response_forward_last()
Definition: x_connection.cc:2009
void server_recv_session_close_response_forward()
Definition: x_connection.cc:3047
void forward_tls_server_to_client()
Definition: x_connection.cc:1161
void server_recv_crud_drop_view_response_forward_last()
Definition: x_connection.cc:2790
void client_recv_auth_continue()
Definition: x_connection.cc:1935
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:122
@ 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:2545
void server_recv_prepare_deallocate_response_forward_last()
Definition: x_connection.cc:2398
void server_recv_prepare_execute_response_forward_last()
Definition: x_connection.cc:2469
void server_recv_session_reset_response_forward()
Definition: x_connection.cc:3111
void tls_connect_init()
Definition: x_connection.cc:1196
bool greeting_from_router_
Definition: x_connection.h:754
void client_session_reset()
Definition: x_connection.cc:3060
void server_recv_session_close_response_forward_last()
Definition: x_connection.cc:3053
void server_recv_prepare_prepare_response_forward_last()
Definition: x_connection.cc:2331
void client_expect_close()
Definition: x_connection.cc:2540
void server_recv_cap_set_response_forward()
Definition: x_connection.cc:1842
void server_recv_cursor_open_response_forward_last()
Definition: x_connection.cc:2857
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:2869
void server_socket_failed(std::error_code ec)
Definition: x_connection.cc:361
const ClientSideConnection & client_conn() const
Definition: x_connection.h:733
ServerSideConnection::protocol_state_type & server_protocol()
Definition: x_connection.h:725
std::string get_destination_id() const override
Definition: x_connection.h:738
void server_recv_session_close_response()
Definition: x_connection.cc:3001
void async_send_client(Function next)
Definition: x_connection.cc:392
void server_recv_cursor_open_response_forward()
Definition: x_connection.cc:2852
void async_send_server_buffer(net::const_buffer send_buf, Function next)
Definition: x_connection.cc:1355
void send_server_failed(std::error_code ec)
Definition: x_connection.cc:329
void server_recv_server_greeting_from_server()
Definition: x_connection.cc:3124
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:1337
void client_con_close()
Definition: x_connection.cc:303
void server_recv_crud_insert_response_forward_last()
Definition: x_connection.cc:2204
ClientSideConnection & client_conn()
Definition: x_connection.h:732
void server_recv_switch_tls_response_passthrough_forward()
Definition: x_connection.cc:1072
void server_recv_cursor_close_response_forward()
Definition: x_connection.cc:2984
void forward_tls_client_to_server()
Definition: x_connection.cc:1146
void client_session_close()
Definition: x_connection.cc:2996
ForwardResult
Definition: x_connection.h:563
void client_cursor_close()
Definition: x_connection.cc:2933
void server_recv_cursor_fetch_response_forward_last()
Definition: x_connection.cc:2926
void client_socket_failed(std::error_code ec)
Definition: x_connection.cc:376
void server_recv_prepare_prepare_response()
Definition: x_connection.cc:2279
void server_recv_auth_response_forward()
Definition: x_connection.cc:1925
void server_recv_auth_response_continue()
Definition: x_connection.cc:1930
void tls_accept_finalize()
Definition: x_connection.cc:1621
void server_recv_session_reset_response()
Definition: x_connection.cc:3065
void server_recv_crud_find_response_forward_last()
Definition: x_connection.cc:2078
void server_send_switch_to_tls()
Definition: x_connection.cc:1698
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:1176
void client_expect_open()
Definition: x_connection.cc:2477
void server_recv_check_caps_response()
Definition: x_connection.cc:1726
void server_recv_crud_create_view_response_forward()
Definition: x_connection.cc:2654
void server_recv_crud_drop_view_response()
Definition: x_connection.cc:2738
void server_send_check_caps()
Definition: x_connection.cc:1713
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:2199
void server_recv_crud_find_response_forward()
Definition: x_connection.cc:2073
void server_recv_expect_open_response_forward_last()
Definition: x_connection.cc:2533
void server_recv_auth_response()
Definition: x_connection.cc:1876
void server_recv_expect_open_response()
Definition: x_connection.cc:2482
void done()
Definition: x_connection.cc:3169
void tls_connect()
connect server_channel to a TLS server.
Definition: x_connection.cc:1225
void client_crud_insert()
Definition: x_connection.cc:2148
void server_recv_cursor_open_response()
Definition: x_connection.cc:2802
void server_recv_crud_drop_view_response_forward()
Definition: x_connection.cc:2784
void server_recv_cursor_fetch_response_forward()
Definition: x_connection.cc:2921
void server_recv_cap_set_response()
Definition: x_connection.cc:1796
void server_recv_crud_update_response()
Definition: x_connection.cc:2216
const ServerSideConnection::protocol_state_type & server_protocol() const
Definition: x_connection.h:728
void tls_accept()
accept a TLS handshake.
Definition: x_connection.cc:1571
void server_recv_crud_update_response_forward_last()
Definition: x_connection.cc:2267
void tls_accept_init()
Definition: x_connection.cc:1551
void server_recv_switch_tls_response_passthrough()
Definition: x_connection.cc:1022
void server_recv_crud_modify_view_response_forward_last()
Definition: x_connection.cc:2725
void client_prepare_prepare()
Definition: x_connection.cc:2274
void server_recv_auth_response_forward_last()
Definition: x_connection.cc:1940
std::optional< net::ip::tcp::endpoint > destination_endpoint() const override
Definition: x_connection.h:742
void server_recv_crud_insert_response()
Definition: x_connection.cc:2153
void server_recv_session_reset_response_forward_last()
Definition: x_connection.cc:3117
ClientSideConnection::protocol_state_type & client_protocol()
Definition: x_connection.h:718
clock_type::time_point last_trace_
Definition: x_connection.h:752
const connector_type & connector() const
Definition: x_connection.h:757
void server_recv_expect_open_response_forward()
Definition: x_connection.cc:2528
void server_recv_switch_tls_response_passthrough_forward_ok()
Definition: x_connection.cc:1086
Destinations destinations_
Definition: x_connection.h:760
void client_cap_set()
client wants to set the capabilities.
Definition: x_connection.cc:1378
void server_recv_cursor_close_response_forward_last()
Definition: x_connection.cc:2989
void server_recv_crud_update_response_forward()
Definition: x_connection.cc:2262
void wait_client_close()
Definition: x_connection.cc:3164
void client_crud_find()
Definition: x_connection.cc:2016
net::impl::socket::native_handle_type get_client_fd() const override
Definition: x_connection.h:116
const ClientSideConnection::protocol_state_type & client_protocol() const
Definition: x_connection.h:721
void server_init_tls()
Definition: x_connection.cc:1643
void server_recv_prepare_deallocate_response()
Definition: x_connection.cc:2344
void finish()
Definition: x_connection.cc:3128
void server_recv_crud_delete_response_forward_last()
Definition: x_connection.cc:2141
void async_recv_server(Function next)
Definition: x_connection.cc:447
void server_recv_crud_create_view_response_forward_last()
Definition: x_connection.cc:2660
void server_recv_crud_create_view_response()
Definition: x_connection.cc:2608
std::shared_ptr< MysqlRoutingXConnection > getptr()
Definition: x_connection.h:103
void server_recv_prepare_prepare_response_forward()
Definition: x_connection.cc:2325
void server_recv_prepare_execute_response()
Definition: x_connection.cc:2411
void server_recv_crud_modify_view_response()
Definition: x_connection.cc:2673
void client_prepare_deallocate()
Definition: x_connection.cc:2339
RouteDestination * route_destination_
Definition: x_connection.h:759
connector_type & connector()
Definition: x_connection.h:756
void async_recv_client(Function next)
Definition: x_connection.cc:413
void server_recv_stmt_execute_response()
Definition: x_connection.cc:1952
void client_crud_delete()
Definition: x_connection.cc:2085
clock_type::time_point started_
Definition: x_connection.h:751
Manage destinations for a Connection Routing.
Definition: destination.h:189
typename base_class_::protocol_state_type protocol_state_type
Definition: basic_protocol_splicer.h:91
protocol_state_type & protocol()
Definition: connection_base.h:398
std::unique_ptr< ConnectionBase > & connection()
Definition: connection_base.h:404
net::impl::socket::native_handle_type native_handle() const
Definition: connection_base.h:367
SslMode ssl_mode() const
Definition: connection_base.h:363
Definition: x_connection.h:39
std::optional< uint8_t > msg_type_
Definition: x_connection.h:56
std::optional< FrameInfo > & current_frame()
Definition: x_connection.h:46
Mysqlx::Connection::Capabilities * caps()
Definition: x_connection.h:49
std::optional< FrameInfo > current_frame_
Definition: x_connection.h:55
void caps(std::unique_ptr< Mysqlx::Connection::Capabilities > caps)
Definition: x_connection.h:50
std::unique_ptr< Mysqlx::Connection::Capabilities > caps_
Definition: x_connection.h:58
std::optional< uint8_t > & current_msg_type()
Definition: x_connection.h:47
int native_handle_type
Definition: socket_constants.h:51
Definition: gcs_xcom_synode.h:64
SslMode
Definition: ssl_mode.h:29
Capabilities.
Definition: mysqlx_connection.proto:53
Severity
Definition: mysqlx.proto:279
@ ERROR
Definition: mysqlx.proto:280
Definition: x_connection.h:41
size_t frame_size_
size of the whole frame
Definition: x_connection.h:42
size_t forwarded_frame_size_
size of the forwarded part of frame
Definition: x_connection.h:43