Skip to content

Commit

Permalink
Merge #292: Televerse v1.25.0
Browse files Browse the repository at this point in the history
Context updates with Bot API 7.10
  • Loading branch information
HeySreelal authored Sep 7, 2024
2 parents 779e838 + 4c8c260 commit 7a8d987
Show file tree
Hide file tree
Showing 18 changed files with 192 additions and 16 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
# 1.25.0

- 🤖 Bot API 7.10
- Added `Bot.onPaidMediaPurchase` for listening to [PaidMediaPurchased](https://core.telegram.org/bots/api#paidmediapurchased) updates.
- Added much more helper methods on `Context`

# 1.24.0

- 🤖 Bot API 7.9
Expand Down
15 changes: 7 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,17 +3,16 @@

[![Pub Version](https://img.shields.io/pub/v/televerse?color=blue&logo=blue)](https://pub.dev/packages/televerse)
![GitHub](https://img.shields.io/github/license/xooniverse/televerse?color=green)
![](https://shields.io/badge/Latest-Bot%20API%207.9-blue)
![](https://shields.io/badge/Latest-Bot%20API%207.10-blue)

<a href="https://telegram.me/TeleverseDart">
<a href="https://telegram.me/TeleverseDart">
<img src="https://img.shields.io/badge/Telegram%2F@TeleverseDart-2CA5E0?style=for-the-badge&logo=telegram&logoColor=white"/>
</a>

</div>

---

🤖 `Bot API version: Bot API 7.9 (August 14, 2024)`
🤖 `Bot API version: Bot API 7.10 (September 6, 2024)`

Televerse is a powerful, easy-to-use, and highly customizable Telegram bot
framework built with Dart programming language. It provides a complete and
Expand All @@ -23,13 +22,13 @@ public interface, making it easy for developers to write strictly typed code.

## 🔥 What's latest?

### 🤖 Bot API 7.9
### 🤖 Bot API 7.10

(🗓️ August 14, 2024)
(🗓️ September 6, 2024)

In a nutshell, this update brigngs support for channel subscription, and support for Paid Media across all chats.
In a nutshell, this update brigngs support for Telegram Star giveaway, new Update type for paid media purchases.

Checkout [changelog](https://core.telegram.org/bots/api-changelog#august-14-2024) for more
Checkout [changelog](https://core.telegram.org/bots/api-changelog#september-6-2024) for more
details! 🚀

### 🎉 Support for Custom Contexts!
Expand Down
2 changes: 1 addition & 1 deletion lib/src/telegram/models/birthdate.dart
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,6 @@ class Birthdate {
'day': day,
'month': month,
'year': year,
};
}..removeWhere(_nullFilter);
}
}
6 changes: 6 additions & 0 deletions lib/src/telegram/models/chat_boost_source_giveaway.dart
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,15 @@ class ChatBoostSourceGiveaway implements ChatBoostSource {
/// Optional. True, if the giveaway was completed, but there was no user to win the prize
final bool? isUnclaimed;

/// Optional. The number of Telegram Stars to be split between giveaway winners; for Telegram Star giveaways only
final int? prizeStarCount;

/// Creates a source of a chat boost.
const ChatBoostSourceGiveaway({
this.user,
this.isUnclaimed,
this.giveawayMessageId = 0,
this.prizeStarCount,
});

/// Converts the `ChatBoostSourceGiveaway` object to a JSON object.
Expand All @@ -30,6 +34,7 @@ class ChatBoostSourceGiveaway implements ChatBoostSource {
'user': user?.toJson(),
'is_unclaimed': isUnclaimed,
'giveaway_message_id': giveawayMessageId,
'prize_star_count': prizeStarCount,
}..removeWhere(_nullFilter);
}

Expand All @@ -39,6 +44,7 @@ class ChatBoostSourceGiveaway implements ChatBoostSource {
user: User.fromJson(json['user']),
isUnclaimed: json['is_unclaimed'],
giveawayMessageId: json['giveaway_message_id'],
prizeStarCount: json['prize_star_count'],
);
}
}
6 changes: 6 additions & 0 deletions lib/src/telegram/models/giveaway.dart
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,9 @@ class Giveaway {
/// The number of months the Telegram Premium subscription won from the giveaway will be active for
final int? premiumSubscriptionMonthCount;

/// Optional. The number of Telegram Stars to be split between giveaway winners; for Telegram Star giveaways only
final int? prizeStarCount;

/// Constructor
const Giveaway({
required this.chats,
Expand All @@ -36,6 +39,7 @@ class Giveaway {
this.prizeDescription,
this.countryCodes,
this.premiumSubscriptionMonthCount,
this.prizeStarCount,
});

/// Constructor from JSON data
Expand All @@ -50,6 +54,7 @@ class Giveaway {
prizeDescription: json['prize_description'],
countryCodes: json['country_codes']?.cast<String>(),
premiumSubscriptionMonthCount: json['premium_subscription_month_count'],
prizeStarCount: json['prize_star_count'],
);
}

Expand All @@ -64,6 +69,7 @@ class Giveaway {
'prize_description': prizeDescription,
'country_codes': countryCodes,
'premium_subscription_month_count': premiumSubscriptionMonthCount,
'prize_star_count': prizeStarCount,
}..removeWhere(_nullFilter);
}
}
6 changes: 6 additions & 0 deletions lib/src/telegram/models/giveaway_completed.dart
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,15 @@ class GiveawayCompleted {
/// Message with the giveaway that was completed, if it wasn't deleted
final Message? giveawayMessage;

/// Optional. True, if the giveaway is a Telegram Star giveaway. Otherwise, currently, the giveaway is a Telegram Premium giveaway.
final bool? isStarGiveaway;

/// Constructor
const GiveawayCompleted({
required this.winnerCount,
this.unclaimedPrizeCount,
this.giveawayMessage,
this.isStarGiveaway,
});

/// Constructor from JSON data
Expand All @@ -26,6 +30,7 @@ class GiveawayCompleted {
giveawayMessage: json['giveaway_message'] != null
? Message.fromJson(json['giveaway_message'])
: null,
isStarGiveaway: json['is_star_giveaway'],
);
}

Expand All @@ -35,6 +40,7 @@ class GiveawayCompleted {
'winner_count': winnerCount,
'unclaimed_prize_count': unclaimedPrizeCount,
'giveaway_message': giveawayMessage?.toJson(),
'is_star_giveaway': isStarGiveaway,
}..removeWhere(_nullFilter);
}
}
15 changes: 12 additions & 3 deletions lib/src/telegram/models/giveaway_created.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,25 @@ part of 'models.dart';

