-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
72 lines (52 loc) · 1.7 KB
/
main.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
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
"""Module that contains main application logic."""
import asyncio
import os
from dotenv import load_dotenv
from database.database_manager import DatabaseManager
from logger.logger import logger
from services.discord_service import MyDiscordClient
def load_env() -> tuple[str, str]:
"""
Loads ENV variables.
:return: discord_token, database_path
"""
load_dotenv()
discord_token = os.getenv("DISCORD_TOKEN")
database_path = os.getenv("DB_PATH")
return discord_token, database_path
async def setup_db(database_path: str):
"""
Sets up the database.
:param database_path: str
:return:
"""
logger.debug("DB setup started.")
# Delete existing database if it exists.
if os.path.exists(database_path):
os.remove(database_path)
# Setup database manager.
database_manager = DatabaseManager(url="sqlite+aiosqlite:///" + database_path)
# Create database tables.
await database_manager.create_models()
# Clean database manager.
await database_manager.cleanup()
logger.info("DB setup finished.")
def main():
"""
Main function.
:return:
"""
logger.info("Application started.")
# Load env variables.
discord_token, database_path = load_env()
# Setup database if it does not exist.
if not os.path.exists(database_path):
logger.debug("Database does not exist. Setting up database.")
asyncio.run(setup_db(database_path))
else:
logger.debug("Database already exists.")
discord_client = MyDiscordClient(database_path=database_path)
discord_client.run(token=discord_token, log_handler=None)
logger.info("Application finished.")
if __name__ == "__main__":
main()