Files
MuditaOS/module-db/Tables/SettingsTable.cpp
2019-08-30 06:40:50 +02:00

111 lines
3.4 KiB
C++

/*
* @file SettingsTable.cpp
* @author Mateusz Piesta (mateusz.piesta@mudita.com)
* @date 05.06.19
* @brief
* @copyright Copyright (C) 2019 mudita.com
* @details
*/
#include "SettingsTable.hpp"
SettingsTable::SettingsTable(Database *db):Table(db) {
}
SettingsTable::~SettingsTable() {
}
bool SettingsTable::Create() {
bool ret = true;
ret = db->Execute(createTableQuery);
if (!ret) {
return false;
}
ret = db->Execute(settingsInitialization);
return ret;
}
SettingsTableRow SettingsTable::GetByID(uint32_t id) {
auto retQuery = db->Query("SELECT * FROM settings WHERE _id= 1;");
if ( (retQuery == nullptr) || (retQuery->GetRowCount() == 0)) {
return SettingsTableRow();
}
return SettingsTableRow{(*retQuery)[0].GetUInt32(), // ID
(*retQuery)[1].GetBool(), // timeFormat12
(*retQuery)[2].GetBool(), // timeAuto
(*retQuery)[3].GetBool(), // brightnessAuto
(*retQuery)[4].GetUInt32(), // brightnessLevel
(*retQuery)[5].GetUInt32(), // fontSize
static_cast<SettingsPinMode >((*retQuery)[6].GetUInt32()), // pinMode
(*retQuery)[7].GetUInt32(), // pinDays
(*retQuery)[8].GetUInt32(), // pinDaysLeft
(*retQuery)[9].GetString(), // pin1
(*retQuery)[10].GetString(), // pin2
(*retQuery)[11].GetUInt32(), // activeSIM
(*retQuery)[12].GetString(), // networkOperator
(*retQuery)[13].GetUInt32(), // lockPassHash
(*retQuery)[14].GetUInt32(), // lockTime
static_cast<SettingsLanguage >((*retQuery)[15].GetUInt32()), // language
};
}
bool SettingsTable::Update(SettingsTableRow entry) {
return db->Execute(
"UPDATE settings SET time_format_12 = %lu, time_auto = %lu ,brightness_auto = %lu, brightness_level = %lu, bigger_font = %lu, pin_mode =%lu, pin_days = %lu ,pin_days_left = %lu, pin1_string = '%s', pin2_string = '%s', active_sim = %lu, network_operator = '%s', lock_pass_hash = %lu, lock_time = %lu, language = %lu WHERE _id=1;",
entry.timeFormat12,
entry.timeAuto,
entry.brightnessAuto,
entry.brightnessLevel,
entry.fontSize,
entry.pinMode,
entry.pinDays,
entry.pinDaysLeft,
entry.pin1.c_str(),
entry.pin2.c_str(),
entry.activeSIM,
entry.networkOperator.c_str(),
entry.lockPassHash,
entry.lockTime,
entry.language
);
}
bool SettingsTable::Add(SettingsTableRow entry) {
//dummy
return true;
}
bool SettingsTable::RemoveByID(uint32_t id) {
return true;
}
std::vector<SettingsTableRow> SettingsTable::GetLimitOffset(uint32_t offset, uint32_t limit) {
return std::vector<SettingsTableRow>{};
}
std::vector<SettingsTableRow> SettingsTable::GetLimitOffsetByField(uint32_t offset, uint32_t limit,
SettingsTableFields field, const char *str) {
return std::vector<SettingsTableRow>{};
}
uint32_t SettingsTable::GetCount() {
return 0;
}
uint32_t SettingsTable::GetCountByFieldID(const char *field, uint32_t id) {
return 0;
}