-
Notifications
You must be signed in to change notification settings - Fork 31
/
cron_reset.py
45 lines (34 loc) · 1.15 KB
/
cron_reset.py
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
import time
from app import refresh_api_list
from app.core.exceptions import SettingNotFound
from app.core.init_app import init_menus, init_users
try:
from app.settings import APP_SETTINGS
except ImportError:
raise SettingNotFound("Can not import settings")
from tortoise import Tortoise, run_async
from loguru import logger
async def init():
await Tortoise.init(
config=APP_SETTINGS.TORTOISE_ORM,
)
await Tortoise.generate_schemas()
# 清空所有表
# await Tortoise._drop_databases()
# await Tortoise.close_connections()
conn = Tortoise.get_connection("conn_system")
# 获取所有表名
total, tables = await conn.execute_query('SELECT tablename FROM pg_tables WHERE schemaname = \'public\';')
# 删除所有表
for table in tables:
table_name = table[0]
if table_name != "aerich":
await conn.execute_query(f'TRUNCATE TABLE "{table_name}" RESTART IDENTITY CASCADE;')
await init_menus()
await refresh_api_list()
await init_users()
await Tortoise.close_connections()
while True:
run_async(init())
logger.info("Reset all tables")
time.sleep(60 * 10)