Compare commits
	
		
			6 Commits
		
	
	
		
			dev
			...
			profitroll
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 88786131f1 | |||
| 6038b5058f | |||
| 646229d919 | |||
| 48fffb82ce | |||
| 29a90fc385 | |||
| 4777b3dc41 | 
							
								
								
									
										20
									
								
								docs/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								docs/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | # Minimal makefile for Sphinx documentation | ||||||
|  | # | ||||||
|  |  | ||||||
|  | # You can set these variables from the command line, and also | ||||||
|  | # from the environment for the first two. | ||||||
|  | SPHINXOPTS    ?= | ||||||
|  | SPHINXBUILD   ?= sphinx-build | ||||||
|  | SOURCEDIR     = . | ||||||
|  | BUILDDIR      = _build | ||||||
|  |  | ||||||
|  | # Put it first so that "make" without argument is like "make help". | ||||||
|  | help: | ||||||
|  | 	@$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) | ||||||
|  |  | ||||||
|  | .PHONY: help Makefile | ||||||
|  |  | ||||||
|  | # Catch-all target: route all unknown targets to Sphinx using the new | ||||||
|  | # "make mode" option.  $(O) is meant as a shortcut for $(SPHINXOPTS). | ||||||
|  | %: Makefile | ||||||
|  | 	@$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) | ||||||
							
								
								
									
										61
									
								
								docs/conf.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								docs/conf.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | # Configuration file for the Sphinx documentation builder. | ||||||
