2025-10-26 00:43:32 +03:00
|
|
|
import psycopg2
|
|
|
|
|
import os
|
|
|
|
|
from contextlib import contextmanager
|
|
|
|
|
from typing import Generator
|
2025-10-27 23:02:19 +03:00
|
|
|
from loguru import logger
|
2025-10-26 00:43:32 +03:00
|
|
|
|
|
|
|
|
from utils.loadDotEnv import initializeENV
|
|
|
|
|
|
|
|
|
|
initializeENV()
|
|
|
|
|
|
2025-10-26 19:32:34 +03:00
|
|
|
|
2025-10-26 19:14:51 +03:00
|
|
|
def PSQLConnect():
|
2025-10-27 23:02:19 +03:00
|
|
|
conn_str = os.getenv('POSTGRES_CONNECTION')
|
|
|
|
|
|
|
|
|
|
if not conn_str:
|
|
|
|
|
logger.error("POSTGRES_CONNECTION не найден в .env файле")
|
|
|
|
|
raise ValueError("POSTGRES_CONNECTION не найден в .env файле")
|
|
|
|
|
|
|
|
|
|
conn = psycopg2.connect(conn_str)
|
|
|
|
|
logger.debug("Подключение к БД установлено")
|
2025-10-26 19:14:51 +03:00
|
|
|
return conn
|
2025-10-26 00:43:32 +03:00
|
|
|
|
2025-10-27 23:02:19 +03:00
|
|
|
|
2025-10-26 19:14:51 +03:00
|
|
|
def PSQLCursor(conn):
|
2025-10-27 23:02:19 +03:00
|
|
|
cur = conn.cursor()
|
|
|
|
|
logger.debug("Курсор БД создан")
|
2025-10-26 19:14:51 +03:00
|
|
|
return cur
|
2025-10-26 00:43:32 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@contextmanager
|
|
|
|
|
def get_connection() -> Generator[psycopg2.extensions.connection, None, None]:
|
|
|
|
|
conn = None
|
|
|
|
|
try:
|
2025-10-26 19:14:51 +03:00
|
|
|
conn = PSQLConnect()
|
2025-10-27 23:02:19 +03:00
|
|
|
logger.debug("Контекст подключения к БД открыт")
|
2025-10-26 00:43:32 +03:00
|
|
|
yield conn
|
|
|
|
|
except Exception as e:
|
2025-10-27 23:02:19 +03:00
|
|
|
logger.error(f"Ошибка в контексте подключения: {e}")
|
|
|
|
|
if conn:
|
|
|
|
|
conn.rollback()
|
|
|
|
|
logger.debug("Откат транзакции выполнен")
|
2025-10-26 00:43:32 +03:00
|
|
|
raise
|
|
|
|
|
finally:
|
|
|
|
|
if conn:
|
2025-10-27 23:02:19 +03:00
|
|
|
conn.close()
|
|
|
|
|
logger.debug("Подключение к БД закрыто")
|
|
|
|
|
|
2025-10-26 00:43:32 +03:00
|
|
|
|
|
|
|
|
def test_connection() -> bool:
|
|
|
|
|
try:
|
|
|
|
|
with get_connection() as conn:
|
2025-10-26 19:14:51 +03:00
|
|
|
cur = PSQLCursor(conn)
|
2025-10-27 23:02:19 +03:00
|
|
|
cur.execute("SELECT version();")
|
|
|
|
|
version = cur.fetchone()
|
|
|
|
|
logger.info(f"Подключение к БД успешно: {version[0]}")
|
|
|
|
|
cur.close()
|
|
|
|
|
logger.debug("Курсор БД закрыт")
|
|
|
|
|
return True
|
2025-10-26 00:43:32 +03:00
|
|
|
except Exception as e:
|
2025-10-27 23:02:19 +03:00
|
|
|
logger.error(f"Ошибка подключения к БД: {e}")
|
2025-10-26 00:43:32 +03:00
|
|
|
return False
|
2025-10-27 23:02:19 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
test_connection()
|