Fix searching Great Minds by name.
GitOrigin-RevId: 1c9b2731b3b44bda2ca001363e5d4754326ecd70
This commit is contained in:
parent
3bb65d6ea3
commit
a25ac45f08
@ -502,6 +502,7 @@ class ReorderStickerSetsQuery : public Td::ResultHandler {
|
|||||||
class GetStickerSetQuery : public Td::ResultHandler {
|
class GetStickerSetQuery : public Td::ResultHandler {
|
||||||
Promise<Unit> promise_;
|
Promise<Unit> promise_;
|
||||||
int64 sticker_set_id_;
|
int64 sticker_set_id_;
|
||||||
|
string sticker_set_name_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit GetStickerSetQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
|
explicit GetStickerSetQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
|
||||||
@ -509,6 +510,10 @@ class GetStickerSetQuery : public Td::ResultHandler {
|
|||||||
|
|
||||||
void send(int64 sticker_set_id, tl_object_ptr<telegram_api::InputStickerSet> &&input_sticker_set) {
|
void send(int64 sticker_set_id, tl_object_ptr<telegram_api::InputStickerSet> &&input_sticker_set) {
|
||||||
sticker_set_id_ = sticker_set_id;
|
sticker_set_id_ = sticker_set_id;
|
||||||
|
if (input_sticker_set->get_id() == telegram_api::inputStickerSetShortName::ID) {
|
||||||
|
sticker_set_name_ =
|
||||||
|
static_cast<const telegram_api::inputStickerSetShortName *>(input_sticker_set.get())->short_name_;
|
||||||
|
}
|
||||||
LOG(INFO) << "Load sticker set " << sticker_set_id << " from server: " << to_string(input_sticker_set);
|
LOG(INFO) << "Load sticker set " << sticker_set_id << " from server: " << to_string(input_sticker_set);
|
||||||
send_query(G()->net_query_creator().create(
|
send_query(G()->net_query_creator().create(
|
||||||
create_storer(telegram_api::messages_getStickerSet(std::move(input_sticker_set)))));
|
create_storer(telegram_api::messages_getStickerSet(std::move(input_sticker_set)))));
|
||||||
@ -520,9 +525,19 @@ class GetStickerSetQuery : public Td::ResultHandler {
|
|||||||
return on_error(id, result_ptr.move_as_error());
|
return on_error(id, result_ptr.move_as_error());
|
||||||
}
|
}
|
||||||
|
|
||||||
auto ptr = result_ptr.move_as_ok();
|
auto set = result_ptr.move_as_ok();
|
||||||
// LOG(DEBUG) << "Receive result for get sticker set " << to_string(ptr);
|
|
||||||
td->stickers_manager_->on_get_messages_sticker_set(sticker_set_id_, std::move(ptr), true);
|
constexpr int64 GREAT_MINDS_COLOR_SET_ID = 151353307481243663;
|
||||||
|
if (set->set_->id_ == GREAT_MINDS_COLOR_SET_ID) {
|
||||||
|
string great_minds_name = "TelegramGreatMinds";
|
||||||
|
if (sticker_set_id_ == StickersManager::GREAT_MINDS_SET_ID ||
|
||||||
|
trim(to_lower(sticker_set_name_)) == to_lower(great_minds_name)) {
|
||||||
|
set->set_->id_ = StickersManager::GREAT_MINDS_SET_ID;
|
||||||
|
set->set_->short_name_ = std::move(great_minds_name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
td->stickers_manager_->on_get_messages_sticker_set(sticker_set_id_, std::move(set), true);
|
||||||
|
|
||||||
promise_.set_value(Unit());
|
promise_.set_value(Unit());
|
||||||
}
|
}
|
||||||
@ -1710,11 +1725,6 @@ void StickersManager::on_get_messages_sticker_set(int64 sticker_set_id,
|
|||||||
bool is_changed) {
|
bool is_changed) {
|
||||||
LOG(INFO) << "Receive sticker set " << to_string(set);
|
LOG(INFO) << "Receive sticker set " << to_string(set);
|
||||||
|
|
||||||
if (sticker_set_id == GREAT_MINDS_SET_ID && set->set_->id_ == GREAT_MINDS_COLOR_SET_ID) {
|
|
||||||
set->set_->id_ = GREAT_MINDS_SET_ID;
|
|
||||||
set->set_->short_name_ = "TelegramGreatMinds";
|
|
||||||
}
|
|
||||||
|
|
||||||
auto set_id = on_get_sticker_set(std::move(set->set_), is_changed);
|
auto set_id = on_get_sticker_set(std::move(set->set_), is_changed);
|
||||||
if (set_id == 0) {
|
if (set_id == 0) {
|
||||||
return;
|
return;
|
||||||
@ -2689,8 +2699,7 @@ void StickersManager::on_load_sticker_set_from_database(int64 sticker_set_id, bo
|
|||||||
CHECK(!sticker_set->load_without_stickers_requests.empty());
|
CHECK(!sticker_set->load_without_stickers_requests.empty());
|
||||||
}
|
}
|
||||||
if (value.empty()) {
|
if (value.empty()) {
|
||||||
reload_sticker_set(sticker_set_id, get_input_sticker_set(sticker_set), Auto());
|
return reload_sticker_set(sticker_set_id, get_input_sticker_set(sticker_set), Auto());
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "Successfully loaded sticker set " << sticker_set_id << " with" << (with_stickers ? "" : "out")
|
LOG(INFO) << "Successfully loaded sticker set " << sticker_set_id << " with" << (with_stickers ? "" : "out")
|
||||||
|
@ -36,6 +36,8 @@ class Td;
|
|||||||
|
|
||||||
class StickersManager : public Actor {
|
class StickersManager : public Actor {
|
||||||
public:
|
public:
|
||||||
|
static constexpr int64 GREAT_MINDS_SET_ID = 1842540969984001;
|
||||||
|
|
||||||
StickersManager(Td *td, ActorShared<> parent);
|
StickersManager(Td *td, ActorShared<> parent);
|
||||||
|
|
||||||
tl_object_ptr<td_api::sticker> get_sticker_object(FileId file_id) const;
|
tl_object_ptr<td_api::sticker> get_sticker_object(FileId file_id) const;
|
||||||
@ -243,9 +245,6 @@ class StickersManager : public Actor {
|
|||||||
static constexpr size_t MAX_STICKER_SET_TITLE_LENGTH = 64; // server side limit
|
static constexpr size_t MAX_STICKER_SET_TITLE_LENGTH = 64; // server side limit
|
||||||
static constexpr size_t MAX_STICKER_SET_SHORT_NAME_LENGTH = 64; // server side limit
|
static constexpr size_t MAX_STICKER_SET_SHORT_NAME_LENGTH = 64; // server side limit
|
||||||
|
|
||||||
static constexpr int64 GREAT_MINDS_SET_ID = 1842540969984001;
|
|
||||||
static constexpr int64 GREAT_MINDS_COLOR_SET_ID = 151353307481243663;
|
|
||||||
|
|
||||||
class Sticker {
|
class Sticker {
|
||||||
public:
|
public:
|
||||||
int64 set_id = 0;
|
int64 set_id = 0;
|
||||||
|
Reference in New Issue
Block a user