Add td_api::EmojiCategoryType.

This commit is contained in:
levlam 2023-01-24 21:38:53 +03:00
parent ae3a96e52d
commit b02f134798
9 changed files with 125 additions and 32 deletions

View File

@ -332,6 +332,7 @@ set(TDLIB_SOURCE
td/telegram/DraftMessage.cpp td/telegram/DraftMessage.cpp
td/telegram/EmailVerification.cpp td/telegram/EmailVerification.cpp
td/telegram/EmojiGroup.cpp td/telegram/EmojiGroup.cpp
td/telegram/EmojiGroupType.cpp
td/telegram/EmojiStatus.cpp td/telegram/EmojiStatus.cpp
td/telegram/FileReferenceManager.cpp td/telegram/FileReferenceManager.cpp
td/telegram/files/FileBitmask.cpp td/telegram/files/FileBitmask.cpp
@ -564,6 +565,7 @@ set(TDLIB_SOURCE
td/telegram/DraftMessage.h td/telegram/DraftMessage.h
td/telegram/EmailVerification.h td/telegram/EmailVerification.h
td/telegram/EmojiGroup.h td/telegram/EmojiGroup.h
td/telegram/EmojiGroupType.h
td/telegram/EmojiStatus.h td/telegram/EmojiStatus.h
td/telegram/EncryptedFile.h td/telegram/EncryptedFile.h
td/telegram/FileReferenceManager.h td/telegram/FileReferenceManager.h

View File

@ -2950,6 +2950,15 @@ emojiCategory name:string icon_custom_emoji_id:int64 emojis:vector<string> = Emo
emojiCategories categories:vector<emojiCategory> = EmojiCategories; emojiCategories categories:vector<emojiCategory> = EmojiCategories;
//@class EmojiCategoryType @description Describes type of an emoji category
//@description The category should be used by default
emojiCategoryTypeDefault = EmojiCategoryType;
//@description The category should be used for emoji status selection
emojiCategoryTypeEmojiStatus = EmojiCategoryType;
//@class CallDiscardReason @description Describes the reason why a call was discarded //@class CallDiscardReason @description Describes the reason why a call was discarded
//@description The call wasn't discarded, or the reason is unknown //@description The call wasn't discarded, or the reason is unknown
@ -7306,8 +7315,8 @@ getStickerEmojis sticker:InputFile = Emojis;
//@input_language_codes List of possible IETF language tags of the user's input language; may be empty if unknown //@input_language_codes List of possible IETF language tags of the user's input language; may be empty if unknown
searchEmojis text:string exact_match:Bool input_language_codes:vector<string> = Emojis; searchEmojis text:string exact_match:Bool input_language_codes:vector<string> = Emojis;
//@description Returns available emojis categories //@description Returns available emojis categories @type Type of emoji categories to return; pass null to get default emoji categories
getEmojiCategories = EmojiCategories; getEmojiCategories type:EmojiCategoryType = EmojiCategories;
//@description Returns an animated emoji corresponding to a given emoji. Returns a 404 error if the emoji has no animated emoji @emoji The emoji //@description Returns an animated emoji corresponding to a given emoji. Returns a 404 error if the emoji has no animated emoji @emoji The emoji
getAnimatedEmoji emoji:string = AnimatedEmoji; getAnimatedEmoji emoji:string = AnimatedEmoji;

View File

@ -45,5 +45,4 @@ void EmojiGroupList::update_next_reload_time() {
next_reload_time_ = Time::now() + 3600; next_reload_time_ = Time::now() + 3600;
} }
} // namespace td } // namespace td

View File

@ -0,0 +1,38 @@
//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
//
// 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/EmojiGroupType.h"
namespace td {
EmojiGroupType get_emoji_group_type(const td_api::object_ptr<td_api::EmojiCategoryType> &type) {
if (type == nullptr) {
return EmojiGroupType::Default;
}
switch (type->get_id()) {
case td_api::emojiCategoryTypeDefault::ID:
return EmojiGroupType::Default;
case td_api::emojiCategoryTypeEmojiStatus::ID:
return EmojiGroupType::EmojiStatus;
default:
UNREACHABLE();
return EmojiGroupType::Default;
}
}
StringBuilder &operator<<(StringBuilder &string_builder, EmojiGroupType emoji_group_type) {
switch (emoji_group_type) {
case EmojiGroupType::Default:
return string_builder << "Default";
case EmojiGroupType::EmojiStatus:
return string_builder << "EmojiStatus";
default:
UNREACHABLE();
return string_builder;
}
}
} // namespace td

