2022-08-30 11:45:27 +03:00
|
|
|
//
|
2023-01-01 00:28:08 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
2022-08-30 11:45:27 +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)
|
|
|
|
//
|
|
|
|
#include "td/telegram/ChatReactions.h"
|
|
|
|
|
|
|
|
#include "td/utils/algorithm.h"
|
2023-08-06 02:32:09 +03:00
|
|
|
#include "td/utils/format.h"
|
2022-08-30 11:45:27 +03:00
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
ChatReactions::ChatReactions(telegram_api::object_ptr<telegram_api::ChatReactions> &&chat_reactions_ptr) {
|
|
|
|
if (chat_reactions_ptr == nullptr) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
switch (chat_reactions_ptr->get_id()) {
|
|
|
|
case telegram_api::chatReactionsNone::ID:
|
|
|
|
break;
|
|
|
|
case telegram_api::chatReactionsAll::ID: {
|
|
|
|
auto chat_reactions = move_tl_object_as<telegram_api::chatReactionsAll>(chat_reactions_ptr);
|
|
|
|
allow_all_ = true;
|
|
|
|
allow_custom_ = chat_reactions->allow_custom_;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case telegram_api::chatReactionsSome::ID: {
|
|
|
|
auto chat_reactions = move_tl_object_as<telegram_api::chatReactionsSome>(chat_reactions_ptr);
|
2023-08-04 18:39:07 +03:00
|
|
|
reaction_types_ = transform(
|
|
|
|
chat_reactions->reactions_,
|
|
|
|
[](const telegram_api::object_ptr<telegram_api::Reaction> &reaction) { return ReactionType(reaction); });
|
2022-08-30 11:45:27 +03:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
UNREACHABLE();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ChatReactions::ChatReactions(td_api::object_ptr<td_api::ChatAvailableReactions> &&chat_reactions_ptr,
|
|
|
|
bool allow_custom) {
|
|
|
|
if (chat_reactions_ptr == nullptr) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
switch (chat_reactions_ptr->get_id()) {
|
|
|
|
case td_api::chatAvailableReactionsAll::ID:
|
|
|
|
allow_all_ = true;
|
|
|
|
allow_custom_ = allow_custom;
|
|
|
|
break;
|
|
|
|
case td_api::chatAvailableReactionsSome::ID: {
|
|
|
|
auto chat_reactions = move_tl_object_as<td_api::chatAvailableReactionsSome>(chat_reactions_ptr);
|
2023-08-04 18:39:07 +03:00
|
|
|
reaction_types_ =
|
|
|
|
transform(chat_reactions->reactions_,
|
|
|
|
[](const td_api::object_ptr<td_api::ReactionType> &reaction) { return ReactionType(reaction); });
|
2022-08-30 11:45:27 +03:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
UNREACHABLE();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-04 18:39:07 +03:00
|
|
|
ChatReactions ChatReactions::get_active_reactions(
|
|
|
|
const FlatHashMap<ReactionType, size_t, ReactionTypeHash> &active_reaction_pos) const {
|
2022-09-08 21:04:23 +03:00
|
|
|
ChatReactions result = *this;
|
2023-08-04 18:39:07 +03:00
|
|
|
if (!reaction_types_.empty()) {
|
2022-09-08 21:04:23 +03:00
|
|
|
CHECK(!allow_all_);
|
|
|
|
CHECK(!allow_custom_);
|
2023-08-04 18:39:07 +03:00
|
|
|
td::remove_if(result.reaction_types_, [&](const ReactionType &reaction_type) {
|
|
|
|
return !reaction_type.is_active_reaction(active_reaction_pos);
|
|
|
|
});
|
2022-09-08 17:56:39 +03:00
|
|
|
}
|
2022-09-08 21:04:23 +03:00
|
|
|
return result;
|
2022-09-08 17:56:39 +03:00
|
|
|
}
|
|
|
|
|
2023-08-04 18:39:07 +03:00
|
|
|
bool ChatReactions::is_allowed_reaction_type(const ReactionType &reaction_type) const {
|
2022-09-09 16:34:14 +03:00
|
|
|
CHECK(!allow_all_);
|
2023-08-04 18:39:07 +03:00
|
|
|
if (allow_custom_ && reaction_type.is_custom_reaction()) {
|
2022-09-09 16:34:14 +03:00
|
|
|
return true;
|
|
|
|
}
|
2023-08-04 18:39:07 +03:00
|
|
|
return td::contains(reaction_types_, reaction_type);
|
2022-09-09 16:34:14 +03:00
|
|
|
}
|
|
|
|
|
2022-08-30 11:45:27 +03:00
|
|
|
td_api::object_ptr<td_api::ChatAvailableReactions> ChatReactions::get_chat_available_reactions_object() const {
|
|
|
|
if (allow_all_) {
|
|
|
|
return td_api::make_object<td_api::chatAvailableReactionsAll>();
|
|
|
|
}
|
2023-08-04 18:39:07 +03:00
|
|
|
return td_api::make_object<td_api::chatAvailableReactionsSome>(transform(
|
|
|
|
reaction_types_, [](const ReactionType &reaction_type) { return reaction_type.get_reaction_type_object(); }));
|
2022-08-30 11:45:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
telegram_api::object_ptr<telegram_api::ChatReactions> ChatReactions::get_input_chat_reactions() const {
|
|
|
|
if (allow_all_) {
|
|
|
|
int32 flags = 0;
|
|
|
|
if (allow_custom_) {
|
|
|
|
flags |= telegram_api::chatReactionsAll::ALLOW_CUSTOM_MASK;
|
|
|
|
}
|
2023-06-23 17:53:38 +03:00
|
|
|
return telegram_api::make_object<telegram_api::chatReactionsAll>(flags, allow_custom_);
|
2022-08-30 11:45:27 +03:00
|
|
|
}
|
2023-08-04 18:39:07 +03:00
|
|
|
if (!reaction_types_.empty()) {
|
|
|
|
return telegram_api::make_object<telegram_api::chatReactionsSome>(transform(
|
|
|
|
reaction_types_, [](const ReactionType &reaction_type) { return reaction_type.get_input_reaction(); }));
|
2022-08-30 11:45:27 +03:00
|
|
|
}
|
|
|
|
return telegram_api::make_object<telegram_api::chatReactionsNone>();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator==(const ChatReactions &lhs, const ChatReactions &rhs) {
|
|
|
|
// don't compare allow_custom_
|
2023-08-04 18:39:07 +03:00
|
|
|
return lhs.reaction_types_ == rhs.reaction_types_ && lhs.allow_all_ == rhs.allow_all_;
|
2022-08-30 11:45:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
StringBuilder &operator<<(StringBuilder &string_builder, const ChatReactions &reactions) {
|
|
|
|
if (reactions.allow_all_) {
|
|
|
|
if (reactions.allow_custom_) {
|
|
|
|
return string_builder << "AllReactions";
|
|
|
|
}
|
|
|
|
return string_builder << "AllRegularReactions";
|
|
|
|
}
|
2023-08-04 18:39:07 +03:00
|
|
|
return string_builder << '[' << reactions.reaction_types_ << ']';
|
2022-08-30 11:45:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|