summaryrefslogtreecommitdiff
path: root/ATRI/database/db.py
blob: b29d860c5fb7365e0acb5c318633611304796be0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
from pathlib import Path
from tortoise import Tortoise

from ATRI.log import log


# 临时的实现,寻求更好的方式!欢迎pr


DB_DIR = Path(".") / "data" / "sql"
DB_DIR.mkdir(parents=True, exist_ok=True)


async def run():
    from ATRI.database import models

    await Tortoise.init(
        {
            "connections": {
                "bilibili": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {"file_path": f"{DB_DIR}/bilibili.sqlite3"},
                },
                "twitter": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {"file_path": f"{DB_DIR}/twitter.sqlite3"},
                },
                "ts": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {"file_path": f"{DB_DIR}/thesaurusstoragor.sqlite3"},
                },
                "tal": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {
                        "file_path": f"{DB_DIR}/thesaurusauditlist.sqlite3"
                    },
                },
                "rrs": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {
                        "file_path": f"{DB_DIR}/rssrsshubsubscription.sqlite3"
                    },
                },
                "rms": {
                    "engine": "tortoise.backends.sqlite",
                    "credentials": {
                        "file_path": f"{DB_DIR}/rssmikananisubscription.sqlite3"
                    },
                },
            },
            "apps": {
                "bilibili": {
                    "models": [locals()["models"]],
                    "default_connection": "bilibili",
                },
                "twitter": {
                    "models": [locals()["models"]],
                    "default_connection": "twitter",
                },
                "ts": {"models": [locals()["models"]], "default_connection": "ts"},
                "tal": {"models": [locals()["models"]], "default_connection": "tal"},
                "rrs": {"models": [locals()["models"]], "default_connection": "rrs"},
                "rms": {"models": [locals()["models"]], "default_connection": "rms"},
            },
        }
    )
    await Tortoise.generate_schemas()


async def init_database():
    log.info("正在初始化数据库...")
    await run()
    log.success("数据库初始化完成")


async def close_database_connection():
    log.info("正在关闭数据库连接...")
    await Tortoise.close_connections()
    log.info("数据库成功关闭")