diff options
Diffstat (limited to 'src/modules/extra')
-rw-r--r-- | src/modules/extra/m_sql.h | 144 |
1 files changed, 75 insertions, 69 deletions
diff --git a/src/modules/extra/m_sql.h b/src/modules/extra/m_sql.h index 519b28f33..2fa61fbe9 100644 --- a/src/modules/extra/m_sql.h +++ b/src/modules/extra/m_sql.h @@ -120,24 +120,24 @@ class SQLResult class SQLQuery { - private: - SQLRequest* rowrequest; + private: + SQLRequest* rowrequest; SQLRequest* query; SQLResult* result; SQLResult* rowresult; - Request* rowquery; - unsigned long dbid; - Module* parent; - Module* SQLModule; - Server* Srv; - + Request* rowquery; + unsigned long dbid; + Module* parent; + Module* SQLModule; + Server* Srv; + std::string error; - bool MakeQueryGoNow(std::string qry) + bool MakeQueryGoNow(std::string qry) { - // Insert Lack of More Original Name here. - Request queryrequest((char*)query, parent, SQLModule); - result = (SQLResult*)queryrequest.Send(); - if (result->GetType() != SQL_ERROR) + // Insert Lack of More Original Name here. + Request queryrequest((char*)query, parent, SQLModule); + result = (SQLResult*)queryrequest.Send(); + if (result->GetType() != SQL_ERROR) { // Query Is fine.. Prepare to get first row... rowrequest = new SQLRequest(SQL_ROW,dbid,""); @@ -148,7 +148,8 @@ class SQLQuery Srv->Log(DEBUG, " ============= SQL Error, Query And Error Follow. ============= "); Srv->Log(DEBUG, "Query: "+ qry); Srv->Log(DEBUG, "Error: "+ result->GetError()); - Srv->Log(DEBUG, " ============================================================== "); + Srv->Log(DEBUG, " ============================================================== "); + error = result->GetError(); // Destroy Variables that were set.. delete query; query = NULL; @@ -156,44 +157,44 @@ class SQLQuery return false; } - public: + public: SQLQuery(Server* S) : Srv(S) { } - SQLQuery(Module* a, unsigned long b, Server* S) : dbid(b), parent(a), Srv(S) - { - // Make a few useful variables.. - SQLModule = Srv->FindModule("m_sql.so"); - } - - ~SQLQuery() - { - } - - bool Query(std::string qry) - { - query = new SQLRequest(SQL_RESULT, dbid, qry); - return MakeQueryGoNow(qry); - } - - bool QueryCount(std::string qry) - { - query = new SQLRequest(SQL_COUNT, dbid, qry); - return MakeQueryGoNow(qry); - } - - bool GetRow() - { + SQLQuery(Module* a, unsigned long b, Server* S) : dbid(b), parent(a), Srv(S) + { + // Make a few useful variables.. + SQLModule = Srv->FindModule("m_sql.so"); + } + + ~SQLQuery() + { + } + + bool Query(std::string qry) + { + query = new SQLRequest(SQL_RESULT, dbid, qry); + return MakeQueryGoNow(qry); + } + + bool QueryCount(std::string qry) + { + query = new SQLRequest(SQL_COUNT, dbid, qry); + return MakeQueryGoNow(qry); + } + + bool GetRow() + { rowresult = (SQLResult*)rowquery->Send(); if (rowresult->GetType() == SQL_ROW) { - // We have got a row.. thats all for now. - return true; - } - // No Row, Error, or end. KILL CALLER! *BANG* - return false; + // We have got a row.. thats all for now. + return true; + } + // No Row, Error, or end. KILL CALLER! *BANG* + return false; } std::string GetField(std::string fname) @@ -204,36 +205,41 @@ class SQLQuery long GetCount() { rowresult = (SQLResult*)rowquery->Send(); - if (rowresult->GetType() == SQL_COUNT) + if (rowresult->GetType() == SQL_COUNT) { - return rowresult->GetCount(); - } + return rowresult->GetCount(); + } else { - return 0; - } - } + return 0; + } + } + + const std::string &GetError() + { + return error; + } - void SQLDone() + void SQLDone() { - // Tell m_sql we are finished.. + // Tell m_sql we are finished.. query->SetQueryType(SQL_DONE); - query->SetConnID(dbid); - Request donerequest((char*)query, parent, SQLModule); - donerequest.Send(); - - // Do Some Clearing up. - delete query; - delete rowrequest; - // Null the variables, so they can be re-used without confusion.. - result = NULL; - query = NULL; - rowrequest = NULL; - rowresult = NULL; - } - - static std::string Sanitise(const std::string& crap) - { + query->SetConnID(dbid); + Request donerequest((char*)query, parent, SQLModule); + donerequest.Send(); + + // Do Some Clearing up. + delete query; + delete rowrequest; + // Null the variables, so they can be re-used without confusion.. + result = NULL; + query = NULL; + rowrequest = NULL; + rowresult = NULL; + } + + static std::string Sanitise(const std::string& crap) + { std::string temp = ""; for (unsigned int q = 0; q < crap.length(); q++) { @@ -255,7 +261,7 @@ class SQLQuery } } return temp; - } + } }; |