Update TDLib to 1.8.41.

This commit is contained in:
levlam 2024-12-01 00:34:48 +03:00
parent 53e15345b0
commit 26f945f2b0
3 changed files with 72 additions and 87 deletions

2
td

@ -1 +1 @@
Subproject commit 66c4751742d2ca810033b289fc57ab4f83cfc833 Subproject commit 7648b99d81d36d44bae3ca6c514a816a2fe8cfd1

View File

@ -4230,104 +4230,87 @@ class Client::JsonRevenueWithdrawalState final : public td::Jsonable {
const td_api::RevenueWithdrawalState *state_; const td_api::RevenueWithdrawalState *state_;
}; };
class Client::JsonStarTransactionPartner final : public td::Jsonable { class Client::JsonStarTransactionType final : public td::Jsonable {
public: public:
JsonStarTransactionPartner(const td_api::StarTransactionPartner *source, const Client *client) JsonStarTransactionType(const td_api::StarTransactionType *type, const Client *client)
: source_(source), client_(client) { : type_(type), client_(client) {
} }
void store(td::JsonValueScope *scope) const { void store(td::JsonValueScope *scope) const {
auto object = scope->enter_object(); auto object = scope->enter_object();
switch (source_->get_id()) { switch (type_->get_id()) {
case td_api::starTransactionPartnerFragment::ID: { case td_api::starTransactionTypeFragmentDeposit::ID:
auto source_fragment = static_cast<const td_api::starTransactionPartnerFragment *>(source_);
object("type", "fragment"); object("type", "fragment");
if (source_fragment->withdrawal_state_ != nullptr) { break;
object("withdrawal_state", JsonRevenueWithdrawalState(source_fragment->withdrawal_state_.get())); case td_api::starTransactionTypeFragmentWithdrawal::ID: {
auto type = static_cast<const td_api::starTransactionTypeFragmentWithdrawal *>(type_);
object("type", "fragment");
if (type->withdrawal_state_ != nullptr) {
object("withdrawal_state", JsonRevenueWithdrawalState(type->withdrawal_state_.get()));
} }
break; break;
} }
case td_api::starTransactionPartnerBot::ID: { case td_api::starTransactionTypeBotPaidMediaSale::ID: {
auto source_user = static_cast<const td_api::starTransactionPartnerBot *>(source_); auto type = static_cast<const td_api::starTransactionTypeBotPaidMediaSale *>(type_);
object("type", "user"); object("type", "user");
object("user", JsonUser(source_user->user_id_, client_)); object("user", JsonUser(type->user_id_, client_));
CHECK(source_user->purpose_ != nullptr); object("paid_media", td::json_array(type->media_, [client = client_](auto &media) {
switch (source_user->purpose_->get_id()) {
case td_api::botTransactionPurposeInvoicePayment::ID: {
auto purpose =
static_cast<const td_api::botTransactionPurposeInvoicePayment *>(source_user->purpose_.get());
if (!purpose->invoice_payload_.empty()) {
if (!td::check_utf8(purpose->invoice_payload_)) {
LOG(WARNING) << "Receive non-UTF-8 invoice payload";
object("invoice_payload", td::JsonRawString(purpose->invoice_payload_));
} else {
object("invoice_payload", purpose->invoice_payload_);
}
}
break;
}
case td_api::botTransactionPurposePaidMedia::ID: {
auto purpose = static_cast<const td_api::botTransactionPurposePaidMedia *>(source_user->purpose_.get());
object("paid_media", td::json_array(purpose->media_, [client = client_](auto &media) {
return JsonPaidMedia(media.get(), client); return JsonPaidMedia(media.get(), client);
})); }));
if (!purpose->payload_.empty()) { if (!type->payload_.empty()) {
object("paid_media_payload", purpose->payload_); object("paid_media_payload", type->payload_);
} }
break; break;
} }
case td_api::botTransactionPurposeSubscription::ID: { case td_api::starTransactionTypeBotInvoiceSale::ID: {
auto purpose = static_cast<const td_api::botTransactionPurposeSubscription *>(source_user->purpose_.get()); auto type = static_cast<const td_api::starTransactionTypeBotInvoiceSale *>(type_);
if (!purpose->invoice_payload_.empty()) { object("type", "user");
if (!td::check_utf8(purpose->invoice_payload_)) { object("user", JsonUser(type->user_id_, client_));
if (!type->invoice_payload_.empty()) {
if (!td::check_utf8(type->invoice_payload_)) {
LOG(WARNING) << "Receive non-UTF-8 invoice payload"; LOG(WARNING) << "Receive non-UTF-8 invoice payload";
object("invoice_payload", td::JsonRawString(purpose->invoice_payload_)); object("invoice_payload", td::JsonRawString(type->invoice_payload_));
} else { } else {
object("invoice_payload", purpose->invoice_payload_); object("invoice_payload", type->invoice_payload_);
} }
} }
if (purpose->period_ > 0) {
object("subscription_period", purpose->period_);
}
break; break;
} }
default: case td_api::starTransactionTypeBotSubscriptionSale::ID: {
UNREACHABLE(); auto type = static_cast<const td_api::starTransactionTypeBotSubscriptionSale *>(type_);
object("type", "user");
object("user", JsonUser(type->user_id_, client_));
if (!type->invoice_payload_.empty()) {
if (!td::check_utf8(type->invoice_payload_)) {
LOG(WARNING) << "Receive non-UTF-8 invoice payload";
object("invoice_payload", td::JsonRawString(type->invoice_payload_));
} else {
object("invoice_payload", type->invoice_payload_);
}
}
if (type->subscription_period_ > 0) {
object("subscription_period", type->subscription_period_);
} }
break; break;
} }
case td_api::starTransactionPartnerTelegramAds::ID: case td_api::starTransactionTypeTelegramAdsWithdrawal::ID:
object("type", "telegram_ads"); object("type", "telegram_ads");
break; break;
case td_api::starTransactionPartnerTelegramApi::ID: { case td_api::starTransactionTypeTelegramApiUsage::ID: {
auto source = static_cast<const td_api::starTransactionPartnerTelegramApi *>(source_); auto type = static_cast<const td_api::starTransactionTypeTelegramApiUsage *>(type_);
object("type", "telegram_api"); object("type", "telegram_api");
object("request_count", source->request_count_); object("request_count", type->request_count_);
break; break;
} }
case td_api::starTransactionPartnerUser::ID: { case td_api::starTransactionTypeGiftPurchase::ID: {
auto source = static_cast<const td_api::starTransactionPartnerUser *>(source_); auto type = static_cast<const td_api::starTransactionTypeGiftPurchase *>(type_);
if (source->purpose_->get_id() == td_api::userTransactionPurposeGiftSend::ID) {
object("type", "user"); object("type", "user");
object("user", JsonUser(source->user_id_, client_)); object("user", JsonUser(type->user_id_, client_));
object( object("gift", JsonGift(type->gift_.get(), client_));
"gift",
JsonGift(static_cast<const td_api::userTransactionPurposeGiftSend *>(source->purpose_.get())->gift_.get(),
client_));
} else {
LOG(ERROR) << "Receive " << to_string(*source_);
object("type", "other");
}
break; break;
} }
case td_api::starTransactionPartnerTelegram::ID: case td_api::starTransactionTypeAffiliateProgramCommission::ID:
case td_api::starTransactionPartnerAppStore::ID: case td_api::starTransactionTypeUnsupported::ID:
case td_api::starTransactionPartnerGooglePlay::ID:
case td_api::starTransactionPartnerBusiness::ID:
case td_api::starTransactionPartnerChat::ID:
LOG(ERROR) << "Receive " << to_string(*source_);
object("type", "other");
break;
case td_api::starTransactionPartnerUnsupported::ID:
object("type", "other"); object("type", "other");
break; break;
default: default:
@ -4336,7 +4319,7 @@ class Client::JsonStarTransactionPartner final : public td::Jsonable {
} }
private: private:
const td_api::StarTransactionPartner *source_; const td_api::StarTransactionType *type_;
const Client *client_; const Client *client_;
}; };
@ -4349,12 +4332,14 @@ class Client::JsonStarTransaction final : public td::Jsonable {
auto object = scope->enter_object(); auto object = scope->enter_object();
object("id", transaction_->id_); object("id", transaction_->id_);
object("date", transaction_->date_); object("date", transaction_->date_);
if (transaction_->star_count_ > 0) { auto star_count = transaction_->star_amount_->star_count_;
object("amount", transaction_->star_count_); auto nanostar_count = transaction_->star_amount_->nanostar_count_;
object("source", JsonStarTransactionPartner(transaction_->partner_.get(), client_)); if (star_count > 0 || nanostar_count > 0) {
object("amount", star_count);
object("source", JsonStarTransactionType(transaction_->type_.get(), client_));
} else { } else {
object("amount", -transaction_->star_count_); object("amount", -star_count);
object("receiver", JsonStarTransactionPartner(transaction_->partner_.get(), client_)); object("receiver", JsonStarTransactionType(transaction_->type_.get(), client_));
} }
} }

View File

@ -204,7 +204,7 @@ class Client final : public WebhookActor::Callback {
class JsonGiveawayCompleted; class JsonGiveawayCompleted;
class JsonChatBoostAdded; class JsonChatBoostAdded;
class JsonRevenueWithdrawalState; class JsonRevenueWithdrawalState;
class JsonStarTransactionPartner; class JsonStarTransactionType;
class JsonStarTransaction; class JsonStarTransaction;
class JsonStarTransactions; class JsonStarTransactions;
class JsonUpdateTypes; class JsonUpdateTypes;