djkesu's picture
added attribute conn
a4f441f
raw
history blame
2.35 kB
import sqlite3
from pathlib import Path
from typing import Any, Dict
from pydantic import BaseModel
class PersistentSettings(BaseModel):
"""
This pydantic model will try to initialize itself from
the database upon every instantiation
It further supplies an update function, that allows to write
back any changes into the database, under its key.
"""
class Config:
arbitrary_types_allowed = True # Exclude conn from Pydantic validation
def __init__(self, **data: Any):
# Connect to the SQLite database
self.conn = sqlite3.connect("config.db")
# Create a table for settings if it doesn't exist
self.conn.execute("""
CREATE TABLE IF NOT EXISTS settings (
key TEXT PRIMARY KEY,
value TEXT
)
""")
# Fetch settings from the database and initialize
super().__init__(**self.fetch_settings(), **data)
def fetch_settings(self) -> Dict[str, Any]:
"""
Retrieve settings from the database
"""
cursor = self.conn.cursor()
cursor.execute("SELECT key, value FROM settings")
settings = dict(cursor.fetchall())
cursor.close()
return settings
def update(self, **data: Any) -> None:
"""
Persist the pydantic-dict that represents the model
"""
cursor = self.conn.cursor()
# Update or insert each key-value pair into the database
for key, value in {**self.dict(), **data}.items():
cursor.execute(
"INSERT OR REPLACE INTO settings (key, value) VALUES (?, ?)",
(key, value)
)
# Commit the changes to the database
self.conn.commit()
cursor.close()
def close(self) -> None:
"""
Close the database connection
"""
self.conn.close()
class TortoiseConfig(PersistentSettings):
EXTRA_VOICES_DIR: str = ""
AR_CHECKPOINT: str = "."
DIFF_CHECKPOINT: str = "."
LOW_VRAM: bool = True
conn: sqlite3.Connection = None
def __init__(self, **data: Any):
super().__init__(**data)
if not Path(self.AR_CHECKPOINT).is_file():
self.AR_CHECKPOINT = "."
if not Path(self.DIFF_CHECKPOINT).is_file():
self.DIFF_CHECKPOINT = "."