From ae14546613d92abd6b75e308587855d052cceb53 Mon Sep 17 00:00:00 2001 From: levlam Date: Sun, 7 Aug 2022 12:48:36 +0300 Subject: [PATCH] Disallow adding new reactions in supergroup if can't send messages there. --- td/telegram/MessagesManager.cpp | 35 ++++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 11 deletions(-) diff --git a/td/telegram/MessagesManager.cpp b/td/telegram/MessagesManager.cpp index 9896c8231..b4c8760b8 100644 --- a/td/telegram/MessagesManager.cpp +++ b/td/telegram/MessagesManager.cpp @@ -24332,24 +24332,37 @@ vector MessagesManager::get_message_available_reactions(const return {}; } - bool is_premium = G()->shared_config().get_option_boolean("is_premium"); + bool can_use_reactions = true; + if (d->dialog_id.get_type() == DialogType::Channel) { + auto channel_id = d->dialog_id.get_channel_id(); + if (td_->contacts_manager_->is_megagroup_channel(channel_id) && + !td_->contacts_manager_->get_channel_status(channel_id).is_member() && + can_send_message(d->dialog_id).is_error()) { + can_use_reactions = false; + } + } + vector result; - int64 reactions_uniq_max = G()->shared_config().get_option_integer("reactions_uniq_max", 11); - bool can_add_new_reactions = - m->reactions == nullptr || static_cast(m->reactions->reactions_.size()) < reactions_uniq_max; - // can add only active available reactions or remove previously set reaction - for (const auto &active_reaction : active_reactions_) { - // can add the reaction if it has already been used for the message or is available in the chat - bool is_set = (m->reactions != nullptr && m->reactions->get_reaction(active_reaction.reaction_) != nullptr); - if (is_set || (can_add_new_reactions && td::contains(active_reactions, active_reaction.reaction_))) { - result.emplace_back(active_reaction.reaction_, !is_premium && active_reaction.is_premium_ && !is_set); + if (can_use_reactions) { + bool is_premium = G()->shared_config().get_option_boolean("is_premium"); + int64 reactions_uniq_max = G()->shared_config().get_option_integer("reactions_uniq_max", 11); + bool can_add_new_reactions = + m->reactions == nullptr || static_cast(m->reactions->reactions_.size()) < reactions_uniq_max; + // can add only active available reactions or remove previously set reaction + for (const auto &active_reaction : active_reactions_) { + // can add the reaction if it has already been used for the message or is available in the chat + bool is_set = (m->reactions != nullptr && m->reactions->get_reaction(active_reaction.reaction_) != nullptr); + if (is_set || (can_add_new_reactions && td::contains(active_reactions, active_reaction.reaction_))) { + result.emplace_back(active_reaction.reaction_, !is_premium && active_reaction.is_premium_ && !is_set); + } } } if (m->reactions != nullptr) { for (const auto &reaction : m->reactions->reactions_) { if (reaction.is_chosen() && get_reaction_type(result, reaction.get_reaction()) == AvailableReactionType::Unavailable) { - CHECK(get_reaction_type(active_reactions_, reaction.get_reaction()) == AvailableReactionType::Unavailable); + CHECK(!can_use_reactions || + get_reaction_type(active_reactions_, reaction.get_reaction()) == AvailableReactionType::Unavailable); result.emplace_back(reaction.get_reaction(), false); } }