mirror of
https://github.com/mudita/MuditaOS.git
synced 2026-06-19 14:00:55 -04:00
79 lines
2.4 KiB
C++
79 lines
2.4 KiB
C++
|
|
/*
|
|
* @file ContactsName.hpp
|
|
* @author Mateusz Piesta (mateusz.piesta@mudita.com)
|
|
* @date 28.05.19
|
|
* @brief
|
|
* @copyright Copyright (C) 2019 mudita.com
|
|
* @details
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "Common/Common.hpp"
|
|
#include "Database/Database.hpp"
|
|
#include "Table.hpp"
|
|
#include "Record.hpp"
|
|
#include "utf8/UTF8.hpp"
|
|
#include <string>
|
|
|
|
struct ContactsNameTableRow : public Record
|
|
{
|
|
uint32_t contactID = 0;
|
|
UTF8 namePrimary = "";
|
|
UTF8 nameAlternative = "";
|
|
uint32_t favourite = 0;
|
|
};
|
|
|
|
enum class ContactNameTableFields
|
|
{
|
|
NamePrimary,
|
|
NameAlternative,
|
|
Favourite
|
|
};
|
|
|
|
class ContactsNameTable : public Table<ContactsNameTableRow, ContactNameTableFields>
|
|
{
|
|
public:
|
|
ContactsNameTable(Database *db);
|
|
|
|
virtual ~ContactsNameTable();
|
|
|
|
bool create() override final;
|
|
|
|
bool add(ContactsNameTableRow entry) override final;
|
|
|
|
bool removeById(uint32_t id) override final;
|
|
|
|
bool update(ContactsNameTableRow entry) override final;
|
|
|
|
ContactsNameTableRow getById(uint32_t id) override final;
|
|
|
|
std::vector<ContactsNameTableRow> getLimitOffset(uint32_t offset, uint32_t limit) override final;
|
|
|
|
std::vector<ContactsNameTableRow> getLimitOffsetByField(uint32_t offset,
|
|
uint32_t limit,
|
|
ContactNameTableFields field,
|
|
const char *str) override final;
|
|
|
|
uint32_t count() override final;
|
|
|
|
uint32_t countByFieldId(const char *field, uint32_t id) override final;
|
|
|
|
std::vector<ContactsNameTableRow> GetByName(const char *primaryName, const char *alternativeName);
|
|
|
|
std::size_t GetCountByName(const std::string &name);
|
|
|
|
std::vector<std::uint32_t> GetIDsByName(const std::string &name, std::uint32_t limit = 0, std::uint32_t offset = 0);
|
|
|
|
private:
|
|
const char *createTableQuery = "CREATE TABLE IF NOT EXISTS contact_name("
|
|
"_id INTEGER PRIMARY KEY,"
|
|
"contact_id INTEGER,"
|
|
"name_primary TEXT NOT NULL,"
|
|
"name_alternative TEXT NOT NULL,"
|
|
"favourite INTEGER DEFAULT 0,"
|
|
"FOREIGN KEY(contact_id) REFERENCES contacts(_id)"
|
|
");";
|
|
};
|