533 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			C
		
	
	
	
		
		
			
		
	
	
			533 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			C
		
	
	
	
|  | /* Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
 | ||
|  | 
 | ||
|  |    This program is free software; you can redistribute it and/or modify | ||
|  |    it under the terms of the GNU General Public License as published by | ||
|  |    the Free Software Foundation; version 2 of the License. | ||
|  | 
 | ||
|  |    This program is distributed in the hope that it will be useful, | ||
|  |    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
|  |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||
|  |    GNU General Public License for more details. | ||
|  | 
 | ||
|  |    You should have received a copy of the GNU General Public License | ||
|  |    along with this program; if not, write to the Free Software | ||
|  |    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA */ | ||
|  | 
 | ||
|  | /*
 | ||
|  | ** Common definition between mysql server & client | ||
|  | */ | ||
|  | 
 | ||
|  | #ifndef _mysql_com_h
 | ||
|  | #define _mysql_com_h
 | ||
|  | 
 | ||
|  | #define HOSTNAME_LENGTH 60
 | ||
|  | #define SYSTEM_CHARSET_MBMAXLEN 3
 | ||
|  | #define NAME_CHAR_LEN	64              /* Field/table name length */
 | ||
|  | #define USERNAME_CHAR_LENGTH 16
 | ||
|  | #define NAME_LEN                (NAME_CHAR_LEN*SYSTEM_CHARSET_MBMAXLEN)
 | ||
|  | #define USERNAME_LENGTH         (USERNAME_CHAR_LENGTH*SYSTEM_CHARSET_MBMAXLEN)
 | ||
|  | 
 | ||
|  | #define SERVER_VERSION_LENGTH 60
 | ||
|  | #define SQLSTATE_LENGTH 5
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |   USER_HOST_BUFF_SIZE -- length of string buffer, that is enough to contain | ||
|  |   username and hostname parts of the user identifier with trailing zero in | ||
|  |   MySQL standard format: | ||
|  |   user_name_part@host_name_part\0 | ||
|  | */ | ||
|  | #define USER_HOST_BUFF_SIZE HOSTNAME_LENGTH + USERNAME_LENGTH + 2
 | ||
|  | 
 | ||
|  | #define LOCAL_HOST	"localhost"
 | ||
|  | #define LOCAL_HOST_NAMEDPIPE "."
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #if defined(__WIN__) && !defined( _CUSTOMCONFIG_)
 | ||
|  | #define MYSQL_NAMEDPIPE "MySQL"
 | ||
|  | #define MYSQL_SERVICENAME "MySQL"
 | ||
|  | #endif /* __WIN__ */
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |   You should add new commands to the end of this list, otherwise old | ||
|  |   servers won't be able to handle them as 'unsupported'. | ||
|  | */ | ||
|  | 
 | ||
