Files
MuditaOS/module-db/Tables/ThreadsTable.hpp
2019-08-08 11:54:34 +02:00

81 lines
2.4 KiB
C++

/*
* @file ThreadsTable.hpp
* @author Mateusz Piesta (mateusz.piesta@mudita.com)
* @date 27.05.19
* @brief
* @copyright Copyright (C) 2019 mudita.com
* @details
*/
#ifndef PUREPHONE_THREADSTABLE_HPP
#define PUREPHONE_THREADSTABLE_HPP
#include "Table.hpp"
#include "Database/Database.hpp"
#include "utf8/UTF8.hpp"
#include "Common/Common.hpp"
struct ThreadsTableRow{
uint32_t ID;
uint32_t date;
uint32_t msgCount;
uint32_t msgRead;
uint32_t contactID;
UTF8 snippet;
SMSType type;
};
enum class ThreadsTableFields{
Date,
MsgCount,
MsgRead,
ContactID,
Type
};
class ThreadsTable : public Table<ThreadsTableRow,ThreadsTableFields> {
public:
ThreadsTable(Database* db);
virtual ~ThreadsTable();
bool Create() override final;
bool Add(ThreadsTableRow entry) override final;
bool RemoveByID(uint32_t id) override final;
bool Update(ThreadsTableRow entry) override final;
ThreadsTableRow GetByID(uint32_t id) override final;
std::vector<ThreadsTableRow> GetLimitOffset(uint32_t offset,uint32_t limit) override final;
std::vector<ThreadsTableRow> GetLimitOffsetByField(uint32_t offset,uint32_t limit,ThreadsTableFields field,const char* str) override final;
uint32_t GetCount() override final;
uint32_t GetCountByFieldID(const char* field,uint32_t id) override final;
private:
const char* createTableQuery =
"CREATE TABLE IF NOT EXISTS threads("
"_id INTEGER PRIMARY KEY,"
"date INTEGER,"
"msg_count INTEGER,"
"read INTEGER,"
"contact_id INTEGER,"
"snippet TEXT NOT NULL,"
"last_dir INTEGER"
");";
const char* createTableThreadsCounterQuery =
"CREATE TABLE IF NOT EXISTS threads_count "
"(_id INTEGER PRIMARY KEY,"
"count INTEGER );";
const char* threadsCounterInsertionQuery = "INSERT OR IGNORE INTO threads_count ( _id, count ) VALUES (1,0);";
const char* threadInsertTriggerQuery = "CREATE TRIGGER IF NOT EXISTS on_thread_insert AFTER INSERT ON threads BEGIN UPDATE threads_count SET count=count+1 WHERE _id=1; END";
const char* threadRemoveTriggerQuery = "CREATE TRIGGER IF NOT EXISTS on_thread_remove AFTER DELETE ON threads BEGIN UPDATE threads_count SET count=count-1 WHERE _id=1; END";
};
#endif //PUREPHONE_THREADSTABLE_HPP