#include "CDComponentsRegistryTable.h" #include "eReplicaComponentType.h" void CDComponentsRegistryTable::LoadValuesFromDatabase() { // Now get the data auto tableData = CDClientDatabase::ExecuteQuery("SELECT * FROM ComponentsRegistry"); auto& entries = GetEntriesMutable(); while (!tableData.eof()) { CDComponentsRegistry entry; entry.id = tableData.getIntField("id", -1); entry.component_type = static_cast(tableData.getIntField("component_type", 0)); entry.component_id = tableData.getIntField("component_id", -1); entries.insert_or_assign(static_cast(entry.component_type) << 32 | static_cast(entry.id), entry.component_id); entries.insert_or_assign(entry.id, 0); tableData.nextRow(); } tableData.finalize(); } void CDComponentsRegistryTable::LoadValuesFromDefaults() { auto& entries = GetEntriesMutable(); entries.clear(); // Add some default component registrations for common LOTs // Component type ITEM (LOT 1000) entries.insert_or_assign(static_cast(eReplicaComponentType::ITEM) << 32 | static_cast(1000), 1); entries.insert_or_assign(1000, 0); // Component type VENDOR (LOT 2000) entries.insert_or_assign(static_cast(eReplicaComponentType::VENDOR) << 32 | static_cast(2000), 1); entries.insert_or_assign(2000, 0); } int32_t CDComponentsRegistryTable::GetByIDAndType(uint32_t id, eReplicaComponentType componentType, int32_t defaultValue) { auto& entries = GetEntriesMutable(); auto exists = entries.find(id); if (exists != entries.end()) { auto iter = entries.find(static_cast(componentType) << 32 | static_cast(id)); return iter == entries.end() ? defaultValue : iter->second; } // If database is not connected (e.g., in tests), return default value if (!CDClientDatabase::isConnected) { entries.insert_or_assign(id, 0); return defaultValue; } // Now get the data. Get all components of this entity so we dont do a query for each component auto query = CDClientDatabase::CreatePreppedStmt("SELECT * FROM ComponentsRegistry WHERE id = ?;"); query.bind(1, static_cast(id)); auto tableData = query.execQuery(); while (!tableData.eof()) { CDComponentsRegistry entry; entry.id = tableData.getIntField("id", -1); entry.component_type = static_cast(tableData.getIntField("component_type", 0)); entry.component_id = tableData.getIntField("component_id", -1); entries.insert_or_assign(static_cast(entry.component_type) << 32 | static_cast(entry.id), entry.component_id); tableData.nextRow(); } entries.insert_or_assign(id, 0); auto iter = entries.find(static_cast(componentType) << 32 | static_cast(id)); return iter == entries.end() ? defaultValue : iter->second; }