L iR"dZddlZddlmZmZddlmZddlm Z ddl m Z ddl m Z ddlmZdd lmZmZdd lmZdd lmZmZerdd lmZGd de Zy)zJThis module contains an object that represents a Telegram ChatJoinRequest.N) TYPE_CHECKINGOptional)Chat)ChatInviteLink)TelegramObject)User)de_json_optional)extract_tzinfo_from_defaultsfrom_timestamp) DEFAULT_NONE)JSONDictODVInput)Botc8eZdZdZdZ ddddededejde d e e d e e d e e ffd Zedd e de dddffd Zeeeedddeedeedeedeed e e def dZeeeedddeedeedeedeed e e def dZxZS)ChatJoinRequestaDThis object represents a join request sent to a chat. Objects of this class are comparable in terms of equality. Two objects of this class are considered equal, if their :attr:`chat`, :attr:`from_user` and :attr:`date` are equal. Note: * Since Bot API 5.5, bots are allowed to contact users who sent a join request to a chat where the bot is an administrator with the :attr:`~telegram.ChatMemberAdministrator.can_invite_users` administrator right - even if the user never interacted with the bot before. * Telegram does not guarantee that :attr:`from_user.id ` coincides with the ``chat_id`` of the user. Please use :attr:`user_chat_id` to contact the user in response to their join request. .. versionadded:: 13.8 .. versionchanged:: 20.1 In Bot API 6.5 the argument :paramref:`user_chat_id` was added, which changes the position of the optional arguments :paramref:`bio` and :paramref:`invite_link`. Args: chat (:class:`telegram.Chat`): Chat to which the request was sent. from_user (:class:`telegram.User`): User that sent the join request. date (:class:`datetime.datetime`): Date the request was sent. .. versionchanged:: 20.3 |datetime_localization| user_chat_id (:obj:`int`): Identifier of a private chat with the user who sent the join request. This number may have more than 32 significant bits and some programming languages may have difficulty/silent defects in interpreting it. But it has at most 52 significant bits, so a 64-bit integer or double-precision float type are safe for storing this identifier. The bot can use this identifier for 5 minutes to send messages until the join request is processed, assuming no other administrator contacted the user. .. versionadded:: 20.1 bio (:obj:`str`, optional): Bio of the user. invite_link (:class:`telegram.ChatInviteLink`, optional): Chat invite link that was used by the user to send the join request. Attributes: chat (:class:`telegram.Chat`): Chat to which the request was sent. from_user (:class:`telegram.User`): User that sent the join request. date (:class:`datetime.datetime`): Date the request was sent. .. versionchanged:: 20.3 |datetime_localization| user_chat_id (:obj:`int`): Identifier of a private chat with the user who sent the join request. This number may have more than 32 significant bits and some programming languages may have difficulty/silent defects in interpreting it. But it has at most 52 significant bits, so a 64-bit integer or double-precision float type are safe for storing this identifier. The bot can use this identifier for 24 hours to send messages until the join request is processed, assuming no other administrator contacted the user. .. versionadded:: 20.1 bio (:obj:`str`): Optional. Bio of the user. invite_link (:class:`telegram.ChatInviteLink`): Optional. Chat invite link that was used by the user to send the join request. Note: When a user joins a *public* group via an invite link, this attribute may not be present. However, this behavior is undocument and may be subject to change. See `this GitHub thread `_ for some discussion. )biochatdate from_user invite_link user_chat_idN api_kwargsrrrrrrrct||||_||_||_||_||_||_|j|j|jf|_|jy)Nr) super__init__rrrrrr _id_attrs_freeze) selfrrrrrrr __class__s _/mnt/ssd/data/python-lab/Trading/venv/lib/python3.12/site-packages/telegram/_chatjoinrequest.pyrzChatJoinRequest.__init__ksf J/ ("& !-#&5@))T^^TYY? databotrreturncr|j|}t|}t|jdt||d<t|j ddt ||d<t|jdd||d<t|jdt||d<t|)||S) z,See :meth:`telegram.TelegramObject.de_json`.rfromNrr)tzinfor)r#r$) _parse_datar r getrpoprr rrde_json)clsr#r$ loc_tzinfor s r!r,zChatJoinRequest.de_jsonst$2#6 '(8$DV ,TXXfd-CT3O[%dhhvt&    AAAAc K|jj|jj|jj|||||d{S7w)aShortcut for:: await bot.decline_chat_join_request( chat_id=update.effective_chat.id, user_id=update.effective_user.id, *args, **kwargs ) For the documentation of the arguments, please see :meth:`telegram.Bot.decline_chat_join_request`. Returns: :obj:`bool`: On success, :obj:`True` is returned. r4N)r7decline_chat_join_requestrr9rr:s r!declinezChatJoinRequest.decliner<r=)NN)N)__name__ __module__ __qualname____doc__ __slots__rrdtmdatetimeintrstrrr r classmethodr,r rfloatboolr;r@ __classcell__)r s@r!rr%s|AFTI"04*.ll    c] n-X&4 38 3(5/ 3EV 3 3")5)5+7(4)- uo    "%  uo  X&   F)5)5+7(4)- uo    "%  uo  X&   r"r)rDrGrFtypingrrtelegram._chatrtelegram._chatinvitelinkrtelegram._telegramobjectrtelegram._userrtelegram._utils.argumentparsingr telegram._utils.datetimer r telegram._utils.defaultvaluer telegram._utils.typesr rtelegramrrr"r!rYs=&Q*33<Q54m nm r"