Browse Source
Add support for multiple subscription tier SKUs
pull/9604/merge
DA344
2 months ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with
5 additions and
0 deletions
-
discord/subscription.py
-
discord/types/subscription.py
|
|
@ -63,6 +63,8 @@ class Subscription(Hashable): |
|
|
|
canceled_at: Optional[:class:`datetime.datetime`] |
|
|
|
When the subscription was canceled. |
|
|
|
This is only available for subscriptions with a :attr:`status` of :attr:`SubscriptionStatus.inactive`. |
|
|
|
renewal_sku_ids: List[:class:`int`] |
|
|
|
The IDs of the SKUs that the user is going to be subscribed to when renewing. |
|
|
|
""" |
|
|
|
|
|
|
|
__slots__ = ( |
|
|
@ -75,6 +77,7 @@ class Subscription(Hashable): |
|
|
|
'current_period_end', |
|
|
|
'status', |
|
|
|
'canceled_at', |
|
|
|
'renewal_sku_ids', |
|
|
|
) |
|
|
|
|
|
|
|
def __init__(self, *, state: ConnectionState, data: SubscriptionPayload): |
|
|
@ -88,6 +91,7 @@ class Subscription(Hashable): |
|
|
|
self.current_period_end: datetime.datetime = utils.parse_time(data['current_period_end']) |
|
|
|
self.status: SubscriptionStatus = try_enum(SubscriptionStatus, data['status']) |
|
|
|
self.canceled_at: Optional[datetime.datetime] = utils.parse_time(data['canceled_at']) |
|
|
|
self.renewal_sku_ids: List[int] = list(map(int, data['renewal_sku_ids'] or [])) |
|
|
|
|
|
|
|
def __repr__(self) -> str: |
|
|
|
return f'<Subscription id={self.id} user_id={self.user_id} status={self.status!r}>' |
|
|
|
|
|
@ -40,3 +40,4 @@ class Subscription(TypedDict): |
|
|
|
current_period_end: str |
|
|
|
status: SubscriptionStatus |
|
|
|
canceled_at: Optional[str] |
|
|
|
renewal_sku_ids: Optional[List[Snowflake]] |
|
|
|