mirror of
https://github.com/OpenFusionProject/OpenFusion.git
synced 2024-11-22 21:40:05 +00:00
Add email structs and functions to DB
Mutex locks included
This commit is contained in:
parent
36e9370ff4
commit
3a55a9b66f
170
src/Database.cpp
170
src/Database.cpp
@ -98,6 +98,29 @@ auto db = make_storage("database.db",
|
|||||||
make_column("PlayerAId", &Database::Buddyship::PlayerAId),
|
make_column("PlayerAId", &Database::Buddyship::PlayerAId),
|
||||||
make_column("PlayerBId", &Database::Buddyship::PlayerBId),
|
make_column("PlayerBId", &Database::Buddyship::PlayerBId),
|
||||||
make_column("Status", &Database::Buddyship::Status)
|
make_column("Status", &Database::Buddyship::Status)
|
||||||
|
),
|
||||||
|
make_table("EmailData",
|
||||||
|
make_column("PlayerId", &Database::EmailData::PlayerId),
|
||||||
|
make_column("MsgIndex", &Database::EmailData::MsgIndex),
|
||||||
|
make_column("ReadFlag", &Database::EmailData::ReadFlag),
|
||||||
|
make_column("ItemFlag", &Database::EmailData::ItemFlag),
|
||||||
|
make_column("SenderId", &Database::EmailData::SenderId),
|
||||||
|
make_column("SenderFirstName", &Database::EmailData::SenderFirstName, collate_nocase()),
|
||||||
|
make_column("SenderLastName", &Database::EmailData::SenderLastName, collate_nocase()),
|
||||||
|
make_column("SubjectLine", &Database::EmailData::SubjectLine),
|
||||||
|
make_column("MsgBody", &Database::EmailData::MsgBody),
|
||||||
|
make_column("Taros", &Database::EmailData::Taros),
|
||||||
|
make_column("SendTime", &Database::EmailData::SendTime),
|
||||||
|
make_column("DeleteTime", &Database::EmailData::DeleteTime)
|
||||||
|
),
|
||||||
|
make_table("EmailItems",
|
||||||
|
make_column("PlayerId", &Database::EmailItem::PlayerId),
|
||||||
|
make_column("MsgIndex", &Database::EmailItem::MsgIndex),
|
||||||
|
make_column("Slot", &Database::EmailItem::Slot),
|
||||||
|
make_column("Id", &Database::EmailItem::Id),
|
||||||
|
make_column("Type", &Database::EmailItem::Type),
|
||||||
|
make_column("Opt", &Database::EmailItem::Opt),
|
||||||
|
make_column("TimeLimit", &Database::EmailItem::TimeLimit)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -743,4 +766,151 @@ int Database::getNumBuddies(Player* player) {
|
|||||||
return buddies.size() > 50 ? 50 : buddies.size();
|
return buddies.size() > 50 ? 50 : buddies.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// email
|
||||||
|
int Database::getUnreadEmailCount(int playerID) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
auto emailData = db.get_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == playerID && c(&Database::EmailData::ReadFlag) == 0)
|
||||||
|
);
|
||||||
|
|
||||||
|
return emailData.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<Database::EmailData> Database::getEmails(int playerID, int page) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
std::vector<Database::EmailData> emails;
|
||||||
|
|
||||||
|
auto emailData = db.get_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == playerID),
|
||||||
|
order_by(&Database::EmailData::MsgIndex).desc(),
|
||||||
|
limit(5 * (page - 1), 5)
|
||||||
|
);
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
for (Database::EmailData email : emailData) {
|
||||||
|
emails.push_back(email);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return emails;
|
||||||
|
}
|
||||||
|
|
||||||
|
Database::EmailData Database::getEmail(int playerID, int index) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
auto emailData = db.get_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == playerID && c(&Database::EmailData::MsgIndex) == index)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (emailData.size() > 1)
|
||||||
|
std::cout << "[WARN] Duplicate emails detected (player " << playerID << ", index " << index << ")" << std::endl;
|
||||||
|
|
||||||
|
return emailData.at(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
sItemBase* Database::getEmailAttachments(int playerID, int index) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
sItemBase* items = new sItemBase[4];
|
||||||
|
for (int i = 0; i < 4; i++)
|
||||||
|
items[i] = { 0, 0, 0, 0 }; // zero out items
|
||||||
|
|
||||||
|
auto attachments = db.get_all<Database::EmailItem>(
|
||||||
|
where(c(&Database::EmailItem::PlayerId) == playerID && c(&Database::EmailItem::MsgIndex) == index)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (attachments.size() > 4)
|
||||||
|
std::cout << "[WARN] Email has too many attachments (player " << playerID << ", index " << index << ")" << std::endl;
|
||||||
|
|
||||||
|
for (Database::EmailItem& item : attachments) {
|
||||||
|
items[item.Slot - 1] = { item.Type, item.Id, item.Opt, item.TimeLimit };
|
||||||
|
}
|
||||||
|
|
||||||
|
return items;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Database::updateEmailContent(EmailData* data) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
db.begin_transaction();
|
||||||
|
|
||||||
|
db.remove_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == data->PlayerId && c(&Database::EmailData::MsgIndex) == data->MsgIndex)
|
||||||
|
);
|
||||||
|
db.insert(*data);
|
||||||
|
|
||||||
|
db.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Database::deleteEmailAttachments(int playerID, int index, int slot) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
db.begin_transaction();
|
||||||
|
|
||||||
|
if (slot == -1) { // delete all
|
||||||
|
db.remove_all<Database::EmailItem>(
|
||||||
|
where(c(&Database::EmailItem::PlayerId) == playerID && c(&Database::EmailItem::MsgIndex) == index)
|
||||||
|
);
|
||||||
|
} else { // delete single by comparing slot num
|
||||||
|
db.remove_all<Database::EmailItem>(
|
||||||
|
where(c(&Database::EmailItem::PlayerId) == playerID && c(&Database::EmailItem::MsgIndex) == index
|
||||||
|
&& c(&Database::EmailItem::Slot) == slot)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
db.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Database::deleteEmails(int playerID, int64_t* indices) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
db.begin_transaction();
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
db.remove_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == playerID && c(&Database::EmailData::MsgIndex) == indices[i])
|
||||||
|
); // no need to check if the index is 0, since an email will never have index < 1
|
||||||
|
}
|
||||||
|
|
||||||
|
db.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
int Database::getNextEmailIndex(int playerID) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
auto emailData = db.get_all<Database::EmailData>(
|
||||||
|
where(c(&Database::EmailData::PlayerId) == playerID),
|
||||||
|
order_by(&Database::EmailData::MsgIndex).desc(),
|
||||||
|
limit(1)
|
||||||
|
);
|
||||||
|
|
||||||
|
return (emailData.size() > 0 ? emailData.at(0).MsgIndex + 1 : 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Database::sendEmail(EmailData* data, std::vector<sItemBase> attachments) {
|
||||||
|
std::lock_guard<std::mutex> lock(dbCrit);
|
||||||
|
|
||||||
|
db.begin_transaction();
|
||||||
|
|
||||||
|
db.insert(*data); // add email data to db
|
||||||
|
// add email attachments to db email inventory
|
||||||
|
int slot = 1;
|
||||||
|
for (sItemBase item : attachments) {
|
||||||
|
EmailItem dbItem = {
|
||||||
|
data->PlayerId,
|
||||||
|
data->MsgIndex,
|
||||||
|
slot,
|
||||||
|
item.iType,
|
||||||
|
item.iID,
|
||||||
|
item.iOpt,
|
||||||
|
item.iTimeLimit
|
||||||
|
};
|
||||||
|
db.insert(dbItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
db.commit();
|
||||||
|
}
|
||||||
|
|
||||||
#pragma endregion ShardServer
|
#pragma endregion ShardServer
|
||||||
|
@ -84,6 +84,29 @@ namespace Database {
|
|||||||
int PlayerBId;
|
int PlayerBId;
|
||||||
int16_t Status;
|
int16_t Status;
|
||||||
};
|
};
|
||||||
|
struct EmailData {
|
||||||
|
int PlayerId;
|
||||||
|
int MsgIndex;
|
||||||
|
int32_t ReadFlag;
|
||||||
|
int32_t ItemFlag;
|
||||||
|
int SenderId;
|
||||||
|
std::string SenderFirstName;
|
||||||
|
std::string SenderLastName;
|
||||||
|
std::string SubjectLine;
|
||||||
|
std::string MsgBody;
|
||||||
|
int Taros;
|
||||||
|
uint64_t SendTime;
|
||||||
|
uint64_t DeleteTime;
|
||||||
|
};
|
||||||
|
struct EmailItem {
|
||||||
|
int PlayerId;
|
||||||
|
int MsgIndex;
|
||||||
|
int Slot;
|
||||||
|
int16_t Type;
|
||||||
|
int16_t Id;
|
||||||
|
int32_t Opt;
|
||||||
|
int32_t TimeLimit;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
#pragma endregion DatabaseStructs
|
#pragma endregion DatabaseStructs
|
||||||
@ -138,4 +161,15 @@ namespace Database {
|
|||||||
// parsing blobs
|
// parsing blobs
|
||||||
void appendBlob(std::vector<char>*blob, int64_t input);
|
void appendBlob(std::vector<char>*blob, int64_t input);
|
||||||
int64_t blobToInt64(std::vector<char>::iterator it);
|
int64_t blobToInt64(std::vector<char>::iterator it);
|
||||||
|
|
||||||
|
// email
|
||||||
|
int getUnreadEmailCount(int playerID);
|
||||||
|
std::vector<EmailData> getEmails(int playerID, int page);
|
||||||
|
EmailData getEmail(int playerID, int index);
|
||||||
|
sItemBase* getEmailAttachments(int playerID, int index);
|
||||||
|
void updateEmailContent(EmailData* data);
|
||||||
|
void deleteEmailAttachments(int playerID, int index, int slot);
|
||||||
|
void deleteEmails(int playerID, int64_t* indices);
|
||||||
|
int getNextEmailIndex(int playerID);
|
||||||
|
void sendEmail(EmailData* data, std::vector<sItemBase> attachments);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user