wrappers.py 1.19 KB
Newer Older
1
from contextvars import ContextVar
2
from peewee import *
3
import logging
4
from playhouse.db_url import connect
5
6
7
8
9

from config import SRC_LOG_LEVELS

log = logging.getLogger(__name__)
log.setLevel(SRC_LOG_LEVELS["DB"])
10
11
12
13

db_state_default = {"closed": None, "conn": None, "ctx": None, "transactions": None}
db_state = ContextVar("db_state", default=db_state_default.copy())

14
class PeeweeConnectionState(object):
15
16
17
18
19
20
21
22
    def __init__(self, **kwargs):
        super().__setattr__("_state", db_state)
        super().__init__(**kwargs)

    def __setattr__(self, name, value):
        self._state.get()[name] = value

    def __getattr__(self, name):
23
24
        value = self._state.get()[name]
        return value
25

26
27
28
def register_connection(db_url):
    db = connect(db_url)
    if isinstance(db, PostgresqlDatabase):
29
        # Enable autoconnect for SQLite databases, managed by Peewee
perf3ct's avatar
perf3ct committed
30
        db.autoconnect = True
31
        log.info("Connected to PostgreSQL database")
32
    elif isinstance(db, SqliteDatabase):
33
        # Enable autoconnect for SQLite databases, managed by Peewee
perf3ct's avatar
perf3ct committed
34
        db.autoconnect = True
35
        log.info("Connected to SQLite database")
36
37
    else:
        raise ValueError('Unsupported database connection')
38
    return db