/// This object represents a service message about the creation of a scheduled giveaway. Currently holds no information.
class GiveawayCreated {
/// Optional. The number of Telegram Stars to be split between giveaway winners; for Telegram Star giveaways only
final int? prizeStarCount;

/// Creates a `GiveawayCreated` object.
const GiveawayCreated();
const GiveawayCreated({
this.prizeStarCount,
});

/// Creates a `GiveawayCreated` object from a JSON object.
factory GiveawayCreated.fromJson(Map<String, dynamic> json) {
return GiveawayCreated();
return GiveawayCreated(
prizeStarCount: json['prize_star_count'],
);
}

/// Converts the `GiveawayCreated` object to a JSON object.
Map<String, dynamic> toJson() {
return {};
return {
'prize_star_count': prizeStarCount,
}..removeWhere(_nullFilter);
}
}
6 changes: 6 additions & 0 deletions lib/src/telegram/models/giveaway_winners.dart
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ class GiveawayWinners {
/// Description of additional giveaway prize
final String? prizeDescription;

/// Optional. The number of Telegram Stars to be split between giveaway winners; for Telegram Star giveaways only
final int? prizeStarCount;

/// Constructor
const GiveawayWinners({
required this.chat,
Expand All @@ -48,6 +51,7 @@ class GiveawayWinners {
this.onlyNewMembers,
this.wasRefunded,
this.prizeDescription,
this.prizeStarCount,
});

/// Constructor from JSON data
Expand All @@ -65,6 +69,7 @@ class GiveawayWinners {
onlyNewMembers: json['only_new_members'],
wasRefunded: json['was_refunded'],
prizeDescription: json['prize_description'],
prizeStarCount: json['prize_star_count'],
);
}

Expand All @@ -82,6 +87,7 @@ class GiveawayWinners {
'only_new_members': onlyNewMembers,
'was_refunded': wasRefunded,
'prize_description': prizeDescription,
'prize_star_count': prizeStarCount,
}..removeWhere(_nullFilter);
}
}
3 changes: 3 additions & 0 deletions lib/src/telegram/models/models.dart
Original file line number Diff line number Diff line change
Expand Up @@ -271,3 +271,6 @@ part 'refunded_payment.dart';

// Bot API 7.9
part 'reaction_type_paid.dart';

// Bot API 7.10
part 'paid_media_purchased.dart';
37 changes: 37 additions & 0 deletions lib/src/telegram/models/paid_media_purchased.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
part of 'models.dart';