|  | enum enum_server_command | ||
|  | { | ||
|  |   COM_SLEEP, COM_QUIT, COM_INIT_DB, COM_QUERY, COM_FIELD_LIST, | ||
|  |   COM_CREATE_DB, COM_DROP_DB, COM_REFRESH, COM_SHUTDOWN, COM_STATISTICS, | ||
|  |   COM_PROCESS_INFO, COM_CONNECT, COM_PROCESS_KILL, COM_DEBUG, COM_PING, | ||
|  |   COM_TIME, COM_DELAYED_INSERT, COM_CHANGE_USER, COM_BINLOG_DUMP, | ||
|  |   COM_TABLE_DUMP, COM_CONNECT_OUT, COM_REGISTER_SLAVE, | ||
|  |   COM_STMT_PREPARE, COM_STMT_EXECUTE, COM_STMT_SEND_LONG_DATA, COM_STMT_CLOSE, | ||
|  |   COM_STMT_RESET, COM_SET_OPTION, COM_STMT_FETCH, COM_DAEMON, | ||
|  |   /* don't forget to update const char *command_name[] in sql_parse.cc */ | ||
|  | 
 | ||
|  |   /* Must be last */ | ||
|  |   COM_END | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |   Length of random string sent by server on handshake; this is also length of | ||
|  |   obfuscated password, recieved from client | ||
|  | */ | ||
|  | #define SCRAMBLE_LENGTH 20
 | ||
|  | #define SCRAMBLE_LENGTH_323 8
 | ||
|  | /* length of password stored in the db: new passwords are preceeded with '*' */ | ||
|  | #define SCRAMBLED_PASSWORD_CHAR_LENGTH (SCRAMBLE_LENGTH*2+1)
 | ||
|  | #define SCRAMBLED_PASSWORD_CHAR_LENGTH_323 (SCRAMBLE_LENGTH_323*2)
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #define NOT_NULL_FLAG	1		/* Field can't be NULL */
 | ||
|  | #define PRI_KEY_FLAG	2		/* Field is part of a primary key */
 | ||
|  | #define UNIQUE_KEY_FLAG 4		/* Field is part of a unique key */
 | ||
|  | #define MULTIPLE_KEY_FLAG 8		/* Field is part of a key */
 | ||
|  | #define BLOB_FLAG	16		/* Field is a blob */
 | ||
|  | #define UNSIGNED_FLAG	32		/* Field is unsigned */
 | ||
|  | #define ZEROFILL_FLAG	64		/* Field is zerofill */
 | ||
|  | #define BINARY_FLAG	128		/* Field is binary   */
 | ||
|  | 
 | ||
|  | /* The following are only sent to new clients */ | ||
|  | #define ENUM_FLAG	256		/* field is an enum */
 | ||
|  | #define AUTO_INCREMENT_FLAG 512		/* field is a autoincrement field */
 | ||
|  | #define TIMESTAMP_FLAG	1024		/* Field is a timestamp */
 | ||
|  | #define SET_FLAG	2048		/* field is a set */
 | ||
|  | #define NO_DEFAULT_VALUE_FLAG 4096	/* Field doesn't have default value */
 | ||
|  | #define ON_UPDATE_NOW_FLAG 8192         /* Field is set to NOW on UPDATE */
 | ||
|  | #define NUM_FLAG	32768		/* Field is num (for clients) */
 | ||
|  | #define PART_KEY_FLAG	16384		/* Intern; Part of some key */
 | ||
|  | #define GROUP_FLAG	32768		/* Intern: Group field */
 | ||
|  | #define UNIQUE_FLAG	65536		/* Intern: Used by sql_yacc */
 | ||
|  | #define BINCMP_FLAG	131072		/* Intern: Used by sql_yacc */
 | ||
|  | #define GET_FIXED_FIELDS_FLAG (1 << 18) /* Used to get fields in item tree */
 | ||
|  | #define FIELD_IN_PART_FUNC_FLAG (1 << 19)/* Field part of partition func */
 | ||
|  | #define FIELD_IN_ADD_INDEX (1<< 20)	/* Intern: Field used in ADD INDEX */
 | ||
|  | #define FIELD_IS_RENAMED (1<< 21)       /* Intern: Field is being renamed */
 | ||
|  | 
 | ||
|  | #define REFRESH_GRANT		1	/* Refresh grant tables */
 | ||
|  | #define REFRESH_LOG		2	/* Start on new log file */
 | ||
|  | #define REFRESH_TABLES		4	/* close all tables */
 | ||
|  | #define REFRESH_HOSTS		8	/* Flush host cache */
 | ||
|  | #define REFRESH_STATUS		16	/* Flush status variables */
 | ||
|  | #define REFRESH_THREADS		32	/* Flush thread cache */
 | ||
|  | #define REFRESH_SLAVE           64      /* Reset master info and restart slave
 | ||
|  | 					   thread */ | ||
|  | #define REFRESH_MASTER          128     /* Remove all bin logs in the index
 | ||
|  | 					   and truncate the index */ | ||
|  | 
 | ||
|  | /* The following can't be set with mysql_refresh() */ | ||
|  | #define REFRESH_READ_LOCK	16384	/* Lock tables for read */
 | ||
|  | #define REFRESH_FAST		32768	/* Intern flag */
 | ||
|  | 
 | ||
|  | /* RESET (remove all queries) from query cache */ | ||
|  | #define REFRESH_QUERY_CACHE	65536
 | ||
|  | #define REFRESH_QUERY_CACHE_FREE 0x20000L /* pack query cache */
 | ||
|  | #define REFRESH_DES_KEY_FILE	0x40000L
 | ||
|  | #define REFRESH_USER_RESOURCES	0x80000L
 | ||
|  | 
 | ||
|  | #define CLIENT_LONG_PASSWORD	1	/* new more secure passwords */
 | ||
|  | #define CLIENT_FOUND_ROWS	2	/* Found instead of affected rows */
 | ||
|  | #define CLIENT_LONG_FLAG	4	/* Get all column flags */
 | ||
|  | #define CLIENT_CONNECT_WITH_DB	8	/* One can specify db on connect */
 | ||
|  | #define CLIENT_NO_SCHEMA	16	/* Don't allow database.table.column */
 | ||
|  | #define CLIENT_COMPRESS		32	/* Can use compression protocol */
 | ||
|  | #define CLIENT_ODBC		64	/* Odbc client */
 | ||
|  | #define CLIENT_LOCAL_FILES	128	/* Can use LOAD DATA LOCAL */
 | ||
|  | #define CLIENT_IGNORE_SPACE	256	/* Ignore spaces before '(' */
 | ||
|  | #define CLIENT_PROTOCOL_41	512	/* New 4.1 protocol */
 | ||
|  | #define CLIENT_INTERACTIVE	1024	/* This is an interactive client */
 | ||
|  | #define CLIENT_SSL              2048	/* Switch to SSL after handshake */
 | ||
|  | #define CLIENT_IGNORE_SIGPIPE   4096    /* IGNORE sigpipes */
 | ||
|  | #define CLIENT_TRANSACTIONS	8192	/* Client knows about transactions */
 | ||
|  | #define CLIENT_RESERVED         16384   /* Old flag for 4.1 protocol  */
 | ||
|  | #define CLIENT_SECURE_CONNECTION 32768  /* New 4.1 authentication */
 | ||
|  | #define CLIENT_MULTI_STATEMENTS (1UL << 16) /* Enable/disable multi-stmt support */
 | ||
|  | #define CLIENT_MULTI_RESULTS    (1UL << 17) /* Enable/disable multi-results */
 | ||
|  | 
 | ||
|  | #define CLIENT_SSL_VERIFY_SERVER_CERT (1UL << 30)
 | ||
|  | #define CLIENT_REMEMBER_OPTIONS (1UL << 31)
 | ||
|  | 
 | ||
|  | /* Gather all possible capabilites (flags) supported by the server */ | ||
|  | #define CLIENT_ALL_FLAGS  (CLIENT_LONG_PASSWORD | \
 | ||
|  |                            CLIENT_FOUND_ROWS | \ | ||
|  |                            CLIENT_LONG_FLAG | \ | ||
|  |                            CLIENT_CONNECT_WITH_DB | \ | ||
|  |                            CLIENT_NO_SCHEMA | \ | ||
|  |                            CLIENT_COMPRESS | \ | ||
|  |                            CLIENT_ODBC | \ | ||
|  |                            CLIENT_LOCAL_FILES | \ | ||
|  |                            CLIENT_IGNORE_SPACE | \ | ||
|  |                            CLIENT_PROTOCOL_41 | \ | ||
|  |                            CLIENT_INTERACTIVE | \ | ||
|  |                            CLIENT_SSL | \ | ||
|  |                            CLIENT_IGNORE_SIGPIPE | \ | ||
|  |                            CLIENT_TRANSACTIONS | \ | ||
|  |                            CLIENT_RESERVED | \ | ||
|  |                            CLIENT_SECURE_CONNECTION | \ | ||
|  |                            CLIENT_MULTI_STATEMENTS | \ | ||
|  |                            CLIENT_MULTI_RESULTS | \ | ||
|  |                            CLIENT_SSL_VERIFY_SERVER_CERT | \ | ||
|  |                            CLIENT_REMEMBER_OPTIONS) | ||
|  | 
 | ||
