Store unmodified server join_to_send/join_request flags.
This commit is contained in:
parent
ad8a2d2296
commit
d351636c83
@ -6594,8 +6594,8 @@ void ContactsManager::toggle_channel_join_to_send(ChannelId channel_id, bool joi
|
|||||||
if (c == nullptr) {
|
if (c == nullptr) {
|
||||||
return promise.set_error(Status::Error(400, "Supergroup not found"));
|
return promise.set_error(Status::Error(400, "Supergroup not found"));
|
||||||
}
|
}
|
||||||
if (get_channel_type(c) == ChannelType::Broadcast) {
|
if (get_channel_type(c) == ChannelType::Broadcast || c->is_gigagroup) {
|
||||||
return promise.set_error(Status::Error(400, "The method can't be called for channels"));
|
return promise.set_error(Status::Error(400, "The method can be called only for ordinary supergroups"));
|
||||||
}
|
}
|
||||||
if (!get_channel_permissions(c).can_restrict_members()) {
|
if (!get_channel_permissions(c).can_restrict_members()) {
|
||||||
return promise.set_error(Status::Error(400, "Not enough rights"));
|
return promise.set_error(Status::Error(400, "Not enough rights"));
|
||||||
@ -6609,8 +6609,8 @@ void ContactsManager::toggle_channel_join_request(ChannelId channel_id, bool joi
|
|||||||
if (c == nullptr) {
|
if (c == nullptr) {
|
||||||
return promise.set_error(Status::Error(400, "Supergroup not found"));
|
return promise.set_error(Status::Error(400, "Supergroup not found"));
|
||||||
}
|
}
|
||||||
if (get_channel_type(c) == ChannelType::Broadcast) {
|
if (get_channel_type(c) == ChannelType::Broadcast || c->is_gigagroup) {
|
||||||
return promise.set_error(Status::Error(400, "The method can't be called for channels"));
|
return promise.set_error(Status::Error(400, "The method can be called only for ordinary supergroups"));
|
||||||
}
|
}
|
||||||
if (!get_channel_permissions(c).can_restrict_members()) {
|
if (!get_channel_permissions(c).can_restrict_members()) {
|
||||||
return promise.set_error(Status::Error(400, "Not enough rights"));
|
return promise.set_error(Status::Error(400, "Not enough rights"));
|
||||||
@ -10330,12 +10330,6 @@ void ContactsManager::update_chat(Chat *c, ChatId chat_id, bool from_binlog, boo
|
|||||||
void ContactsManager::update_channel(Channel *c, ChannelId channel_id, bool from_binlog, bool from_database) {
|
void ContactsManager::update_channel(Channel *c, ChannelId channel_id, bool from_binlog, bool from_database) {
|
||||||
CHECK(c != nullptr);
|
CHECK(c != nullptr);
|
||||||
bool need_update_channel_full = false;
|
bool need_update_channel_full = false;
|
||||||
if (!c->is_megagroup || !c->has_linked_channel) {
|
|
||||||
c->join_to_send = true;
|
|
||||||
}
|
|
||||||
if (!c->is_megagroup || (c->username.empty() && !c->has_linked_channel && !c->has_location)) {
|
|
||||||
c->join_request = false;
|
|
||||||
}
|
|
||||||
if (c->is_photo_changed) {
|
if (c->is_photo_changed) {
|
||||||
td_->messages_manager_->on_dialog_photo_updated(DialogId(channel_id));
|
td_->messages_manager_->on_dialog_photo_updated(DialogId(channel_id));
|
||||||
c->is_photo_changed = false;
|
c->is_photo_changed = false;
|
||||||
@ -15056,6 +15050,14 @@ bool ContactsManager::get_channel_can_be_deleted(const Channel *c) {
|
|||||||
return c->can_be_deleted;
|
return c->can_be_deleted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ContactsManager::get_channel_join_to_send(const Channel *c) {
|
||||||
|
return c->join_to_send || !c->is_megagroup || !c->has_linked_channel;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ContactsManager::get_channel_join_request(const Channel *c) {
|
||||||
|
return c->join_request && c->is_megagroup && (is_channel_public(c) || c->has_linked_channel);
|
||||||
|
}
|
||||||
|
|
||||||
ChannelId ContactsManager::get_channel_linked_channel_id(ChannelId channel_id) {
|
ChannelId ContactsManager::get_channel_linked_channel_id(ChannelId channel_id) {
|
||||||
auto channel_full = get_channel_full_const(channel_id);
|
auto channel_full = get_channel_full_const(channel_id);
|
||||||
if (channel_full == nullptr) {
|
if (channel_full == nullptr) {
|
||||||
@ -16171,13 +16173,6 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
bool have_participant_count = (channel.flags_ & CHANNEL_FLAG_HAS_PARTICIPANT_COUNT) != 0;
|
bool have_participant_count = (channel.flags_ & CHANNEL_FLAG_HAS_PARTICIPANT_COUNT) != 0;
|
||||||
int32 participant_count = have_participant_count ? channel.participants_count_ : 0;
|
int32 participant_count = have_participant_count ? channel.participants_count_ : 0;
|
||||||
|
|
||||||
if (!is_megagroup || !has_linked_channel) {
|
|
||||||
join_to_send = true;
|
|
||||||
}
|
|
||||||
if (!is_megagroup || (channel.username_.empty() && !has_linked_channel && !channel.has_geo_)) {
|
|
||||||
join_request = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (have_participant_count) {
|
if (have_participant_count) {
|
||||||
auto channel_full = get_channel_full_const(channel_id);
|
auto channel_full = get_channel_full_const(channel_id);
|
||||||
if (channel_full != nullptr && channel_full->administrator_count > participant_count) {
|
if (channel_full != nullptr && channel_full->administrator_count > participant_count) {
|
||||||
@ -16229,6 +16224,9 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
Channel *c = get_channel_force(channel_id);
|
Channel *c = get_channel_force(channel_id);
|
||||||
if (c != nullptr) {
|
if (c != nullptr) {
|
||||||
LOG(DEBUG) << "Receive known min " << channel_id;
|
LOG(DEBUG) << "Receive known min " << channel_id;
|
||||||
|
|
||||||
|
auto old_join_to_send = get_channel_join_to_send(c);
|
||||||
|
auto old_join_request = get_channel_join_request(c);
|
||||||
on_update_channel_title(c, channel_id, std::move(channel.title_));
|
on_update_channel_title(c, channel_id, std::move(channel.title_));
|
||||||
on_update_channel_username(c, channel_id, std::move(channel.username_));
|
on_update_channel_username(c, channel_id, std::move(channel.username_));
|
||||||
on_update_channel_photo(c, channel_id, std::move(channel.photo_));
|
on_update_channel_photo(c, channel_id, std::move(channel.photo_));
|
||||||
@ -16238,8 +16236,7 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
|
|
||||||
if (c->has_linked_channel != has_linked_channel || c->is_slow_mode_enabled != is_slow_mode_enabled ||
|
if (c->has_linked_channel != has_linked_channel || c->is_slow_mode_enabled != is_slow_mode_enabled ||
|
||||||
c->is_megagroup != is_megagroup || c->restriction_reasons != restriction_reasons || c->is_scam != is_scam ||
|
c->is_megagroup != is_megagroup || c->restriction_reasons != restriction_reasons || c->is_scam != is_scam ||
|
||||||
c->is_fake != is_fake || c->is_gigagroup != is_gigagroup || c->join_to_send != join_to_send ||
|
c->is_fake != is_fake || c->is_gigagroup != is_gigagroup) {
|
||||||
c->join_request != join_request) {
|
|
||||||
c->has_linked_channel = has_linked_channel;
|
c->has_linked_channel = has_linked_channel;
|
||||||
c->is_slow_mode_enabled = is_slow_mode_enabled;
|
c->is_slow_mode_enabled = is_slow_mode_enabled;
|
||||||
c->is_megagroup = is_megagroup;
|
c->is_megagroup = is_megagroup;
|
||||||
@ -16247,18 +16244,25 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
c->is_scam = is_scam;
|
c->is_scam = is_scam;
|
||||||
c->is_fake = is_fake;
|
c->is_fake = is_fake;
|
||||||
c->is_gigagroup = is_gigagroup;
|
c->is_gigagroup = is_gigagroup;
|
||||||
c->join_to_send = join_to_send;
|
|
||||||
c->join_request = join_request;
|
|
||||||
|
|
||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
invalidate_channel_full(channel_id, !c->is_slow_mode_enabled);
|
invalidate_channel_full(channel_id, !c->is_slow_mode_enabled);
|
||||||
}
|
}
|
||||||
|
if (c->join_to_send != join_to_send || c->join_request != join_request) {
|
||||||
|
c->join_to_send = join_to_send;
|
||||||
|
c->join_request = join_request;
|
||||||
|
|
||||||
|
c->need_save_to_database = true;
|
||||||
|
}
|
||||||
// sign_messages isn't known for min-channels
|
// sign_messages isn't known for min-channels
|
||||||
if (c->is_verified != is_verified) {
|
if (c->is_verified != is_verified) {
|
||||||
c->is_verified = is_verified;
|
c->is_verified = is_verified;
|
||||||
|
|
||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
}
|
}
|
||||||
|
if (old_join_to_send != get_channel_join_to_send(c) || old_join_request != get_channel_join_request(c)) {
|
||||||
|
c->is_changed = true;
|
||||||
|
}
|
||||||
|
|
||||||
update_channel(c, channel_id);
|
update_channel(c, channel_id);
|
||||||
} else {
|
} else {
|
||||||
@ -16289,6 +16293,8 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
if (c->status.is_banned()) { // possibly uninited channel
|
if (c->status.is_banned()) { // possibly uninited channel
|
||||||
min_channels_.erase(channel_id);
|
min_channels_.erase(channel_id);
|
||||||
}
|
}
|
||||||
|
auto old_join_to_send = get_channel_join_to_send(c);
|
||||||
|
auto old_join_request = get_channel_join_request(c);
|
||||||
if (c->access_hash != access_hash) {
|
if (c->access_hash != access_hash) {
|
||||||
c->access_hash = access_hash;
|
c->access_hash = access_hash;
|
||||||
c->need_save_to_database = true;
|
c->need_save_to_database = true;
|
||||||
@ -16314,8 +16320,7 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
bool need_invalidate_channel_full = false;
|
bool need_invalidate_channel_full = false;
|
||||||
if (c->has_linked_channel != has_linked_channel || c->is_slow_mode_enabled != is_slow_mode_enabled ||
|
if (c->has_linked_channel != has_linked_channel || c->is_slow_mode_enabled != is_slow_mode_enabled ||
|
||||||
c->is_megagroup != is_megagroup || c->restriction_reasons != restriction_reasons || c->is_scam != is_scam ||
|
c->is_megagroup != is_megagroup || c->restriction_reasons != restriction_reasons || c->is_scam != is_scam ||
|
||||||
c->is_fake != is_fake || c->is_gigagroup != is_gigagroup || c->join_to_send != join_to_send ||
|
c->is_fake != is_fake || c->is_gigagroup != is_gigagroup) {
|
||||||
c->join_request != join_request) {
|
|
||||||
c->has_linked_channel = has_linked_channel;
|
c->has_linked_channel = has_linked_channel;
|
||||||
c->is_slow_mode_enabled = is_slow_mode_enabled;
|
c->is_slow_mode_enabled = is_slow_mode_enabled;
|
||||||
c->is_megagroup = is_megagroup;
|
c->is_megagroup = is_megagroup;
|
||||||
@ -16329,12 +16334,21 @@ void ContactsManager::on_chat_update(telegram_api::channel &channel, const char
|
|||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
need_invalidate_channel_full = true;
|
need_invalidate_channel_full = true;
|
||||||
}
|
}
|
||||||
|
if (c->join_to_send != join_to_send || c->join_request != join_request) {
|
||||||
|
c->join_to_send = join_to_send;
|
||||||
|
c->join_request = join_request;
|
||||||
|
|
||||||
|
c->need_save_to_database = true;
|
||||||
|
}
|
||||||
if (c->is_verified != is_verified || c->sign_messages != sign_messages) {
|
if (c->is_verified != is_verified || c->sign_messages != sign_messages) {
|
||||||
c->is_verified = is_verified;
|
c->is_verified = is_verified;
|
||||||
c->sign_messages = sign_messages;
|
c->sign_messages = sign_messages;
|
||||||
|
|
||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
}
|
}
|
||||||
|
if (old_join_to_send != get_channel_join_to_send(c) || old_join_request != get_channel_join_request(c)) {
|
||||||
|
c->is_changed = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (c->cache_version != Channel::CACHE_VERSION) {
|
if (c->cache_version != Channel::CACHE_VERSION) {
|
||||||
c->cache_version = Channel::CACHE_VERSION;
|
c->cache_version = Channel::CACHE_VERSION;
|
||||||
@ -16383,6 +16397,8 @@ void ContactsManager::on_chat_update(telegram_api::channelForbidden &channel, co
|
|||||||
if (c->status.is_banned()) { // possibly uninited channel
|
if (c->status.is_banned()) { // possibly uninited channel
|
||||||
min_channels_.erase(channel_id);
|
min_channels_.erase(channel_id);
|
||||||
}
|
}
|
||||||
|
auto old_join_to_send = get_channel_join_to_send(c);
|
||||||
|
auto old_join_request = get_channel_join_request(c);
|
||||||
if (c->access_hash != channel.access_hash_) {
|
if (c->access_hash != channel.access_hash_) {
|
||||||
c->access_hash = channel.access_hash_;
|
c->access_hash = channel.access_hash_;
|
||||||
c->need_save_to_database = true;
|
c->need_save_to_database = true;
|
||||||
@ -16411,10 +16427,6 @@ void ContactsManager::on_chat_update(telegram_api::channelForbidden &channel, co
|
|||||||
bool is_scam = false;
|
bool is_scam = false;
|
||||||
bool is_fake = false;
|
bool is_fake = false;
|
||||||
|
|
||||||
if (!is_megagroup || !c->has_linked_channel) {
|
|
||||||
join_to_send = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
bool is_broadcast = (channel.flags_ & CHANNEL_FLAG_IS_BROADCAST) != 0;
|
bool is_broadcast = (channel.flags_ & CHANNEL_FLAG_IS_BROADCAST) != 0;
|
||||||
LOG_IF(ERROR, is_broadcast == is_megagroup)
|
LOG_IF(ERROR, is_broadcast == is_megagroup)
|
||||||
@ -16442,12 +16454,21 @@ void ContactsManager::on_chat_update(telegram_api::channelForbidden &channel, co
|
|||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
need_invalidate_channel_full = true;
|
need_invalidate_channel_full = true;
|
||||||
}
|
}
|
||||||
|
if (c->join_to_send != join_to_send || c->join_request != join_request) {
|
||||||
|
c->join_to_send = join_to_send;
|
||||||
|
c->join_request = join_request;
|
||||||
|
|
||||||
|
c->need_save_to_database = true;
|
||||||
|
}
|
||||||
if (c->sign_messages != sign_messages || c->is_verified != is_verified) {
|
if (c->sign_messages != sign_messages || c->is_verified != is_verified) {
|
||||||
c->sign_messages = sign_messages;
|
c->sign_messages = sign_messages;
|
||||||
c->is_verified = is_verified;
|
c->is_verified = is_verified;
|
||||||
|
|
||||||
c->is_changed = true;
|
c->is_changed = true;
|
||||||
}
|
}
|
||||||
|
if (old_join_to_send != get_channel_join_to_send(c) || old_join_request != get_channel_join_request(c)) {
|
||||||
|
c->is_changed = true;
|
||||||
|
}
|
||||||
|
|
||||||
bool need_drop_participant_count = c->participant_count != 0;
|
bool need_drop_participant_count = c->participant_count != 0;
|
||||||
if (need_drop_participant_count) {
|
if (need_drop_participant_count) {
|
||||||
@ -16728,8 +16749,8 @@ tl_object_ptr<td_api::supergroup> ContactsManager::get_supergroup_object(Channel
|
|||||||
}
|
}
|
||||||
return td_api::make_object<td_api::supergroup>(
|
return td_api::make_object<td_api::supergroup>(
|
||||||
channel_id.get(), c->username, c->date, get_channel_status(c).get_chat_member_status_object(),
|
channel_id.get(), c->username, c->date, get_channel_status(c).get_chat_member_status_object(),
|
||||||
c->participant_count, c->has_linked_channel, c->has_location, c->sign_messages, c->join_to_send, c->join_request,
|
c->participant_count, c->has_linked_channel, c->has_location, c->sign_messages, get_channel_join_to_send(c),
|
||||||
c->is_slow_mode_enabled, !c->is_megagroup, c->is_gigagroup, c->is_verified,
|
get_channel_join_request(c), c->is_slow_mode_enabled, !c->is_megagroup, c->is_gigagroup, c->is_verified,
|
||||||
get_restriction_reason_description(c->restriction_reasons), c->is_scam, c->is_fake);
|
get_restriction_reason_description(c->restriction_reasons), c->is_scam, c->is_fake);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1222,6 +1222,8 @@ class ContactsManager final : public Actor {
|
|||||||
static bool get_channel_sign_messages(const Channel *c);
|
static bool get_channel_sign_messages(const Channel *c);
|
||||||
static bool get_channel_has_linked_channel(const Channel *c);
|
static bool get_channel_has_linked_channel(const Channel *c);
|
||||||
static bool get_channel_can_be_deleted(const Channel *c);
|
static bool get_channel_can_be_deleted(const Channel *c);
|
||||||
|
static bool get_channel_join_to_send(const Channel *c);
|
||||||
|
static bool get_channel_join_request(const Channel *c);
|
||||||
|
|
||||||
void set_my_id(UserId my_id);
|
void set_my_id(UserId my_id);
|
||||||
|
|
||||||
|
@ -4378,7 +4378,7 @@ class CliClient final : public Actor {
|
|||||||
get_args(args, supergroup_id, join_to_send_message);
|
get_args(args, supergroup_id, join_to_send_message);
|
||||||
send_request(td_api::make_object<td_api::toggleSupergroupJoinToSendMessages>(as_supergroup_id(supergroup_id),
|
send_request(td_api::make_object<td_api::toggleSupergroupJoinToSendMessages>(as_supergroup_id(supergroup_id),
|
||||||
join_to_send_message));
|
join_to_send_message));
|
||||||
} else if (op == "tsgjtsm") {
|
} else if (op == "tsgjbr") {
|
||||||
string supergroup_id;
|
string supergroup_id;
|
||||||
bool join_by_request;
|
bool join_by_request;
|
||||||
get_args(args, supergroup_id, join_by_request);
|
get_args(args, supergroup_id, join_by_request);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user