/// Represents a paid media purchase made by a user.
class PaidMediaPurchased implements WithUser {
/// The user who purchased the media.
@override
final User from;

/// A bot-specified payload related to the paid media.
final String paidMediaPayload;

/// Creates a [PaidMediaPurchased] object.
const PaidMediaPurchased({
required this.from,
required this.paidMediaPayload,
});

/// Creates a [PaidMediaPurchased] object from a JSON map.
///
/// The JSON map should contain `from` and `paid_media_payload` fields.
factory PaidMediaPurchased.fromJson(Map<String, dynamic> json) {
return PaidMediaPurchased(
from: User.fromJson(json['from']),
paidMediaPayload: json['paid_media_payload'],
);
}

/// Converts this object to a JSON map.
///
/// Returns a map with `from` and `paid_media_payload` fields.
Map<String, dynamic> toJson() {
return {
'from': from.toJson(),
'paid_media_payload': paidMediaPayload,
};
}
}
6 changes: 6 additions & 0 deletions lib/src/telegram/models/transaction_partner_user.dart
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,15 @@ class TransactionPartnerUser extends TransactionPartner {
/// Optional. Information about the paid media bought by the user
final List<PaidMedia>? paidMedia;

/// Optional. Bot-specified paid media payload
final String? paidMediaPayload;

/// Constructs a [TransactionPartnerUser] object.
const TransactionPartnerUser({
required this.user,
this.invoicePayload,
this.paidMedia,
this.paidMediaPayload,
});

/// Creates a [TransactionPartnerUser] object from JSON.
Expand All @@ -33,6 +37,7 @@ class TransactionPartnerUser extends TransactionPartner {
),
)
: null,
paidMediaPayload: json['paid_media_payload'],
);
}

Expand All @@ -44,6 +49,7 @@ class TransactionPartnerUser extends TransactionPartner {
'user': user.toJson(),
'invoice_payload': invoicePayload,
'paid_media': paidMedia?.map((e) => e.toJson()).toList(),
'paid_media_payload': paidMediaPayload,
}..removeWhere(_nullFilter);
}
}
10 changes: 10 additions & 0 deletions lib/src/telegram/models/update.dart
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,9 @@ class Update {
/// Optional. Messages were deleted from a connected business account
final BusinessMessagesDeleted? deletedBusinessMessages;

/// Optional. A user purchased paid media with a non-empty payload sent by the bot in a non-channel chat
final PaidMediaPurchased? purchasedPaidMedia;

/// Update Constructor
const Update({
required this.updateId,
Expand All @@ -98,6 +101,7 @@ class Update {
this.businessMessage,
this.editedBusinessMessage,
this.deletedBusinessMessages,
this.purchasedPaidMedia,
});

/// Creates a [Update] from json [Map].
Expand Down Expand Up @@ -169,6 +173,9 @@ class Update {
deletedBusinessMessages: json['deleted_business_messages'] != null
? BusinessMessagesDeleted.fromJson(json['deleted_business_messages'])
: null,
purchasedPaidMedia: json['purchased_paid_media'] != null
? PaidMediaPurchased.fromJson(json['purchased_paid_media'])
: null,
);
}

Expand Down Expand Up @@ -198,6 +205,7 @@ class Update {
'business_message': businessMessage?.toJson(),
'edited_business_message': editedBusinessMessage?.toJson(),
'deleted_business_messages': deletedBusinessMessages?.toJson(),
'purchased_paid_media': purchasedPaidMedia?.toJson(),
}..removeWhere(_nullFilter);
}

Expand Down Expand Up @@ -250,6 +258,8 @@ class Update {
return UpdateType.editedBusinessMessage;
} else if (deletedBusinessMessages != null) {
return UpdateType.deletedBusinessMessages;
} else if (purchasedPaidMedia != null) {
return UpdateType.purchasedPaidMedia;
} else {
throw TeleverseException(
"The update type is unknown",
Expand Down
2 changes: 2 additions & 0 deletions lib/src/televerse/api/raw_api.dart
Original file line number Diff line number Diff line change
Expand Up @@ -3984,6 +3984,7 @@ class RawAPI {
ReplyParameters? replyParameters,
ReplyMarkup? replyMarkup,
String? businessConnectionId,
String? payload,
}) async {
final params = {
"chat_id": chatId.id,
Expand All @@ -3997,6 +3998,7 @@ class RawAPI {
"reply_parameters": replyParameters?.toJson(),
"reply_markup": replyMarkup?.toJson(),
"business_connection_id": businessConnectionId,
"payload": payload,
};

List<_MultipartHelper> helpers = [];
Expand Down
10 changes: 10 additions & 0 deletions lib/src/televerse/bot/bot.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2653,4 +2653,14 @@ class Bot<CTX extends Context> {
options: options,
);
}

/// Registers a callback to be fired when a user purchases paid media sent by the bot
void onPaidMediaPurchase(
Handler<CTX> callback,
) {
return _acceptAll(
callback,
[UpdateType.purchasedPaidMedia],
);
}
}
Loading

0 comments on commit 7a8d987

Please sign in to comment.