|  | /*
 | ||
|  |   Switch off the flags that are optional and depending on build flags | ||
|  |   If any of the optional flags is supported by the build it will be switched | ||
|  |   on before sending to the client during the connection handshake. | ||
|  | */ | ||
|  | #define CLIENT_BASIC_FLAGS (((CLIENT_ALL_FLAGS & ~CLIENT_SSL) \
 | ||
|  |                                                & ~CLIENT_COMPRESS) \ | ||
|  |                                                & ~CLIENT_SSL_VERIFY_SERVER_CERT) | ||
|  | 
 | ||
|  | #define SERVER_STATUS_IN_TRANS     1	/* Transaction has started */
 | ||
|  | #define SERVER_STATUS_AUTOCOMMIT   2	/* Server in auto_commit mode */
 | ||
|  | #define SERVER_MORE_RESULTS_EXISTS 8    /* Multi query - next query exists */
 | ||
|  | #define SERVER_QUERY_NO_GOOD_INDEX_USED 16
 | ||
|  | #define SERVER_QUERY_NO_INDEX_USED      32
 | ||
|  | /**
 | ||
|  |   The server was able to fulfill the clients request and opened a | ||
|  |   read-only non-scrollable cursor for a query. This flag comes | ||
|  |   in reply to COM_STMT_EXECUTE and COM_STMT_FETCH commands. | ||
|  | */ | ||
|  | #define SERVER_STATUS_CURSOR_EXISTS 64
 | ||
