mirror of
https://github.com/mudita/MuditaOS.git
synced 2026-06-18 05:21:24 -04:00
58 lines
1.8 KiB
C++
58 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include "Table.hpp"
|
|
#include "Record.hpp"
|
|
#include "utf8/UTF8.hpp"
|
|
|
|
struct ContactsAddressTableRow : public Record
|
|
{
|
|
uint32_t contactID = DB_ID_NONE;
|
|
UTF8 address;
|
|
UTF8 note;
|
|
UTF8 mail;
|
|
};
|
|
|
|
enum class ContactAddressTableFields
|
|
{
|
|
Mail
|
|
};
|
|
|
|
class ContactsAddressTable : public Table<ContactsAddressTableRow, ContactAddressTableFields>
|
|
{
|
|
public:
|
|
ContactsAddressTable(Database *db);
|
|
|
|
virtual ~ContactsAddressTable();
|
|
|
|
bool create() override final;
|
|
|
|
bool add(ContactsAddressTableRow entry) override final;
|
|
|
|
bool removeById(uint32_t id) override final;
|
|
|
|
bool update(ContactsAddressTableRow entry) override final;
|
|
|
|
ContactsAddressTableRow getById(uint32_t id) override final;
|
|
|
|
std::vector<ContactsAddressTableRow> getLimitOffset(uint32_t offset, uint32_t limit) override final;
|
|
|
|
std::vector<ContactsAddressTableRow> getLimitOffsetByField(uint32_t offset,
|
|
uint32_t limit,
|
|
ContactAddressTableFields 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_address("
|
|
"_id INTEGER PRIMARY KEY,"
|
|
"contact_id INTEGER,"
|
|
"address TEXT NOT NULL,"
|
|
"note TEXT NOT NULL,"
|
|
"mail TEXT NOT NULL,"
|
|
"FOREIGN KEY(contact_id) REFERENCES contacts(_id)"
|
|
");";
|
|
};
|