From a91bb8b9945d4380ce4aa478c1492edbb41fa4fd Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:49:39 +0530 Subject: [PATCH 1/7] update cli.py -> use figlet -> make rich logging -> check latest release using verlat -> update app help message -> refactor code --- tgcf/cli.py | 73 +++++++++++++++++++++++++++++++++++++---------------- 1 file changed, 51 insertions(+), 22 deletions(-) diff --git a/tgcf/cli.py b/tgcf/cli.py index 7039b60b..8e4ed08d 100644 --- a/tgcf/cli.py +++ b/tgcf/cli.py @@ -10,6 +10,10 @@ import typer from dotenv import load_dotenv +from pyfiglet import Figlet +from rich import print, traceback +from rich.logging import RichHandler +from verlat import latest_release from tgcf import __version__ @@ -19,6 +23,13 @@ app = typer.Typer(add_completion=False) +def topper(): + fig = Figlet(font="speed") + print(fig.renderText("tgcf")) + version_check() + print("\n\n") + + class Mode(str, Enum): """tgcf works in two modes.""" @@ -26,21 +37,50 @@ class Mode(str, Enum): LIVE = "live" +def verbosity_callback(value: bool): + """Set logging level.""" + traceback.install() + if value: + level = logging.INFO + else: + level = logging.WARNING + logging.basicConfig( + level=level, + format="%(message)s", + handlers=[ + RichHandler( + rich_tracebacks=True, + markup=True, + ) + ], + ) + topper() + logging.info("Verbosity turned on! This is suitable for debugging") + nl = "\n" + logging.info( + f"""Running tgcf {__version__}\ + \nPython {sys.version.replace(nl,"")}\ + \nOS {os.name}\ + \nPlatform {platform.system()} {platform.release()}\ + \n{platform.architecture()} {platform.processor()}""" + ) + + def version_callback(value: bool): """Show current version and exit.""" + if value: print(__version__) raise typer.Exit() -def verbosity_callback(value: bool): - """Set logging level.""" - if value: - level = logging.INFO - else: - level = logging.WARNING - logging.basicConfig(level=level) - logging.info("Verbosity turned on. \nThis is suitable for debugging.\n") +def version_check(): + latver = latest_release("tgcf").version + if __version__ != latver: + print( + f"tgcf has a newer release {latver} availaible!\ + \nVisit http://bit.ly/update-tgcf" + ) @app.command() @@ -64,23 +104,12 @@ def main( help="Show version and exit.", ), ): - """Tgcf is a powerful tool for forwarding telegram messages from source to destination. + """The ultimate tool to automate custom telegram message forwarding. - Don't forget to star https://github.com/aahnik/tgcf + Source Code: https://github.com/aahnik/tgcf - Telegram Channel https://telegram.me/tg_cf - """ - nl = "\n" - logging.info( - f""" Runing tgcf {__version__} - ** System Info ** - Python {sys.version.replace(nl,"")} - OS {os.name} - Platform {platform.system()} {platform.release()} - {platform.architecture()} {platform.processor()} + For updates join telegram channel @aahniks_code """ - ) - if FAKE: print(f"mode = {mode}") sys.exit(1) From c15fb0781a8f445520bb59d94333d6f1cbc5f10d Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:50:07 +0530 Subject: [PATCH 2/7] add new deps: rich, pyfiglet, verlat --- poetry.lock | 79 ++++++++++++++++++++++++++++++++++++++++++++++++-- pyproject.toml | 3 ++ 2 files changed, 80 insertions(+), 2 deletions(-) diff --git a/poetry.lock b/poetry.lock index 1e1abd1f..d5d3e1ef 100644 --- a/poetry.lock +++ b/poetry.lock @@ -116,10 +116,21 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" name = "colorama" version = "0.4.4" description = "Cross-platform colored terminal text." -category = "dev" +category = "main" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" +[[package]] +name = "commonmark" +version = "0.9.1" +description = "Python parser for the CommonMark Markdown spec" +category = "main" +optional = false +python-versions = "*" + +[package.extras] +test = ["flake8 (==3.7.8)", "hypothesis (==3.55.3)"] + [[package]] name = "cryptg" version = "0.2.post4" @@ -301,6 +312,22 @@ typing-extensions = ">=3.7.4.3" dotenv = ["python-dotenv (>=0.10.4)"] email = ["email-validator (>=1.0.3)"] +[[package]] +name = "pyfiglet" +version = "0.8.post1" +description = "Pure-python FIGlet implementation" +category = "main" +optional = false +python-versions = "*" + +[[package]] +name = "pygments" +version = "2.9.0" +description = "Pygments is a syntax highlighting package written in Python." +category = "main" +optional = false +python-versions = ">=3.5" + [[package]] name = "pytesseract" version = "0.3.7" @@ -357,6 +384,22 @@ urllib3 = ">=1.21.1,<1.27" security = ["pyOpenSSL (>=0.14)", "cryptography (>=1.3.4)"] socks = ["PySocks (>=1.5.6,!=1.5.7)", "win-inet-pton"] +[[package]] +name = "rich" +version = "10.3.0" +description = "Render rich text, tables, progress bars, syntax highlighting, markdown and more to the terminal" +category = "main" +optional = false +python-versions = ">=3.6,<4.0" + +[package.dependencies] +colorama = ">=0.4.0,<0.5.0" +commonmark = ">=0.9.0,<0.10.0" +pygments = ">=2.6.0,<3.0.0" + +[package.extras] +jupyter = ["ipywidgets (>=7.5.1,<8.0.0)"] + [[package]] name = "rsa" version = "4.7.2" @@ -480,6 +523,18 @@ brotli = ["brotlipy (>=0.6.0)"] secure = ["pyOpenSSL (>=0.14)", "cryptography (>=1.3.4)", "idna (>=2.0.0)", "certifi", "ipaddress"] socks = ["PySocks (>=1.5.6,!=1.5.7,<2.0)"] +[[package]] +name = "verlat" +version = "0.1.0.post1" +description = "Get info about the latest release of a package on PyPI." +category = "main" +optional = false +python-versions = ">=3.8,<4.0" + +[package.dependencies] +pydantic = ">=1.8.2,<2.0.0" +requests = ">=2.25.1,<3.0.0" + [[package]] name = "virtualenv" version = "20.4.7" @@ -533,7 +588,7 @@ testing = ["pytest (>=4.6)", "pytest-checkdocs (>=1.2.3)", "pytest-flake8", "pyt [metadata] lock-version = "1.1" python-versions = "^3.8" -content-hash = "81d86169fd8af5257e09af970d7d986eb4b580fc04906afa2bca843fd044589c" +content-hash = "baa9414957d9423a3b8c7fb1c27f8de153c0963ee393cc99b63f8bdc897e43e3" [metadata.files] aiohttp = [ @@ -661,6 +716,10 @@ colorama = [ {file = "colorama-0.4.4-py2.py3-none-any.whl", hash = "sha256:9f47eda37229f68eee03b24b9748937c7dc3868f906e8ba69fbcbdd3bc5dc3e2"}, {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, ] +commonmark = [ + {file = "commonmark-0.9.1-py2.py3-none-any.whl", hash = "sha256:da2f38c92590f83de410ba1a3cbceafbc74fee9def35f9251ba9a971d6d66fd9"}, + {file = "commonmark-0.9.1.tar.gz", hash = "sha256:452f9dc859be7f06631ddcb328b6919c67984aca654e5fefb3914d54691aed60"}, +] cryptg = [ {file = "cryptg-0.2.post4-cp36-cp36m-macosx_10_6_intel.whl", hash = "sha256:b6352555e47f389ed502269bdb537233d0a928b12d9f4caa57e8c707151acd30"}, {file = "cryptg-0.2.post4-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:7fc8e1893775c6f53dceda1959f19833cc27a67a80492c10e2415dc601b36650"}, @@ -862,6 +921,14 @@ pydantic = [ {file = "pydantic-1.8.2-py3-none-any.whl", hash = "sha256:fec866a0b59f372b7e776f2d7308511784dace622e0992a0b59ea3ccee0ae833"}, {file = "pydantic-1.8.2.tar.gz", hash = "sha256:26464e57ccaafe72b7ad156fdaa4e9b9ef051f69e175dbbb463283000c05ab7b"}, ] +pyfiglet = [ + {file = "pyfiglet-0.8.post1-py2.py3-none-any.whl", hash = "sha256:d555bcea17fbeaf70eaefa48bb119352487e629c9b56f30f383e2c62dd67a01c"}, + {file = "pyfiglet-0.8.post1.tar.gz", hash = "sha256:c6c2321755d09267b438ec7b936825a4910fec696292139e664ca8670e103639"}, +] +pygments = [ + {file = "Pygments-2.9.0-py3-none-any.whl", hash = "sha256:d66e804411278594d764fc69ec36ec13d9ae9147193a1740cd34d272ca383b8e"}, + {file = "Pygments-2.9.0.tar.gz", hash = "sha256:a18f47b506a429f6f4b9df81bb02beab9ca21d0a5fee38ed15aef65f0545519f"}, +] pytesseract = [ {file = "pytesseract-0.3.7.tar.gz", hash = "sha256:4ecfc898d00a70fcc38d2bce729de1597c67e7bc5d2fa26094714c9f5b573645"}, ] @@ -947,6 +1014,10 @@ requests = [ {file = "requests-2.25.1-py2.py3-none-any.whl", hash = "sha256:c210084e36a42ae6b9219e00e48287def368a26d03a048ddad7bfee44f75871e"}, {file = "requests-2.25.1.tar.gz", hash = "sha256:27973dd4a904a4f13b263a19c866c13b92a39ed1c964655f025f3f8d3d75b804"}, ] +rich = [ + {file = "rich-10.3.0-py3-none-any.whl", hash = "sha256:b3b5e6c47bf6ea7a2479f5d9245d5ed32f542931912e14203292dfaa0c6c1437"}, + {file = "rich-10.3.0.tar.gz", hash = "sha256:a83bff83309687e1859c75b499879738b135d700738dd2721c22965497af05bd"}, +] rsa = [ {file = "rsa-4.7.2-py3-none-any.whl", hash = "sha256:78f9a9bf4e7be0c5ded4583326e7461e3a3c5aae24073648b4bdfa797d78c9d2"}, {file = "rsa-4.7.2.tar.gz", hash = "sha256:9d689e6ca1b3038bc82bf8d23e944b6b6037bc02301a574935b2dd946e0353b9"}, @@ -1020,6 +1091,10 @@ urllib3 = [ {file = "urllib3-1.26.5-py2.py3-none-any.whl", hash = "sha256:753a0374df26658f99d826cfe40394a686d05985786d946fbe4165b5148f5a7c"}, {file = "urllib3-1.26.5.tar.gz", hash = "sha256:a7acd0977125325f516bda9735fa7142b909a8d01e8b2e4c8108d0984e6e0098"}, ] +verlat = [ + {file = "verlat-0.1.0.post1-py3-none-any.whl", hash = "sha256:62835f120e88f8f3cb2879d7394f971a588aad3cd0cc5d08e7d3bc9b29697555"}, + {file = "verlat-0.1.0.post1.tar.gz", hash = "sha256:10a03e3aa87e5ffa0fdc55819931b5738752651387cd65517311088506951938"}, +] virtualenv = [ {file = "virtualenv-20.4.7-py2.py3-none-any.whl", hash = "sha256:2b0126166ea7c9c3661f5b8e06773d28f83322de7a3ff7d06f0aed18c9de6a76"}, {file = "virtualenv-20.4.7.tar.gz", hash = "sha256:14fdf849f80dbb29a4eb6caa9875d476ee2a5cf76a5f5415fa2f1606010ab467"}, diff --git a/pyproject.toml b/pyproject.toml index 05cf41da..5e5b23e4 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -23,6 +23,9 @@ aiohttp = "^3.7.4" tg-login = "^0.0.2" "watermark.py" = "^0.0.3" pytesseract = "^0.3.7" +rich = "^10.3.0" +pyfiglet = "^0.8.post1" +verlat = "^0.1.0" [tool.poetry.dev-dependencies] typer-cli = "^0.0.11" From 59fc607f14de86228d71f00900fa54cb6a2a6193 Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:52:20 +0530 Subject: [PATCH 3/7] update config.py -> add new module attribute is_bot -> move admins to top of Config -> change default value of end to 0 0 is falsy value, and indicates absence of the configuration end --- tgcf/config.py | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/tgcf/config.py b/tgcf/config.py index edde3a2f..8c52dccc 100644 --- a/tgcf/config.py +++ b/tgcf/config.py @@ -23,7 +23,7 @@ class Forward(BaseModel): source: Union[int, str] dest: List[Union[int, str]] = [] offset: int = 0 - end: Optional[int] = None + end: Optional[int] = 0 class LiveSettings(BaseModel): @@ -56,11 +56,11 @@ class Config(BaseModel): """The blueprint for tgcf's whole config.""" # pylint: disable=too-few-public-methods + admins: List[int] = [] forwards: List[Forward] = [] show_forwarded_from: bool = False live: LiveSettings = LiveSettings() past: PastSettings = PastSettings() - admins: List[int] = [] plugins: Dict = {} @@ -70,16 +70,16 @@ def detect_config_type() -> int: tutorial_link = "Learn more http://bit.ly/configure-tgcf" if CONFIG_FILE_NAME in os.listdir(): - logging.info(f"{CONFIG_FILE_NAME} detected.") + logging.info(f"{CONFIG_FILE_NAME} detected") return 1 if os.getenv("TGCF_CONFIG"): - logging.info(f"env var {CONFIG_ENV_VAR_NAME} detected.") + logging.info(f"env var {CONFIG_ENV_VAR_NAME} detected") if not ".env" in os.listdir(): return 2 logging.warning( f"If you can create files in your system,\ - you should use tgcf.config.yml and not .env to define configuration. {tutorial_link}" + you should use tgcf.config.yml and not .env to define configuration {tutorial_link}" ) sys.exit(1) else: @@ -106,7 +106,7 @@ def read_config() -> Config: else: config = Config() except Exception as err: - print(err) + logging.exception(err) sys.exit(1) else: logging.info(config) @@ -181,5 +181,5 @@ async def _(peer): from_to = {} - +is_bot: Optional[bool] = None logging.info("config.py got executed") From 409ef9acbeeae740ee528e222cec45bf65cd4e9b Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:54:19 +0530 Subject: [PATCH 4/7] allow comands when tgcf live is run using userbot -> replace print statements with logs -> remove temporary debug prints left accidentally --- tgcf/bot/__init__.py | 2 +- tgcf/bot/live_bot.py | 40 ++++++++++++++++++++++++---------------- tgcf/live.py | 25 ++++++++----------------- 3 files changed, 33 insertions(+), 34 deletions(-) diff --git a/tgcf/bot/__init__.py b/tgcf/bot/__init__.py index 8f96e76b..d76f6bc9 100644 --- a/tgcf/bot/__init__.py +++ b/tgcf/bot/__init__.py @@ -1,3 +1,3 @@ """The subpackage for interative bot for tgcf.""" -from .live_bot import BOT_EVENTS +from .live_bot import get_events diff --git a/tgcf/bot/live_bot.py b/tgcf/bot/live_bot.py index 086e73a8..59cd19f3 100644 --- a/tgcf/bot/live_bot.py +++ b/tgcf/bot/live_bot.py @@ -1,10 +1,18 @@ """A bot to controll settings for tgcf live mode.""" +import logging + import yaml from telethon import events from tgcf import config, const, plugins -from tgcf.bot.utils import admin_protect, display_forwards, get_args, remove_source +from tgcf.bot.utils import ( + admin_protect, + display_forwards, + get_args, + get_command_prefix, + remove_source, +) @admin_protect @@ -30,9 +38,7 @@ async def forward_command_handler(event): raise ValueError(f"{notes}\n{display_forwards(config.CONFIG.forwards)}") parsed_args = yaml.safe_load(args) - print(parsed_args) forward = config.Forward(**parsed_args) - print(forward) try: remove_source(forward.source, config.CONFIG.forwards) except: @@ -43,7 +49,7 @@ async def forward_command_handler(event): await event.respond("Success") config.write_config(config.CONFIG) except ValueError as err: - print(err) + logging.error(err) await event.respond(str(err)) finally: @@ -68,17 +74,14 @@ async def remove_command_handler(event): raise ValueError(f"{notes}\n{display_forwards(config.CONFIG.forwards)}") parsed_args = yaml.safe_load(args) - print(parsed_args) source_to_remove = parsed_args.get("source") - print(source_to_remove) config.CONFIG.forwards = remove_source(source_to_remove, config.CONFIG.forwards) - print(config.CONFIG.forwards) config.from_to = config.load_from_to(event.client, config.CONFIG.forwards) await event.respond("Success") config.write_config(config.CONFIG) except ValueError as err: - print(err) + logging.error(err) await event.respond(str(err)) finally: @@ -111,7 +114,7 @@ async def style_command_handler(event): config.write_config(config.CONFIG) except ValueError as err: - print(err) + logging.error(err) await event.respond(str(err)) finally: @@ -128,10 +131,15 @@ async def help_command_handler(event): await event.respond(const.BotMessages.bot_help) -BOT_EVENTS = { - "bot_start": (start_command_handler, events.NewMessage(pattern="/start")), - "bot_forward": (forward_command_handler, events.NewMessage(pattern="/forward")), - "bot_remove": (remove_command_handler, events.NewMessage(pattern="/remove")), - "bot_style": (style_command_handler, events.NewMessage(pattern="/style")), - "bot_help": (help_command_handler, events.NewMessage(pattern="/help")), -} +def get_events(): + _ = get_command_prefix() + + command_events = { + "start": (start_command_handler, events.NewMessage(pattern=f"{_}start")), + "forward": (forward_command_handler, events.NewMessage(pattern=f"{_}forward")), + "remove": (remove_command_handler, events.NewMessage(pattern=f"{_}remove")), + "style": (style_command_handler, events.NewMessage(pattern=f"{_}style")), + "help": (help_command_handler, events.NewMessage(pattern=f"{_}help")), + } + + return command_events diff --git a/tgcf/live.py b/tgcf/live.py index dbaa4df1..c7ea7a17 100644 --- a/tgcf/live.py +++ b/tgcf/live.py @@ -8,8 +8,8 @@ from tgcf import config, const from tgcf import storage as st -from tgcf.bot import BOT_EVENTS -from tgcf.plugins import apply_plugins, plugins +from tgcf.bot import get_events +from tgcf.plugins import apply_plugins from tgcf.utils import send_message @@ -109,34 +109,25 @@ async def deleted_message_handler(event): "deleted": (deleted_message_handler, events.MessageDeleted()), } -ALL_EVENTS.update(BOT_EVENTS) - -for _, plugin in plugins.items(): - try: - event_handlers = getattr(plugin, "event_handlers") - if event_handlers: - ALL_EVENTS.update(event_handlers) - except AttributeError: - pass - async def start_sync() -> None: """Start tgcf live sync.""" client = TelegramClient(config.SESSION, config.API_ID, config.API_HASH) await client.start(bot_token=config.BOT_TOKEN) - is_bot = await client.is_bot() + config.is_bot = await client.is_bot() + logging.info(f"config.is_bot={config.is_bot}") + command_events = get_events() + + ALL_EVENTS.update(command_events) for key, val in ALL_EVENTS.items(): - if key.startswith("bot"): - if not is_bot: - continue if config.CONFIG.live.delete_sync is False and key == "deleted": continue client.add_event_handler(*val) logging.info(f"Added event handler for {key}") - if is_bot and const.REGISTER_COMMANDS: + if config.is_bot and const.REGISTER_COMMANDS: await client( functions.bots.SetBotCommandsRequest( commands=[ From 18d6f3bf9adc8c361a7cf529d3c08eb836264f05 Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:55:42 +0530 Subject: [PATCH 5/7] make the param case_sensitive meaningless when using regex --- tgcf/plugins/filter.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tgcf/plugins/filter.py b/tgcf/plugins/filter.py index 1bf70b5e..39a87c2e 100644 --- a/tgcf/plugins/filter.py +++ b/tgcf/plugins/filter.py @@ -40,7 +40,7 @@ def __init__(self, data: Dict[str, Any]) -> None: def case_correct(self) -> None: textf: TextFilter = self.filters.text - if textf.case_sensitive is False: + if textf.case_sensitive is False and textf.regex is False: textf.blacklist = [item.lower() for item in textf.blacklist] textf.whitelist = [item.lower() for item in textf.whitelist] From c217b791687a0402482100aae34ec4d2775926ce Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:56:07 +0530 Subject: [PATCH 6/7] enhance logging, remove prints --- tgcf/bot/utils.py | 13 ++++++++----- tgcf/past.py | 2 +- tgcf/plugins/filter.py | 6 +++--- tgcf/plugins/mark.py | 11 ++++++----- 4 files changed, 18 insertions(+), 14 deletions(-) diff --git a/tgcf/bot/utils.py b/tgcf/bot/utils.py index 0adb7166..bda7da1b 100644 --- a/tgcf/bot/utils.py +++ b/tgcf/bot/utils.py @@ -1,4 +1,5 @@ """helper functions for the bot.""" +import logging from typing import List from telethon import events @@ -32,9 +33,8 @@ def get_args(text: str) -> str: return "" prefix, args = splitted - print(prefix) args = args.strip() - print(args) + logging.info(f"Got command {prefix} with args {args}") return args @@ -55,10 +55,13 @@ def display_forwards(forwards: List[Forward]) -> str: def remove_source(source, forwards: List[Forward]) -> List[Forward]: """Remove a source from forwards.""" for i, forward in enumerate(forwards): - print(forward) - print(type(forward.source)) - print(type(source)) if forward.source == source: del forwards[i] return forwards raise ValueError("The source does not exist") + + +def get_command_prefix(): + if config.is_bot is None: + raise ValueError("config.is_bot is not set!") + return "/" if config.is_bot else "." diff --git a/tgcf/past.py b/tgcf/past.py index c090e9e6..ffeede07 100644 --- a/tgcf/past.py +++ b/tgcf/past.py @@ -66,7 +66,7 @@ async def forward_job() -> None: logging.info(f"slept for {CONFIG.past.delay} seconds") except FloodWaitError as fwe: - print(f"Sleeping for {fwe}") + logging.info(f"Sleeping for {fwe}") await asyncio.sleep(delay=fwe.seconds) except Exception as err: logging.exception(err) diff --git a/tgcf/plugins/filter.py b/tgcf/plugins/filter.py index 39a87c2e..11bd13e9 100644 --- a/tgcf/plugins/filter.py +++ b/tgcf/plugins/filter.py @@ -32,7 +32,6 @@ class TgcfFilter(TgcfPlugin): id_ = "filter" def __init__(self, data: Dict[str, Any]) -> None: - print("tgcf filter data loaded") self.filters = Filters(**data) self.case_correct() logging.info(self.filters) @@ -47,8 +46,11 @@ def case_correct(self) -> None: def modify(self, tm: TgcfMessage) -> TgcfMessage: if self.users_safe(tm): + logging.info("Message passed users filter") if self.files_safe(tm): + logging.info("Message passed files filter") if self.text_safe(tm): + logging.info("Message passed text filter") return tm def text_safe(self, tm: TgcfMessage) -> bool: @@ -76,7 +78,6 @@ def text_safe(self, tm: TgcfMessage) -> bool: def users_safe(self, tm: TgcfMessage) -> bool: flist = self.filters.users sender = str(tm.sender_id) - logging.info(f"M message from sender id {sender}") if sender in flist.blacklist: return False if not flist.whitelist: @@ -87,7 +88,6 @@ def users_safe(self, tm: TgcfMessage) -> bool: def files_safe(self, tm: TgcfMessage) -> bool: flist = self.filters.files fl_type = tm.file_type - print(fl_type) if fl_type in flist.blacklist: return False if not flist.whitelist: diff --git a/tgcf/plugins/mark.py b/tgcf/plugins/mark.py index e9e07d72..d32085a0 100644 --- a/tgcf/plugins/mark.py +++ b/tgcf/plugins/mark.py @@ -1,3 +1,4 @@ +import logging import os import shutil from typing import Any, Dict @@ -18,21 +19,21 @@ class MarkConfig(BaseModel): def download_image(url: str, filename: str = "image.png") -> bool: if filename in os.listdir(): - print("Image exists") + logging.info("Image for watermarking already exists.") return True try: - print("Downloading image ... ") + logging.info(f"Downloading image {url}") response = requests.get(url, stream=True) if response.status_code == 200: - print("Got file response") + logging.info("Got Response 200") with open(filename, "wb") as file: response.raw.decode_content = True shutil.copyfileobj(response.raw, file) except Exception as err: - print(err) + logging.error(err) return False else: - print("File created image") + logging.info("File created image") return True From bd4b764eb9c4ab734841d682e670425b9dafef7c Mon Sep 17 00:00:00 2001 From: aahnik Date: Fri, 11 Jun 2021 18:58:36 +0530 Subject: [PATCH 7/7] bump version to 0.2.6 --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index 5e5b23e4..7d24dd3e 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "tgcf" -version = "0.2.5.post0" +version = "0.2.6" description = "The ultimate tool to automate custom telegram message forwarding." authors = ["aahnik "] license = "MIT"