mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-10-24 18:13:00 +00:00
Add support for application tags and install params
This commit is contained in:
@@ -29,6 +29,7 @@ from typing import List, TYPE_CHECKING, Optional
|
|||||||
from . import utils
|
from . import utils
|
||||||
from .asset import Asset
|
from .asset import Asset
|
||||||
from .flags import ApplicationFlags
|
from .flags import ApplicationFlags
|
||||||
|
from .permissions import Permissions
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from .guild import Guild
|
from .guild import Guild
|
||||||
@@ -36,6 +37,7 @@ if TYPE_CHECKING:
|
|||||||
AppInfo as AppInfoPayload,
|
AppInfo as AppInfoPayload,
|
||||||
PartialAppInfo as PartialAppInfoPayload,
|
PartialAppInfo as PartialAppInfoPayload,
|
||||||
Team as TeamPayload,
|
Team as TeamPayload,
|
||||||
|
InstallParams as InstallParamsPayload,
|
||||||
)
|
)
|
||||||
from .user import User
|
from .user import User
|
||||||
from .state import ConnectionState
|
from .state import ConnectionState
|
||||||
@@ -43,6 +45,7 @@ if TYPE_CHECKING:
|
|||||||
__all__ = (
|
__all__ = (
|
||||||
'AppInfo',
|
'AppInfo',
|
||||||
'PartialAppInfo',
|
'PartialAppInfo',
|
||||||
|
'AppInstallParams',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@@ -107,6 +110,21 @@ class AppInfo:
|
|||||||
privacy_policy_url: Optional[:class:`str`]
|
privacy_policy_url: Optional[:class:`str`]
|
||||||
The application's privacy policy URL, if set.
|
The application's privacy policy URL, if set.
|
||||||
|
|
||||||
|
.. versionadded:: 2.0
|
||||||
|
|
||||||
|
tags: List[:class:`str`]
|
||||||
|
The list of tags describing the functionality of the application.
|
||||||
|
|
||||||
|
.. versionadded:: 2.0
|
||||||
|
|
||||||
|
custom_install_url: List[:class:`str`]
|
||||||
|
The custom authorization URL for the application, if enabled.
|
||||||
|
|
||||||
|
.. versionadded:: 2.0
|
||||||
|
|
||||||
|
install_params: Optional[:class:`AppInstallParams`]
|
||||||
|
The settings for custom authorization URL of application, if enabled.
|
||||||
|
|
||||||
.. versionadded:: 2.0
|
.. versionadded:: 2.0
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@@ -129,6 +147,9 @@ class AppInfo:
|
|||||||
'_flags',
|
'_flags',
|
||||||
'terms_of_service_url',
|
'terms_of_service_url',
|
||||||
'privacy_policy_url',
|
'privacy_policy_url',
|
||||||
|
'tags',
|
||||||
|
'custom_install_url',
|
||||||
|
'install_params',
|
||||||
)
|
)
|
||||||
|
|
||||||
def __init__(self, state: ConnectionState, data: AppInfoPayload):
|
def __init__(self, state: ConnectionState, data: AppInfoPayload):
|
||||||
@@ -157,6 +178,11 @@ class AppInfo:
|
|||||||
self._cover_image: Optional[str] = data.get('cover_image')
|
self._cover_image: Optional[str] = data.get('cover_image')
|
||||||
self.terms_of_service_url: Optional[str] = data.get('terms_of_service_url')
|
self.terms_of_service_url: Optional[str] = data.get('terms_of_service_url')
|
||||||
self.privacy_policy_url: Optional[str] = data.get('privacy_policy_url')
|
self.privacy_policy_url: Optional[str] = data.get('privacy_policy_url')
|
||||||
|
self.tags: List[str] = data.get('tags', [])
|
||||||
|
self.custom_install_url: Optional[str] = data.get('custom_install_url')
|
||||||
|
|
||||||
|
params = data.get('install_params')
|
||||||
|
self.install_params: Optional[AppInstallParams] = AppInstallParams(params) if params else None
|
||||||
|
|
||||||
def __repr__(self) -> str:
|
def __repr__(self) -> str:
|
||||||
return (
|
return (
|
||||||
@@ -266,3 +292,24 @@ class PartialAppInfo:
|
|||||||
.. versionadded:: 2.0
|
.. versionadded:: 2.0
|
||||||
"""
|
"""
|
||||||
return ApplicationFlags._from_value(self._flags)
|
return ApplicationFlags._from_value(self._flags)
|
||||||
|
|
||||||
|
|
||||||
|
class AppInstallParams:
|
||||||
|
"""Represents the settings for custom authorization URL of an application.
|
||||||
|
|
||||||
|
.. versionadded:: 2.0
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
scopes: List[:class:`str`]
|
||||||
|
The list of `OAuth2 scopes <https://discord.com/developers/docs/topics/oauth2#shared-resources-oauth2-scopes>`_
|
||||||
|
to add the application to a guild with.
|
||||||
|
permissions: :class:`Permissions`
|
||||||
|
The permissions to give to application in the guild.
|
||||||
|
"""
|
||||||
|
|
||||||
|
__slots__ = ('scopes', 'permissions')
|
||||||
|
|
||||||
|
def __init__(self, data: InstallParamsPayload) -> None:
|
||||||
|
self.scopes: List[str] = data.get('scopes', [])
|
||||||
|
self.permissions: Permissions = Permissions(int(data['permissions']))
|
||||||
|
@@ -32,6 +32,11 @@ from .team import Team
|
|||||||
from .snowflake import Snowflake
|
from .snowflake import Snowflake
|
||||||
|
|
||||||
|
|
||||||
|
class InstallParams(TypedDict):
|
||||||
|
scopes: List[str]
|
||||||
|
permissions: str
|
||||||
|
|
||||||
|
|
||||||
class BaseAppInfo(TypedDict):
|
class BaseAppInfo(TypedDict):
|
||||||
id: Snowflake
|
id: Snowflake
|
||||||
name: str
|
name: str
|
||||||
@@ -54,6 +59,9 @@ class AppInfo(BaseAppInfo):
|
|||||||
privacy_policy_url: NotRequired[str]
|
privacy_policy_url: NotRequired[str]
|
||||||
hook: NotRequired[bool]
|
hook: NotRequired[bool]
|
||||||
max_participants: NotRequired[int]
|
max_participants: NotRequired[int]
|
||||||
|
tags: NotRequired[List[str]]
|
||||||
|
install_params: NotRequired[InstallParams]
|
||||||
|
custom_install_url: NotRequired[str]
|
||||||
|
|
||||||
|
|
||||||
class PartialAppInfo(BaseAppInfo, total=False):
|
class PartialAppInfo(BaseAppInfo, total=False):
|
||||||
|
@@ -72,6 +72,14 @@ PartialAppInfo
|
|||||||
.. autoclass:: PartialAppInfo()
|
.. autoclass:: PartialAppInfo()
|
||||||
:members:
|
:members:
|
||||||
|
|
||||||
|
AppInstallParams
|
||||||
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. attributetable:: AppInstallParams
|
||||||
|
|
||||||
|
.. autoclass:: AppInstallParams()
|
||||||
|
:members:
|
||||||
|
|
||||||
Team
|
Team
|
||||||
~~~~~
|
~~~~~
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user