A modified pyromod by www.da.gd/aditya
Project description
patchpyro
This is a fork of pyromod (renamed as patchpyro) for personal usecases.
Remember that this fork contains only conversation patch.
Requirements:
pyrogram>=2.0.69
python>=3.9
Usage
Import patchpyro at least one time in your script, so you'll be able to use modified pyrogram in all files of the same proccess.
Example:
# config.py
from patchpyro import listen # or import patchpyro.listen
from pyrogram import Client
mybot = Client("mysession")
# any other .py
from config import mybot
# no need to import patchpyro again, pyrogram is already monkeypatched globally (at the same proccess)
patchpyro.listen
Just import it, it will automatically do the monkeypatch and you'll get these new methods:
-
Available bound methods::
Chat.listen, User.listenChat.ask, User.askChat.asker, User.asker
-
await mybot.listen(chat_id, filters=None, timeout=30)- raises
asyncio.TimeoutErrorif timeout (optional parameter) - Awaits for a new message in the specified chat and returns it.
- You can pass Update Filters to the filters parameter just like you do for the update handlers.
- E.g.
filters=filters.photo & filters.bot
- raises
-
await mybot.ask(text, chat_id, filters=None, timeout=30)- Same of
.listen()above, but sends a message before awaiting. - You can pass custom parameters to its send_message() call. Check the example below.
- Same of
-
await mybot.asker(chat_id, filters=None, timeout=36)- same as
.listen()but.asker()returnsNoneinstead of raisingasyncio.TimeoutError. - Found useful in some cases for me,
.asker()has a default timeout of 2 minutes. - You can adjust it by passing as a argument. Refer the example code given below.
- same as
Examples:
from patchpyro import listen # or import patchpyro.listen
from pyrogram import Client
client = Client(...)
# For .asker():
...
sendx = await client.send_message(chat_id, "`Send me your name:`")
answer = await client.asker(chat_id, filters=None, timeout=60)
if not answer: # `None` if timeout if no reply received.
return await sendx.reply_text("How long should I wait?, Eh! Bye!")
await answer.reply_text(f"{answer.text}, That's a cool name!")
# For .ask():
...
answer = await client.ask(chat_id, '*Send me your name:*', parse_mode='Markdown')
await client.send_message(chat_id, f'Your name is: {answer.text}')
...
Copyright & License
This project may include snippets of Pyrogram code
- Pyrogram - Telegram MTProto API Client Library for Python. Copyright (C) 2017-2022 Dan <https://github.com/delivrance>
Licensed under the terms of the GNU Lesser General Public License v3 or later (LGPLv3+)
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file patchpyro-2.0.0-py3-none-any.whl.
File metadata
- Download URL: patchpyro-2.0.0-py3-none-any.whl
- Upload date:
- Size: 27.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
92a22ed5a3ab5a1b8b9b722be46789bd5ded2d2c18118ec441d2acd9bf92f076
|
|
| MD5 |
8c8c1c4544fac5ae5502a1a464852a0a
|
|
| BLAKE2b-256 |
cb451ca81759eff44a4897abfd7a1d1142b41fde76de148dd8712451560c636e
|