# Pyrofork - Telegram MTProto API Client Library for Python # Copyright (C) 2020 Cezar H. # Copyright (C) 2022-present Mayuri-Chan # # This file is part of Pyrofork. # # Pyrofork is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published # by the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # Pyrofork is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with Pyrofork. If not, see . import pyrogram from pyrogram.filters import Filter from typing import List, Optional, Union from pyrogram.types import ListenerTypes class Ask: async def ask( self: "pyrogram.Client", chat_id: Union[Union[int, str], List[Union[int, str]]], text: str, filters: Optional[Filter] = None, listener_type: ListenerTypes = ListenerTypes.MESSAGE, timeout: Optional[int] = None, unallowed_click_alert: bool = True, user_id: Union[Union[int, str], List[Union[int, str]]] = None, message_id: Union[int, List[int]] = None, inline_message_id: Union[str, List[str]] = None, *args, **kwargs, ): """ Sends a message and waits for a response. :param chat_id: The chat ID(s) to wait for a message from. The first chat ID will be used to send the message. :param text: The text to send. :param filters: Same as :meth:`pyromod.types.Client.listen`. :param listener_type: Same as :meth:`pyromod.types.Client.listen`. :param timeout: Same as :meth:`pyromod.types.Client.listen`. :param unallowed_click_alert: Same as :meth:`pyromod.types.Client.listen`. :param user_id: Same as :meth:`pyromod.types.Client.listen`. :param message_id: Same as :meth:`pyromod.types.Client.listen`. :param inline_message_id: Same as :meth:`pyromod.types.Client.listen`. :param args: Additional arguments to pass to :meth:`pyrogram.Client.send_message`. :param kwargs: Additional keyword arguments to pass to :meth:`pyrogram.Client.send_message`. :return: Same as :meth:`pyromod.types.Client.listen`. The sent message is returned as the attribute ``sent_message``. """ sent_message = None if text.strip() != "": chat_to_ask = chat_id[0] if isinstance(chat_id, list) else chat_id sent_message = await self.send_message(chat_to_ask, text, *args, **kwargs) response = await self.listen( filters=filters, listener_type=listener_type, timeout=timeout, unallowed_click_alert=unallowed_click_alert, chat_id=chat_id, user_id=user_id, message_id=message_id, inline_message_id=inline_message_id, ) if response: response.sent_message = sent_message return response