Add fetch_invite with with_expiration
This commit is contained in:
		| @@ -1132,7 +1132,7 @@ class Client: | ||||
|  | ||||
|     # Invite management | ||||
|  | ||||
|     async def fetch_invite(self, url: Union[Invite, str], *, with_counts: bool = True) -> Invite: | ||||
|     async def fetch_invite(self, url: Union[Invite, str], *, with_counts: bool = True, with_expiration: bool = True) -> Invite: | ||||
|         """|coro| | ||||
|  | ||||
|         Gets an :class:`.Invite` from a discord.gg URL or ID. | ||||
| @@ -1151,6 +1151,11 @@ class Client: | ||||
|             Whether to include count information in the invite. This fills the | ||||
|             :attr:`.Invite.approximate_member_count` and :attr:`.Invite.approximate_presence_count` | ||||
|             fields. | ||||
|         with_expiration: :class:`bool` | ||||
|             Whether to include the expiration date of the invite. This fills the | ||||
|             :attr:`.Invite.expires_at` field. | ||||
|  | ||||
|             .. versionadded:: 2.0 | ||||
|  | ||||
|         Raises | ||||
|         ------- | ||||
| @@ -1166,7 +1171,7 @@ class Client: | ||||
|         """ | ||||
|  | ||||
|         invite_id = utils.resolve_invite(url) | ||||
|         data = await self.http.get_invite(invite_id, with_counts=with_counts) | ||||
|         data = await self.http.get_invite(invite_id, with_counts=with_counts, with_expiration=with_expiration) | ||||
|         return Invite.from_incomplete(state=self._connection, data=data) | ||||
|  | ||||
|     async def delete_invite(self, invite: Union[Invite, str]) -> None: | ||||
|   | ||||
| @@ -975,9 +975,10 @@ class HTTPClient: | ||||
|  | ||||
|         return self.request(r, reason=reason, json=payload) | ||||
|  | ||||
|     def get_invite(self, invite_id, *, with_counts=True): | ||||
|     def get_invite(self, invite_id, *, with_counts=True, with_expiration=True): | ||||
|         params = { | ||||
|             'with_counts': int(with_counts), | ||||
|             'with_expiration': int(with_expiration), | ||||
|         } | ||||
|         return self.request(Route('GET', '/invites/{invite_id}', invite_id=invite_id), params=params) | ||||
|  | ||||
|   | ||||
| @@ -219,23 +219,25 @@ class Invite(Hashable): | ||||
|  | ||||
|     The following table illustrates what methods will obtain the attributes: | ||||
|  | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     |             Attribute              |                          Method                            | | ||||
|     +====================================+==========================================================+ | ||||
|     +====================================+============================================================+ | ||||
|     | :attr:`max_age`                    | :meth:`abc.GuildChannel.invites`\, :meth:`Guild.invites`   | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`max_uses`                   | :meth:`abc.GuildChannel.invites`\, :meth:`Guild.invites`   | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`created_at`                 | :meth:`abc.GuildChannel.invites`\, :meth:`Guild.invites`   | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`temporary`                  | :meth:`abc.GuildChannel.invites`\, :meth:`Guild.invites`   | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`uses`                       | :meth:`abc.GuildChannel.invites`\, :meth:`Guild.invites`   | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     | :attr:`approximate_member_count`   | :meth:`Client.fetch_invite`                              | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     | :attr:`approximate_presence_count` | :meth:`Client.fetch_invite`                              | | ||||
|     +------------------------------------+----------------------------------------------------------+ | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`approximate_member_count`   | :meth:`Client.fetch_invite` with `with_counts` enabled     | | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`approximate_presence_count` | :meth:`Client.fetch_invite` with `with_counts` enabled     | | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|     | :attr:`expires_at`                 | :meth:`Client.fetch_invite` with `with_expiration` enabled | | ||||
|     +------------------------------------+------------------------------------------------------------+ | ||||
|  | ||||
|     If it's not in the table above then it is available by all methods. | ||||
|  | ||||
| @@ -267,6 +269,12 @@ class Invite(Hashable): | ||||
|     approximate_presence_count: Optional[:class:`int`] | ||||
|         The approximate number of members currently active in the guild. | ||||
|         This includes idle, dnd, online, and invisible members. Offline members are excluded. | ||||
|     expires_at: Optional[:class:`datetime.datetime`] | ||||
|         The expiration date of the invite. If the value is ``None`` when received through | ||||
|         `Client.fetch_invite` with `with_expiration` enabled, the invite will never expire. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|  | ||||
|     channel: Union[:class:`abc.GuildChannel`, :class:`Object`, :class:`PartialInviteChannel`] | ||||
|         The channel the invite is for. | ||||
|     target_user: Optional[:class:`User`] | ||||
| @@ -295,6 +303,7 @@ class Invite(Hashable): | ||||
|         '_state', | ||||
|         'approximate_member_count', | ||||
|         'approximate_presence_count', | ||||
|         'expires_at', | ||||
|     ) | ||||
|  | ||||
|     BASE = 'https://discord.gg' | ||||
| @@ -311,6 +320,8 @@ class Invite(Hashable): | ||||
|         self.max_uses = data.get('max_uses') | ||||
|         self.approximate_presence_count = data.get('approximate_presence_count') | ||||
|         self.approximate_member_count = data.get('approximate_member_count') | ||||
|         expires_at = data.get('expires_at', None) | ||||
|         self.expires_at = parse_time(expires_at) if expires_at else None | ||||
|  | ||||
|         inviter_data = data.get('inviter') | ||||
|         self.inviter = None if inviter_data is None else self._state.store_user(inviter_data) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user