Created initial version

This commit is contained in:
Profitroll 2023-05-11 20:19:46 +02:00
parent ca948b0329
commit 948942fdf2
7 changed files with 134 additions and 0 deletions

6
.gitignore vendored
View File

@ -160,3 +160,9 @@ cython_debug/
# option (not recommended) you can uncomment the following to ignore the entire idea folder. # option (not recommended) you can uncomment the following to ignore the entire idea folder.
#.idea/ #.idea/
# Project
venv
venv_linux
venv_windows
.vscode

17
.renovaterc Normal file
View File

@ -0,0 +1,17 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [
"config:base"
],
"packageRules": [
{
"matchUpdateTypes": [
"minor",
"patch",
"pin",
"digest"
],
"automerge": true
}
]
}

7
libbot/__init__.py Normal file
View File

@ -0,0 +1,7 @@
__name__ = "libbot"
__version__ = "0.1"
__license__ = "GPL3"
__author__ = "Profitroll"
from .__main__ import *
from . import sync

35
libbot/__main__.py Normal file
View File

@ -0,0 +1,35 @@
from typing import Any
import aiofiles
from ujson import loads, dumps
async def json_read(path: str) -> Any:
async with aiofiles.open(path, mode="r", encoding="utf-8") as f:
data = await f.read()
return loads(data)
async def json_write(data: Any, path: str) -> None:
async with aiofiles.open(path, mode="w", encoding="utf-8") as f:
await f.write(dumps(data, ensure_ascii=False, escape_forward_slashes=False))
async def config_get(key: str, *path: str) -> Any:
this_key = await json_read("config.json")
for dict_key in path:
this_key = this_key[dict_key]
return this_key[key]
async def config_set(key: str, value: Any, *path: str) -> None:
this_dict = await json_read("config.json")
string = "this_dict"
for arg in path:
string += f'["{arg}"]'
if type(value) in [str]:
string += f'["{key}"] = "{value}"'
else:
string += f'["{key}"] = {value}'
exec(string)
await json_write(this_dict, "config.json")
return

35
libbot/sync/__init__.py Normal file
View File

@ -0,0 +1,35 @@
from typing import Any
from ujson import dumps, loads
def json_read(path: str) -> Any:
with open(path, mode="r", encoding="utf-8") as f:
data = f.read()
return loads(data)
def json_write(data: Any, path: str) -> None:
with open(path, mode="w", encoding="utf-8") as f:
f.write(dumps(data, ensure_ascii=False, escape_forward_slashes=False, indent=4))
def config_get(key: str, *path: str) -> Any:
this_key = json_read("config.json")
for dict_key in path:
this_key = this_key[dict_key]
return this_key[key]
def config_set(key: str, value: Any, *path: str) -> None:
this_dict = json_read("config.json")
string = "this_dict"
for arg in path:
string += f'["{arg}"]'
if type(value) in [str]:
string += f'["{key}"] = "{value}"'
else:
string += f'["{key}"] = {value}'
exec(string)
json_write(this_dict, "config.json")
return

3
setup.cfg Normal file
View File

@ -0,0 +1,3 @@
[metadata]
description_file=README.md
license_files=LICENSE

31
setup.py Normal file
View File

@ -0,0 +1,31 @@
from setuptools import setup
setup(
name="libbot",
version="0.1",
author="Profitroll",
description="Universal bot library with functions needed for basic Discord/Telegram bot development.",
long_description="Universal bot library with functions needed for basic Discord/Telegram bot development.",
long_description_content_type="text/markdown",
author_email="profitroll@end-play.xyz",
url="https://git.end-play.xyz/profitroll/LibBotUniversal",
project_urls={
"Bug Tracker": "https://git.end-play.xyz/profitroll/LibBotUniversal/issues",
"Documentation": "https://git.end-play.xyz/profitroll/LibBotUniversal/wiki",
"Source Code": "https://git.end-play.xyz/profitroll/LibBotUniversal.git",
},
packages=[
"libbot",
"libbot.sync",
],
install_requires=["aiofiles~=23.1.0", "ujson==5.7.0"],
classifiers=[
"Development Status :: 3 - Alpha",
"Intended Audience :: Developers",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
"Programming Language :: Python :: 3",
"Topic :: Software Development :: Libraries :: Python Modules",
"Topic :: Utilities",
],
)