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

Installation:

python -m pip install patchpyro

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

      • 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
    • Chat.ask, User.ask

      • 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.
    • Chat.asker, User.asker

      • 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:

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=enums.ParseMode.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.3-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file patchpyro-2.0.3-py3-none-any.whl.

File metadata

  • Download URL: patchpyro-2.0.3-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for patchpyro-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e5d049419789830aac6f8676b240df5cfe0a0129ff3db1848ffea09b975ae3f2
MD5 a6c56d934a703e897ddafba01a31ee4b
BLAKE2b-256 f5bee9c275a043811db14b31eabdc325adacd2d4eea2609f0e79a193ea7e59c5

See more details on using hashes here.

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