open-webui/backend/apps/webui/internal/db.py

55 lines
1.5 KiB
Python
Raw Normal View History

2024-03-02 08:19:24 +00:00
import os
import logging
2024-05-30 13:44:13 +00:00
import json
2023-12-26 05:44:28 +00:00
2024-05-30 13:44:13 +00:00
from peewee import *
from peewee_migrate import Router
from apps.webui.internal.wrappers import register_connection
2024-05-30 13:44:13 +00:00
from config import SRC_LOG_LEVELS, DATA_DIR, DATABASE_URL, BACKEND_DIR
log = logging.getLogger(__name__)
log.setLevel(SRC_LOG_LEVELS["DB"])
2024-06-20 11:53:23 +00:00
class JSONField(TextField):
def db_value(self, value):
return json.dumps(value)
def python_value(self, value):
if value is not None:
return json.loads(value)
2024-06-20 11:53:23 +00:00
2024-03-02 08:19:24 +00:00
# Check if the file exists
if os.path.exists(f"{DATA_DIR}/ollama.db"):
# Rename the file
os.rename(f"{DATA_DIR}/ollama.db", f"{DATA_DIR}/webui.db")
log.info("Database migrated from Ollama-WebUI successfully.")
2024-03-02 08:19:24 +00:00
else:
pass
2024-06-20 11:53:23 +00:00
# The `register_connection` function encapsulates the logic for setting up
# the database connection based on the connection string, while `connect`
# is a Peewee-specific method to manage the connection state and avoid errors
# when a connection is already open.
try:
DB = register_connection(DATABASE_URL)
log.info(f"Connected to a {DB.__class__.__name__} database.")
except Exception as e:
log.error(f"Failed to initialize the database connection: {e}")
raise
2024-05-20 03:12:03 +00:00
router = Router(
2024-05-26 08:16:58 +00:00
DB,
migrate_dir=BACKEND_DIR / "apps" / "webui" / "internal" / "migrations",
logger=log,
2024-05-20 03:12:03 +00:00
)
2024-04-01 10:12:46 +00:00
router.run()
try:
DB.connect(reuse_if_open=True)
except OperationalError as e:
log.info(f"Failed to connect to database again due to: {e}")
2024-06-20 11:53:23 +00:00
pass