2016-06-03 21:33:21 +03:00
|
|
|
#ifndef _SQMYSQL_CONNECTION_HPP_
|
|
|
|
#define _SQMYSQL_CONNECTION_HPP_
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
#include "Handle/Connection.hpp"
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
namespace SqMod {
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
2016-06-03 22:17:52 +03:00
|
|
|
* Allows management and interaction with a connection handle.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
|
|
|
class Connection
|
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
private:
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
ConnHnd m_Handle; // Handle to the actual database connection.
|
2016-05-22 22:34:27 +03:00
|
|
|
|
2016-06-03 21:33:21 +03:00
|
|
|
public:
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Default constructor.
|
|
|
|
*/
|
|
|
|
Connection()
|
|
|
|
: m_Handle()
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Base constructor.
|
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
Connection(const Account & acc)
|
|
|
|
: m_Handle(acc)
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
2016-06-05 05:08:59 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Base constructor.
|
|
|
|
*/
|
|
|
|
Connection(const ConnHnd & conn)
|
|
|
|
: m_Handle(conn)
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
2016-05-22 22:34:27 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy constructor.
|
|
|
|
*/
|
|
|
|
Connection(const Connection & o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move constructor.
|
|
|
|
*/
|
|
|
|
Connection(Connection && o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Destructor.
|
|
|
|
*/
|
2016-06-03 22:17:52 +03:00
|
|
|
~Connection()
|
|
|
|
{
|
|
|
|
// Let the handle deal with closing the connection if necessary
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy assignment operator.
|
|
|
|
*/
|
|
|
|
Connection & operator = (const Connection & o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move assignment operator.
|
|
|
|
*/
|
|
|
|
Connection & operator = (Connection && o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Used by the script engine to compare two instances of this type.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
Int32 Cmp(const Connection & o) const;
|
2016-05-22 22:34:27 +03:00
|
|
|
|
2016-06-03 21:33:21 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to convert an instance of this type to a string.
|
|
|
|
*/
|
|
|
|
CSStr ToString() const;
|
2016-05-22 22:34:27 +03:00
|
|
|
|
2016-06-03 21:33:21 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to retrieve the name from instances of this type.
|
|
|
|
*/
|
|
|
|
static SQInteger Typename(HSQUIRRELVM vm);
|
2016-05-22 22:34:27 +03:00
|
|
|
|
2016-06-05 05:36:33 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether the managed handle is valid.
|
|
|
|
*/
|
|
|
|
bool IsValid() const
|
|
|
|
{
|
|
|
|
return m_Handle;
|
|
|
|
}
|
|
|
|
|
2016-06-03 21:33:21 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Validate the managed connection handle and throw exception if it doesn't exist.
|
|
|
|
*/
|
|
|
|
void Validate() const;
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Implicit conversion to the managed connection handle.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
operator ConnHnd & ()
|
2016-05-22 22:34:27 +03:00
|
|
|
{
|
|
|
|
return m_Handle;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Implicit conversion to the managed connection handle.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
|
|
|
operator const ConnHnd & () const
|
|
|
|
{
|
|
|
|
return m_Handle;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the managed connection handle.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
ConnHnd & GetHnd()
|
|
|
|
{
|
|
|
|
return m_Handle;
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the managed connection handle.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
const ConnHnd & GetHnd() const
|
|
|
|
{
|
|
|
|
return m_Handle;
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether a successful connection was made or not.
|
|
|
|
*/
|
|
|
|
bool Connected() const
|
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
return m_Handle;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Disconnect from the currently connected database.
|
|
|
|
*/
|
|
|
|
void Disconnect()
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Perform the requested operation
|
|
|
|
m_Handle->Disconnect();
|
2016-05-22 22:34:27 +03:00
|
|
|
}
|
|
|
|
|
2016-06-03 22:17:52 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the current error number.
|
|
|
|
*/
|
|
|
|
SQInteger GetErrNo() const;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the current error message.
|
|
|
|
*/
|
|
|
|
CSStr GetErrStr() const;
|
|
|
|
|
2016-05-22 22:34:27 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the last received error number.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
SQInteger GetLastErrNo() const
|
2016-05-22 22:34:27 +03:00
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return static_cast< SQInteger >(m_Handle->mErrNo);
|
2016-05-22 22:34:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the last received error message.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
const String & GetLastErrStr() const
|
2016-05-22 22:34:27 +03:00
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mErrStr;
|
2016-05-22 22:34:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the connection port number.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
SQInteger GetPortNum() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return static_cast< SQInteger >(m_Handle->mPort);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection host address.
|
|
|
|
*/
|
|
|
|
const String & GetHost() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mHost;
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Retrieve the connection user name.
|
|
|
|
*/
|
|
|
|
const String & GetUser() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mUser;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection password.
|
|
|
|
*/
|
|
|
|
const String & GetPass() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mPass;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the selected database name.
|
|
|
|
*/
|
|
|
|
const String & GetName() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mName;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Modify the selected database name.
|
|
|
|
*/
|
|
|
|
void SetName(CSStr name);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection socket.
|
|
|
|
*/
|
|
|
|
const String & GetSocket() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSocket;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection flags.
|
|
|
|
*/
|
|
|
|
SQInteger GetFlags() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return static_cast< SQInteger >(m_Handle->mFlags);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection SSL key.
|
|
|
|
*/
|
|
|
|
const String & GetSSL_Key() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSSL_Key;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection SSL certificate.
|
|
|
|
*/
|
|
|
|
const String & GetSSL_Cert() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSSL_Cert;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection SSL certificate authority.
|
|
|
|
*/
|
|
|
|
const String & GetSSL_CA() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSSL_CA;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection SSL certificate authority path.
|
|
|
|
*/
|
|
|
|
const String & GetSSL_CA_Path() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSSL_CA_Path;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the connection SSL cipher.
|
|
|
|
*/
|
|
|
|
const String & GetSSL_Cipher() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mSSL_Cipher;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the default character set for the managed connection.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
|
|
|
const String & GetCharset() const
|
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mCharset;
|
2016-05-22 22:34:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:33:21 +03:00
|
|
|
* Modify the default character set for the managed connection.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
void SetCharset(CSStr charset);
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether auto-commit is enabled or not.
|
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
bool GetAutoCommit() const
|
2016-05-22 22:34:27 +03:00
|
|
|
{
|
2016-06-03 21:33:21 +03:00
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mAutoCommit;
|
2016-05-22 22:34:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Set whether auto-commit should be enabled or not.
|
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
void SetAutoCommit(bool toggle);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether the connection is in the middle of a transaction.
|
|
|
|
*/
|
|
|
|
bool GetInTransaction() const
|
|
|
|
{
|
|
|
|
// Validate the managed handle
|
|
|
|
m_Handle.Validate();
|
|
|
|
// Return the requested information
|
|
|
|
return m_Handle->mInTransaction;
|
|
|
|
}
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Execute a query on the server.
|
|
|
|
*/
|
2016-06-03 22:17:52 +03:00
|
|
|
Object Execute(CSStr query);
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Execute a query on the server.
|
|
|
|
*/
|
2016-06-03 22:17:52 +03:00
|
|
|
Object Insert(CSStr query);
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Execute a query on the server.
|
|
|
|
*/
|
2016-06-03 22:17:52 +03:00
|
|
|
ResultSet Query(CSStr query);
|
2016-05-22 22:34:27 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 22:17:52 +03:00
|
|
|
* Create a new statement on the managed connection.
|
2016-05-22 22:34:27 +03:00
|
|
|
*/
|
2016-06-03 21:33:21 +03:00
|
|
|
Statement GetStatement(CSStr query);
|
2016-06-03 22:17:52 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Create a new transaction on the managed connection.
|
|
|
|
*/
|
|
|
|
Transaction GetTransaction();
|
2016-05-22 22:34:27 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
} // Namespace:: SqMod
|
|
|
|
|
2016-06-03 21:33:21 +03:00
|
|
|
#endif // _SQMYSQL_CONNECTION_HPP_
|