Source code for discord_http.entitlements

from datetime import datetime
from typing import TYPE_CHECKING

from . import utils
from .enums import EntitlementType, EntitlementOwnerType, SKUType
from .flags import SKUFlags
from .guild import Guild, PartialGuild
from .object import PartialBase, Snowflake
from .user import PartialUser

if TYPE_CHECKING:
    from .http import DiscordAPI

__all__ = (
    "Entitlements",
    "PartialEntitlements",
    "PartialSKU",
    "SKU",
)


[docs] class PartialSKU(PartialBase): def __init__( self, *, state: "DiscordAPI", id: int ): super().__init__(id=int(id)) self._state = state def __repr__(self) -> str: return f"<PartialSKU id={self.id}>"
[docs] async def create_test_entitlement( self, *, owner_id: Snowflake | int, owner_type: EntitlementOwnerType | int, ) -> "PartialEntitlements": """ Create an entitlement for testing purposes. Parameters ---------- owner_id: `Union[Snowflake, int]` The ID of the owner, can be GuildID or UserID. owner_type: `Union[EntitlementOwnerType, int]` The type of the owner. Returns ------- `PartialEntitlements` The created entitlement. """ r = await self._state.query( "POST", f"/applications/{self._state.application_id}/entitlements", json={ "sku_id": str(self.id), "owner_id": str(int(owner_id)), "owner_type": int(owner_type) } ) return PartialEntitlements( state=self._state, id=int(r.response["id"]) )
[docs] class SKU(PartialSKU): def __init__( self, *, state: "DiscordAPI", data: dict ): super().__init__(state=state, id=int(data["id"])) self.name: str = data["name"] self.slug: str = data["slug"] self.type: SKUType = SKUType(data["type"]) self.flags: SKUFlags = SKUFlags(data["flags"]) self.application: PartialUser = PartialUser( state=self._state, id=int(data["application_id"]) ) def __repr__(self) -> str: return f"<SKU id={self.id} name={self.name} type={self.type}>" def __str__(self) -> str: return f"{self.name}"
[docs] class PartialEntitlements(PartialBase): def __init__( self, *, state: "DiscordAPI", id: int ): super().__init__(id=int(id)) self._state = state def __repr__(self) -> str: return f"<PartialEntitlements id={self.id}>"
[docs] async def fetch(self) -> "Entitlements": """ `Entitlements`: Fetches the entitlement. """ r = await self._state.query( "GET", f"/applications/{self._state.application_id}/entitlements/{self.id}" ) return Entitlements( state=self._state, data=r.response )
[docs] async def consume(self) -> None: """ Mark the entitlement as consumed. """ await self._state.query( "POST", f"/applications/{self._state.application_id}/entitlements/{self.id}/consume", res_method="text" )
[docs] async def delete_test_entitlement(self) -> None: """ Deletes a test entitlement. """ await self._state.query( "DELETE", f"/applications/{self._state.application_id}/entitlements/{self.id}", res_method="text" )
[docs] class Entitlements(PartialEntitlements): def __init__( self, *, state: "DiscordAPI", data: dict ): super().__init__(state=state, id=int(data["id"])) self.deleted: bool = data["deleted"] self.type: EntitlementType = EntitlementType(data["type"]) self.user: PartialUser | None = None self.guild_id: int | None = utils.get_int(data, "guild_id") self.application: PartialUser = PartialUser( state=self._state, id=int(data["application_id"]) ) self.sku: PartialSKU = PartialSKU( state=self._state, id=int(data["sku_id"]) ) self.starts_at: datetime | None = None self.ends_at: datetime | None = None self._from_data(data) self._data_consumed: bool = data.get("consumed", False) def __repr__(self) -> str: return f"<Entitlements id={self.id} sku={self.sku} type={self.type}>" def __str__(self) -> str: return f"{self.sku}" def _from_data(self, data: dict): if data.get("user_id", None): self.user = PartialUser(state=self._state, id=int(data["user_id"])) if data.get("starts_at", None): self.starts_at = utils.parse_time(data["starts_at"]) if data.get("ends_at", None): self.ends_at = utils.parse_time(data["ends_at"]) @property def guild(self) -> Guild | PartialGuild | None: """ `PartialGuild | None`: Returns the guild the entitlement is in """ if not self.guild_id: return None cache = self._state.cache.get_guild(self.guild_id) if cache: return cache from .guild import PartialGuild return PartialGuild(state=self._state, id=self.guild_id)
[docs] def is_consumed(self) -> bool: """ `bool`: Returns whether the entitlement is consumed or not. """ return bool(self._data_consumed)