|  | # | ||||||
|  | # For the full list of built-in configuration values, see the documentation: | ||||||
|  | # https://www.sphinx-doc.org/en/master/usage/configuration.html | ||||||
|  | import os | ||||||
|  | import sys | ||||||
|  | from datetime import datetime | ||||||
|  | from typing import List, Dict, Any | ||||||
|  |  | ||||||
|  | import libbot | ||||||
|  |  | ||||||
|  | sys.path.insert(0, os.path.abspath("..")) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # -- Project information ----------------------------------------------------- | ||||||
|  | # https://www.sphinx-doc.org/en/master/usage/configuration.html#project-information | ||||||
|  |  | ||||||
|  | project: str = "LibBotUniversal" | ||||||
|  | author: str = libbot.__author__ | ||||||
|  | version: str = libbot.__version__ | ||||||
|  | release: str = version | ||||||
|  | copyright: str = f"{datetime.now().year} {author}" | ||||||
|  |  | ||||||
|  | html_title: str = f"{project} v{version} Documentation" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # -- General configuration --------------------------------------------------- | ||||||
|  | # https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration | ||||||
|  |  | ||||||
|  | extensions: List[str] = [ | ||||||
|  |     "sphinx.ext.autodoc", | ||||||
|  |     "sphinx.ext.autosummary", | ||||||
|  |     "sphinx.ext.viewcode", | ||||||
|  |     "sphinx.ext.viewcode", | ||||||
|  |     "sphinx.ext.napoleon", | ||||||
|  |     "sphinx_copybutton", | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | templates_path: List[str] = ["_templates"] | ||||||
|  | exclude_patterns: List[str] = ["_build", "Thumbs.db", ".DS_Store"] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # -- Options for HTML output ------------------------------------------------- | ||||||
|  | # https://www.sphinx-doc.org/en/master/usage/configuration.html#options-for-html-output | ||||||
|  |  | ||||||
|  | html_theme: str = "furo" | ||||||
|  | html_static_path: List[str] = ["_static"] | ||||||
|  |  | ||||||
|  | html_theme_options: Dict[str, Any] = { | ||||||
|  |     "source_repository": "https://git.end-play.xyz/profitroll/LibBotUniversal", | ||||||
|  |     "source_branch": "main", | ||||||
|  |     "source_directory": "docs/", | ||||||
|  |     "light_css_variables": { | ||||||
|  |         "font-stack": "'Outfit', sans-serif", | ||||||
|  |     }, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | resource_links: Dict[str, Any] = { | ||||||
|  |     "issues": "https://git.end-play.xyz/profitroll/LibBotUniversal/issues", | ||||||
|  |     "examples": "https://git.end-play.xyz/profitroll/LibBotUniversal/tree/main/examples", | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								docs/index.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								docs/index.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | Welcome to LibBotUniversal | ||||||
|  | ============================= | ||||||
|  |  | ||||||
|  | LibBotUniversal (AKA libbot) simplifies development and maintenance of different chatbots. | ||||||
|  |  | ||||||
|  | Getting started | ||||||
|  | ***************************** | ||||||
|  |  | ||||||
|  | There are a few pages to take a look at if you're just getting started. | ||||||
|  |  | ||||||
|  | * Installing the library | ||||||
|  | * Creating your first bot | ||||||
|  | * Examples of different bots | ||||||
|  |  | ||||||
|  | Getting help | ||||||
|  | ***************************** | ||||||
|  |  | ||||||
|  | If you are looking for help or want to report a bug, we got you covered. | ||||||
|  |  | ||||||
|  | * Bug reports are being submitted on the repo's issue tracker. | ||||||
|  |  | ||||||
|  | Package | ||||||
|  | ***************************** | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |    :maxdepth: 1 | ||||||
|  |    :caption: API reference | ||||||
|  |  | ||||||
|  |    modules | ||||||
							
								
								
									
										35
									
								
								docs/make.bat
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								docs/make.bat
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | @ECHO OFF | ||||||
|  |  | ||||||
|  | pushd %~dp0 | ||||||
|  |  | ||||||
|  | REM Command file for Sphinx documentation | ||||||
|  |  | ||||||
|  | if "%SPHINXBUILD%" == "" ( | ||||||
|  | 	set SPHINXBUILD=sphinx-build | ||||||
|  | ) | ||||||
|  | set SOURCEDIR=. | ||||||
|  | set BUILDDIR=_build | ||||||
|  |  | ||||||
|  | %SPHINXBUILD% >NUL 2>NUL | ||||||
|  | if errorlevel 9009 ( | ||||||
|  | 	echo. | ||||||
|  | 	echo.The 'sphinx-build' command was not found. Make sure you have Sphinx | ||||||
|  | 	echo.installed, then set the SPHINXBUILD environment variable to point | ||||||
|  | 	echo.to the full path of the 'sphinx-build' executable. Alternatively you | ||||||
|  | 	echo.may add the Sphinx directory to PATH. | ||||||
|  | 	echo. | ||||||
|  | 	echo.If you don't have Sphinx installed, grab it from | ||||||
|  | 	echo.https://www.sphinx-doc.org/ | ||||||
|  | 	exit /b 1 | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | if "%1" == "" goto help | ||||||
|  |  | ||||||
|  | %SPHINXBUILD% -M %1 %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% | ||||||
|  | goto end | ||||||
|  |  | ||||||
|  | :help | ||||||
|  | %SPHINXBUILD% -M help %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% | ||||||
|  |  | ||||||
|  | :end | ||||||
|  | popd | ||||||
							
								
								
									
										7
									
								
								docs/modules.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								docs/modules.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | libbot | ||||||
|  | ====== | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |    :maxdepth: 5 | ||||||
|  |  | ||||||
|  |    libbot | ||||||
| @@ -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" } | ||||||
|  | docs = { file = "requirements/docs.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.15.0 | typing-extensions~=4.14.0 | ||||||
| @@ -1,2 +1,2 @@ | |||||||
| pymemcache~=4.0.0 | pymemcache~=4.0.0 | ||||||
| redis~=6.4.0 | redis~=6.2.0 | ||||||
| @@ -1,12 +1,12 @@ | |||||||
| black==25.9.0 | black==25.1.0 | ||||||
| build==1.3.0 | build==1.2.2.post1 | ||||||
| isort==5.13.2 | isort==5.13.2 | ||||||
| mypy==1.18.2 | mypy==1.16.1 | ||||||
| pylint==4.0.1 | pylint==3.3.7 | ||||||
| pytest-asyncio==1.2.0 | pytest-asyncio==1.0.0 | ||||||
| pytest-cov==7.0.0 | pytest-cov==6.2.1 | ||||||
| pytest==8.4.2 | pytest==8.4.1 | ||||||
| tox==4.31.0 | tox==4.27.0 | ||||||
| twine==6.2.0 | twine==6.1.0 | ||||||
| types-aiofiles==25.1.0.20251011 | types-aiofiles==24.1.0.20250708 | ||||||
| types-ujson==5.10.0.20250822 | types-ujson==5.10.0.20250326 | ||||||
							
								
								
									
										3
									
								
								requirements/docs.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								requirements/docs.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | furo==2024.8.6 | ||||||
|  | sphinx==8.1.3 | ||||||
|  | sphinx_copybutton==0.5.2 | ||||||
| @@ -1 +1 @@ | |||||||
| ujson~=5.11.0 | ujson~=5.10.0 | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| __version__ = "4.4.0" | __version__ = "4.3.0" | ||||||
| __license__ = "GPL3" | __license__ = "GPL3" | ||||||
| __author__ = "Profitroll" | __author__ = "Profitroll" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								src/libbot/cache/classes/cache_memcached.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								src/libbot/cache/classes/cache_memcached.py
									
									
									
									
										vendored
									
									
								
							| @@ -29,7 +29,7 @@ class CacheMemcached(Cache): | |||||||
|                 "Cache configuration is invalid. Please check if all keys are set (engine: memcached)" |                 "Cache configuration is invalid. Please check if all keys are set (engine: memcached)" | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|         return cls(Client(engine_config["uri"], default_noreply=True), prefix=prefix, default_ttl_seconds=default_ttl_seconds) |         return cls(Client(engine_config["uri"], default_noreply=True, default_ttl_seconds=default_ttl_seconds), prefix=prefix) | ||||||
|  |  | ||||||
|     def _get_prefixed_key(self, key: str) -> str: |     def _get_prefixed_key(self, key: str) -> str: | ||||||
|         return key if self.prefix is None else f"{self.prefix}_{key}" |         return key if self.prefix is None else f"{self.prefix}_{key}" | ||||||
|   | |||||||
| @@ -4,8 +4,8 @@ from typing import Any, List, Optional | |||||||
| class ConfigKeyError(Exception): | class ConfigKeyError(Exception): | ||||||
|     """Raised when config key is not found. |     """Raised when config key is not found. | ||||||
|  |  | ||||||
|     ### Attributes: |     Args: | ||||||
|         * key (`str | List[str]`): Missing config key. |         key (str | List[str]): Missing config key | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     def __init__(self, key: str | List[str]) -> None: |     def __init__(self, key: str | List[str]) -> None: | ||||||
| @@ -21,9 +21,9 @@ class ConfigKeyError(Exception): | |||||||
| class ConfigValueError(Exception): | class ConfigValueError(Exception): | ||||||
|     """Raised when config key's value is invalid. |     """Raised when config key's value is invalid. | ||||||
|  |  | ||||||
|     ### Attributes: |     Args: | ||||||
|         * key (`str | List[str]`): Invalid config key. |         key (str | List[str]): Invalid config key | ||||||
|         * value (`Optional[Any]`): Key's correct value. |         value (Optional[Any]): Key's correct value | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     def __init__(self, key: str | List[str], value: Optional[Any] = None) -> None: |     def __init__(self, key: str | List[str], value: Optional[Any] = None) -> None: | ||||||
|   | |||||||
| @@ -18,16 +18,16 @@ def _( | |||||||
|     locale: str | None = "en", |     locale: str | None = "en", | ||||||
|     locales_root: str | Path = Path("locale"), |     locales_root: str | Path = Path("locale"), | ||||||
| ) -> Any: | ) -> Any: | ||||||
|     """Get value of locale string. |     """Get value of the locale string. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locale (str | None): Locale to looked up in. Defaults to "en". |         locale (str | None): Locale to be looked up in. Defaults to `"en"` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to Path("locale"). |         locales_root (str | Path, optional):Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]`. |         Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]` | ||||||
|     """ |     """ | ||||||
|     if locale is None: |     if locale is None: | ||||||
|         locale: str = config_get("locale") |         locale: str = config_get("locale") | ||||||
| @@ -58,16 +58,16 @@ async def _( | |||||||
|     locale: str | None = "en", |     locale: str | None = "en", | ||||||
|     locales_root: str | Path = Path("locale"), |     locales_root: str | Path = Path("locale"), | ||||||
| ) -> Any: | ) -> Any: | ||||||
|     """Get value of locale string. |     """Get value of the locale string. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locale (str | None): Locale to looked up in. Defaults to "en". |         locale (str | None): Locale to be looked up in. Defaults to `"en"` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to Path("locale"). |         locales_root (str | Path, optional):Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]`. |         Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]` | ||||||
|     """ |     """ | ||||||
|     locale: str = config_get("locale") if locale is None else locale |     locale: str = config_get("locale") if locale is None else locale | ||||||
|  |  | ||||||
| @@ -97,14 +97,13 @@ def in_all_locales(key: str, *args: str, locales_root: str | Path = Path("locale | |||||||
|     """Get value of the provided key and path in all available locales. |     """Get value of the provided key and path in all available locales. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to `Path("locale")`. |         locales_root (str | Path, optional): Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         List[Any]: List of values in all locales. |         List[Any]: List of values in all locales | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     output: List[Any] = [] |     output: List[Any] = [] | ||||||
|  |  | ||||||
|     for locale in _get_valid_locales(locales_root): |     for locale in _get_valid_locales(locales_root): | ||||||
| @@ -131,12 +130,12 @@ async def in_all_locales(key: str, *args: str, locales_root: str | Path = Path(" | |||||||
|     """Get value of the provided key and path in all available locales. |     """Get value of the provided key and path in all available locales. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to Path("locale"). |         locales_root (str | Path, optional): Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         List[Any]: List of values in all locales. |         List[Any]: List of values in all locales | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     output: List[Any] = [] |     output: List[Any] = [] | ||||||
| @@ -161,20 +160,17 @@ async def in_all_locales(key: str, *args: str, locales_root: str | Path = Path(" | |||||||
|  |  | ||||||
|  |  | ||||||
| @asyncable | @asyncable | ||||||
| def in_every_locale( | def in_every_locale(key: str, *args: str, locales_root: str | Path = Path("locale")) -> Dict[str, Any]: | ||||||
|     key: str, *args: str, locales_root: str | Path = Path("locale") |  | ||||||
| ) -> Dict[str, Any]: |  | ||||||
|     """Get value of the provided key and path in every available locale with locale tag. |     """Get value of the provided key and path in every available locale with locale tag. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to Path("locale"). |         locales_root (str | Path, optional): Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         Dict[str, Any]: Locale is a key, and it's value from locale file is a value. |         Dict[str, Any]: Locale is a key, and it's value from locale file is a value | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     output: Dict[str, Any] = {} |     output: Dict[str, Any] = {} | ||||||
|  |  | ||||||
|     for locale in _get_valid_locales(locales_root): |     for locale in _get_valid_locales(locales_root): | ||||||
| @@ -203,12 +199,12 @@ async def in_every_locale( | |||||||
|     """Get value of the provided key and path in every available locale with locale tag. |     """Get value of the provided key and path in every available locale with locale tag. | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         key (str): The last key of the locale's keys path. |         key (str): The last key of the locale's keys path | ||||||
|         *args (str): Path to key like: `dict[args][key]`. |         *args (str): Path to key like: `dict[args][key]` | ||||||
|         locales_root (str | Path, optional): Folder where locales are located. Defaults to Path("locale"). |         locales_root (str | Path, optional): Folder where locales are located. Defaults to `Path("locale")` | ||||||
|  |  | ||||||
|     Returns: |     Returns: | ||||||
|         Dict[str, Any]: Locale is a key, and it's value from locale file is a value. |         Dict[str, Any]: Locale is a key, and it's value from locale file is a value | ||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     output: Dict[str, Any] = {} |     output: Dict[str, Any] = {} | ||||||
|   | |||||||
| @@ -16,8 +16,8 @@ class BotLocale: | |||||||
|     ) -> None: |     ) -> None: | ||||||
|         """ |         """ | ||||||
|         Args: |         Args: | ||||||
|             default_locale (str | None, optional): Default locale. Defaults to "en". |             default_locale (str | None): Default bot's locale. Defaults to `"en"` | ||||||
|             locales_root (str | Path, optional): Path to a directory with locale files. Defaults to Path("locale"). |             locales_root (str | Path): Folder where locales are located. Defaults to `Path("locale")` | ||||||
|         """ |         """ | ||||||
|         if isinstance(locales_root, str): |         if isinstance(locales_root, str): | ||||||
|             locales_root = Path(locales_root) |             locales_root = Path(locales_root) | ||||||
| @@ -38,12 +38,12 @@ class BotLocale: | |||||||
|         """Get value of locale string. |         """Get value of locale string. | ||||||
|  |  | ||||||
|         Args: |         Args: | ||||||
|             key (str): The last key of the locale's keys path. |             key (str): The last key of the locale's keys path | ||||||
|             *args (str): Path to key like: `dict[args][key]`. |             *args (str): Path to key like: `dict[args][key]` | ||||||
|             locale (str | None, optional): Locale to looked up in. Defaults to config's `"locale"` value. |             locale (str | None, optional): Locale to be looked up in. Defaults to config's `"locale"` value | ||||||
|  |  | ||||||
|         Returns: |         Returns: | ||||||
|             Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]`. |             Any: Value of provided locale key. Is usually `str`, `Dict[str, Any]` or `List[Any]` | ||||||
|         """ |         """ | ||||||
|         if locale is None: |         if locale is None: | ||||||
|             locale: str = self.default |             locale: str = self.default | ||||||
| @@ -72,11 +72,11 @@ class BotLocale: | |||||||
|         """Get value of the provided key and path in all available locales. |         """Get value of the provided key and path in all available locales. | ||||||
|  |  | ||||||
|         Args: |         Args: | ||||||
|             key (str): The last key of the locale's keys path. |             key (str): The last key of the locale's keys path | ||||||
|             *args (str): Path to key like: `dict[args][key]`. |             *args (str): Path to key like: `dict[args][key]` | ||||||
|  |  | ||||||
|         Returns: |         Returns: | ||||||
|             List[Any]: List of values in all locales. |             List[Any]: List of values in all locales | ||||||
|         """ |         """ | ||||||
|         output: List[Any] = [] |         output: List[Any] = [] | ||||||
|  |  | ||||||
| @@ -102,11 +102,11 @@ class BotLocale: | |||||||
|         """Get value of the provided key and path in every available locale with locale tag. |         """Get value of the provided key and path in every available locale with locale tag. | ||||||
|  |  | ||||||
|         Args: |         Args: | ||||||
|             key (str): The last key of the locale's keys path. |             key (str): The last key of the locale's keys path | ||||||
|             *args (str): Path to key like: `dict[args][key]`. |             *args (str): Path to key like: `dict[args][key]` | ||||||
|  |  | ||||||
|         Returns: |         Returns: | ||||||
|             Dict[str, Any]: Locale is a key, and it's value from locale file is a value. |             Dict[str, Any]: Locale is a key, and it's value from locale file is a value | ||||||
|         """ |         """ | ||||||
|         output: Dict[str, Any] = {} |         output: Dict[str, Any] = {} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,16 +19,27 @@ logger: Logger = logging.getLogger(__name__) | |||||||
|  |  | ||||||
|  |  | ||||||
| class PycordBot(Bot): | class PycordBot(Bot): | ||||||
|  |     # TODO Write a docstring | ||||||
|     @override |     @override | ||||||
|     def __init__( |     def __init__( | ||||||
|             self, |         self, | ||||||
|             *args, |         *args, | ||||||
|             config: Dict[str, Any] | None = None, |         config: Dict[str, Any] | None = None, | ||||||
|             config_path: str | Path = Path("config.json"), |         config_path: str | Path = Path("config.json"), | ||||||
|             locales_root: str | Path | None = None, |         locales_root: str | Path | None = None, | ||||||
|             scheduler: AsyncIOScheduler | BackgroundScheduler | None = None, |         scheduler: AsyncIOScheduler | BackgroundScheduler | None = None, | ||||||
|             **kwargs, |         **kwargs, | ||||||
|     ): |     ): | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             *args: | ||||||
|  |             config: | ||||||
|  |             config_path: | ||||||
|  |             locales_root: | ||||||
|  |             scheduler: | ||||||
|  |             **kwargs: | ||||||
|  |         """ | ||||||
|         self.config: Dict[str, Any] = config if config is not None else json_read(config_path) |         self.config: Dict[str, Any] = config if config is not None else json_read(config_path) | ||||||
|  |  | ||||||
|         super().__init__( |         super().__init__( | ||||||
| @@ -51,15 +62,30 @@ class PycordBot(Bot): | |||||||
|  |  | ||||||
|         self.scheduler: AsyncIOScheduler | BackgroundScheduler | None = scheduler |         self.scheduler: AsyncIOScheduler | BackgroundScheduler | None = scheduler | ||||||
|  |  | ||||||
|  |     # TODO Write a docstring | ||||||
|     @override |     @override | ||||||
|     async def start(self, token: str, reconnect: bool = True, scheduler_start: bool = True) -> None: |     async def start(self, token: str, reconnect: bool = True, scheduler_start: bool = True) -> None: | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             token: | ||||||
|  |             reconnect: | ||||||
|  |             scheduler_start: | ||||||
|  |         """ | ||||||
|         if self.scheduler is not None and scheduler_start: |         if self.scheduler is not None and scheduler_start: | ||||||
|             self.scheduler.start() |             self.scheduler.start() | ||||||
|  |  | ||||||
|         await super().start(token, reconnect=reconnect) |         await super().start(token, reconnect=reconnect) | ||||||
|  |  | ||||||
|  |     # TODO Write a docstring | ||||||
|     @override |     @override | ||||||
|     async def close(self, scheduler_shutdown: bool = True, scheduler_wait: bool = True) -> None: |     async def close(self, scheduler_shutdown: bool = True, scheduler_wait: bool = True) -> None: | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             scheduler_shutdown: | ||||||
|  |             scheduler_wait: | ||||||
|  |         """ | ||||||
|         if self.scheduler is not None and scheduler_shutdown: |         if self.scheduler is not None and scheduler_shutdown: | ||||||
|             self.scheduler.shutdown(scheduler_wait) |             self.scheduler.shutdown(scheduler_wait) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,20 +16,24 @@ def _hex_from_int(color_int: int) -> str: | |||||||
|  |  | ||||||
|  |  | ||||||
| def color_from_hex(hex_string: str) -> Colour: | def color_from_hex(hex_string: str) -> Colour: | ||||||
|     """Convert valid hexadecimal string to discord.Colour. |     """Convert valid hexadecimal string to :class:`discord.Colour`. | ||||||
|  |  | ||||||
|     :param hex_string: Hexadecimal string to convert into Colour object |     Args: | ||||||
|     :type hex_string: str |         hex_string (str): Hexadecimal string to convert into :class:`discord.Colour` object | ||||||
|     :return: Colour object |  | ||||||
|  |     Returns: | ||||||
|  |         Colour: :class:`discord.Colour` object | ||||||
|     """ |     """ | ||||||
|     return Colour(_int_from_hex(hex_string)) |     return Colour(_int_from_hex(hex_string)) | ||||||
|  |  | ||||||
|  |  | ||||||
| def hex_from_color(color: Colour) -> str: | def hex_from_color(color: Colour) -> str: | ||||||
|     """Convert discord.Colour to hexadecimal string. |     """Convert :class:`discord.Colour` to hexadecimal string. | ||||||
|  |  | ||||||
|     :param color: Colour object to convert into the string |     Args: | ||||||
|     :type color: Colour |         color (Colour): :class:`discord.Colour` object to convert into the string | ||||||
|     :return: Hexadecimal string in #XXXXXX format |  | ||||||
|  |     Returns: | ||||||
|  |         str: Hexadecimal string in #XXXXXX format | ||||||
|     """ |     """ | ||||||
|     return _hex_from_int(color.value) |     return _hex_from_int(color.value) | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ from logging import Logger | |||||||
| from os import cpu_count, getpid | from os import cpu_count, getpid | ||||||
| from pathlib import Path | from pathlib import Path | ||||||
| from time import time | from time import time | ||||||
| from typing import Any, Dict, List | from typing import Any, Dict, List, Optional | ||||||
|  |  | ||||||
| from typing_extensions import override | from typing_extensions import override | ||||||
|  |  | ||||||
| @@ -46,27 +46,28 @@ logger: Logger = logging.getLogger(__name__) | |||||||
|  |  | ||||||
|  |  | ||||||
| class PyroClient(Client): | class PyroClient(Client): | ||||||
|  |     # TODO Write a docstring | ||||||
|     @override |     @override | ||||||
|     def __init__( |     def __init__( | ||||||
|             self, |         self, | ||||||
|             name: str = "bot_client", |         name: str = "bot_client", | ||||||
|             owner: int | None = None, |         owner: int | None = None, | ||||||
|             config: Dict[str, Any] | None = None, |         config: Dict[str, Any] | None = None, | ||||||
|             config_path: str | Path = Path("config.json"), |         config_path: str | Path = Path("config.json"), | ||||||
|             api_id: int | None = None, |         api_id: int | None = None, | ||||||
|             api_hash: str | None = None, |         api_hash: str | None = None, | ||||||
|             bot_token: str | None = None, |         bot_token: str | None = None, | ||||||
|             workers: int = min(32, cpu_count() + 4), |         workers: int = min(32, cpu_count() + 4), | ||||||
|             locales_root: str | Path | None = None, |         locales_root: str | Path | None = None, | ||||||
|             plugins_root: str = "plugins", |         plugins_root: str = "plugins", | ||||||
|             plugins_exclude: List[str] | None = None, |         plugins_exclude: List[str] | None = None, | ||||||
|             sleep_threshold: int = 120, |         sleep_threshold: int = 120, | ||||||
|             max_concurrent_transmissions: int = 1, |         max_concurrent_transmissions: int = 1, | ||||||
|             commands_source: Dict[str, dict] | None = None, |         commands_source: Dict[str, dict] | None = None, | ||||||
|             scoped_commands: bool | None = None, |         scoped_commands: bool | None = None, | ||||||
|             i18n_bot_info: bool = False, |         i18n_bot_info: bool = False, | ||||||
|             scheduler: AsyncIOScheduler | BackgroundScheduler | None = None, |         scheduler: AsyncIOScheduler | BackgroundScheduler | None = None, | ||||||
|             **kwargs, |         **kwargs, | ||||||
|     ): |     ): | ||||||
|         self.config: Dict[str, Any] = config if config is not None else json_read(config_path) |         self.config: Dict[str, Any] = config if config is not None else json_read(config_path) | ||||||
|  |  | ||||||
| @@ -119,6 +120,12 @@ class PyroClient(Client): | |||||||
|  |  | ||||||
|     @override |     @override | ||||||
|     async def start(self, register_commands: bool = True, scheduler_start: bool = True) -> None: |     async def start(self, register_commands: bool = True, scheduler_start: bool = True) -> None: | ||||||
|  |         """Start the bot and it's services. | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             register_commands (bool, optional): Register commands on start. Defaults to `True` | ||||||
|  |             scheduler_start (bool, optional): Start the scheduler on start. Defaults to `True` | ||||||
|  |         """ | ||||||
|         await super().start() |         await super().start() | ||||||
|  |  | ||||||
|         self.start_time = time() |         self.start_time = time() | ||||||
| @@ -209,8 +216,15 @@ class PyroClient(Client): | |||||||
|  |  | ||||||
|     @override |     @override | ||||||
|     async def stop( |     async def stop( | ||||||
|             self, exit_completely: bool = True, scheduler_shutdown: bool = True, scheduler_wait: bool = True |         self, exit_completely: bool = True, scheduler_shutdown: bool = True, scheduler_wait: bool = True | ||||||
|     ) -> None: |     ) -> None: | ||||||
|  |         """Stop the bot and it's services. | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             exit_completely (bool, optional): Exit the program. Defaults to `True` | ||||||
|  |             scheduler_shutdown (bool): Shutdown the scheduler. Defaults to `True` | ||||||
|  |             scheduler_wait (bool): Wait for tasks to finish. Defaults to `True` | ||||||
|  |         """ | ||||||
|         try: |         try: | ||||||
|             await self.send_message( |             await self.send_message( | ||||||
|                 chat_id=( |                 chat_id=( | ||||||
| @@ -237,10 +251,10 @@ class PyroClient(Client): | |||||||
|                 raise SystemExit("Bot has been shut down, this is not an application error!") from exc |                 raise SystemExit("Bot has been shut down, this is not an application error!") from exc | ||||||
|  |  | ||||||
|     async def collect_commands(self) -> List[CommandSet] | None: |     async def collect_commands(self) -> List[CommandSet] | None: | ||||||
|         """Gather list of the bot's commands |         """Gather list of the bot's commands. | ||||||
|  |  | ||||||
|         ### Returns: |         Returns: | ||||||
|             * `List[CommandSet]`: List of the commands' sets. |             List[CommandSet]: List of the commands' sets | ||||||
|         """ |         """ | ||||||
|         command_sets = None |         command_sets = None | ||||||
|  |  | ||||||
| @@ -308,7 +322,7 @@ class PyroClient(Client): | |||||||
|             # in it, if there are any. Then adds them to self.commands |             # in it, if there are any. Then adds them to self.commands | ||||||
|             for handler in self.dispatcher.groups[0]: |             for handler in self.dispatcher.groups[0]: | ||||||
|                 if isinstance(handler, MessageHandler) and ( |                 if isinstance(handler, MessageHandler) and ( | ||||||
|                         hasattr(handler.filters, "base") or hasattr(handler.filters, "other") |                     hasattr(handler.filters, "base") or hasattr(handler.filters, "other") | ||||||
|                 ): |                 ): | ||||||
|                     for entry in [handler.filters.base, handler.filters.other]: |                     for entry in [handler.filters.base, handler.filters.other]: | ||||||
|                         if hasattr(entry, "commands"): |                         if hasattr(entry, "commands"): | ||||||
| @@ -319,13 +333,13 @@ class PyroClient(Client): | |||||||
|         return command_sets |         return command_sets | ||||||
|  |  | ||||||
|     def add_command( |     def add_command( | ||||||
|             self, |         self, | ||||||
|             command: str, |         command: str, | ||||||
|     ) -> None: |     ) -> None: | ||||||
|         """Add command to the bot's internal commands list |         """Add command to the bot's internal commands list. | ||||||
|  |  | ||||||
|         ### Args: |         Args: | ||||||
|             * command (`str`) |             command (str): Command's name | ||||||
|         """ |         """ | ||||||
|         self.commands.append( |         self.commands.append( | ||||||
|             PyroCommand( |             PyroCommand( | ||||||
| @@ -338,9 +352,12 @@ class PyroClient(Client): | |||||||
|             command, |             command, | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     async def register_commands(self, command_sets: List[CommandSet] | None = None) -> None: |     async def register_commands(self, command_sets: Optional[List[CommandSet]] = None) -> None: | ||||||
|         """Register commands stored in bot's 'commands' attribute""" |         """Register commands stored in bot's 'commands' attribute. | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             command_sets (List[CommandSet], optional): List of command sets. Commands will be parsed from bot's 'commands' attribute if not provided | ||||||
|  |         """ | ||||||
|         if command_sets is None: |         if command_sets is None: | ||||||
|             commands = [ |             commands = [ | ||||||
|                 BotCommand(command=command.command, description=command.description) |                 BotCommand(command=command.command, description=command.description) | ||||||
| @@ -365,9 +382,12 @@ class PyroClient(Client): | |||||||
|                 language_code=command_set.language_code, |                 language_code=command_set.language_code, | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|     async def remove_commands(self, command_sets: List[CommandSet] | None = None) -> None: |     async def remove_commands(self, command_sets: Optional[List[CommandSet]] = None) -> None: | ||||||
|         """Remove commands stored in bot's 'commands' attribute""" |         """Remove commands stored in bot's 'commands' attribute. | ||||||
|  |  | ||||||
|  |         Args: | ||||||
|  |             command_sets (List[CommandSet], optional): List of command sets. Commands with scope :class:`pyrogram.types.BotCommandScopeDefault` will be removed if not provided | ||||||
|  |         """ | ||||||
|         if command_sets is None: |         if command_sets is None: | ||||||
|             logger.info("Removing commands with a default scope 'BotCommandScopeDefault'") |             logger.info("Removing commands with a default scope 'BotCommandScopeDefault'") | ||||||
|             await self.delete_bot_commands(BotCommandScopeDefault()) |             await self.delete_bot_commands(BotCommandScopeDefault()) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user