View File

@ -0,0 +1,24 @@
//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
//
// 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/td_api.h"
#include "td/utils/common.h"
#include "td/utils/StringBuilder.h"
namespace td {
enum class EmojiGroupType : int32 { Default, EmojiStatus };
static constexpr int32 MAX_EMOJI_GROUP_TYPE = 2;
EmojiGroupType get_emoji_group_type(const td_api::object_ptr<td_api::EmojiCategoryType> &type);
StringBuilder &operator<<(StringBuilder &string_builder, EmojiGroupType emoji_group_type);
} // namespace td

View File

@ -1353,11 +1353,23 @@ class GetEmojiGroupsQuery final : public Td::ResultHandler {
: promise_(std::move(promise)) { : promise_(std::move(promise)) {
} }
void send(int32 hash) { void send(EmojiGroupType group_type, int32 hash) {
switch (group_type) {
case EmojiGroupType::Default:
send_query(G()->net_query_creator().create(telegram_api::messages_getEmojiGroups(hash))); send_query(G()->net_query_creator().create(telegram_api::messages_getEmojiGroups(hash)));
break;
case EmojiGroupType::EmojiStatus:
send_query(G()->net_query_creator().create(telegram_api::messages_getEmojiStatusGroups(hash)));
break;
default:
UNREACHABLE();
}
} }
void on_result(BufferSlice packet) final { void on_result(BufferSlice packet) final {
static_assert(std::is_same<telegram_api::messages_getEmojiGroups::ReturnType,
telegram_api::messages_getEmojiStatusGroups::ReturnType>::value,
"");
auto result_ptr = fetch_result<telegram_api::messages_getEmojiGroups>(packet); auto result_ptr = fetch_result<telegram_api::messages_getEmojiGroups>(packet);
if (result_ptr.is_error()) { if (result_ptr.is_error()) {
return on_error(result_ptr.move_as_error()); return on_error(result_ptr.move_as_error());
@ -9955,34 +9967,39 @@ td_api::object_ptr<td_api::httpUrl> StickersManager::get_emoji_suggestions_url_r
return result; return result;
} }
void StickersManager::get_emoji_categories(Promise<td_api::object_ptr<td_api::emojiCategories>> &&promise) { void StickersManager::get_emoji_groups(EmojiGroupType group_type,
Promise<td_api::object_ptr<td_api::emojiCategories>> &&promise) {
auto type = static_cast<int32>(group_type);
auto used_language_codes = implode(get_used_language_codes({}, Slice()), '$'); auto used_language_codes = implode(get_used_language_codes({}, Slice()), '$');
LOG(INFO) << "Have language codes " << used_language_codes; LOG(INFO) << "Have language codes " << used_language_codes;
if (emoji_group_list_.get_used_language_codes() == used_language_codes) { if (emoji_group_list_[type].get_used_language_codes() == used_language_codes) {
promise.set_value(emoji_group_list_.get_emoji_categories_object()); promise.set_value(emoji_group_list_[type].get_emoji_categories_object());
if (!emoji_group_list_.is_expired()) { if (!emoji_group_list_[type].is_expired()) {
return; return;
} }
promise = Promise<td_api::object_ptr<td_api::emojiCategories>>(); promise = Promise<td_api::object_ptr<td_api::emojiCategories>>();
} }
emoji_group_load_queries_.push_back(std::move(promise)); emoji_group_load_queries_[type].push_back(std::move(promise));
if (emoji_group_load_queries_.size() != 1) { if (emoji_group_load_queries_[type].size() != 1) {
// query has already been sent, just wait for the result // query has already been sent, just wait for the result
return; return;
} }
auto query_promise = auto query_promise = PromiseCreator::lambda(
PromiseCreator::lambda([actor_id = actor_id(this), used_language_codes = std::move(used_language_codes)]( [actor_id = actor_id(this), group_type, used_language_codes = std::move(used_language_codes)](
Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups) { Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups) {
send_closure(actor_id, &StickersManager::on_get_emoji_categories, std::move(used_language_codes), send_closure(actor_id, &StickersManager::on_get_emoji_groups, group_type, std::move(used_language_codes),
std::move(r_emoji_groups)); std::move(r_emoji_groups));
}); });
td_->create_handler<GetEmojiGroupsQuery>(std::move(query_promise))->send(emoji_group_list_.get_hash()); td_->create_handler<GetEmojiGroupsQuery>(std::move(query_promise))
->send(group_type, emoji_group_list_[type].get_hash());
} }
void StickersManager::on_get_emoji_categories( void StickersManager::on_get_emoji_groups(
string used_language_codes, Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups) { EmojiGroupType group_type, string used_language_codes,
Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups) {
auto type = static_cast<int32>(group_type);
if (G()->close_flag()) { if (G()->close_flag()) {
r_emoji_groups = Global::request_aborted_error(); r_emoji_groups = Global::request_aborted_error();
} }
@ -9990,7 +10007,7 @@ void StickersManager::on_get_emoji_categories(
if (!G()->is_expected_error(r_emoji_groups.error())) { if (!G()->is_expected_error(r_emoji_groups.error())) {
LOG(ERROR) << "Receive " << r_emoji_groups.error() << " from GetEmojiGroupsQuery"; LOG(ERROR) << "Receive " << r_emoji_groups.error() << " from GetEmojiGroupsQuery";
} }
return fail_promises(emoji_group_load_queries_, r_emoji_groups.move_as_error()); return fail_promises(emoji_group_load_queries_[type], r_emoji_groups.move_as_error());
} }
auto new_used_language_codes = implode(get_used_language_codes({}, Slice()), '$'); auto new_used_language_codes = implode(get_used_language_codes({}, Slice()), '$');
@ -10001,21 +10018,22 @@ void StickersManager::on_get_emoji_categories(
auto emoji_groups = r_emoji_groups.move_as_ok(); auto emoji_groups = r_emoji_groups.move_as_ok();
switch (emoji_groups->get_id()) { switch (emoji_groups->get_id()) {
case telegram_api::messages_emojiGroupsNotModified::ID: case telegram_api::messages_emojiGroupsNotModified::ID:
emoji_group_list_.update_next_reload_time(); emoji_group_list_[type].update_next_reload_time();
break; break;
case telegram_api::messages_emojiGroups::ID: { case telegram_api::messages_emojiGroups::ID: {
auto groups = telegram_api::move_object_as<telegram_api::messages_emojiGroups>(emoji_groups); auto groups = telegram_api::move_object_as<telegram_api::messages_emojiGroups>(emoji_groups);
emoji_group_list_ = EmojiGroupList(std::move(used_language_codes), groups->hash_, std::move(groups->groups_)); emoji_group_list_[type] =
EmojiGroupList(std::move(used_language_codes), groups->hash_, std::move(groups->groups_));
break; break;
} }
default: default:
UNREACHABLE(); UNREACHABLE();
} }
auto promises = std::move(emoji_group_load_queries_); auto promises = std::move(emoji_group_load_queries_[type]);
reset_to_empty(emoji_group_load_queries_); reset_to_empty(emoji_group_load_queries_[type]);
for (auto &promise : promises) { for (auto &promise : promises) {
promise.set_value(emoji_group_list_.get_emoji_categories_object()); promise.set_value(emoji_group_list_[type].get_emoji_categories_object());
} }
} }

View File

@ -10,6 +10,7 @@
#include "td/telegram/DialogId.h" #include "td/telegram/DialogId.h"
#include "td/telegram/Dimensions.h" #include "td/telegram/Dimensions.h"
#include "td/telegram/EmojiGroup.h" #include "td/telegram/EmojiGroup.h"
#include "td/telegram/EmojiGroupType.h"
#include "td/telegram/files/FileId.h" #include "td/telegram/files/FileId.h"
#include "td/telegram/files/FileSourceId.h" #include "td/telegram/files/FileSourceId.h"
#include "td/telegram/FullMessageId.h" #include "td/telegram/FullMessageId.h"
@ -365,7 +366,7 @@ class StickersManager final : public Actor {
int64 get_emoji_suggestions_url(const string &language_code, Promise<Unit> &&promise); int64 get_emoji_suggestions_url(const string &language_code, Promise<Unit> &&promise);
void get_emoji_categories(Promise<td_api::object_ptr<td_api::emojiCategories>> &&promise); void get_emoji_groups(EmojiGroupType group_type, Promise<td_api::object_ptr<td_api::emojiCategories>> &&promise);
td_api::object_ptr<td_api::httpUrl> get_emoji_suggestions_url_result(int64 random_id); td_api::object_ptr<td_api::httpUrl> get_emoji_suggestions_url_result(int64 random_id);
@ -1001,7 +1002,7 @@ class StickersManager final : public Actor {
void on_get_emoji_suggestions_url(int64 random_id, Promise<Unit> &&promise, void on_get_emoji_suggestions_url(int64 random_id, Promise<Unit> &&promise,
Result<telegram_api::object_ptr<telegram_api::emojiURL>> &&r_emoji_url); Result<telegram_api::object_ptr<telegram_api::emojiURL>> &&r_emoji_url);
void on_get_emoji_categories(string used_language_codes, void on_get_emoji_groups(EmojiGroupType group_type, string used_language_codes,
Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups); Result<telegram_api::object_ptr<telegram_api::messages_EmojiGroups>> r_emoji_groups);
Td *td_; Td *td_;
@ -1181,8 +1182,8 @@ class StickersManager final : public Actor {
string emoji_sounds_str_; string emoji_sounds_str_;
FlatHashMap<string, FileId> emoji_sounds_; FlatHashMap<string, FileId> emoji_sounds_;
EmojiGroupList emoji_group_list_; EmojiGroupList emoji_group_list_[MAX_EMOJI_GROUP_TYPE];
vector<Promise<td_api::object_ptr<td_api::emojiCategories>>> emoji_group_load_queries_; vector<Promise<td_api::object_ptr<td_api::emojiCategories>>> emoji_group_load_queries_[MAX_EMOJI_GROUP_TYPE];
vector<CustomEmojiId> default_dialog_photo_custom_emoji_ids_[2]; vector<CustomEmojiId> default_dialog_photo_custom_emoji_ids_[2];
int64 default_dialog_photo_custom_emoji_ids_hash_[2] = {0, 0}; int64 default_dialog_photo_custom_emoji_ids_hash_[2] = {0, 0};

View File

@ -43,6 +43,7 @@
#include "td/telegram/DownloadManager.h" #include "td/telegram/DownloadManager.h"
#include "td/telegram/DownloadManagerCallback.h" #include "td/telegram/DownloadManagerCallback.h"
#include "td/telegram/EmailVerification.h" #include "td/telegram/EmailVerification.h"
#include "td/telegram/EmojiGroupType.h"
#include "td/telegram/EmojiStatus.h" #include "td/telegram/EmojiStatus.h"
#include "td/telegram/FileReferenceManager.h" #include "td/telegram/FileReferenceManager.h"
#include "td/telegram/files/FileGcParameters.h" #include "td/telegram/files/FileGcParameters.h"
@ -7351,7 +7352,7 @@ void Td::on_request(uint64 id, td_api::searchEmojis &request) {
void Td::on_request(uint64 id, const td_api::getEmojiCategories &request) { void Td::on_request(uint64 id, const td_api::getEmojiCategories &request) {
CHECK_IS_USER(); CHECK_IS_USER();
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
stickers_manager_->get_emoji_categories(std::move(promise)); stickers_manager_->get_emoji_groups(get_emoji_group_type(request.type_), std::move(promise));
} }
void Td::on_request(uint64 id, td_api::getAnimatedEmoji &request) { void Td::on_request(uint64 id, td_api::getAnimatedEmoji &request) {

View File

@ -2921,8 +2921,9 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::searchEmojis>(args, true, vector<string>())); send_request(td_api::make_object<td_api::searchEmojis>(args, true, vector<string>()));
} else if (op == "seru") { } else if (op == "seru") {
send_request(td_api::make_object<td_api::searchEmojis>(args, false, vector<string>{"ru_RU"})); send_request(td_api::make_object<td_api::searchEmojis>(args, false, vector<string>{"ru_RU"}));
} else if (op == "gec") { } else if (op == "gec" || op == "geces") {
send_request(td_api::make_object<td_api::getEmojiCategories>()); auto type = op == "geces" ? td_api::make_object<td_api::emojiCategoryTypeEmojiStatus>() : nullptr;
send_request(td_api::make_object<td_api::getEmojiCategories>(std::move(type)));
} else if (op == "gae") { } else if (op == "gae") {
send_request(td_api::make_object<td_api::getAnimatedEmoji>(args)); send_request(td_api::make_object<td_api::getAnimatedEmoji>(args));
} else if (op == "gesu") { } else if (op == "gesu") {