Support action bar report in reportChat.
GitOrigin-RevId: 2c85ca043c9615a27c1bdf46b7fd01ed98940699
This commit is contained in:
parent
378ed2c659
commit
7327b673de
@ -3901,7 +3901,7 @@ deleteAccount reason:string = Ok;
|
|||||||
//@description Removes a chat action bar without any other action @chat_id Chat identifier
|
//@description Removes a chat action bar without any other action @chat_id Chat identifier
|
||||||
removeChatActionBar chat_id:int53 = Ok;
|
removeChatActionBar chat_id:int53 = Ok;
|
||||||
|
|
||||||
//@description Reports a chat to the Telegram moderators. Supported only for supergroups, channels, or private chats with bots, since other chats can't be checked by moderators @chat_id Chat identifier @reason The reason for reporting the chat @message_ids Identifiers of reported messages, if any
|
//@description Reports a chat to the Telegram moderators. Supported only for supergroups, channels, or private chats with bots, since other chats can't be checked by moderators, or when the report is done from the chat action bar @chat_id Chat identifier @reason The reason for reporting the chat @message_ids Identifiers of reported messages, if any
|
||||||
reportChat chat_id:int53 reason:ChatReportReason message_ids:vector<int53> = Ok;
|
reportChat chat_id:int53 reason:ChatReportReason message_ids:vector<int53> = Ok;
|
||||||
|
|
||||||
|
|
||||||
|
@ -6454,6 +6454,21 @@ void MessagesManager::repair_dialog_action_bar(DialogId dialog_id) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MessagesManager::hide_dialog_action_bar(Dialog *d) {
|
||||||
|
CHECK(d->dialog_id.get_type() != DialogType::SecretChat);
|
||||||
|
if (!d->can_report_spam && !d->can_add_contact && !d->can_block_user && !d->can_share_phone_number &&
|
||||||
|
!d->can_report_location) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
d->can_report_spam = false;
|
||||||
|
d->can_add_contact = false;
|
||||||
|
d->can_block_user = false;
|
||||||
|
d->can_share_phone_number = false;
|
||||||
|
d->can_report_location = false;
|
||||||
|
send_update_chat_action_bar(d);
|
||||||
|
}
|
||||||
|
|
||||||
void MessagesManager::remove_dialog_action_bar(DialogId dialog_id, Promise<Unit> &&promise) {
|
void MessagesManager::remove_dialog_action_bar(DialogId dialog_id, Promise<Unit> &&promise) {
|
||||||
Dialog *d = get_dialog_force(dialog_id);
|
Dialog *d = get_dialog_force(dialog_id);
|
||||||
if (d == nullptr) {
|
if (d == nullptr) {
|
||||||
@ -6464,6 +6479,17 @@ void MessagesManager::remove_dialog_action_bar(DialogId dialog_id, Promise<Unit>
|
|||||||
return promise.set_error(Status::Error(3, "Can't access the chat"));
|
return promise.set_error(Status::Error(3, "Can't access the chat"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (dialog_id.get_type() == DialogType::SecretChat) {
|
||||||
|
dialog_id = DialogId(td_->contacts_manager_->get_secret_chat_user_id(dialog_id.get_secret_chat_id()));
|
||||||
|
d = get_dialog_force(dialog_id);
|
||||||
|
if (d == nullptr) {
|
||||||
|
return promise.set_error(Status::Error(3, "Chat with the user not found"));
|
||||||
|
}
|
||||||
|
if (!have_input_peer(dialog_id, AccessRights::Read)) {
|
||||||
|
return promise.set_error(Status::Error(3, "Can't access the chat"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!d->know_can_report_spam) {
|
if (!d->know_can_report_spam) {
|
||||||
return promise.set_error(Status::Error(3, "Can't update chat action bar"));
|
return promise.set_error(Status::Error(3, "Can't update chat action bar"));
|
||||||
}
|
}
|
||||||
@ -6473,12 +6499,7 @@ void MessagesManager::remove_dialog_action_bar(DialogId dialog_id, Promise<Unit>
|
|||||||
return promise.set_value(Unit());
|
return promise.set_value(Unit());
|
||||||
}
|
}
|
||||||
|
|
||||||
d->can_report_spam = false;
|
hide_dialog_action_bar(d);
|
||||||
d->can_add_contact = false;
|
|
||||||
d->can_block_user = false;
|
|
||||||
d->can_share_phone_number = false;
|
|
||||||
d->can_report_location = false;
|
|
||||||
on_dialog_updated(dialog_id, "remove_dialog_action_bar");
|
|
||||||
|
|
||||||
change_dialog_report_spam_state_on_server(dialog_id, false, 0, std::move(promise));
|
change_dialog_report_spam_state_on_server(dialog_id, false, 0, std::move(promise));
|
||||||
}
|
}
|
||||||
@ -6568,7 +6589,34 @@ void MessagesManager::report_dialog(DialogId dialog_id, const tl_object_ptr<td_a
|
|||||||
return promise.set_error(Status::Error(3, "Reason shouldn't be empty"));
|
return promise.set_error(Status::Error(3, "Reason shouldn't be empty"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Dialog *user_d = d;
|
||||||
|
bool is_dialog_spam_report = false;
|
||||||
|
bool can_report_spam = d->can_report_spam;
|
||||||
|
if (reason->get_id() == td_api::chatReportReasonSpam::ID && message_ids.empty()) {
|
||||||
|
if (dialog_id.get_type() == DialogType::SecretChat) {
|
||||||
|
auto user_dialog_id = DialogId(td_->contacts_manager_->get_secret_chat_user_id(dialog_id.get_secret_chat_id()));
|
||||||
|
user_d = get_dialog_force(user_dialog_id);
|
||||||
|
if (user_d == nullptr) {
|
||||||
|
return promise.set_error(Status::Error(3, "Chat with the user not found"));
|
||||||
|
}
|
||||||
|
|
||||||
|
is_dialog_spam_report = user_d->know_can_report_spam;
|
||||||
|
can_report_spam = user_d->can_report_spam;
|
||||||
|
} else {
|
||||||
|
is_dialog_spam_report = d->know_can_report_spam;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_dialog_spam_report && can_report_spam) {
|
||||||
|
hide_dialog_action_bar(user_d);
|
||||||
|
return change_dialog_report_spam_state_on_server(dialog_id, true, 0, std::move(promise));
|
||||||
|
}
|
||||||
|
|
||||||
if (!can_report_dialog(dialog_id)) {
|
if (!can_report_dialog(dialog_id)) {
|
||||||
|
if (is_dialog_spam_report) {
|
||||||
|
return promise.set_value(Unit());
|
||||||
|
}
|
||||||
|
|
||||||
return promise.set_error(Status::Error(3, "Chat can't be reported"));
|
return promise.set_error(Status::Error(3, "Chat can't be reported"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1809,6 +1809,8 @@ class MessagesManager : public Actor {
|
|||||||
|
|
||||||
void send_update_chat_action_bar(const Dialog *d);
|
void send_update_chat_action_bar(const Dialog *d);
|
||||||
|
|
||||||
|
void hide_dialog_action_bar(Dialog *d);
|
||||||
|
|
||||||
tl_object_ptr<td_api::message> get_message_object(DialogId dialog_id, const Message *m,
|
tl_object_ptr<td_api::message> get_message_object(DialogId dialog_id, const Message *m,
|
||||||
bool for_event_log = false) const;
|
bool for_event_log = false) const;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user