mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-09 14:27:10 +00:00
66 lines
3.2 KiB
C++
66 lines
3.2 KiB
C++
|
#include "SQLiteDatabase.h"
|
||
|
|
||
|
std::vector<IPropertyContents::Model> SQLiteDatabase::GetPropertyModels(const LWOOBJID& propertyId) {
|
||
|
auto [_, result] = ExecuteSelect(
|
||
|
"SELECT id, lot, x, y, z, rx, ry, rz, rw, ugc_id, "
|
||
|
"behavior_1, behavior_2, behavior_3, behavior_4, behavior_5 "
|
||
|
"FROM properties_contents WHERE property_id = ?;", propertyId);
|
||
|
|
||
|
std::vector<IPropertyContents::Model> toReturn;
|
||
|
while (!result.eof()) {
|
||
|
IPropertyContents::Model model;
|
||
|
model.id = result.getInt64Field("id");
|
||
|
model.lot = static_cast<LOT>(result.getIntField("lot"));
|
||
|
model.position.x = result.getFloatField("x");
|
||
|
model.position.y = result.getFloatField("y");
|
||
|
model.position.z = result.getFloatField("z");
|
||
|
model.rotation.w = result.getFloatField("rw");
|
||
|
model.rotation.x = result.getFloatField("rx");
|
||
|
model.rotation.y = result.getFloatField("ry");
|
||
|
model.rotation.z = result.getFloatField("rz");
|
||
|
model.ugcId = result.getInt64Field("ugc_id");
|
||
|
model.behaviors[0] = result.getIntField("behavior_1");
|
||
|
model.behaviors[1] = result.getIntField("behavior_2");
|
||
|
model.behaviors[2] = result.getIntField("behavior_3");
|
||
|
model.behaviors[3] = result.getIntField("behavior_4");
|
||
|
model.behaviors[4] = result.getIntField("behavior_5");
|
||
|
|
||
|
toReturn.push_back(std::move(model));
|
||
|
result.nextRow();
|
||
|
}
|
||
|
return toReturn;
|
||
|
}
|
||
|
|
||
|
void SQLiteDatabase::InsertNewPropertyModel(const LWOOBJID& propertyId, const IPropertyContents::Model& model, const std::string_view name) {
|
||
|
try {
|
||
|
ExecuteInsert(
|
||
|
"INSERT INTO properties_contents"
|
||
|
"(id, property_id, ugc_id, lot, x, y, z, rx, ry, rz, rw, model_name, model_description, behavior_1, behavior_2, behavior_3, behavior_4, behavior_5)"
|
||
|
"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
|
||
|
// 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17 18
|
||
|
model.id, propertyId, model.ugcId == 0 ? std::nullopt : std::optional(model.ugcId), static_cast<uint32_t>(model.lot),
|
||
|
model.position.x, model.position.y, model.position.z, model.rotation.x, model.rotation.y, model.rotation.z, model.rotation.w,
|
||
|
name, "", // Model description. TODO implement this.
|
||
|
model.behaviors[0], // behavior 1
|
||
|
model.behaviors[1], // behavior 2
|
||
|
model.behaviors[2], // behavior 3
|
||
|
model.behaviors[3], // behavior 4
|
||
|
model.behaviors[4] // behavior 5
|
||
|
);
|
||
|
} catch (std::exception& e) {
|
||
|
LOG("Error inserting new property model: %s", e.what());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void SQLiteDatabase::UpdateModel(const LWOOBJID& propertyId, const NiPoint3& position, const NiQuaternion& rotation, const std::array<std::pair<int32_t, std::string>, 5>& behaviors) {
|
||
|
ExecuteUpdate(
|
||
|
"UPDATE properties_contents SET x = ?, y = ?, z = ?, rx = ?, ry = ?, rz = ?, rw = ?, "
|
||
|
"behavior_1 = ?, behavior_2 = ?, behavior_3 = ?, behavior_4 = ?, behavior_5 = ? WHERE id = ?;",
|
||
|
position.x, position.y, position.z, rotation.x, rotation.y, rotation.z, rotation.w,
|
||
|
behaviors[0].first, behaviors[1].first, behaviors[2].first, behaviors[3].first, behaviors[4].first, propertyId);
|
||
|
}
|
||
|
|
||
|
void SQLiteDatabase::RemoveModel(const LWOOBJID& modelId) {
|
||
|
ExecuteDelete("DELETE FROM properties_contents WHERE id = ?;", modelId);
|
||
|
}
|