mirror of
https://github.com/EQEmu/Server.git
synced 2026-03-26 17:52:34 +00:00
LoadChatChannels converted to QueryDatabase
This commit is contained in:
parent
19486bac0d
commit
76fdfa87c1
@ -246,32 +246,21 @@ bool Database::LoadChatChannels() {
|
|||||||
|
|
||||||
_log(UCS__INIT, "Loading chat channels from the database.");
|
_log(UCS__INIT, "Loading chat channels from the database.");
|
||||||
|
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
const std::string query = "SELECT `name`, `owner`, `password`, `minstatus` FROM `chatchannels`";
|
||||||
char* query = 0;
|
auto results = QueryDatabase(query);
|
||||||
MYSQL_RES *result;
|
if (!results.Success()) {
|
||||||
MYSQL_ROW row;
|
_log(UCS__ERROR, "Failed to load channels. %s %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
|
||||||
if (!RunQuery(query,MakeAnyLenString(&query, "select `name`,`owner`,`password`, `minstatus` from `chatchannels`"),errbuf,&result)){
|
|
||||||
|
|
||||||
_log(UCS__ERROR, "Failed to load channels. %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) {
|
||||||
|
std::string channelName = row[0];
|
||||||
|
std::string channelOwner = row[1];
|
||||||
|
std::string channelPassword = row[2];
|
||||||
|
|
||||||
while((row = mysql_fetch_row(result))) {
|
ChannelList->CreateChannel(channelName, channelOwner, channelPassword, true, atoi(row[3]));
|
||||||
|
|
||||||
std::string ChannelName = row[0];
|
|
||||||
std::string ChannelOwner = row[1];
|
|
||||||
std::string ChannelPassword = row[2];
|
|
||||||
|
|
||||||
ChannelList->CreateChannel(ChannelName, ChannelOwner, ChannelPassword, true, atoi(row[3]));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
mysql_free_result(result);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user