nheko/src/CacheStructs.h

130 lines
3.0 KiB
C
Raw Normal View History

2021-03-05 00:35:15 +01:00
// SPDX-FileCopyrightText: 2021 Nheko Contributors
// SPDX-FileCopyrightText: 2022 Nheko Contributors
2021-03-05 00:35:15 +01:00
//
// SPDX-License-Identifier: GPL-3.0-or-later
#pragma once
#include <QDateTime>
#include <QImage>
#include <QString>
#include <string>
#include <mtx/events/join_rules.hpp>
#include <mtx/events/mscs/image_packs.hpp>
2020-05-02 16:44:50 +02:00
namespace cache {
enum class CacheVersion : int
{
2021-09-18 00:22:33 +02:00
Older = -1,
Current = 0,
Newer = 1,
2020-05-02 16:44:50 +02:00
};
}
struct RoomMember
{
2021-09-18 00:22:33 +02:00
QString user_id;
QString display_name;
bool is_direct = false;
};
//! Used to uniquely identify a list of read receipts.
struct ReadReceiptKey
{
2021-09-18 00:22:33 +02:00
std::string event_id;
std::string room_id;
};
void
to_json(nlohmann::json &j, const ReadReceiptKey &key);
void
from_json(const nlohmann::json &j, ReadReceiptKey &key);
struct DescInfo
{
2021-09-18 00:22:33 +02:00
QString event_id;
QString userid;
QString body;
QString descriptiveTime;
uint64_t timestamp = 0;
2021-09-18 00:22:33 +02:00
QDateTime datetime;
};
2021-05-21 21:19:03 +02:00
inline bool
operator==(const DescInfo &a, const DescInfo &b)
{
2021-09-18 00:22:33 +02:00
return std::tie(a.timestamp, a.event_id, a.userid, a.body, a.descriptiveTime) ==
std::tie(b.timestamp, b.event_id, b.userid, b.body, b.descriptiveTime);
2021-05-21 21:19:03 +02:00
}
inline bool
operator!=(const DescInfo &a, const DescInfo &b)
{
2021-09-18 00:22:33 +02:00
return std::tie(a.timestamp, a.event_id, a.userid, a.body, a.descriptiveTime) !=
std::tie(b.timestamp, b.event_id, b.userid, b.body, b.descriptiveTime);
2021-05-21 21:19:03 +02:00
}
//! UI info associated with a room.
struct RoomInfo
{
2021-09-18 00:22:33 +02:00
//! The calculated name of the room.
std::string name;
//! The topic of the room.
std::string topic;
//! The calculated avatar url of the room.
std::string avatar_url;
//! The calculated version of this room set at creation time.
std::string version;
//! Whether or not the room is an invite.
bool is_invite = false;
//! Wheter or not the room is a space
bool is_space = false;
//! Total number of members in the room.
size_t member_count = 0;
//! Who can access to the room.
mtx::events::state::JoinRule join_rule = mtx::events::state::JoinRule::Public;
bool guest_access = false;
//! The list of tags associated with this room
std::vector<std::string> tags;
//! An approximate timestamp of when the last message was sent in the room.
//! Use the TimelineModel::lastMessage for an accurate timestamp.
uint64_t approximate_last_modification_ts = 0;
uint16_t highlight_count = 0;
uint16_t notification_count = 0;
};
void
to_json(nlohmann::json &j, const RoomInfo &info);
void
from_json(const nlohmann::json &j, RoomInfo &info);
2021-03-27 00:22:51 +01:00
//! Basic information per member.
struct MemberInfo
{
2021-09-18 00:22:33 +02:00
std::string name;
std::string avatar_url;
bool is_direct = false;
};
void
to_json(nlohmann::json &j, const MemberInfo &info);
void
from_json(const nlohmann::json &j, MemberInfo &info);
struct RoomSearchResult
{
2021-09-18 00:22:33 +02:00
std::string room_id;
RoomInfo info;
};
struct ImagePackInfo
{
2021-09-18 00:22:33 +02:00
mtx::events::msc2545::ImagePack pack;
std::string source_room;
std::string state_key;
};