2022-01-20 22:54:34 +03:00
|
|
|
//
|
2024-01-01 03:07:21 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
|
2022-01-20 22:54:34 +03:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "td/telegram/MessageReaction.h"
|
2023-04-25 16:41:04 +03:00
|
|
|
#include "td/telegram/MinChannel.hpp"
|
2023-08-04 18:39:07 +03:00
|
|
|
#include "td/telegram/ReactionType.hpp"
|
2022-01-20 22:54:34 +03:00
|
|
|
|
2023-07-13 13:54:58 +03:00
|
|
|
#include "td/utils/algorithm.h"
|
2022-01-20 22:54:34 +03:00
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
template <class StorerT>
|
|
|
|
void MessageReaction::store(StorerT &storer) const {
|
|
|
|
CHECK(!is_empty());
|
2022-01-21 13:15:27 +03:00
|
|
|
bool has_recent_chooser_dialog_ids = !recent_chooser_dialog_ids_.empty();
|
|
|
|
bool has_recent_chooser_min_channels = !recent_chooser_min_channels_.empty();
|
2023-04-27 16:20:54 +03:00
|
|
|
bool has_my_recent_chooser_dialog_id = my_recent_chooser_dialog_id_.is_valid();
|
2022-01-20 22:54:34 +03:00
|
|
|
BEGIN_STORE_FLAGS();
|
|
|
|
STORE_FLAG(is_chosen_);
|
2022-01-21 13:15:27 +03:00
|
|
|
STORE_FLAG(has_recent_chooser_dialog_ids);
|
|
|
|
STORE_FLAG(has_recent_chooser_min_channels);
|
2023-04-27 16:20:54 +03:00
|
|
|
STORE_FLAG(has_my_recent_chooser_dialog_id);
|
2022-01-20 22:54:34 +03:00
|
|
|
END_STORE_FLAGS();
|
2023-08-04 18:39:07 +03:00
|
|
|
td::store(reaction_type_, storer);
|
2022-01-20 22:54:34 +03:00
|
|
|
td::store(choose_count_, storer);
|
2022-01-21 13:15:27 +03:00
|
|
|
if (has_recent_chooser_dialog_ids) {
|
|
|
|
td::store(recent_chooser_dialog_ids_, storer);
|
|
|
|
}
|
|
|
|
if (has_recent_chooser_min_channels) {
|
|
|
|
td::store(recent_chooser_min_channels_, storer);
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
2023-04-27 16:20:54 +03:00
|
|
|
if (has_my_recent_chooser_dialog_id) {
|
|
|
|
td::store(my_recent_chooser_dialog_id_, storer);
|
|
|
|
}
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void MessageReaction::parse(ParserT &parser) {
|
2022-01-21 13:15:27 +03:00
|
|
|
bool has_recent_chooser_dialog_ids;
|
|
|
|
bool has_recent_chooser_min_channels;
|
2023-04-27 16:20:54 +03:00
|
|
|
bool has_my_recent_chooser_dialog_id;
|
2022-01-20 22:54:34 +03:00
|
|
|
BEGIN_PARSE_FLAGS();
|
|
|
|
PARSE_FLAG(is_chosen_);
|
2022-01-21 13:15:27 +03:00
|
|
|
PARSE_FLAG(has_recent_chooser_dialog_ids);
|
|
|
|
PARSE_FLAG(has_recent_chooser_min_channels);
|
2023-04-27 16:20:54 +03:00
|
|
|
PARSE_FLAG(has_my_recent_chooser_dialog_id);
|
2022-01-20 22:54:34 +03:00
|
|
|
END_PARSE_FLAGS();
|
2023-08-04 18:39:07 +03:00
|
|
|
td::parse(reaction_type_, parser);
|
2022-01-20 22:54:34 +03:00
|
|
|
td::parse(choose_count_, parser);
|
2022-01-21 13:15:27 +03:00
|
|
|
if (has_recent_chooser_dialog_ids) {
|
|
|
|
td::parse(recent_chooser_dialog_ids_, parser);
|
|
|
|
}
|
|
|
|
if (has_recent_chooser_min_channels) {
|
|
|
|
td::parse(recent_chooser_min_channels_, parser);
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
2023-04-27 16:20:54 +03:00
|
|
|
if (has_my_recent_chooser_dialog_id) {
|
|
|
|
td::parse(my_recent_chooser_dialog_id_, parser);
|
2024-01-02 03:03:39 +03:00
|
|
|
if (!my_recent_chooser_dialog_id_.is_valid() ||
|
|
|
|
!td::contains(recent_chooser_dialog_ids_, my_recent_chooser_dialog_id_)) {
|
|
|
|
return parser.set_error("Invalid recent reaction chooser");
|
|
|
|
}
|
2023-04-27 16:20:54 +03:00
|
|
|
}
|
2024-01-02 02:54:57 +03:00
|
|
|
fix_choose_count();
|
2024-01-02 03:03:39 +03:00
|
|
|
|
|
|
|
if (is_empty() || reaction_type_.is_empty()) {
|
|
|
|
parser.set_error("Invalid message reaction");
|
|
|
|
}
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
|
|
|
|
2022-01-28 17:10:17 +03:00
|
|
|
template <class StorerT>
|
|
|
|
void UnreadMessageReaction::store(StorerT &storer) const {
|
|
|
|
BEGIN_STORE_FLAGS();
|
|
|
|
STORE_FLAG(is_big_);
|
|
|
|
END_STORE_FLAGS();
|
2023-08-04 18:39:07 +03:00
|
|
|
td::store(reaction_type_, storer);
|
2022-01-28 17:10:17 +03:00
|
|
|
td::store(sender_dialog_id_, storer);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void UnreadMessageReaction::parse(ParserT &parser) {
|
|
|
|
BEGIN_PARSE_FLAGS();
|
|
|
|
PARSE_FLAG(is_big_);
|
|
|
|
END_PARSE_FLAGS();
|
2023-08-04 18:39:07 +03:00
|
|
|
td::parse(reaction_type_, parser);
|
2022-01-28 17:10:17 +03:00
|
|
|
td::parse(sender_dialog_id_, parser);
|
2024-01-02 03:03:39 +03:00
|
|
|
if (reaction_type_.is_empty()) {
|
|
|
|
parser.set_error("Invalid unread message reaction");
|
|
|
|
}
|
2022-01-28 17:10:17 +03:00
|
|
|
}
|
|
|
|
|
2022-01-20 22:54:34 +03:00
|
|
|
template <class StorerT>
|
|
|
|
void MessageReactions::store(StorerT &storer) const {
|
|
|
|
bool has_reactions = !reactions_.empty();
|
2022-01-28 17:10:17 +03:00
|
|
|
bool has_unread_reactions = !unread_reactions_.empty();
|
2022-09-11 13:35:25 +03:00
|
|
|
bool has_chosen_reaction_order = !chosen_reaction_order_.empty();
|
2022-01-20 22:54:34 +03:00
|
|
|
BEGIN_STORE_FLAGS();
|
|
|
|
STORE_FLAG(is_min_);
|
|
|
|
STORE_FLAG(need_polling_);
|
2022-01-30 13:24:27 +03:00
|
|
|
STORE_FLAG(can_get_added_reactions_);
|
2022-01-28 17:10:17 +03:00
|
|
|
STORE_FLAG(has_unread_reactions);
|
2022-01-20 22:54:34 +03:00
|
|
|
STORE_FLAG(has_reactions);
|
2022-09-11 13:35:25 +03:00
|
|
|
STORE_FLAG(has_chosen_reaction_order);
|
2024-01-22 19:37:05 +03:00
|
|
|
STORE_FLAG(are_tags_);
|
2022-01-20 22:54:34 +03:00
|
|
|
END_STORE_FLAGS();
|
|
|
|
if (has_reactions) {
|
|
|
|
td::store(reactions_, storer);
|
|
|
|
}
|
2022-01-28 17:10:17 +03:00
|
|
|
if (has_unread_reactions) {
|
|
|
|
td::store(unread_reactions_, storer);
|
|
|
|
}
|
2022-09-11 13:35:25 +03:00
|
|
|
if (has_chosen_reaction_order) {
|
|
|
|
td::store(chosen_reaction_order_, storer);
|
|
|
|
}
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void MessageReactions::parse(ParserT &parser) {
|
|
|
|
bool has_reactions;
|
2022-01-28 17:10:17 +03:00
|
|
|
bool has_unread_reactions;
|
2022-09-11 13:35:25 +03:00
|
|
|
bool has_chosen_reaction_order;
|
2022-01-20 22:54:34 +03:00
|
|
|
BEGIN_PARSE_FLAGS();
|
|
|
|
PARSE_FLAG(is_min_);
|
|
|
|
PARSE_FLAG(need_polling_);
|
2022-01-30 13:24:27 +03:00
|
|
|
PARSE_FLAG(can_get_added_reactions_);
|
2022-01-28 17:10:17 +03:00
|
|
|
PARSE_FLAG(has_unread_reactions);
|
2022-01-20 22:54:34 +03:00
|
|
|
PARSE_FLAG(has_reactions);
|
2022-09-11 13:35:25 +03:00
|
|
|
PARSE_FLAG(has_chosen_reaction_order);
|
2024-01-22 19:37:05 +03:00
|
|
|
PARSE_FLAG(are_tags_);
|
2022-01-20 22:54:34 +03:00
|
|
|
END_PARSE_FLAGS();
|
|
|
|
if (has_reactions) {
|
|
|
|
td::parse(reactions_, parser);
|
|
|
|
}
|
2022-01-28 17:10:17 +03:00
|
|
|
if (has_unread_reactions) {
|
|
|
|
td::parse(unread_reactions_, parser);
|
|
|
|
}
|
2022-09-11 13:35:25 +03:00
|
|
|
if (has_chosen_reaction_order) {
|
|
|
|
td::parse(chosen_reaction_order_, parser);
|
|
|
|
}
|
2022-01-20 22:54:34 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|