Skip to main content

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.listen
    • Chat.ask, User.ask
    • Chat.asker, User.asker
  • await mybot.listen(chat_id, filters=None, timeout=30)

    • raises asyncio.TimeoutError if 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
  • 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.
  • await mybot.asker(chat_id, filters=None, timeout=36)

    • same as .listen() but .asker() returns None instead of raising asyncio.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.

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

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

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

patchpyro-2.0.0-py3-none-any.whl (27.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page