Add option "chat_filter_chosen_chat_count_max".
This commit is contained in:
parent
c584b48c10
commit
d986c9bc27
@ -974,9 +974,9 @@ chatTypeSecret secret_chat_id:int32 user_id:int53 = ChatType;
|
|||||||
//@title The title of the filter; 1-12 characters without line feeds
|
//@title The title of the filter; 1-12 characters without line feeds
|
||||||
//@icon_name The chosen icon name for short filter representation. If non-empty, must be one of "All", "Unread", "Unmuted", "Bots", "Channels", "Groups", "Private", "Custom", "Setup", "Cat", "Crown", "Favorite", "Flower", "Game", "Home", "Love", "Mask", "Party", "Sport", "Study", "Trade", "Travel", "Work".
|
//@icon_name The chosen icon name for short filter representation. If non-empty, must be one of "All", "Unread", "Unmuted", "Bots", "Channels", "Groups", "Private", "Custom", "Setup", "Cat", "Crown", "Favorite", "Flower", "Game", "Home", "Love", "Mask", "Party", "Sport", "Study", "Trade", "Travel", "Work".
|
||||||
//-If empty, use getChatFilterDefaultIconName to get default icon name for the filter
|
//-If empty, use getChatFilterDefaultIconName to get default icon name for the filter
|
||||||
//@pinned_chat_ids The chat identifiers of pinned chats in the filtered chat list
|
//@pinned_chat_ids The chat identifiers of pinned chats in the filtered chat list. There can be up to GetOption("chat_filter_chosen_chat_count_max") pinned and always included non-secret chats and the same number of secret chats, but the limit can be increased with Telegram Premium
|
||||||
//@included_chat_ids The chat identifiers of always included chats in the filtered chat list
|
//@included_chat_ids The chat identifiers of always included chats in the filtered chat list. There can be up to GetOption("chat_filter_chosen_chat_count_max") pinned and always included non-secret chats and the same number of secret chats, but the limit can be increased with Telegram Premium
|
||||||
//@excluded_chat_ids The chat identifiers of always excluded chats in the filtered chat list
|
//@excluded_chat_ids The chat identifiers of always excluded chats in the filtered chat list. There can be up to GetOption("chat_filter_chosen_chat_count_max") always excluded non-secret chats and the same number of secret chats, but the limit can be increased with Telegram Premium
|
||||||
//@exclude_muted True, if muted chats need to be excluded
|
//@exclude_muted True, if muted chats need to be excluded
|
||||||
//@exclude_read True, if read chats need to be excluded
|
//@exclude_read True, if read chats need to be excluded
|
||||||
//@exclude_archived True, if archived chats need to be excluded
|
//@exclude_archived True, if archived chats need to be excluded
|
||||||
@ -2892,7 +2892,7 @@ premiumLimitTypeFavoriteStickerCount = PremiumLimitType;
|
|||||||
premiumLimitTypeChatFilterCount = PremiumLimitType;
|
premiumLimitTypeChatFilterCount = PremiumLimitType;
|
||||||
|
|
||||||
//@description The maximum number of pinned and always included, or always excluded chats in a chat list
|
//@description The maximum number of pinned and always included, or always excluded chats in a chat list
|
||||||
premiumLimitTypeChatFilterSpecificChatCount = PremiumLimitType;
|
premiumLimitTypeChatFilterChosenChatCount = PremiumLimitType;
|
||||||
|
|
||||||
//@description The maximum number of pinned chats in the main chat list
|
//@description The maximum number of pinned chats in the main chat list
|
||||||
premiumLimitTypePinnedChatCount = PremiumLimitType;
|
premiumLimitTypePinnedChatCount = PremiumLimitType;
|
||||||
|
@ -1209,7 +1209,7 @@ void ConfigManager::get_premium_features(Promise<td_api::object_ptr<td_api::prem
|
|||||||
return td_api::make_object<td_api::premiumLimitTypeChatFilterCount>();
|
return td_api::make_object<td_api::premiumLimitTypeChatFilterCount>();
|
||||||
}
|
}
|
||||||
if (key == "dialog_filters_chats_limit") {
|
if (key == "dialog_filters_chats_limit") {
|
||||||
return td_api::make_object<td_api::premiumLimitTypeChatFilterSpecificChatCount>();
|
return td_api::make_object<td_api::premiumLimitTypeChatFilterChosenChatCount>();
|
||||||
}
|
}
|
||||||
if (key == "dialogs_pinned_limit") {
|
if (key == "dialogs_pinned_limit") {
|
||||||
return td_api::make_object<td_api::premiumLimitTypePinnedChatCount>();
|
return td_api::make_object<td_api::premiumLimitTypePinnedChatCount>();
|
||||||
@ -1970,6 +1970,12 @@ void ConfigManager::process_app_config(tl_object_ptr<telegram_api::JSONValue> &c
|
|||||||
is_premium ? Slice("dialog_filters_limit_premium") : Slice("dialog_filters_limit_default"), is_premium ? 20 : 10);
|
is_premium ? Slice("dialog_filters_limit_premium") : Slice("dialog_filters_limit_default"), is_premium ? 20 : 10);
|
||||||
shared_config.set_option_integer("chat_filter_count_max", static_cast<int32>(chat_filter_count_max));
|
shared_config.set_option_integer("chat_filter_count_max", static_cast<int32>(chat_filter_count_max));
|
||||||
|
|
||||||
|
auto chat_filter_chosen_chat_count_max = shared_config.get_option_integer(
|
||||||
|
is_premium ? Slice("dialog_filters_chats_limit_premium") : Slice("dialog_filters_chats_limit_default"),
|
||||||
|
is_premium ? 200 : 100);
|
||||||
|
shared_config.set_option_integer("chat_filter_chosen_chat_count_max",
|
||||||
|
static_cast<int32>(chat_filter_chosen_chat_count_max));
|
||||||
|
|
||||||
shared_config.set_option_string("premium_features", implode(premium_features, ','));
|
shared_config.set_option_string("premium_features", implode(premium_features, ','));
|
||||||
|
|
||||||
shared_config.set_option_empty("default_ton_blockchain_config");
|
shared_config.set_option_empty("default_ton_blockchain_config");
|
||||||
|
@ -6,18 +6,21 @@
|
|||||||
//
|
//
|
||||||
#include "td/telegram/DialogFilter.h"
|
#include "td/telegram/DialogFilter.h"
|
||||||
|
|
||||||
|
#include "td/telegram/ConfigShared.h"
|
||||||
#include "td/telegram/DialogId.h"
|
#include "td/telegram/DialogId.h"
|
||||||
|
#include "td/telegram/Global.h"
|
||||||
|
|
||||||
#include "td/utils/algorithm.h"
|
#include "td/utils/algorithm.h"
|
||||||
#include "td/utils/emoji.h"
|
#include "td/utils/emoji.h"
|
||||||
#include "td/utils/FlatHashSet.h"
|
#include "td/utils/FlatHashSet.h"
|
||||||
#include "td/utils/format.h"
|
#include "td/utils/format.h"
|
||||||
#include "td/utils/logging.h"
|
#include "td/utils/logging.h"
|
||||||
|
#include "td/utils/misc.h"
|
||||||
|
|
||||||
namespace td {
|
namespace td {
|
||||||
|
|
||||||
int32 DialogFilter::get_max_filter_dialogs() {
|
int32 DialogFilter::get_max_filter_dialogs() {
|
||||||
return 100; // server side limit
|
return narrow_cast<int32>(G()->shared_config().get_option_integer("chat_filter_chosen_chat_count_max", 100));
|
||||||
}
|
}
|
||||||
|
|
||||||
unique_ptr<DialogFilter> DialogFilter::get_dialog_filter(
|
unique_ptr<DialogFilter> DialogFilter::get_dialog_filter(
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
|
|
||||||
#include "td/telegram/ConfigShared.h"
|
#include "td/telegram/ConfigShared.h"
|
||||||
#include "td/telegram/net/ConnectionCreator.h"
|
#include "td/telegram/net/ConnectionCreator.h"
|
||||||
#include "td/telegram/net/MtprotoHeader.h"
|
|
||||||
#include "td/telegram/net/NetQueryDispatcher.h"
|
#include "td/telegram/net/NetQueryDispatcher.h"
|
||||||
#include "td/telegram/net/TempAuthKeyWatchdog.h"
|
#include "td/telegram/net/TempAuthKeyWatchdog.h"
|
||||||
#include "td/telegram/OptionManager.h"
|
#include "td/telegram/OptionManager.h"
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
|
|
||||||
#include "td/telegram/DhConfig.h"
|
#include "td/telegram/DhConfig.h"
|
||||||
#include "td/telegram/net/DcId.h"
|
#include "td/telegram/net/DcId.h"
|
||||||
|
#include "td/telegram/net/MtprotoHeader.h"
|
||||||
#include "td/telegram/net/NetQueryCreator.h"
|
#include "td/telegram/net/NetQueryCreator.h"
|
||||||
#include "td/telegram/TdParameters.h"
|
#include "td/telegram/TdParameters.h"
|
||||||
|
|
||||||
@ -45,7 +46,6 @@ class GroupCallManager;
|
|||||||
class LanguagePackManager;
|
class LanguagePackManager;
|
||||||
class LinkManager;
|
class LinkManager;
|
||||||
class MessagesManager;
|
class MessagesManager;
|
||||||
class MtprotoHeader;
|
|
||||||
class NetQueryDispatcher;
|
class NetQueryDispatcher;
|
||||||
class NotificationManager;
|
class NotificationManager;
|
||||||
class NotificationSettingsManager;
|
class NotificationSettingsManager;
|
||||||
|
@ -114,6 +114,9 @@ OptionManager::OptionManager(Td *td, ActorShared<> parent) : td_(td), parent_(st
|
|||||||
if (!G()->shared_config().have_option("chat_filter_count_max")) {
|
if (!G()->shared_config().have_option("chat_filter_count_max")) {
|
||||||
G()->shared_config().set_option_integer("chat_filter_count_max", G()->is_test_dc() ? 3 : 10);
|
G()->shared_config().set_option_integer("chat_filter_count_max", G()->is_test_dc() ? 3 : 10);
|
||||||
}
|
}
|
||||||
|
if (!G()->shared_config().have_option("chat_filter_chosen_chat_count_max")) {
|
||||||
|
G()->shared_config().set_option_integer("chat_filter_chosen_chat_count_max", G()->is_test_dc() ? 5 : 100);
|
||||||
|
}
|
||||||
G()->shared_config().set_option_integer("utc_time_offset", Clocks::tz_offset());
|
G()->shared_config().set_option_integer("utc_time_offset", Clocks::tz_offset());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user