Support action bar report in reportChat.

GitOrigin-RevId: 2c85ca043c9615a27c1bdf46b7fd01ed98940699
This commit is contained in:
levlam 2019-10-11 04:17:46 +03:00
parent 378ed2c659
commit 7327b673de
3 changed files with 57 additions and 7 deletions

View File

@ -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;

View File

@ -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"));
} }

View File

@ -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;