Add userFullInfo.business_location.
This commit is contained in:
parent
d5af2f6ced
commit
9c51809490
@ -847,8 +847,9 @@ botInfo short_description:string description:string photo:photo animation:animat
|
||||
//@bio A short user bio; may be null for bots
|
||||
//@premium_gift_options The list of available options for gifting Telegram Premium to the user
|
||||
//@group_in_common_count Number of group chats where both the other user and the current user are a member; 0 for the current user
|
||||
//@business_location Location of the business for Telegram Business users; may be null if none
|
||||
//@bot_info For bots, information about the bot; may be null if the user isn't a bot
|
||||
userFullInfo personal_photo:chatPhoto photo:chatPhoto public_photo:chatPhoto block_list:BlockList can_be_called:Bool supports_video_calls:Bool has_private_calls:Bool has_private_forwards:Bool has_restricted_voice_and_video_note_messages:Bool has_pinned_stories:Bool need_phone_number_privacy_exception:Bool set_chat_background:Bool bio:formattedText premium_gift_options:vector<premiumPaymentOption> group_in_common_count:int32 bot_info:botInfo = UserFullInfo;
|
||||
userFullInfo personal_photo:chatPhoto photo:chatPhoto public_photo:chatPhoto block_list:BlockList can_be_called:Bool supports_video_calls:Bool has_private_calls:Bool has_private_forwards:Bool has_restricted_voice_and_video_note_messages:Bool has_pinned_stories:Bool need_phone_number_privacy_exception:Bool set_chat_background:Bool bio:formattedText premium_gift_options:vector<premiumPaymentOption> group_in_common_count:int32 business_location:chatLocation bot_info:botInfo = UserFullInfo;
|
||||
|
||||
//@description Represents a list of users @total_count Approximate total number of users found @user_ids A list of user identifiers
|
||||
users total_count:int32 user_ids:vector<int53> = Users;
|
||||
|
@ -3428,6 +3428,7 @@ void ContactsManager::UserFull::store(StorerT &storer) const {
|
||||
bool has_premium_gift_options = !premium_gift_options.empty();
|
||||
bool has_personal_photo = !personal_photo.is_empty();
|
||||
bool has_fallback_photo = !fallback_photo.is_empty();
|
||||
bool has_location = !location.empty();
|
||||
BEGIN_STORE_FLAGS();
|
||||
STORE_FLAG(has_about);
|
||||
STORE_FLAG(is_blocked);
|
||||
@ -3454,6 +3455,7 @@ void ContactsManager::UserFull::store(StorerT &storer) const {
|
||||
STORE_FLAG(wallpaper_overridden);
|
||||
STORE_FLAG(read_dates_private);
|
||||
STORE_FLAG(contact_require_premium);
|
||||
STORE_FLAG(has_location);
|
||||
END_STORE_FLAGS();
|
||||
if (has_about) {
|
||||
store(about, storer);
|
||||
@ -3497,6 +3499,9 @@ void ContactsManager::UserFull::store(StorerT &storer) const {
|
||||
if (has_fallback_photo) {
|
||||
store(fallback_photo, storer);
|
||||
}
|
||||
if (has_location) {
|
||||
store(location, storer);
|
||||
}
|
||||
}
|
||||
|
||||
template <class ParserT>
|
||||
@ -3515,6 +3520,7 @@ void ContactsManager::UserFull::parse(ParserT &parser) {
|
||||
bool has_premium_gift_options;
|
||||
bool has_personal_photo;
|
||||
bool has_fallback_photo;
|
||||
bool has_location;
|
||||
BEGIN_PARSE_FLAGS();
|
||||
PARSE_FLAG(has_about);
|
||||
PARSE_FLAG(is_blocked);
|
||||
@ -3541,6 +3547,7 @@ void ContactsManager::UserFull::parse(ParserT &parser) {
|
||||
PARSE_FLAG(wallpaper_overridden);
|
||||
PARSE_FLAG(read_dates_private);
|
||||
PARSE_FLAG(contact_require_premium);
|
||||
PARSE_FLAG(has_location);
|
||||
END_PARSE_FLAGS();
|
||||
if (has_about) {
|
||||
parse(about, parser);
|
||||
@ -3584,6 +3591,9 @@ void ContactsManager::UserFull::parse(ParserT &parser) {
|
||||
if (has_fallback_photo) {
|
||||
parse(fallback_photo, parser);
|
||||
}
|
||||
if (has_location) {
|
||||
parse(location, parser);
|
||||
}
|
||||
}
|
||||
|
||||
template <class StorerT>
|
||||
@ -11277,6 +11287,7 @@ void ContactsManager::on_get_user_full(tl_object_ptr<telegram_api::userFull> &&u
|
||||
|
||||
on_update_user_full_is_blocked(user_full, user_id, user->blocked_, user->blocked_my_stories_from_);
|
||||
on_update_user_full_common_chat_count(user_full, user_id, user->common_chats_count_);
|
||||
on_update_user_full_location(user_full, user_id, DialogLocation(td_, std::move(user->business_location_)));
|
||||
on_update_user_full_need_phone_number_privacy_exception(user_full, user_id,
|
||||
user->settings_->need_contacts_exception_);
|
||||
on_update_user_full_wallpaper_overridden(user_full, user_id, user->wallpaper_overridden_);
|
||||
@ -12652,6 +12663,29 @@ void ContactsManager::on_update_user_full_common_chat_count(UserFull *user_full,
|
||||
}
|
||||
}
|
||||
|
||||
void ContactsManager::on_update_user_location(UserId user_id, DialogLocation &&location) {
|
||||
LOG(INFO) << "Receive " << location << " for " << user_id;
|
||||
if (!user_id.is_valid()) {
|
||||
LOG(ERROR) << "Receive invalid " << user_id;
|
||||
return;
|
||||
}
|
||||
|
||||
UserFull *user_full = get_user_full_force(user_id, "on_update_user_location");
|
||||
if (user_full == nullptr) {
|
||||
return;
|
||||
}
|
||||
on_update_user_full_location(user_full, user_id, std::move(location));
|
||||
update_user_full(user_full, user_id, "on_update_user_location");
|
||||
}
|
||||
|
||||
void ContactsManager::on_update_user_full_location(UserFull *user_full, UserId user_id, DialogLocation &&location) {
|
||||
CHECK(user_full != nullptr);
|
||||
if (user_full->location != location) {
|
||||
user_full->location = std::move(location);
|
||||
user_full->is_changed = true;
|
||||
}
|
||||
}
|
||||
|
||||
void ContactsManager::on_update_user_full_commands(UserFull *user_full, UserId user_id,
|
||||
vector<tl_object_ptr<telegram_api::botCommand>> &&bot_commands) {
|
||||
CHECK(user_full != nullptr);
|
||||
@ -13038,6 +13072,7 @@ void ContactsManager::drop_user_full(UserId user_id) {
|
||||
user_full->menu_button = nullptr;
|
||||
user_full->commands.clear();
|
||||
user_full->common_chat_count = 0;
|
||||
user_full->location = {};
|
||||
user_full->private_forward_name.clear();
|
||||
user_full->group_administrator_rights = {};
|
||||
user_full->broadcast_administrator_rights = {};
|
||||
@ -17010,7 +17045,7 @@ tl_object_ptr<td_api::userFullInfo> ContactsManager::get_user_full_info_object(U
|
||||
!user_full->private_forward_name.empty(), voice_messages_forbidden, user_full->has_pinned_stories,
|
||||
user_full->need_phone_number_privacy_exception, user_full->wallpaper_overridden, std::move(bio_object),
|
||||
get_premium_payment_options_object(user_full->premium_gift_options), user_full->common_chat_count,
|
||||
std::move(bot_info));
|
||||
user_full->location.get_chat_location_object(), std::move(bot_info));
|
||||
}
|
||||
|
||||
td_api::object_ptr<td_api::updateBasicGroup> ContactsManager::get_update_basic_group_object(ChatId chat_id,
|
||||
|
@ -250,6 +250,7 @@ class ContactsManager final : public Actor {
|
||||
void on_update_user_is_blocked(UserId user_id, bool is_blocked, bool is_blocked_for_stories);
|
||||
void on_update_user_has_pinned_stories(UserId user_id, bool has_pinned_stories);
|
||||
void on_update_user_common_chat_count(UserId user_id, int32 common_chat_count);
|
||||
void on_update_user_location(UserId user_id, DialogLocation &&location);
|
||||
void on_update_user_need_phone_number_privacy_exception(UserId user_id, bool need_phone_number_privacy_exception);
|
||||
void on_update_user_wallpaper_overridden(UserId user_id, bool wallpaper_overridden);
|
||||
|
||||
@ -824,6 +825,8 @@ class ContactsManager final : public Actor {
|
||||
|
||||
int32 common_chat_count = 0;
|
||||
|
||||
DialogLocation location;
|
||||
|
||||
bool is_blocked = false;
|
||||
bool is_blocked_for_stories = false;
|
||||
bool can_be_called = false;
|
||||
@ -1429,6 +1432,7 @@ class ContactsManager final : public Actor {
|
||||
static void on_update_user_full_is_blocked(UserFull *user_full, UserId user_id, bool is_blocked,
|
||||
bool is_blocked_for_stories);
|
||||
static void on_update_user_full_common_chat_count(UserFull *user_full, UserId user_id, int32 common_chat_count);
|
||||
static void on_update_user_full_location(UserFull *user_full, UserId user_id, DialogLocation &&location);
|
||||
static void on_update_user_full_commands(UserFull *user_full, UserId user_id,
|
||||
vector<tl_object_ptr<telegram_api::botCommand>> &&bot_commands);
|
||||
static void on_update_user_full_menu_button(UserFull *user_full, UserId user_id,
|
||||
|
@ -18,6 +18,13 @@ DialogLocation::DialogLocation(Td *td, telegram_api::object_ptr<telegram_api::Ch
|
||||
}
|
||||
}
|
||||
|
||||
DialogLocation::DialogLocation(Td *td, telegram_api::object_ptr<telegram_api::businessLocation> &&business_location) {
|
||||
if (business_location != nullptr) {
|
||||
location_ = Location(td, business_location->geo_point_);
|
||||
address_ = std::move(business_location->address_);
|
||||
}
|
||||
}
|
||||
|
||||
DialogLocation::DialogLocation(td_api::object_ptr<td_api::chatLocation> &&chat_location) {
|
||||
if (chat_location != nullptr) {
|
||||
location_ = Location(chat_location->location_);
|
||||
|
@ -32,6 +32,8 @@ class DialogLocation {
|
||||
|
||||
DialogLocation(Td *td, telegram_api::object_ptr<telegram_api::ChannelLocation> &&channel_location_ptr);
|
||||
|
||||
DialogLocation(Td *td, telegram_api::object_ptr<telegram_api::businessLocation> &&business_location);
|
||||
|
||||
explicit DialogLocation(td_api::object_ptr<td_api::chatLocation> &&chat_location);
|
||||
|
||||
bool empty() const;
|
||||
|
Loading…
x
Reference in New Issue
Block a user