comparison love/poppy/utils/database.py @ 38:cf9caa4abc3e

[Love] FE and BE. Can chat and render images. Also created MCP for powerpoint generations.
author MrJuneJune <me@mrjunejune.com>
date Mon, 01 Dec 2025 20:35:56 -0800
parents
children
comparison
equal deleted inserted replaced
37:fb9bcd3145cb 38:cf9caa4abc3e
1 from sqlmodel import SQLModel, create_engine
2 from sqlalchemy.ext.asyncio import (
3 create_async_engine,
4 async_sessionmaker,
5 AsyncEngine,
6 AsyncSession,
7 )
8 import os
9
10 ASYNC_DATABASE_URL = os.getenv("ASYNC_DATABASE_URL", "sqlite+aiosqlite:///./poppy.db")
11 SYNC_DATABASE_URL = os.getenv("SYNC_DATABASE_URL", "sqlite:///./poppy.db")
12
13 # For migrations, we can probably use async?
14 sync_engine = create_engine(
15 SYNC_DATABASE_URL,
16 echo=False,
17 future=True,
18 )
19
20 async_engine: AsyncEngine = create_async_engine(
21 ASYNC_DATABASE_URL,
22 echo=False,
23 future=True,
24 )
25
26 AsyncSessionLocal = async_sessionmaker(
27 bind=async_engine,
28 class_=AsyncSession,
29 expire_on_commit=False,
30 )
31
32
33 async def get_session():
34 async with AsyncSessionLocal() as session:
35 yield session
36
37
38 def create_db_and_tables():
39 SQLModel.metadata.create_all(sync_engine)