mirror of
https://github.com/EQEmu/Server.git
synced 2026-03-03 11:12:25 +00:00
Merge pull request #189 from addtheice/RunQueryToDatabaseQuery_lfguild
Run query to database query lfguild
This commit is contained in:
commit
964c4c83df
@ -34,37 +34,27 @@ GuildLookingForPlayers::GuildLookingForPlayers(char *Name, char *Comments, uint3
|
|||||||
|
|
||||||
bool LFGuildManager::LoadDatabase()
|
bool LFGuildManager::LoadDatabase()
|
||||||
{
|
{
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
std::string query = "SELECT `type`,`name`,`comment`, "
|
||||||
char* query = 0;
|
"`fromlevel`, `tolevel`, `classes`, "
|
||||||
MYSQL_RES *result;
|
"`aacount`, `timezone`, `timeposted` FROM `lfguild`";
|
||||||
MYSQL_ROW row;
|
auto results = database.QueryDatabase(query);
|
||||||
|
if (!results.Success()) {
|
||||||
if (!database.RunQuery(query,MakeAnyLenString(&query, "SELECT `type`,`name`,`comment`, `fromlevel`, `tolevel`, `classes`, `aacount`, `timezone`, `timeposted` FROM `lfguild`"),errbuf,&result)){
|
_log(QUERYSERV__ERROR, "Failed to load LFGuild info from database. %s %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
_log(QUERYSERV__ERROR, "Failed to load LFGuild info from database. %s %s", query, errbuf);
|
|
||||||
safe_delete_array(query);
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
safe_delete_array(query);
|
for (auto row = results.begin(); row != results.end(); ++row) {
|
||||||
|
|
||||||
while((row = mysql_fetch_row(result))) {
|
|
||||||
|
|
||||||
uint32 type = atoul(row[0]);
|
uint32 type = atoul(row[0]);
|
||||||
if(type == 0)
|
if(type == 0)
|
||||||
{
|
{
|
||||||
PlayerLookingForGuild p(row[1], row[2], atoul(row[3]), atoul(row[5]), atoul(row[6]), atoul(row[7]), atoul(row[8]));
|
PlayerLookingForGuild p(row[1], row[2], atoul(row[3]), atoul(row[5]), atoul(row[6]), atoul(row[7]), atoul(row[8]));
|
||||||
Players.push_back(p);
|
Players.push_back(p);
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
GuildLookingForPlayers g(row[1], row[2], atoul(row[3]), atoul(row[4]), atoul(row[5]), atoul(row[6]), atoul(row[7]), atoul(row[8]));
|
|
||||||
Guilds.push_back(g);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
mysql_free_result(result);
|
GuildLookingForPlayers g(row[1], row[2], atoul(row[3]), atoul(row[4]), atoul(row[5]), atoul(row[6]), atoul(row[7]), atoul(row[8]));
|
||||||
|
Guilds.push_back(g);
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -242,37 +232,31 @@ void LFGuildManager::SendGuildMatches(uint32 FromZoneID, uint32 FromInstanceID,
|
|||||||
|
|
||||||
void LFGuildManager::TogglePlayer(uint32 FromZoneID, uint32 FromInstanceID, char *From, uint32 Class, uint32 Level, uint32 AAPoints, char *Comments, uint32 Toggle, uint32 TimeZone)
|
void LFGuildManager::TogglePlayer(uint32 FromZoneID, uint32 FromInstanceID, char *From, uint32 Class, uint32 Level, uint32 AAPoints, char *Comments, uint32 Toggle, uint32 TimeZone)
|
||||||
{
|
{
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
for(auto it = Players.begin(); it != Players.end(); ++it)
|
||||||
char* query = 0;
|
if(!strcasecmp((*it).Name.c_str(), From)) {
|
||||||
|
|
||||||
std::list<PlayerLookingForGuild>::iterator it;
|
|
||||||
|
|
||||||
for(it = Players.begin(); it != Players.end(); ++it)
|
|
||||||
{
|
|
||||||
if(!strcasecmp((*it).Name.c_str(), From))
|
|
||||||
{
|
|
||||||
Players.erase(it);
|
Players.erase(it);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "DELETE FROM `lfguild` WHERE `type` = 0 AND `name` = '%s'", From), errbuf, 0, 0))
|
std::string query = StringFormat("DELETE FROM `lfguild` WHERE `type` = 0 AND `name` = '%s'", From);
|
||||||
_log(QUERYSERV__ERROR, "Error removing player from LFGuild table, query was %s, %s", query, errbuf);
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
safe_delete_array(query);
|
_log(QUERYSERV__ERROR, "Error removing player from LFGuild table, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
uint32 Now = time(nullptr);
|
uint32 Now = time(nullptr);
|
||||||
|
|
||||||
if(Toggle == 1)
|
if(Toggle == 1) {
|
||||||
{
|
|
||||||
PlayerLookingForGuild p(From, Comments, Level, Class, AAPoints, TimeZone, Now);
|
PlayerLookingForGuild p(From, Comments, Level, Class, AAPoints, TimeZone, Now);
|
||||||
Players.push_back(p);
|
Players.push_back(p);
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "INSERT INTO `lfguild` (`type`, `name`, `comment`, `fromlevel`, `tolevel`, `classes`, `aacount`, `timezone`, `timeposted`) VALUES(0, '%s', '%s', %u, 0, %u, %u, %u, %u)", From, Comments, Level, Class, AAPoints, TimeZone, Now), errbuf, 0, 0))
|
|
||||||
_log(QUERYSERV__ERROR, "Error inserting player into LFGuild table, query was %s, %s", query, errbuf);
|
|
||||||
|
|
||||||
safe_delete_array(query);
|
|
||||||
|
|
||||||
|
query = StringFormat("INSERT INTO `lfguild` "
|
||||||
|
"(`type`, `name`, `comment`, `fromlevel`, `tolevel`, "
|
||||||
|
"`classes`, `aacount`, `timezone`, `timeposted`) "
|
||||||
|
"VALUES (0, '%s', '%s', %u, 0, %u, %u, %u, %u)",
|
||||||
|
From, Comments, Level, Class, AAPoints, TimeZone, Now);
|
||||||
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
|
_log(QUERYSERV__ERROR, "Error inserting player into LFGuild table, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
ServerPacket *pack = new ServerPacket(ServerOP_QueryServGeneric, strlen(From) + strlen(Comments) + 30);
|
ServerPacket *pack = new ServerPacket(ServerOP_QueryServGeneric, strlen(From) + strlen(Comments) + 30);
|
||||||
@ -289,29 +273,21 @@ void LFGuildManager::TogglePlayer(uint32 FromZoneID, uint32 FromInstanceID, char
|
|||||||
|
|
||||||
worldserver->SendPacket(pack);
|
worldserver->SendPacket(pack);
|
||||||
safe_delete(pack);
|
safe_delete(pack);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void LFGuildManager::ToggleGuild(uint32 FromZoneID, uint32 FromInstanceID, char *From, char* GuildName, char *Comments, uint32 FromLevel, uint32 ToLevel, uint32 Classes, uint32 AACount, uint32 Toggle, uint32 TimeZone)
|
void LFGuildManager::ToggleGuild(uint32 FromZoneID, uint32 FromInstanceID, char *From, char* GuildName, char *Comments, uint32 FromLevel, uint32 ToLevel, uint32 Classes, uint32 AACount, uint32 Toggle, uint32 TimeZone)
|
||||||
{
|
{
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
for(auto it = Guilds.begin(); it != Guilds.end(); ++it)
|
||||||
char* query = 0;
|
|
||||||
|
|
||||||
std::list<GuildLookingForPlayers>::iterator it;
|
|
||||||
|
|
||||||
for(it = Guilds.begin(); it != Guilds.end(); ++it)
|
|
||||||
{
|
|
||||||
if(!strcasecmp((*it).Name.c_str(), GuildName))
|
if(!strcasecmp((*it).Name.c_str(), GuildName))
|
||||||
{
|
{
|
||||||
Guilds.erase(it);
|
Guilds.erase(it);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "DELETE FROM `lfguild` WHERE `type` = 1 AND `name` = '%s'", GuildName), errbuf, 0, 0))
|
std::string query = StringFormat("DELETE FROM `lfguild` WHERE `type` = 1 AND `name` = '%s'", GuildName);
|
||||||
_log(QUERYSERV__ERROR, "Error removing guild from LFGuild table, query was %s, %s", query, errbuf);
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
safe_delete_array(query);
|
_log(QUERYSERV__ERROR, "Error removing guild from LFGuild table, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
uint32 Now = time(nullptr);
|
uint32 Now = time(nullptr);
|
||||||
|
|
||||||
@ -319,12 +295,19 @@ void LFGuildManager::ToggleGuild(uint32 FromZoneID, uint32 FromInstanceID, char
|
|||||||
{
|
{
|
||||||
GuildLookingForPlayers g(GuildName, Comments, FromLevel, ToLevel, Classes, AACount, TimeZone, Now);
|
GuildLookingForPlayers g(GuildName, Comments, FromLevel, ToLevel, Classes, AACount, TimeZone, Now);
|
||||||
Guilds.push_back(g);
|
Guilds.push_back(g);
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "INSERT INTO `lfguild` (`type`, `name`, `comment`, `fromlevel`, `tolevel`, `classes`, `aacount`, `timezone`, `timeposted`) VALUES(1, '%s', '%s', %u, %u, %u, %u, %u, %u)", GuildName, Comments, FromLevel, ToLevel, Classes, AACount, TimeZone, Now), errbuf, 0, 0))
|
|
||||||
_log(QUERYSERV__ERROR, "Error inserting guild into LFGuild table, query was %s, %s", query, errbuf);
|
|
||||||
|
|
||||||
safe_delete_array(query);
|
query = StringFormat("INSERT INTO `lfguild` "
|
||||||
|
"(`type`, `name`, `comment`, `fromlevel`, `tolevel`, "
|
||||||
|
"`classes`, `aacount`, `timezone`, `timeposted`) "
|
||||||
|
"VALUES (1, '%s', '%s', %u, %u, %u, %u, %u, %u)",
|
||||||
|
GuildName, Comments, FromLevel, ToLevel,
|
||||||
|
Classes, AACount, TimeZone, Now);
|
||||||
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
|
_log(QUERYSERV__ERROR, "Error inserting guild into LFGuild table, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ServerPacket *pack = new ServerPacket(ServerOP_LFGuildUpdate, strlen(GuildName) + strlen(Comments) + 30);
|
ServerPacket *pack = new ServerPacket(ServerOP_LFGuildUpdate, strlen(GuildName) + strlen(Comments) + 30);
|
||||||
|
|
||||||
pack->WriteString(GuildName);
|
pack->WriteString(GuildName);
|
||||||
@ -343,36 +326,30 @@ void LFGuildManager::ToggleGuild(uint32 FromZoneID, uint32 FromInstanceID, char
|
|||||||
|
|
||||||
void LFGuildManager::ExpireEntries()
|
void LFGuildManager::ExpireEntries()
|
||||||
{
|
{
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
for(auto it = Players.begin(); it != Players.end(); ++it)
|
||||||
char* query = 0;
|
|
||||||
|
|
||||||
std::list<PlayerLookingForGuild>::iterator it;
|
|
||||||
std::list<GuildLookingForPlayers>::iterator it2;
|
|
||||||
|
|
||||||
for(it = Players.begin(); it != Players.end(); ++it)
|
|
||||||
{
|
{
|
||||||
if((*it).TimePosted + 604800 <= (uint32)time(nullptr))
|
if((*it).TimePosted + 604800 > (uint32)time(nullptr))
|
||||||
{
|
continue;
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "DELETE from `lfguild` WHERE `type` = 0 AND `name` = '%s'", (*it).Name.c_str()), errbuf, 0, 0))
|
|
||||||
_log(QUERYSERV__ERROR, "Error expiring player LFGuild entry, query was %s, %s", query, errbuf);
|
|
||||||
|
|
||||||
safe_delete_array(query);
|
std::string query = StringFormat("DELETE from `lfguild` WHERE `type` = 0 AND `name` = '%s'", (*it).Name.c_str());
|
||||||
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
|
_log(QUERYSERV__ERROR, "Error expiring player LFGuild entry, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
it = Players.erase(it);
|
it = Players.erase(it);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
for(it2 = Guilds.begin(); it2 != Guilds.end(); ++it2)
|
for(auto it2 = Guilds.begin(); it2 != Guilds.end(); ++it2)
|
||||||
{
|
{
|
||||||
if((*it2).TimePosted + 2592000 <= time(nullptr))
|
if((*it2).TimePosted + 2592000 > time(nullptr))
|
||||||
{
|
continue;
|
||||||
if(!database.RunQuery(query, MakeAnyLenString(&query, "DELETE from `lfguild` WHERE `type` = 1 AND `name` = '%s'", (*it2).Name.c_str()), errbuf, 0, 0))
|
|
||||||
_log(QUERYSERV__ERROR, "Error removing guild LFGuild entry, query was %s, %s", query, errbuf);
|
|
||||||
|
|
||||||
safe_delete_array(query);
|
std::string query = StringFormat("DELETE from `lfguild` WHERE `type` = 1 AND `name` = '%s'", (*it2).Name.c_str());
|
||||||
|
auto results = database.QueryDatabase(query);
|
||||||
|
if(!results.Success())
|
||||||
|
_log(QUERYSERV__ERROR, "Error removing guild LFGuild entry, query was %s, %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
it2 = Guilds.erase(it2);
|
it2 = Guilds.erase(it2);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user