mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-11-10 10:18:21 +00:00
df83f0d847
* feat: reward codes this is for giving rewards across characters as the did in live. Tested that the default config works Tested that all claim codes work Tested that saving and loading claim codes work Tested that mail sends correctly * newlines * include array * delete cascade * newline * address feedback
48 lines
1.3 KiB
C++
48 lines
1.3 KiB
C++
#include "CDRewardCodesTable.h"
|
|
|
|
void CDRewardCodesTable::LoadValuesFromDatabase() {
|
|
|
|
// First, get the size of the table
|
|
unsigned int size = 0;
|
|
auto tableSize = CDClientDatabase::ExecuteQuery("SELECT COUNT(*) FROM RewardCodes");
|
|
while (!tableSize.eof()) {
|
|
size = tableSize.getIntField(0, 0);
|
|
|
|
tableSize.nextRow();
|
|
}
|
|
|
|
tableSize.finalize();
|
|
|
|
// Reserve the size
|
|
this->entries.reserve(size);
|
|
|
|
// Now get the data
|
|
auto tableData = CDClientDatabase::ExecuteQuery("SELECT * FROM RewardCodes");
|
|
while (!tableData.eof()) {
|
|
CDRewardCode entry;
|
|
entry.id = tableData.getIntField("id", -1);
|
|
entry.code = tableData.getStringField("code", "");
|
|
entry.attachmentLOT = tableData.getIntField("attachmentLOT", -1);
|
|
UNUSED_COLUMN(entry.locStatus = tableData.getIntField("locStatus", -1));
|
|
UNUSED_COLUMN(entry.gate_version = tableData.getStringField("gate_version", ""));
|
|
|
|
this->entries.push_back(entry);
|
|
tableData.nextRow();
|
|
}
|
|
}
|
|
|
|
LOT CDRewardCodesTable::GetAttachmentLOT(uint32_t rewardCodeId) const {
|
|
for (auto const &entry : this->entries){
|
|
if (rewardCodeId == entry.id) return entry.attachmentLOT;
|
|
}
|
|
return LOT_NULL;
|
|
}
|
|
|
|
uint32_t CDRewardCodesTable::GetCodeID(std::string code) const {
|
|
for (auto const &entry : this->entries){
|
|
if (code == entry.code) return entry.id;
|
|
}
|
|
return -1;
|
|
}
|
|
|