00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #include <mysql/errmsg.h>
00017 #include "mysqlDatabase.hpp"
00018 #include "mysqlSocket.hpp"
00019 #include "timer.hpp"
00020
00021 using namespace std;
00022
00023 MySQLSocket::MySQLSocket( const std::string &_userName,
00024 const std::string &_passWord,
00025 const std::string &_socketName,
00026 MySQLDaemonPtr _daemon ) throw (Error):
00027 MySQLServer( _userName, _passWord ), socketName(_socketName),
00028 daemon(_daemon)
00029 {
00030 connect( "", &connection );
00031 }
00032
00033 void MySQLSocket::connect( const std::string &database, MYSQL *m )
00034 throw (Error)
00035 {
00036 mysql_init( m );
00037
00038 const int timeout = 10;
00039 mysql_options( m, MYSQL_OPT_CONNECT_TIMEOUT,
00040 (const char *)&timeout );
00041
00042 try {
00043
00044 MYSQL *result = NULL;
00045 timer t;
00046
00047
00048
00049 do {
00050
00051 result = mysql_real_connect( m, NULL,
00052 userName.c_str(),
00053 passWord.empty() ? (const char *)NULL :
00054 passWord.c_str(),
00055 database.empty() ? (const char *)NULL :
00056 database.c_str(),
00057 0, socketName.c_str(), 0 );
00058 if ( result == NULL ) {
00059 if ( t.elapsed() > timeout ||
00060 mysql_errno( m ) != CR_CONNECTION_ERROR ||
00061 !daemon ) {
00062 ERRORMACRO( result != NULL, Error, , "Error connecting to socket '"
00063 << socketName << "' as user '" << userName << "' "
00064 << ( passWord.empty() ? "without" : "with" )
00065 << " password: " << mysql_error( m ) );
00066 } else
00067 sleep( 1 );
00068 };
00069 } while ( result == NULL );
00070
00071
00072
00073
00074 mysql_query( m, "SET NAMES utf8;" );
00075
00076 } catch ( Error &e ) {
00077
00078 mysql_close( m );
00079 throw e;
00080
00081 };
00082 };
00083
00084 MySQLSocket::~MySQLSocket(void)
00085 {
00086 mysql_close( &connection );
00087 }