MySQL 8.0.37
Source Code Documentation
ChangeUserForwarder Class Reference

forwards COM_CHANGE_USER from client to the server. More...

#include <classic_change_user_forwarder.h>

Inheritance diagram for ChangeUserForwarder:
[legend]

Public Types

enum class  Stage {
  Command , Connect , Connected , Response ,
  Ok , Error , Done
}
 
- Public Types inherited from BasicProcessor
enum class  Result {
  Again , RecvFromClient , SendToClient , RecvFromServer ,
  RecvFromBoth , SendToServer , SendableToServer , Suspend ,
  Done , Void
}
 

Public Member Functions

stdx::expected< Result, std::error_code > process () override
 forward the change-user message flow. More...
 
void stage (Stage stage)
 
Stage stage () const
 
- Public Member Functions inherited from Processor
 BasicProcessor (MysqlRoutingClassicConnectionBase *conn)
 
- Public Member Functions inherited from BasicProcessor
 BasicProcessor (MysqlRoutingClassicConnectionBase *conn)
 
virtual ~BasicProcessor ()=default
 
const MysqlRoutingClassicConnectionBaseconnection () const
 
MysqlRoutingClassicConnectionBaseconnection ()
 

Private Member Functions

stdx::expected< Result, std::error_code > command ()
 
stdx::expected< Result, std::error_code > connect ()
 
stdx::expected< Result, std::error_code > connected ()
 
stdx::expected< Result, std::error_code > response ()
 
stdx::expected< Result, std::error_code > ok ()
 
stdx::expected< Result, std::error_code > error ()
 

Private Attributes

Stage stage_ {Stage::Command}
 

Additional Inherited Members

- Protected Member Functions inherited from ForwardingProcessor
stdx::expected< Result, std::error_code > forward_server_to_client (bool noflush=false)
 forward the current packet from the server-side to the client-side. More...
 
stdx::expected< Result, std::error_code > forward_client_to_server (bool noflush=false)
 forward the current packet from the client-side to the server-side. More...
 
stdx::expected< bool, std::error_code > pool_server_connection ()
 move the server connection to the pool. More...
 
stdx::expected< Processor::Result, std::error_code > socket_reconnect_start ()
 reconnect a socket. More...
 
stdx::expected< Processor::Result, std::error_code > mysql_reconnect_start ()
 reconnect a mysql classic connection. More...
 
stdx::expected< Result, std::error_code > recv_server_failed_and_check_client_socket (std::error_code ec)
 handle error-code of a failed receive() from the server-socket and check the status of the client socket. More...
 
stdx::expected< Processor::Result, std::error_code > reconnect_send_error_msg (Channel *src_channel, ClassicProtocolState *src_protocol)
 send a Error msg based on the reconnect_error(). More...
 
void reconnect_error (classic_protocol::message::server::Error err)
 set the reconnect error. More...
 
classic_protocol::message::server::Error reconnect_error () const
 get the reconnect error. More...
 
- Protected Member Functions inherited from Processor
stdx::expected< Result, std::error_code > send_server_failed (std::error_code ec)
 
stdx::expected< Result, std::error_code > recv_server_failed (std::error_code ec)
 
stdx::expected< Result, std::error_code > send_client_failed (std::error_code ec)
 
stdx::expected< Result, std::error_code > recv_client_failed (std::error_code ec)
 
stdx::expected< Result, std::error_code > server_socket_failed (std::error_code ec)
 
stdx::expected< Result, std::error_code > client_socket_failed (std::error_code ec)
 
stdx::expected< void, std::error_code > discard_current_msg (Channel *src_channel, ClassicProtocolState *src_protocol)
 discard to current message. More...
 
void trace (Tracer::Event e)
 
Tracertracer ()
 
- Static Protected Member Functions inherited from Processor
static void log_fatal_error_code (const char *msg, std::error_code ec)
 log a message with error-code as error. More...
 

Detailed Description

forwards COM_CHANGE_USER from client to the server.

Member Enumeration Documentation

◆ Stage

enum class ChangeUserForwarder::Stage
strong
Enumerator
Command 
Connect 
Connected 
Response 
Ok 
Error 
Done 

Member Function Documentation

◆ command()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::command ( )
private

◆ connect()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::connect ( )
private

◆ connected()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::connected ( )
private

◆ error()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::error ( )
private

◆ ok()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::ok ( )
private

◆ process()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::process ( )
overridevirtual

forward the change-user message flow.

Expected overall flow:

alt fast-path
alt
c<-s: Error
else
c<-s: Ok
else auth-method-switch
c<-s: auth-method-switch
c->s: auth-method-data
loop more data
c<-s: auth-method-data
opt
c->s: auth-method-data
alt
c<-s: Error
else
c<-s: Ok
Class representing an error.
Definition: error.h:48
@ COM_CHANGE_USER
See COM_CHANGE_USER.
Definition: my_command.h:70
static char * path
Definition: mysqldump.cc:137
borrowable::message::server::Ok< false > Ok
Definition: classic_protocol_message.h:1398
Cursor end()
A past-the-end Cursor.
Definition: rules_table_service.cc:192

If there is no server connection, it is created on demand.

Implements BasicProcessor.

◆ response()

stdx::expected< Processor::Result, std::error_code > ChangeUserForwarder::response ( )
private

◆ stage() [1/2]

Stage ChangeUserForwarder::stage ( ) const
inline

◆ stage() [2/2]

void ChangeUserForwarder::stage ( Stage  stage)
inline

Member Data Documentation

◆ stage_

Stage ChangeUserForwarder::stage_ {Stage::Command}
private

The documentation for this class was generated from the following files: