__init__.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import json
  2. import logging
  3. import os
  4. conf = {
  5. "SECRET_KEY": "HBlog-R-Salt",
  6. "BLOG_NAME": "HBlog",
  7. "BLOG_DESCRIBE": "Huan Blog.",
  8. "FOOT": "Power by HBlog",
  9. "ABOUT_ME_PAGE": "",
  10. "INTRODUCTION": "",
  11. "INTRODUCTION_LINK": "",
  12. "MYSQL_URL": "localhost",
  13. "MYSQL_NAME": "local",
  14. "MYSQL_PASSWD": "123456",
  15. "MYSQL_PORT": 3306,
  16. "MAIL_SERVER": "",
  17. "MAIL_PORT": "",
  18. "MAIL_USE_TLS": False,
  19. "MAIL_USE_SSL": False,
  20. "MAIL_PASSWORD": "",
  21. "MAIL_USERNAME": "",
  22. "MAIL_PREFIX": "",
  23. "MAIL_SENDER": "",
  24. "USE_ALIYUN": False,
  25. "ALIYUN_KEY": "",
  26. "ALIYUN_SECRET": "",
  27. "ALIYUN_BUCKET_ENDPOINT": "",
  28. "ALIYUN_BUCKET_NAME": "",
  29. "ALIYUN_BUCKET_IS_CNAME": False,
  30. "ALIYUN_BUCKET_USE_SIGN_URL": True,
  31. "LOG_HOME": "",
  32. "LOG_FORMAT": "[%(levelname)s]:%(name)s:%(asctime)s "
  33. "(%(filename)s:%(lineno)d %(funcName)s) "
  34. "%(process)d %(thread)d "
  35. "%(message)s",
  36. "LOG_LEVEL": logging.INFO,
  37. "LOG_STDERR": True,
  38. "LOGO": "logo.jpg",
  39. "ICP": None,
  40. "GONG_AN": None,
  41. }
  42. def configure(conf_file: str, encoding="utf-8"):
  43. """ 运行配置程序, 该函数需要在其他模块被执行前调用 """
  44. with open(conf_file, mode="r", encoding=encoding) as f:
  45. json_str = f.read()
  46. conf.update(json.loads(json_str))
  47. if type(conf["LOG_LEVEL"]) is str:
  48. conf["LOG_LEVEL"] = {"debug": logging.DEBUG,
  49. "info": logging.INFO,
  50. "warning": logging.WARNING,
  51. "error": logging.ERROR}.get(conf["LOG_LEVEL"])
  52. introduce = conf["INTRODUCE"]
  53. introduce_list = []
  54. for i in introduce:
  55. describe: str = introduce[i]
  56. describe = " ".join([f"<p>{i}</p>" for i in describe.split('\n')])
  57. introduce_list.append((i, describe))
  58. conf["INTRODUCE"] = introduce_list
  59. if len(conf["LOG_HOME"]) > 0:
  60. os.makedirs(conf["LOG_HOME"], exist_ok=True)