mirror of
https://github.com/tdlight-team/tdlight-telegram-bot-api.git
synced 2025-01-16 06:47:33 +01:00
add user status
This commit is contained in:
parent
edcb8529e6
commit
411f4b15c5
@ -411,6 +411,9 @@ class Client::JsonUser final : public Jsonable {
|
||||
if (user_info != nullptr && user_info->is_scam) {
|
||||
object("is_scam", td::JsonBool(user_info->is_scam));
|
||||
}
|
||||
if (user_info != nullptr) {
|
||||
json_store_user_status(object, user_info->status.get());
|
||||
}
|
||||
//end custom properties impl
|
||||
|
||||
if (is_bot && full_bot_info_) {
|
||||
@ -715,6 +718,8 @@ class Client::JsonChat final : public Jsonable {
|
||||
if (user_info->is_scam) {
|
||||
object("is_scam", td::JsonBool(user_info->is_scam));
|
||||
}
|
||||
|
||||
json_store_user_status(object, user_info->status.get());
|
||||
// end custom properties impl
|
||||
|
||||
if (is_full_) {
|
||||
@ -5269,6 +5274,12 @@ void Client::on_update(object_ptr<td_api::Object> result) {
|
||||
set_user_has_private_forwards(user_id, full_info->has_private_forwards_);
|
||||
break;
|
||||
}
|
||||
case td_api::updateUserStatus::ID: {
|
||||
auto update = move_object_as<td_api::updateUserStatus>(result);
|
||||
auto user_id = update->user_id_;
|
||||
set_user_status(user_id, std::move(update->status_));
|
||||
break;
|
||||
}
|
||||
case td_api::updateBasicGroup::ID: {
|
||||
auto update = move_object_as<td_api::updateBasicGroup>(result);
|
||||
auto *group_info = add_group_info(update->basic_group_->id_);
|
||||
@ -10195,6 +10206,7 @@ void Client::add_user(UserInfo *user_info, object_ptr<td_api::user> &&user) {
|
||||
// start custom properties
|
||||
user_info->is_verified = user->is_verified_;
|
||||
user_info->is_scam = user->is_scam_;
|
||||
user_info->status = std::move(user->status_);
|
||||
//end custom properties
|
||||
|
||||
user_info->have_access = user->have_access_;
|
||||
@ -10251,6 +10263,10 @@ void Client::set_user_has_private_forwards(int64 user_id, bool has_private_forwa
|
||||
add_user_info(user_id)->has_private_forwards = has_private_forwards;
|
||||
}
|
||||
|
||||
void Client::set_user_status(int64 user_id, object_ptr<td_api::UserStatus> &&status) {
|
||||
add_user_info(user_id)->status = std::move(status);
|
||||
}
|
||||
|
||||
void Client::add_group(GroupInfo *group_info, object_ptr<td_api::basicGroup> &&group) {
|
||||
group_info->member_count = group->member_count_;
|
||||
group_info->left = group->status_->get_id() == td_api::chatMemberStatusLeft::ID;
|
||||
@ -10528,6 +10544,30 @@ void Client::json_store_permissions(td::JsonObjectScope &object, const td_api::c
|
||||
object("can_pin_messages", td::JsonBool(permissions->can_pin_messages_));
|
||||
}
|
||||
|
||||
void Client::json_store_user_status(td::JsonObjectScope &object, const td_api::UserStatus *userStatus) {
|
||||
switch (userStatus->get_id()) {
|
||||
case td_api::userStatusEmpty::ID:
|
||||
object("user_status", nullptr);
|
||||
break;
|
||||
case td_api::userStatusLastMonth::ID:
|
||||
object("user_status", "month");
|
||||
break;
|
||||
case td_api::userStatusLastWeek::ID:
|
||||
object("user_status", "week");
|
||||
break;
|
||||
case td_api::userStatusOffline::ID:
|
||||
object("user_status", "offline");
|
||||
object("last_seen", static_cast<const td_api::userStatusOffline *>(userStatus)->was_online_);
|
||||
break;
|
||||
case td_api::userStatusOnline::ID:
|
||||
object("user_status", "online");
|
||||
break;
|
||||
case td_api::userStatusRecently::ID:
|
||||
object("user_status", "recently");
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
Client::Slice Client::get_update_type_name(UpdateType update_type) {
|
||||
switch (update_type) {
|
||||
case UpdateType::Message:
|
||||
|
@ -711,6 +711,7 @@ class Client final : public WebhookActor::Callback {
|
||||
// start custom properties
|
||||
bool is_verified = false;
|
||||
bool is_scam = false;
|
||||
object_ptr<td_api::UserStatus> status;
|
||||
// end custom properties
|
||||
|
||||
bool have_access = false;
|
||||
@ -723,6 +724,7 @@ class Client final : public WebhookActor::Callback {
|
||||
void set_user_photo(int64 user_id, object_ptr<td_api::chatPhoto> &&photo);
|
||||
void set_user_bio(int64 user_id, td::string &&bio);
|
||||
void set_user_has_private_forwards(int64 user_id, bool has_private_forwards);
|
||||
void set_user_status(int64 user_id, object_ptr<td_api::UserStatus> &&status);
|
||||
UserInfo *add_user_info(int64 user_id);
|
||||
const UserInfo *get_user_info(int64 user_id) const;
|
||||
|
||||
@ -870,6 +872,8 @@ class Client final : public WebhookActor::Callback {
|
||||
|
||||
static void json_store_permissions(td::JsonObjectScope &object, const td_api::chatPermissions *permissions);
|
||||
|
||||
static void json_store_user_status(td::JsonObjectScope &object, const td_api::UserStatus *userStatus);
|
||||
|
||||
void remove_replies_to_message(int64 chat_id, int64 reply_to_message_id, bool only_from_cache);
|
||||
void delete_message(int64 chat_id, int64 message_id, bool only_from_cache);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user