#ifndef _MYSQL_PROTOCOL_H #define _MYSQL_PROTOCOL_H /* * This file is distributed as part of the SkySQL Gateway. It 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. * * 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. * * Copyright SkySQL Ab 2013 */ /* * Revision History * * Date Who Description * 01-06-2013 Mark Riddoch Initial implementation * 14-06-2013 Massimiliano Pinto Added specific data * for MySQL session */ #ifndef MYSQL_SCRAMBLE_LEN #define MYSQL_SCRAMBLE_LEN GW_MYSQL_SCRAMBLE_SIZE #endif #define MYSQL_USER_MAXLEN 128 #define MYSQL_DATABASE_MAXLEN 128 struct dcb; /** * MySQL Protocol specific state data */ typedef struct { int fd; /**< The socket descriptor */ struct dcb *descriptor; /**< The DCB of the socket we are running on */ int state; /**< Current descriptor state */ char scramble[MYSQL_SCRAMBLE_LEN]; /**< server scramble, created or received */ uint32_t server_capabilities; /**< server capabilities, created or received */ uint32_t client_capabilities; /**< client capabilities, created or received */ unsigned long tid; /**< MySQL Thread ID, in handshake */ } MySQLProtocol; /** * MySQL session specific data * */ typedef struct mysql_session { uint8_t client_sha1[MYSQL_SCRAMBLE_LEN]; /**< SHA1(passowrd) */ char user[MYSQL_USER_MAXLEN]; /**< username */ char db[MYSQL_DATABASE_MAXLEN]; /**< database */ } MYSQL_session; /* MySQL Protocol States */ #define MYSQL_ALLOC 0 /**< Allocate data */ #define MYSQL_AUTH_SENT 1 /**< Authentication handshake has been sent */ #define MYSQL_AUTH_RECV 2 /**< Received user, password, db and capabilities */ #define MYSQL_AUTH_FAILED 3 /**< Auth failed, return error packet */ #define MYSQL_IDLE 4 /**< Auth done. Protocol is idle, waiting for statements */ #define MYSQL_ROUTING 5 /**< The received command has been routed to backend(s) */ #define MYSQL_WAITING_RESULT 6 /**< Waiting for result set */ #endif