|  | /**
 | ||
|  |   This flag is sent when a read-only cursor is exhausted, in reply to | ||
|  |   COM_STMT_FETCH command. | ||
|  | */ | ||
|  | #define SERVER_STATUS_LAST_ROW_SENT 128
 | ||
|  | #define SERVER_STATUS_DB_DROPPED        256 /* A database was dropped */
 | ||
|  | #define SERVER_STATUS_NO_BACKSLASH_ESCAPES 512
 | ||
|  | /**
 | ||
|  |   Sent to the client if after a prepared statement reprepare | ||
|  |   we discovered that the new statement returns a different  | ||
|  |   number of result set columns. | ||
|  | */ | ||
|  | #define SERVER_STATUS_METADATA_CHANGED 1024
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |   Server status flags that must be cleared when starting | ||
|  |   execution of a new SQL statement. | ||
|  |   Flags from this set are only added to the | ||
|  |   current server status by the execution engine, but  | ||
|  |   never removed -- the execution engine expects them  | ||
|  |   to disappear automagically by the next command. | ||
|  | */ | ||
|  | #define SERVER_STATUS_CLEAR_SET (SERVER_QUERY_NO_GOOD_INDEX_USED| \
 | ||
|  |                                  SERVER_QUERY_NO_INDEX_USED|\ | ||
|  |                                  SERVER_MORE_RESULTS_EXISTS|\ | ||
|  |                                  SERVER_STATUS_METADATA_CHANGED) | ||
|  | 
 | ||
|  | #define MYSQL_ERRMSG_SIZE	512
 | ||
|  | #define NET_READ_TIMEOUT	30		/* Timeout on read */
 | ||
|  | #define NET_WRITE_TIMEOUT	60		/* Timeout on write */
 | ||
|  | #define NET_WAIT_TIMEOUT	8*60*60		/* Wait for new query */
 | ||
|  | 
 | ||
|  | #define ONLY_KILL_QUERY         1
 | ||
|  | 
 | ||
|  | 
 | ||
|  | struct st_vio;					/* Only C */ | ||
|  | typedef struct st_vio Vio; | ||
|  | 
 | ||
|  | #define MAX_TINYINT_WIDTH       3       /* Max width for a TINY w.o. sign */
 | ||
|  | #define MAX_SMALLINT_WIDTH      5       /* Max width for a SHORT w.o. sign */
 | ||
|  | #define MAX_MEDIUMINT_WIDTH     8       /* Max width for a INT24 w.o. sign */
 | ||
|  | #define MAX_INT_WIDTH           10      /* Max width for a LONG w.o. sign */
 | ||
|  | #define MAX_BIGINT_WIDTH        20      /* Max width for a LONGLONG */
 | ||
|  | #define MAX_CHAR_WIDTH		255	/* Max length for a CHAR colum */
 | ||
|  | #define MAX_BLOB_WIDTH		16777216	/* Default width for blob */
 | ||
|  | 
 | ||
