/*
* @file ContactsNumberTable.hpp
* @author Mateusz Piesta (mateusz.piesta@mudita.com)
* @date 28.05.19
* @brief
* @copyright Copyright (C) 2019 mudita.com
* @details
*/
#pragma once
#include "Record.hpp"
#include "Common/Common.hpp"
#include "Database/Database.hpp"
#include "Table.hpp"
#include "utf8/UTF8.hpp"
#include <string>
struct ContactsNumberTableRow : public Record
{
uint32_t contactID = 0;
std::string numberUser = "";
std::string numbere164 = "";
ContactNumberType type = ContactNumberType::OTHER;
};
enum class ContactNumberTableFields
{
NumberUser,
NumberE164
};
class ContactsNumberTable : public Table<ContactsNumberTableRow, ContactNumberTableFields>
{
public:
ContactsNumberTable(Database *db);
virtual ~ContactsNumberTable();
bool create() override final;
bool add(ContactsNumberTableRow entry) override final;
bool removeById(uint32_t id) override final;
bool update(ContactsNumberTableRow entry) override final;
ContactsNumberTableRow getById(uint32_t id) override final;
std::vector<ContactsNumberTableRow> getByContactId(uint32_t id);
std::vector<ContactsNumberTableRow> getLimitOffset(uint32_t offset, uint32_t limit) override final;
std::vector<ContactsNumberTableRow> getLimitOffsetByField(uint32_t offset,
uint32_t limit,
ContactNumberTableFields field,
const char *str) override final;
uint32_t count() override final;
uint32_t countByFieldId(const char *field, uint32_t id) override final;
private:
const char *createTableQuery = "CREATE TABLE IF NOT EXISTS contact_number("
"_id INTEGER PRIMARY KEY,"
"contact_id INTEGER,"
"number_user TEXT NOT NULL,"
"number_e164 TEXT NOT NULL,"
"type INTEGER,"
"FOREIGN KEY(contact_id) REFERENCES contacts(_id)"
");";
};