Compare commits
	
		
			10 Commits
		
	
	
		
			v4.0.1
			...
			profitroll
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a458788841 | |||
| b76f727263 | |||
|  | 5a244f603d | ||
|  | 9bc4d0348d | ||
|  | ae54bd5cce | ||
|  | 9ce251d733 | ||
|  | 5dd873d683 | ||
| b47bcbe513 | |||
|  | bbbec75f91 | ||
|  | 94553b602e | 
							
								
								
									
										90
									
								
								.gitea/workflows/publish.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								.gitea/workflows/publish.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | |||||||
|  | name: Upload Python Package | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [ published ] | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   release-build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: catthehacker/ubuntu:act-latest | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - uses: actions/setup-python@v5 | ||||||
|  |         with: | ||||||
|  |           python-version: "3.x" | ||||||
|  |  | ||||||
|  |       - name: Build release distributions | ||||||
|  |         run: | | ||||||
|  |           python -m pip install build | ||||||
|  |           python -m build | ||||||
|  |  | ||||||
|  |       - name: Upload distributions | ||||||
|  |         uses: christopherhx/gitea-upload-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: release-dists | ||||||
|  |           path: dist/ | ||||||
|  |  | ||||||
|  |   gitea-publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: catthehacker/ubuntu:act-latest | ||||||
|  |  | ||||||
|  |     needs: | ||||||
|  |       - release-build | ||||||
|  |  | ||||||
|  |     permissions: | ||||||
|  |       id-token: write | ||||||
|  |  | ||||||
|  |     environment: | ||||||
|  |       name: gitea | ||||||
|  |       url: https://git.end-play.xyz/profitroll/-/packages/pypi/libbot | ||||||
|  |  | ||||||
|  |     env: | ||||||
|  |       GITHUB_WORKFLOW_REF: ${{ gitea.workflow_ref }} | ||||||
|  |       INPUT_REPOSITORY_URL: https://git.end-play.xyz/api/packages/profitroll/pypi | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - name: Retrieve release distributions | ||||||
|  |         uses: christopherhx/gitea-download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: release-dists | ||||||
|  |           path: dist/ | ||||||
|  |  | ||||||
|  |       - name: Publish package distributions to TestPyPI | ||||||
|  |         uses: pypa/gh-action-pypi-publish@release/v1 | ||||||
|  |         with: | ||||||
|  |           password: ${{ secrets.PYPI_GITEA_API_TOKEN }} | ||||||
|  |           repository-url: https://git.end-play.xyz/api/packages/profitroll/pypi | ||||||
|  |  | ||||||
|  |   pypi-publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: catthehacker/ubuntu:act-latest | ||||||
|  |  | ||||||
|  |     needs: | ||||||
|  |       - release-build | ||||||
|  |  | ||||||
|  |     permissions: | ||||||
|  |       id-token: write | ||||||
|  |  | ||||||
|  |     environment: | ||||||
|  |       name: pypi | ||||||
|  |  | ||||||
|  |     env: | ||||||
|  |       GITHUB_WORKFLOW_REF: ${{ gitea.workflow_ref }} | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - name: Retrieve release distributions | ||||||
|  |         uses: christopherhx/gitea-download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: release-dists | ||||||
|  |           path: dist/ | ||||||
|  |  | ||||||
|  |       - name: Publish package distributions to TestPyPI | ||||||
|  |         uses: pypa/gh-action-pypi-publish@release/v1 | ||||||
|  |         with: | ||||||
|  |           password: ${{ secrets.PYPI_PYPI_API_TOKEN }} | ||||||
| @@ -36,6 +36,8 @@ pip install libbot[pycord,speed] | |||||||
| ### Pyrogram | ### Pyrogram | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import sys | ||||||
|  |  | ||||||
| from libbot.pyrogram.classes import PyroClient | from libbot.pyrogram.classes import PyroClient | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -47,7 +49,7 @@ def main(): | |||||||
|     except KeyboardInterrupt: |     except KeyboardInterrupt: | ||||||
|         print("Shutting down...") |         print("Shutting down...") | ||||||
|     finally: |     finally: | ||||||
|         exit() |         sys.exit() | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
| @@ -57,6 +59,9 @@ if __name__ == "__main__": | |||||||
| ### Pycord | ### Pycord | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import asyncio | ||||||
|  | from asyncio import AbstractEventLoop | ||||||
|  |  | ||||||
| from discord import Intents | from discord import Intents | ||||||
| from libbot.utils import config_get | from libbot.utils import config_get | ||||||
| from libbot.pycord.classes import PycordBot | from libbot.pycord.classes import PycordBot | ||||||
| @@ -76,7 +81,7 @@ async def main(): | |||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
|     loop = asyncio.get_event_loop() |     loop: AbstractEventLoop = asyncio.get_event_loop() | ||||||
|     loop.run_until_complete(main()) |     loop.run_until_complete(main()) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								examples/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								examples/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | # Examples | ||||||
|  |  | ||||||
|  | If you're looking for Pyrogram usage examples, please take a look at | ||||||
|  | the [PyrogramBotBase](https://git.end-play.xyz/profitroll/PyrogramBotBase) repository. | ||||||
| @@ -28,6 +28,7 @@ dependencies = { file = "requirements/_.txt" } | |||||||
|  |  | ||||||
| [tool.setuptools.dynamic.optional-dependencies] | [tool.setuptools.dynamic.optional-dependencies] | ||||||
| dev = { file = "requirements/dev.txt" } | dev = { file = "requirements/dev.txt" } | ||||||
|  | matrix = { file = "requirements/matrix.txt" } | ||||||
| pycord = { file = "requirements/pycord.txt" } | pycord = { file = "requirements/pycord.txt" } | ||||||
| pyrogram = { file = "requirements/pyrogram.txt" } | pyrogram = { file = "requirements/pyrogram.txt" } | ||||||
| speed = { file = "requirements/speed.txt" } | speed = { file = "requirements/speed.txt" } | ||||||
|   | |||||||
| @@ -1,2 +1,2 @@ | |||||||
| aiofiles>=23.0.0 | aiofiles>=23.0.0 | ||||||
| typing_extensions~=4.12.2 | typing-extensions~=4.12.2 | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| black==24.10.0 | black==24.10.0 | ||||||
| build==1.2.2.post1 | build==1.2.2.post1 | ||||||
| isort==5.13.2 | isort==5.13.2 | ||||||
| mypy==1.14.0 | mypy==1.14.1 | ||||||
| pylint==3.3.3 | pylint==3.3.3 | ||||||
| pytest-asyncio==0.25.0 | pytest-asyncio==0.25.0 | ||||||
| pytest-cov==6.0.0 | pytest-cov==6.0.0 | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								requirements/matrix.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								requirements/matrix.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | simplematrixbotlib~=2.12.1 | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| __version__ = "4.0.1" | __version__ = "4.0.2" | ||||||
| __license__ = "GPL3" | __license__ = "GPL3" | ||||||
| __author__ = "Profitroll" | __author__ = "Profitroll" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								src/libbot/matrix/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								src/libbot/matrix/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | # This file is left empty on purpose | ||||||
|  | # Adding imports here will cause import errors when libbot[matrix] is not installed | ||||||
							
								
								
									
										1
									
								
								src/libbot/matrix/classes/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/libbot/matrix/classes/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | from .bot import MatrixBot | ||||||
							
								
								
									
										80
									
								
								src/libbot/matrix/classes/bot.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								src/libbot/matrix/classes/bot.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | |||||||
|  | import logging | ||||||
|  | from logging import Logger | ||||||
|  | from pathlib import Path | ||||||
|  | from typing import Dict, Any | ||||||
|  |  | ||||||
|  | from typing_extensions import override | ||||||
|  |  | ||||||
|  | from ... import __version__ as __libbot_version__ | ||||||
|  | from ...i18n.classes import BotLocale | ||||||
|  | from ...utils import json_read | ||||||
|  |  | ||||||
|  | try: | ||||||
|  |     from apscheduler.schedulers.asyncio import AsyncIOScheduler | ||||||
|  |     from apscheduler.schedulers.background import BackgroundScheduler | ||||||
|  |     from simplematrixbotlib import Bot, Creds, Config | ||||||
|  | except ImportError as exc: | ||||||
|  |     raise ImportError("You need to install libbot[matrix] in order to use this class.") from exc | ||||||
|  |  | ||||||
|  | logger: Logger = logging.getLogger(__name__) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class MatrixBot(Bot): | ||||||
|  |     @override | ||||||
|  |     def __init__( | ||||||
|  |         self, | ||||||
|  |         config: Dict[str, Any] | None = None, | ||||||
|  |         config_path: str | Path = Path("config.json"), | ||||||
|  |         locales_root: str | Path | None = None, | ||||||
|  |         scheduler: AsyncIOScheduler | BackgroundScheduler | None = None, | ||||||
|  |         smbl_creds: Creds = None, | ||||||
|  |         smbl_config: Config = None, | ||||||
|  |     ): | ||||||
|  |         self.bot_config: Dict[str, Any] = config if config is not None else json_read(config_path) | ||||||
|  |  | ||||||
|  |         super().__init__( | ||||||
|  |             creds=( | ||||||
|  |                 smbl_creds | ||||||
|  |                 if smbl_creds is not None | ||||||
|  |                 else Creds( | ||||||
|  |                     homeserver=self.bot_config["bot"]["homeserver"], | ||||||
|  |                     username=self.bot_config["bot"]["username"], | ||||||
|  |                     password=self.bot_config["bot"]["password"], | ||||||
|  |                     device_name=( | ||||||
|  |                         f"LibBotUniversal v{__libbot_version__}" | ||||||
|  |                         if "device_name" not in self.bot_config["bot"] | ||||||
|  |                         else self.bot_config["bot"]["device_name"] | ||||||
|  |                     ), | ||||||
|  |                 ) | ||||||
|  |             ), | ||||||
|  |             config=smbl_config, | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         self.bot_prefix: str = ( | ||||||
|  |             "!" if "prefix" not in self.bot_config["bot"] else self.bot_config["bot"]["prefix"] | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         self.bot_locale: BotLocale = BotLocale( | ||||||
|  |             default_locale=self.bot_config["locale"], | ||||||
|  |             locales_root=(Path("locale") if locales_root is None else locales_root), | ||||||
|  |         ) | ||||||
|  |         self.default_locale: str = self.bot_locale.default | ||||||
|  |         self.locales: Dict[str, Any] = self.bot_locale.locales | ||||||
|  |  | ||||||
|  |         self._ = self.bot_locale._ | ||||||
|  |         self.in_all_locales = self.bot_locale.in_all_locales | ||||||
|  |         self.in_every_locale = self.bot_locale.in_every_locale | ||||||
|  |  | ||||||
|  |         self.scheduler: AsyncIOScheduler | BackgroundScheduler | None = scheduler | ||||||
|  |  | ||||||
|  |     @override | ||||||
|  |     def run( | ||||||
|  |         self, scheduler_start: bool = True, scheduler_shutdown: bool = True, scheduler_wait: bool = True | ||||||
|  |     ) -> None: | ||||||
|  |         if self.scheduler is not None and scheduler_start: | ||||||
|  |             self.scheduler.start() | ||||||
|  |  | ||||||
|  |         super().run() | ||||||
|  |  | ||||||
|  |         if self.scheduler is not None and scheduler_shutdown: | ||||||
|  |             self.scheduler.shutdown(scheduler_wait) | ||||||
							
								
								
									
										1
									
								
								src/libbot/pycord/utils/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/libbot/pycord/utils/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | from .color import color_from_hex, hex_from_color | ||||||
							
								
								
									
										35
									
								
								src/libbot/pycord/utils/color.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								src/libbot/pycord/utils/color.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | from discord import Colour | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def _int_from_hex(hex_string: str) -> int: | ||||||
|  |     try: | ||||||
|  |         return int(hex_string, base=16) | ||||||
|  |     except Exception as exc: | ||||||
|  |         raise ValueError("Input string must be a valid HEX code.") from exc | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def _hex_from_int(color_int: int) -> str: | ||||||
|  |     if not 0 <= color_int <= 0xFFFFFF: | ||||||
|  |         raise ValueError("Color's value must be in the range 0 to 0xFFFFFF.") | ||||||
|  |  | ||||||
|  |     return f"#{color_int:06x}" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def color_from_hex(hex_string: str) -> Colour: | ||||||
|  |     """Convert valid hexadecimal string to discord.Colour. | ||||||
|  |  | ||||||
|  |     :param hex_string: Hexadecimal string to convert into Colour object | ||||||
|  |     :type hex_string: str | ||||||
|  |     :return: Colour object | ||||||
|  |     """ | ||||||
|  |     return Colour(_int_from_hex(hex_string)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def hex_from_color(color: Colour) -> str: | ||||||
|  |     """Convert discord.Colour to hexadecimal string. | ||||||
|  |  | ||||||
|  |     :param color: Colour object to convert into the string | ||||||
|  |     :type color: Colour | ||||||
|  |     :return: Hexadecimal string in #XXXXXX format | ||||||
|  |     """ | ||||||
|  |     return _hex_from_int(color.value) | ||||||
		Reference in New Issue
	
	Block a user