|  | typedef struct st_net { | ||
|  | #if !defined(CHECK_EMBEDDED_DIFFERENCES) || !defined(EMBEDDED_LIBRARY)
 | ||
|  |   Vio *vio; | ||
|  |   unsigned char *buff,*buff_end,*write_pos,*read_pos; | ||
|  |   my_socket fd;					/* For Perl DBI/dbd */ | ||
|  |   /*
 | ||
|  |     The following variable is set if we are doing several queries in one | ||
|  |     command ( as in LOAD TABLE ... FROM MASTER ), | ||
|  |     and do not want to confuse the client with OK at the wrong time | ||
|  |   */ | ||
|  |   unsigned long remain_in_buf,length, buf_length, where_b; | ||
|  |   unsigned long max_packet,max_packet_size; | ||
|  |   unsigned int pkt_nr,compress_pkt_nr; | ||
|  |   unsigned int write_timeout, read_timeout, retry_count; | ||
|  |   int fcntl; | ||
|  |   unsigned int *return_status; | ||
|  |   unsigned char reading_or_writing; | ||
|  |   char save_char; | ||
|  |   my_bool unused0; /* Please remove with the next incompatible ABI change. */ | ||
|  |   my_bool unused; /* Please remove with the next incompatible ABI change */ | ||
|  |   my_bool compress; | ||
|  |   my_bool unused1; /* Please remove with the next incompatible ABI change. */ | ||
|  |   /*
 | ||
|  |     Pointer to query object in query cache, do not equal NULL (0) for | ||
|  |     queries in cache that have not stored its results yet | ||
|  |   */ | ||
|  | #endif
 | ||
|  |   /*
 | ||
|  |     'query_cache_query' should be accessed only via query cache | ||
|  |     functions and methods to maintain proper locking. | ||
|  |   */ | ||
|  |   unsigned char *query_cache_query; | ||
|  |   unsigned int last_errno; | ||
|  |   unsigned char error;  | ||
|  |   my_bool unused2; /* Please remove with the next incompatible ABI change. */ | ||
|  |   my_bool return_errno; | ||
|  |   /** Client library error message buffer. Actually belongs to struct MYSQL. */ | ||
|  |   char last_error[MYSQL_ERRMSG_SIZE]; | ||
|  |   /** Client library sqlstate buffer. Set along with the error message. */ | ||
|  |   char sqlstate[SQLSTATE_LENGTH+1]; | ||
|  |   void *extension; | ||
|  | #if defined(MYSQL_SERVER) && !defined(EMBEDDED_LIBRARY)
 | ||
|  |   /*
 | ||
|  |     Controls whether a big packet should be skipped. | ||
|  | 
 | ||
|  |     Initially set to FALSE by default. Unauthenticated sessions must have | ||
|  |     this set to FALSE so that the server can't be tricked to read packets | ||
|  |     indefinitely. | ||
|  |   */ | ||
|  |   my_bool skip_big_packet; | ||
|  | #endif
 | ||
|  | } NET; | ||
|  | 
 | ||
|  | 
 | ||
|  | #define packet_error (~(unsigned long) 0)
 | ||
|  | 
 | ||
|  | enum enum_field_types { MYSQL_TYPE_DECIMAL, MYSQL_TYPE_TINY, | ||
|  | 			MYSQL_TYPE_SHORT,  MYSQL_TYPE_LONG, | ||
|  | 			MYSQL_TYPE_FLOAT,  MYSQL_TYPE_DOUBLE, | ||
|  | 			MYSQL_TYPE_NULL,   MYSQL_TYPE_TIMESTAMP, | ||
|  | 			MYSQL_TYPE_LONGLONG,MYSQL_TYPE_INT24, | ||
|  | 			MYSQL_TYPE_DATE,   MYSQL_TYPE_TIME, | ||
|  | 			MYSQL_TYPE_DATETIME, MYSQL_TYPE_YEAR, | ||
|  | 			MYSQL_TYPE_NEWDATE, MYSQL_TYPE_VARCHAR, | ||
|  | 			MYSQL_TYPE_BIT, | ||
|  |                         MYSQL_TYPE_NEWDECIMAL=246, | ||
|  | 			MYSQL_TYPE_ENUM=247, | ||
|  | 			MYSQL_TYPE_SET=248, | ||
|  | 			MYSQL_TYPE_TINY_BLOB=249, | ||
|  | 			MYSQL_TYPE_MEDIUM_BLOB=250, | ||
|  | 			MYSQL_TYPE_LONG_BLOB=251, | ||
|  | 			MYSQL_TYPE_BLOB=252, | ||
|  | 			MYSQL_TYPE_VAR_STRING=253, | ||
|  | 			MYSQL_TYPE_STRING=254, | ||
|  | 			MYSQL_TYPE_GEOMETRY=255 | ||
|  | 
 | ||
|  | }; | ||
|  | 
 | ||
