PhotosAPI/modules/utils.py

87 lines
2.4 KiB
Python
Raw Normal View History

2022-12-20 02:22:32 +02:00
from traceback import print_exc
2023-06-22 14:17:53 +03:00
from typing import Any, Union
from ujson import JSONDecodeError, dumps, loads
2022-12-20 02:22:32 +02:00
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
# Print to stdout and then to log
def logWrite(message: str, debug: bool = False) -> None:
# save to log file and rotation is to be done
# logAppend(f'{message}', debug=debug)
print(f"{message}", flush=True)
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
def jsonLoad(filepath: str) -> Any:
"""Load json file
### Args:
* filepath (`str`): Path to input file
### Returns:
* `Any`: Some json deserializable
2023-03-12 15:59:13 +02:00
"""
with open(filepath, "r", encoding="utf8") as file:
2022-12-20 02:22:32 +02:00
try:
output = loads(file.read())
except JSONDecodeError:
2023-03-12 15:59:13 +02:00
logWrite(
f"Could not load json file {filepath}: file seems to be incorrect!\n{print_exc()}"
)
2022-12-20 02:22:32 +02:00
raise
except FileNotFoundError:
2023-03-12 15:59:13 +02:00
logWrite(
f"Could not load json file {filepath}: file does not seem to exist!\n{print_exc()}"
)
2022-12-20 02:22:32 +02:00
raise
file.close()
return output
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
def jsonSave(contents: Union[list, dict], filepath: str) -> None:
"""Save contents into json file
### Args:
* contents (`Union[list, dict]`): Some json serializable
* filepath (`str`): Path to output file
2023-03-12 15:59:13 +02:00
"""
2022-12-20 02:22:32 +02:00
try:
2023-03-12 15:59:13 +02:00
with open(filepath, "w", encoding="utf8") as file:
2022-12-20 02:22:32 +02:00
file.write(dumps(contents, ensure_ascii=False, indent=4))
file.close()
except Exception as exp:
logWrite(f"Could not save json file {filepath}: {exp}\n{print_exc()}")
return
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
def configGet(key: str, *args: str) -> Any:
"""Get value of the config key
### Args:
* key (`str`): The last key of the keys path.
* *args (`str`): Path to key like: dict[args][key].
### Returns:
* `Any`: Value of provided key
2023-03-12 15:59:13 +02:00
"""
2022-12-20 02:22:32 +02:00
this_dict = jsonLoad("config.json")
this_key = this_dict
for dict_key in args:
this_key = this_key[dict_key]
return this_key[key]
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
def apiKeyInvalid(obj):
obj.send_response(401)
2023-03-12 15:59:13 +02:00
obj.send_header("Content-type", "application/json; charset=utf-8")
2022-12-20 02:22:32 +02:00
obj.end_headers()
obj.wfile.write(b'{"code":401, "message": "Invalid API key"}')
return
2023-03-12 15:59:13 +02:00
2022-12-20 02:22:32 +02:00
def apiKeyExpired(obj):
obj.send_response(403)
2023-03-12 15:59:13 +02:00
obj.send_header("Content-type", "application/json; charset=utf-8")
2022-12-20 02:22:32 +02:00
obj.end_headers()
obj.wfile.write(b'{"code":403, "message": "API key expired"}')
2023-03-12 15:59:13 +02:00
return