/* * nheko Copyright (C) 2017 Konstantinos Sideris * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #pragma once #include #include #include #include class RoomState { public: RoomState(); RoomState(const mtx::responses::Timeline &timeline); RoomState(const mtx::responses::State &state); // Calculate room data that are not immediatly accessible. Like room name and // avatar. // // e.g If the room is 1-on-1 name and avatar should be extracted from a user. void resolveName(); void resolveAvatar(); void parse(const nlohmann::json &object); QUrl getAvatar() const { return avatar_; }; QString getName() const { return name_; }; QString getTopic() const { return QString::fromStdString(topic.content.topic).simplified(); }; void removeLeaveMemberships(); void update(const RoomState &state); template void updateFromEvents(const std::vector &collection); std::string serialize() const; // The latest state events. mtx::events::StateEvent aliases; mtx::events::StateEvent avatar; mtx::events::StateEvent canonical_alias; mtx::events::StateEvent create; mtx::events::StateEvent history_visibility; mtx::events::StateEvent join_rules; mtx::events::StateEvent name; mtx::events::StateEvent power_levels; mtx::events::StateEvent topic; // Contains the m.room.member events for all the joined users. using UserID = std::string; std::map> memberships; private: QUrl avatar_; QString name_; // It defines the user whose avatar is used for the room. If the room has an // avatar event this should be empty. QString userAvatar_; }; template void RoomState::updateFromEvents(const std::vector &collection) { using Aliases = mtx::events::StateEvent; using Avatar = mtx::events::StateEvent; using CanonicalAlias = mtx::events::StateEvent; using Create = mtx::events::StateEvent; using HistoryVisibility = mtx::events::StateEvent; using JoinRules = mtx::events::StateEvent; using Member = mtx::events::StateEvent; using Name = mtx::events::StateEvent; using PowerLevels = mtx::events::StateEvent; using Topic = mtx::events::StateEvent; for (const auto &event : collection) { if (mpark::holds_alternative(event)) { this->aliases = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->avatar = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->canonical_alias = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->create = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->history_visibility = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->join_rules = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->name = mpark::get(event); } else if (mpark::holds_alternative(event)) { auto membership = mpark::get(event); this->memberships.emplace(membership.state_key, membership); } else if (mpark::holds_alternative(event)) { this->power_levels = mpark::get(event); } else if (mpark::holds_alternative(event)) { this->topic = mpark::get(event); } } }