mirror of
https://github.com/ddnet/ddnet.git
synced 2024-11-14 20:18:19 +00:00
1314085928
reading from and writing to several different servers is now possible TODO: -handle Exceptions properly (try another sqlserver) -if everything fails while writing write the insert to a file
40 lines
996 B
C++
40 lines
996 B
C++
#ifndef ENGINE_SERVER_SQL_CONNECTOR_H
|
|
#define ENGINE_SERVER_SQL_CONNECTOR_H
|
|
|
|
#include "sql_server.h"
|
|
|
|
enum
|
|
{
|
|
MAX_SQLSERVERS=15
|
|
};
|
|
|
|
// implementation to provide sqlservers
|
|
class CSqlConnector
|
|
{
|
|
public:
|
|
CSqlConnector();
|
|
|
|
CSqlServer* SqlServer(int i, bool ReadOnly = true) { return ReadOnly ? ms_ppSqlReadServers[i] : ms_ppSqlWriteServers[i]; }
|
|
|
|
// always returns the last connected sql-server
|
|
CSqlServer* SqlServer() { return m_pSqlServer; }
|
|
|
|
static void SetReadServers(CSqlServer** ppReadServers) { ms_ppSqlReadServers = ppReadServers; }
|
|
static void SetWriteServers(CSqlServer** ppWriteServers) { ms_ppSqlWriteServers = ppWriteServers; }
|
|
|
|
bool ConnectSqlServer(bool ReadOnly = true);
|
|
|
|
bool MaxTriesReached(bool ReadOnly = true) { return ReadOnly ? m_NumReadRetries : m_NumWriteRetries >= MAX_SQLSERVERS; }
|
|
|
|
private:
|
|
|
|
CSqlServer *m_pSqlServer;
|
|
static CSqlServer **ms_ppSqlReadServers;
|
|
static CSqlServer **ms_ppSqlWriteServers;
|
|
|
|
int m_NumReadRetries;
|
|
int m_NumWriteRetries;
|
|
};
|
|
|
|
#endif
|