|  | /* For backward compatibility */ | ||
|  | #define CLIENT_MULTI_QUERIES    CLIENT_MULTI_STATEMENTS    
 | ||
|  | #define FIELD_TYPE_DECIMAL     MYSQL_TYPE_DECIMAL
 | ||
|  | #define FIELD_TYPE_NEWDECIMAL  MYSQL_TYPE_NEWDECIMAL
 | ||
|  | #define FIELD_TYPE_TINY        MYSQL_TYPE_TINY
 | ||
|  | #define FIELD_TYPE_SHORT       MYSQL_TYPE_SHORT
 | ||
|  | #define FIELD_TYPE_LONG        MYSQL_TYPE_LONG
 | ||
|  | #define FIELD_TYPE_FLOAT       MYSQL_TYPE_FLOAT
 | ||
|  | #define FIELD_TYPE_DOUBLE      MYSQL_TYPE_DOUBLE
 | ||
|  | #define FIELD_TYPE_NULL        MYSQL_TYPE_NULL
 | ||
|  | #define FIELD_TYPE_TIMESTAMP   MYSQL_TYPE_TIMESTAMP
 | ||
|  | #define FIELD_TYPE_LONGLONG    MYSQL_TYPE_LONGLONG
 | ||
|  | #define FIELD_TYPE_INT24       MYSQL_TYPE_INT24
 | ||
|  | #define FIELD_TYPE_DATE        MYSQL_TYPE_DATE
 | ||
|  | #define FIELD_TYPE_TIME        MYSQL_TYPE_TIME
 | ||
|  | #define FIELD_TYPE_DATETIME    MYSQL_TYPE_DATETIME
 | ||
|  | #define FIELD_TYPE_YEAR        MYSQL_TYPE_YEAR
 | ||
|  | #define FIELD_TYPE_NEWDATE     MYSQL_TYPE_NEWDATE
 | ||
|  | #define FIELD_TYPE_ENUM        MYSQL_TYPE_ENUM
 | ||
|  | #define FIELD_TYPE_SET         MYSQL_TYPE_SET
 | ||
|  | #define FIELD_TYPE_TINY_BLOB   MYSQL_TYPE_TINY_BLOB
 | ||
|  | #define FIELD_TYPE_MEDIUM_BLOB MYSQL_TYPE_MEDIUM_BLOB
 | ||
|  | #define FIELD_TYPE_LONG_BLOB   MYSQL_TYPE_LONG_BLOB
 | ||
|  | #define FIELD_TYPE_BLOB        MYSQL_TYPE_BLOB
 | ||
|  | #define FIELD_TYPE_VAR_STRING  MYSQL_TYPE_VAR_STRING
 | ||
|  | #define FIELD_TYPE_STRING      MYSQL_TYPE_STRING
 | ||
|  | #define FIELD_TYPE_CHAR        MYSQL_TYPE_TINY
 | ||
|  | #define FIELD_TYPE_INTERVAL    MYSQL_TYPE_ENUM
 | ||
|  | #define FIELD_TYPE_GEOMETRY    MYSQL_TYPE_GEOMETRY
 | ||
|  | #define FIELD_TYPE_BIT         MYSQL_TYPE_BIT
 | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Shutdown/kill enums and constants */  | ||
|  | 
 | ||
|  | /* Bits for THD::killable. */ | ||
|  | #define MYSQL_SHUTDOWN_KILLABLE_CONNECT    (unsigned char)(1 << 0)
 | ||
|  | #define MYSQL_SHUTDOWN_KILLABLE_TRANS      (unsigned char)(1 << 1)
 | ||
|  | #define MYSQL_SHUTDOWN_KILLABLE_LOCK_TABLE (unsigned char)(1 << 2)
 | ||
|  | #define MYSQL_SHUTDOWN_KILLABLE_UPDATE     (unsigned char)(1 << 3)
 | ||
|  | 
 | ||
