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

If you're not sure about the file name format, learn more about wheel file names.

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

Uploaded Python 3

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

Hashes for patchpyro-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 92a22ed5a3ab5a1b8b9b722be46789bd5ded2d2c18118ec441d2acd9bf92f076
MD5 8c8c1c4544fac5ae5502a1a464852a0a
BLAKE2b-256 cb451ca81759eff44a4897abfd7a1d1142b41fde76de148dd8712451560c636e

See more details on using hashes here.

Supported by

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