2021-08-24 10:22:36 +00:00
|
|
|
import os
|
2022-06-18 16:21:59 +00:00
|
|
|
import sys
|
2021-08-24 10:22:36 +00:00
|
|
|
|
2021-07-30 19:32:58 +00:00
|
|
|
from config import Config
|
|
|
|
|
2023-06-28 12:16:22 +00:00
|
|
|
if Config('db_path') is None:
|
|
|
|
raise AttributeError('Wait! You need to fill a valid database address into the config.cfg "db_path" field\n'
|
2021-07-30 19:32:58 +00:00
|
|
|
'Example: \ndb_path = sqlite:///database/save.db\n'
|
2021-07-30 19:57:40 +00:00
|
|
|
'(Also you can fill in the above example directly,'
|
2021-07-30 19:32:58 +00:00
|
|
|
' bot will automatically create a SQLite database in the "./database/save.db")')
|
|
|
|
|
2022-08-31 14:31:19 +00:00
|
|
|
from database import BotDBUtil, session
|
|
|
|
from database.tables import DBVersion
|
|
|
|
|
2021-02-19 08:56:57 +00:00
|
|
|
import asyncio
|
2021-04-10 13:12:32 +00:00
|
|
|
import traceback
|
2021-08-04 16:14:23 +00:00
|
|
|
import aioconsole
|
2021-02-19 08:56:57 +00:00
|
|
|
|
2022-07-01 06:26:41 +00:00
|
|
|
from bot import init_bot
|
2023-08-30 11:30:45 +00:00
|
|
|
from bots.scheduler.bot import load_schedulers
|
2023-08-30 10:54:13 +00:00
|
|
|
from core.builtins import PrivateAssets, EnableDirtyWordCheck
|
2023-02-05 14:33:33 +00:00
|
|
|
from core.types import MsgInfo, AutoSession
|
2023-04-19 07:45:29 +00:00
|
|
|
from core.console.template import Template as MessageSession
|
2021-07-30 18:06:04 +00:00
|
|
|
from core.parser.message import parser
|
2023-03-01 13:41:42 +00:00
|
|
|
from core.utils.bot import init_async
|
2022-01-20 13:31:50 +00:00
|
|
|
from core.logger import Logger
|
2021-08-24 10:22:36 +00:00
|
|
|
|
2022-08-31 14:31:19 +00:00
|
|
|
query_dbver = session.query(DBVersion).first()
|
|
|
|
if query_dbver is None:
|
2023-04-14 13:17:59 +00:00
|
|
|
session.add_all([DBVersion(value=str(BotDBUtil.database_version))])
|
2022-08-31 14:31:19 +00:00
|
|
|
session.commit()
|
|
|
|
query_dbver = session.query(DBVersion).first()
|
|
|
|
|
|
|
|
if (current_ver := int(query_dbver.value)) < (target_ver := BotDBUtil.database_version):
|
|
|
|
print(f'Updating database from {current_ver} to {target_ver}...')
|
|
|
|
from database.update import update_database
|
|
|
|
|
|
|
|
update_database()
|
|
|
|
print('Database updated successfully! Please restart the program.')
|
|
|
|
sys.exit()
|
|
|
|
|
2021-11-01 15:54:12 +00:00
|
|
|
EnableDirtyWordCheck.status = True
|
2021-08-24 10:22:36 +00:00
|
|
|
PrivateAssets.set(os.path.abspath(os.path.dirname(__file__) + '/assets'))
|
2021-02-19 12:20:00 +00:00
|
|
|
|
2021-08-04 16:14:23 +00:00
|
|
|
|
2022-01-08 07:31:30 +00:00
|
|
|
async def console_scheduler():
|
2023-08-30 11:30:45 +00:00
|
|
|
load_schedulers()
|
2023-03-01 13:41:42 +00:00
|
|
|
await init_async()
|
2021-08-04 16:14:23 +00:00
|
|
|
|
|
|
|
|
2022-01-08 07:31:30 +00:00
|
|
|
async def console_command():
|
2021-08-04 16:14:23 +00:00
|
|
|
try:
|
|
|
|
m = await aioconsole.ainput('> ')
|
2022-08-13 07:13:30 +00:00
|
|
|
asyncio.create_task(console_command())
|
2022-06-18 16:21:59 +00:00
|
|
|
await send_command(m)
|
2021-08-04 16:14:23 +00:00
|
|
|
except KeyboardInterrupt:
|
|
|
|
print('Exited.')
|
2021-10-14 15:18:47 +00:00
|
|
|
exit()
|
2021-08-04 16:14:23 +00:00
|
|
|
except Exception:
|
2022-01-20 13:31:50 +00:00
|
|
|
Logger.error(traceback.format_exc())
|
2021-08-04 16:14:23 +00:00
|
|
|
|
2021-08-23 12:44:31 +00:00
|
|
|
|
2022-06-26 06:06:26 +00:00
|
|
|
async def send_command(msg, interactions=None):
|
2022-06-18 16:21:59 +00:00
|
|
|
Logger.info('-------Start-------')
|
2022-08-27 17:51:43 +00:00
|
|
|
returns = await parser(MessageSession(target=MsgInfo(targetId='TEST|Console|0',
|
2022-06-26 06:06:26 +00:00
|
|
|
senderId='TEST|0',
|
|
|
|
senderName='',
|
|
|
|
targetFrom='TEST|Console',
|
2022-08-27 17:51:43 +00:00
|
|
|
senderFrom='TEST', clientName='TEST', messageId=0,
|
2022-07-31 08:33:20 +00:00
|
|
|
replyId=None),
|
2022-08-27 17:51:43 +00:00
|
|
|
session=AutoSession(message=msg, target='TEST|Console|0', sender='TEST|0',
|
2022-06-26 06:06:26 +00:00
|
|
|
auto_interactions=interactions)))
|
2022-07-27 14:32:16 +00:00
|
|
|
# print(returns)
|
2022-06-18 16:21:59 +00:00
|
|
|
Logger.info('----Process end----')
|
2022-06-26 06:06:26 +00:00
|
|
|
return returns
|
2022-06-18 16:21:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
init_bot()
|
|
|
|
loop = asyncio.get_event_loop()
|
2023-08-30 10:54:13 +00:00
|
|
|
loop.create_task(console_scheduler())
|
|
|
|
loop.create_task(console_command())
|
|
|
|
loop.run_forever()
|