|  | enum mysql_enum_shutdown_level { | ||
|  |   /*
 | ||
|  |     We want levels to be in growing order of hardness (because we use number | ||
|  |     comparisons). Note that DEFAULT does not respect the growing property, but | ||
|  |     it's ok. | ||
|  |   */ | ||
|  |   SHUTDOWN_DEFAULT = 0, | ||
|  |   /* wait for existing connections to finish */ | ||
|  |   SHUTDOWN_WAIT_CONNECTIONS= MYSQL_SHUTDOWN_KILLABLE_CONNECT, | ||
|  |   /* wait for existing trans to finish */ | ||
|  |   SHUTDOWN_WAIT_TRANSACTIONS= MYSQL_SHUTDOWN_KILLABLE_TRANS, | ||
|  |   /* wait for existing updates to finish (=> no partial MyISAM update) */ | ||
|  |   SHUTDOWN_WAIT_UPDATES= MYSQL_SHUTDOWN_KILLABLE_UPDATE, | ||
|  |   /* flush InnoDB buffers and other storage engines' buffers*/ | ||
|  |   SHUTDOWN_WAIT_ALL_BUFFERS= (MYSQL_SHUTDOWN_KILLABLE_UPDATE << 1), | ||
|  |   /* don't flush InnoDB buffers, flush other storage engines' buffers*/ | ||
|  |   SHUTDOWN_WAIT_CRITICAL_BUFFERS= (MYSQL_SHUTDOWN_KILLABLE_UPDATE << 1) + 1, | ||
|  |   /* Now the 2 levels of the KILL command */ | ||
|  | #if MYSQL_VERSION_ID >= 50000
 | ||
|  |   KILL_QUERY= 254, | ||
|  | #endif
 | ||
|  |   KILL_CONNECTION= 255 | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | enum enum_cursor_type | ||
|  | { | ||
|  |   CURSOR_TYPE_NO_CURSOR= 0, | ||
|  |   CURSOR_TYPE_READ_ONLY= 1, | ||
|  |   CURSOR_TYPE_FOR_UPDATE= 2, | ||
|  |   CURSOR_TYPE_SCROLLABLE= 4 | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | /* options for mysql_set_option */ | ||
|  | enum enum_mysql_set_option | ||
|  | { | ||
|  |   MYSQL_OPTION_MULTI_STATEMENTS_ON, | ||
|  |   MYSQL_OPTION_MULTI_STATEMENTS_OFF | ||
|  | }; | ||
|  | 
 | ||
|  | #define net_new_transaction(net) ((net)->pkt_nr=0)
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | my_bool	my_net_init(NET *net, Vio* vio); | ||
|  | void	my_net_local_init(NET *net); | ||
|  | void	net_end(NET *net); | ||
|  |   void	net_clear(NET *net, my_bool clear_buffer); | ||
|  | my_bool net_realloc(NET *net, size_t length); | ||
|  | my_bool	net_flush(NET *net); | ||
|  | my_bool	my_net_write(NET *net,const unsigned char *packet, size_t len); | ||
|  | my_bool	net_write_command(NET *net,unsigned char command, | ||
|  | 			  const unsigned char *header, size_t head_len, | ||
|  | 			  const unsigned char *packet, size_t len); | ||
|  | int	net_real_write(NET *net,const unsigned char *packet, size_t len); | ||
|  | unsigned long my_net_read(NET *net); | ||
|  | 
 | ||
|  | #ifdef _global_h
 | ||
|  | void my_net_set_write_timeout(NET *net, uint timeout); | ||
|  | void my_net_set_read_timeout(NET *net, uint timeout); | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |   The following function is not meant for normal usage | ||
|  |   Currently it's used internally by manager.c | ||
|  | */ | ||
|  | struct sockaddr; | ||
|  | int my_connect(my_socket s, const struct sockaddr *name, unsigned int namelen, | ||
|  | 	       unsigned int timeout); | ||
|  | 
 | ||
|  | struct rand_struct { | ||
|  |   unsigned long seed1,seed2,max_value; | ||
|  |   double max_value_dbl; | ||
|  | }; | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  |   /* The following is for user defined functions */ | ||
|  | 
 | ||
|  | enum Item_result {STRING_RESULT=0, REAL_RESULT, INT_RESULT, ROW_RESULT, | ||
|  |                   DECIMAL_RESULT}; | ||
|  | 
 | ||
|  | typedef struct st_udf_args | ||
|  | { | ||
|  |   unsigned int arg_count;		/* Number of arguments */ | ||
|  |   enum Item_result *arg_type;		/* Pointer to item_results */ | ||
|  |   char **args;				/* Pointer to argument */ | ||
|  |   unsigned long *lengths;		/* Length of string arguments */ | ||
|  |   char *maybe_null;			/* Set to 1 for all maybe_null args */ | ||
|  |   char **attributes;                    /* Pointer to attribute name */ | ||
|  |   unsigned long *attribute_lengths;     /* Length of attribute arguments */ | ||
|  |   void *extension; | ||
|  | } UDF_ARGS; | ||
|  | 
 | ||
|  |   /* This holds information about the result */ | ||
|  | 
 | ||
|  | typedef struct st_udf_init | ||
|  | { | ||
|  |   my_bool maybe_null;          /* 1 if function can return NULL */ | ||
|  |   unsigned int decimals;       /* for real functions */ | ||
|  |   unsigned long max_length;    /* For string functions */ | ||
|  |   char *ptr;                   /* free pointer for function data */ | ||
|  |   my_bool const_item;          /* 1 if function always returns the same value */ | ||
|  |   void *extension; | ||
|  | } UDF_INIT; | ||
|  | /* 
 | ||
|  |   TODO: add a notion for determinism of the UDF.  | ||
|  |   See Item_udf_func::update_used_tables () | ||
|  | */ | ||
|  | 
 | ||
|  |   /* Constants when using compression */ | ||
|  | #define NET_HEADER_SIZE 4		/* standard header size */
 | ||
|  | #define COMP_HEADER_SIZE 3		/* compression header extra size */
 | ||
|  | 
 | ||
|  |   /* Prototypes to password functions */ | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |   These functions are used for authentication by client and server and | ||
|  |   implemented in sql/password.c | ||
|  | */ | ||
|  | 
 | ||
|  | void randominit(struct rand_struct *, unsigned long seed1, | ||
|  |                 unsigned long seed2); | ||
|  | double my_rnd(struct rand_struct *); | ||
|  | void create_random_string(char *to, unsigned int length, struct rand_struct *rand_st); | ||
|  | 
 | ||
|  | void hash_password(unsigned long *to, const char *password, unsigned int password_len); | ||
|  | void make_scrambled_password_323(char *to, const char *password); | ||
|  | void scramble_323(char *to, const char *message, const char *password); | ||
|  | my_bool check_scramble_323(const char *, const char *message, | ||
|  |                            unsigned long *salt); | ||
|  | void get_salt_from_password_323(unsigned long *res, const char *password); | ||
|  | void make_password_from_salt_323(char *to, const unsigned long *salt); | ||
|  | 
 | ||
|  | void make_scrambled_password(char *to, const char *password); | ||
|  | void scramble(char *to, const char *message, const char *password); | ||
|  | my_bool check_scramble(const char *reply, const char *message, | ||
|  |                        const unsigned char *hash_stage2); | ||
|  | void get_salt_from_password(unsigned char *res, const char *password); | ||
|  | void make_password_from_salt(char *to, const unsigned char *hash_stage2); | ||
|  | char *octet2hex(char *to, const char *str, unsigned int len); | ||
|  | 
 | ||
|  | /* end of password.c */ | ||
|  | 
 | ||
|  | char *get_tty_password(const char *opt_message); | ||
|  | const char *mysql_errno_to_sqlstate(unsigned int mysql_errno); | ||
|  | 
 | ||
|  | /* Some other useful functions */ | ||
|  | 
 | ||
|  | my_bool my_thread_init(void); | ||
|  | void my_thread_end(void); | ||
|  | 
 | ||
|  | #ifdef _global_h
 | ||
|  | ulong STDCALL net_field_length(uchar **packet); | ||
|  | my_ulonglong net_field_length_ll(uchar **packet); | ||
|  | uchar *net_store_length(uchar *pkg, ulonglong length); | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #define NULL_LENGTH ((unsigned long) ~0) /* For net_store_length */
 | ||
|  | #define MYSQL_STMT_HEADER       4
 | ||
|  | #define MYSQL_LONG_DATA_HEADER  6
 | ||
|  | 
 | ||
|  | #endif
 |