Add subscription information to chatInviteLinkInfo.
This commit is contained in:
parent
7ed407ec14
commit
33492e0b01
@ -1241,12 +1241,14 @@ inviteLinkChatTypeChannel = InviteLinkChatType;
|
|||||||
//@param_description Chat description
|
//@param_description Chat description
|
||||||
//@member_count Number of members in the chat
|
//@member_count Number of members in the chat
|
||||||
//@member_user_ids User identifiers of some chat members that may be known to the current user
|
//@member_user_ids User identifiers of some chat members that may be known to the current user
|
||||||
|
//@subscription_pricing Information about subscription plan that must be paid by the user to use the link; may be null if the link doesn't require subscription
|
||||||
|
//@subscription_form_id Identifier of the payment form to use for subscription payment
|
||||||
//@creates_join_request True, if the link only creates join request
|
//@creates_join_request True, if the link only creates join request
|
||||||
//@is_public True, if the chat is a public supergroup or channel, i.e. it has a username or it is a location-based supergroup
|
//@is_public True, if the chat is a public supergroup or channel, i.e. it has a username or it is a location-based supergroup
|
||||||
//@is_verified True, if the chat is verified
|
//@is_verified True, if the chat is verified
|
||||||
//@is_scam True, if many users reported this chat as a scam
|
//@is_scam True, if many users reported this chat as a scam
|
||||||
//@is_fake True, if many users reported this chat as a fake account
|
//@is_fake True, if many users reported this chat as a fake account
|
||||||
chatInviteLinkInfo chat_id:int53 accessible_for:int32 type:InviteLinkChatType title:string photo:chatPhotoInfo accent_color_id:int32 description:string member_count:int32 member_user_ids:vector<int53> creates_join_request:Bool is_public:Bool is_verified:Bool is_scam:Bool is_fake:Bool = ChatInviteLinkInfo;
|
chatInviteLinkInfo chat_id:int53 accessible_for:int32 type:InviteLinkChatType title:string photo:chatPhotoInfo accent_color_id:int32 description:string member_count:int32 member_user_ids:vector<int53> subscription_pricing:starSubscriptionPricing subscription_form_id:int64 creates_join_request:Bool is_public:Bool is_verified:Bool is_scam:Bool is_fake:Bool = ChatInviteLinkInfo;
|
||||||
|
|
||||||
|
|
||||||
//@description Describes a user that sent a join request and waits for administrator approval @user_id User identifier @date Point in time (Unix timestamp) when the user sent the join request @bio A short bio of the user
|
//@description Describes a user that sent a join request and waits for administrator approval @user_id User identifier @date Point in time (Unix timestamp) when the user sent the join request @bio A short bio of the user
|
||||||
|
@ -730,6 +730,8 @@ void DialogInviteLinkManager::on_get_dialog_invite_link_info(
|
|||||||
invite_link_info->description = std::move(chat_invite->about_);
|
invite_link_info->description = std::move(chat_invite->about_);
|
||||||
invite_link_info->participant_count = chat_invite->participants_count_;
|
invite_link_info->participant_count = chat_invite->participants_count_;
|
||||||
invite_link_info->participant_user_ids = std::move(participant_user_ids);
|
invite_link_info->participant_user_ids = std::move(participant_user_ids);
|
||||||
|
invite_link_info->subscription_pricing = StarSubscriptionPricing(std::move(chat_invite->subscription_pricing_));
|
||||||
|
invite_link_info->subscription_form_id = chat_invite->subscription_form_id_;
|
||||||
invite_link_info->creates_join_request = std::move(chat_invite->request_needed_);
|
invite_link_info->creates_join_request = std::move(chat_invite->request_needed_);
|
||||||
invite_link_info->is_chat = !chat_invite->channel_;
|
invite_link_info->is_chat = !chat_invite->channel_;
|
||||||
invite_link_info->is_channel = chat_invite->channel_;
|
invite_link_info->is_channel = chat_invite->channel_;
|
||||||
@ -772,7 +774,7 @@ td_api::object_ptr<td_api::chatInviteLinkInfo> DialogInviteLinkManager::get_chat
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto invite_link_info = it->second.get();
|
const auto *invite_link_info = it->second.get();
|
||||||
CHECK(invite_link_info != nullptr);
|
CHECK(invite_link_info != nullptr);
|
||||||
|
|
||||||
DialogId dialog_id = invite_link_info->dialog_id;
|
DialogId dialog_id = invite_link_info->dialog_id;
|
||||||
@ -785,6 +787,8 @@ td_api::object_ptr<td_api::chatInviteLinkInfo> DialogInviteLinkManager::get_chat
|
|||||||
string description;
|
string description;
|
||||||
int32 participant_count = 0;
|
int32 participant_count = 0;
|
||||||
vector<int64> member_user_ids;
|
vector<int64> member_user_ids;
|
||||||
|
td_api::object_ptr<td_api::starSubscriptionPricing> subscription_pricing;
|
||||||
|
int64 subscription_form_id = 0;
|
||||||
bool creates_join_request = false;
|
bool creates_join_request = false;
|
||||||
bool is_public = false;
|
bool is_public = false;
|
||||||
bool is_member = false;
|
bool is_member = false;
|
||||||
@ -834,6 +838,10 @@ td_api::object_ptr<td_api::chatInviteLinkInfo> DialogInviteLinkManager::get_chat
|
|||||||
participant_count = invite_link_info->participant_count;
|
participant_count = invite_link_info->participant_count;
|
||||||
member_user_ids = td_->user_manager_->get_user_ids_object(invite_link_info->participant_user_ids,
|
member_user_ids = td_->user_manager_->get_user_ids_object(invite_link_info->participant_user_ids,
|
||||||
"get_chat_invite_link_info_object");
|
"get_chat_invite_link_info_object");
|
||||||
|
subscription_pricing = invite_link_info->subscription_pricing.get_star_subscription_pricing_object();
|
||||||
|
if (subscription_pricing != nullptr) {
|
||||||
|
subscription_form_id = invite_link_info->subscription_form_id;
|
||||||
|
}
|
||||||
creates_join_request = invite_link_info->creates_join_request;
|
creates_join_request = invite_link_info->creates_join_request;
|
||||||
is_public = invite_link_info->is_public;
|
is_public = invite_link_info->is_public;
|
||||||
is_verified = invite_link_info->is_verified;
|
is_verified = invite_link_info->is_verified;
|
||||||
@ -861,7 +869,8 @@ td_api::object_ptr<td_api::chatInviteLinkInfo> DialogInviteLinkManager::get_chat
|
|||||||
return td_api::make_object<td_api::chatInviteLinkInfo>(
|
return td_api::make_object<td_api::chatInviteLinkInfo>(
|
||||||
td_->dialog_manager_->get_chat_id_object(dialog_id, "chatInviteLinkInfo"), accessible_for, std::move(chat_type),
|
td_->dialog_manager_->get_chat_id_object(dialog_id, "chatInviteLinkInfo"), accessible_for, std::move(chat_type),
|
||||||
title, get_chat_photo_info_object(td_->file_manager_.get(), photo), accent_color_id_object, description,
|
title, get_chat_photo_info_object(td_->file_manager_.get(), photo), accent_color_id_object, description,
|
||||||
participant_count, std::move(member_user_ids), creates_join_request, is_public, is_verified, is_scam, is_fake);
|
participant_count, std::move(member_user_ids), std::move(subscription_pricing), subscription_form_id,
|
||||||
|
creates_join_request, is_public, is_verified, is_scam, is_fake);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DialogInviteLinkManager::add_dialog_access_by_invite_link(DialogId dialog_id, const string &invite_link,
|
void DialogInviteLinkManager::add_dialog_access_by_invite_link(DialogId dialog_id, const string &invite_link,
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include "td/telegram/AccentColorId.h"
|
#include "td/telegram/AccentColorId.h"
|
||||||
#include "td/telegram/DialogId.h"
|
#include "td/telegram/DialogId.h"
|
||||||
#include "td/telegram/Photo.h"
|
#include "td/telegram/Photo.h"
|
||||||
|
#include "td/telegram/StarSubscriptionPricing.h"
|
||||||
#include "td/telegram/td_api.h"
|
#include "td/telegram/td_api.h"
|
||||||
#include "td/telegram/telegram_api.h"
|
#include "td/telegram/telegram_api.h"
|
||||||
#include "td/telegram/UserId.h"
|
#include "td/telegram/UserId.h"
|
||||||
@ -113,6 +114,8 @@ class DialogInviteLinkManager final : public Actor {
|
|||||||
int32 participant_count = 0;
|
int32 participant_count = 0;
|
||||||
vector<UserId> participant_user_ids;
|
vector<UserId> participant_user_ids;
|
||||||
string description;
|
string description;
|
||||||
|
StarSubscriptionPricing subscription_pricing;
|
||||||
|
int64 subscription_form_id;
|
||||||
bool creates_join_request = false;
|
bool creates_join_request = false;
|
||||||
bool is_chat = false;
|
bool is_chat = false;
|
||||||
bool is_channel = false;
|
bool is_channel = false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user